@ndla/ui 22.0.0 → 22.0.3

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 (108) hide show
  1. package/es/Article/ArticleByline.js +7 -4
  2. package/es/Article/ArticleNotions.js +10 -6
  3. package/es/Breadcrumb/ActionBreadcrumb.js +4 -4
  4. package/es/CompetenceGoals/CompetenceGoalsDialog.js +8 -4
  5. package/es/ContentLoader/index.js +8 -3
  6. package/es/Filter/FilterButtons.js +10 -9
  7. package/es/Footer/FooterPrivacy.js +3 -2
  8. package/es/Masthead/MastheadSearchModal.js +4 -3
  9. package/es/Resource/BlockResource.js +105 -18
  10. package/es/Resource/ListResource.js +124 -26
  11. package/es/ResourcesWrapper/ResourcesTopicTitle.js +7 -4
  12. package/es/Search/ContentTypeResult.js +1 -2
  13. package/es/SearchTypeResult/PopupFilter.js +12 -8
  14. package/es/SearchTypeResult/SearchItem.js +8 -8
  15. package/es/SearchTypeResult/components/ItemContexts.js +8 -7
  16. package/es/SnackBar/DefaultSnackbar.js +56 -0
  17. package/es/SnackBar/SnackbarProvider.js +179 -0
  18. package/es/SnackBar/index.js +2 -2
  19. package/es/Topic/Topic.js +21 -20
  20. package/es/TreeStructure/FolderItem.js +64 -44
  21. package/es/TreeStructure/FolderItems.js +4 -4
  22. package/es/TreeStructure/TreeStructure.js +15 -8
  23. package/es/User/AuthModal.js +9 -8
  24. package/es/index.js +1 -1
  25. package/es/locale/messages-en.js +26 -5
  26. package/es/locale/messages-nb.js +26 -5
  27. package/es/locale/messages-nn.js +26 -5
  28. package/es/locale/messages-se.js +26 -5
  29. package/es/locale/messages-sma.js +26 -5
  30. package/lib/Article/ArticleByline.js +7 -4
  31. package/lib/Article/ArticleNotions.js +10 -6
  32. package/lib/Breadcrumb/ActionBreadcrumb.js +4 -4
  33. package/lib/CompetenceGoals/CompetenceGoalsDialog.js +8 -4
  34. package/lib/ContentLoader/index.d.ts +4 -8
  35. package/lib/ContentLoader/index.js +8 -3
  36. package/lib/Filter/FilterButtons.js +10 -9
  37. package/lib/Footer/FooterPrivacy.js +3 -2
  38. package/lib/Masthead/MastheadSearchModal.js +4 -3
  39. package/lib/Resource/BlockResource.d.ts +2 -1
  40. package/lib/Resource/BlockResource.js +106 -18
  41. package/lib/Resource/ListResource.d.ts +2 -1
  42. package/lib/Resource/ListResource.js +125 -26
  43. package/lib/ResourcesWrapper/ResourcesTopicTitle.js +7 -4
  44. package/lib/Search/ContentTypeResult.js +1 -2
  45. package/lib/SearchTypeResult/PopupFilter.js +12 -8
  46. package/lib/SearchTypeResult/SearchItem.js +8 -8
  47. package/lib/SearchTypeResult/components/ItemContexts.js +8 -7
  48. package/lib/SnackBar/DefaultSnackbar.d.ts +11 -0
  49. package/lib/SnackBar/DefaultSnackbar.js +70 -0
  50. package/lib/SnackBar/SnackbarProvider.d.ts +32 -0
  51. package/lib/SnackBar/SnackbarProvider.js +197 -0
  52. package/lib/SnackBar/index.d.ts +3 -3
  53. package/lib/SnackBar/index.js +23 -3
  54. package/lib/Topic/Topic.js +21 -20
  55. package/lib/TreeStructure/FolderItem.d.ts +1 -1
  56. package/lib/TreeStructure/FolderItem.js +65 -44
  57. package/lib/TreeStructure/FolderItems.js +4 -4
  58. package/lib/TreeStructure/TreeStructure.d.ts +1 -1
  59. package/lib/TreeStructure/TreeStructure.js +15 -8
  60. package/lib/TreeStructure/types.d.ts +2 -1
  61. package/lib/User/AuthModal.js +9 -8
  62. package/lib/index.d.ts +2 -2
  63. package/lib/index.js +24 -3
  64. package/lib/locale/messages-en.d.ts +21 -0
  65. package/lib/locale/messages-en.js +26 -5
  66. package/lib/locale/messages-nb.d.ts +21 -0
  67. package/lib/locale/messages-nb.js +26 -5
  68. package/lib/locale/messages-nn.d.ts +21 -0
  69. package/lib/locale/messages-nn.js +26 -5
  70. package/lib/locale/messages-se.d.ts +21 -0
  71. package/lib/locale/messages-se.js +26 -5
  72. package/lib/locale/messages-sma.d.ts +21 -0
  73. package/lib/locale/messages-sma.js +26 -5
  74. package/package.json +6 -6
  75. package/src/Article/ArticleByline.tsx +4 -1
  76. package/src/Article/ArticleNotions.tsx +4 -1
  77. package/src/Breadcrumb/ActionBreadcrumb.tsx +1 -1
  78. package/src/CompetenceGoals/CompetenceGoalsDialog.jsx +5 -2
  79. package/src/ContentLoader/index.tsx +9 -9
  80. package/src/Filter/FilterButtons.tsx +1 -0
  81. package/src/Footer/FooterPrivacy.tsx +4 -1
  82. package/src/Masthead/MastheadSearchModal.tsx +1 -0
  83. package/src/Resource/BlockResource.tsx +65 -4
  84. package/src/Resource/ListResource.tsx +85 -10
  85. package/src/ResourcesWrapper/ResourcesTopicTitle.tsx +5 -1
  86. package/src/Search/ContentTypeResult.tsx +0 -1
  87. package/src/SearchTypeResult/PopupFilter.tsx +3 -1
  88. package/src/SearchTypeResult/SearchItem.tsx +0 -1
  89. package/src/SearchTypeResult/components/ItemContexts.tsx +1 -0
  90. package/src/SnackBar/DefaultSnackbar.tsx +70 -0
  91. package/src/SnackBar/SnackbarProvider.tsx +147 -0
  92. package/src/SnackBar/index.ts +3 -5
  93. package/src/Topic/Topic.tsx +1 -0
  94. package/src/TreeStructure/FolderItem.tsx +56 -37
  95. package/src/TreeStructure/FolderItems.tsx +3 -2
  96. package/src/TreeStructure/TreeStructure.tsx +9 -4
  97. package/src/TreeStructure/types.ts +2 -1
  98. package/src/User/AuthModal.tsx +2 -1
  99. package/src/index.ts +2 -2
  100. package/src/locale/messages-en.ts +21 -0
  101. package/src/locale/messages-nb.ts +21 -0
  102. package/src/locale/messages-nn.ts +21 -0
  103. package/src/locale/messages-se.ts +21 -0
  104. package/src/locale/messages-sma.ts +21 -0
  105. package/es/SnackBar/SnackBar.js +0 -117
  106. package/lib/SnackBar/SnackBar.d.ts +0 -23
  107. package/lib/SnackBar/SnackBar.js +0 -127
  108. package/src/SnackBar/SnackBar.tsx +0 -183
@@ -44,13 +44,13 @@ var HeaderWrapper = (0, _styledBase["default"])("div", {
44
44
  } : {
45
45
  name: "6f3adf",
46
46
  styles: "padding:14px 20px 14px 0;display:flex;align-items:center;justify-content:space-between;width:100%;",
47
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNvbXBldGVuY2VHb2Fsc0RpYWxvZy5qc3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBaUJnQyIsImZpbGUiOiJDb21wZXRlbmNlR29hbHNEaWFsb2cuanN4Iiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIENvcHlyaWdodCAoYykgMjAxOC1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCwgeyBGcmFnbWVudCB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5pbXBvcnQgeyB1c2VUcmFuc2xhdGlvbiB9IGZyb20gJ3JlYWN0LWkxOG5leHQnO1xuaW1wb3J0IHsgZm9udHMgfSBmcm9tICdAbmRsYS9jb3JlJztcbmltcG9ydCBNb2RhbCwgeyBNb2RhbEhlYWRlciwgTW9kYWxCb2R5LCBNb2RhbENsb3NlQnV0dG9uIH0gZnJvbSAnQG5kbGEvbW9kYWwnO1xuaW1wb3J0IHsgRm9vdGVySGVhZGVySWNvbiB9IGZyb20gJ0BuZGxhL2ljb25zL2NvbW1vbic7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBjbGFzc2VzIH0gZnJvbSAnLi9Db21wZXRlbmNlR29hbHMnO1xuXG5jb25zdCBIZWFkZXJXcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgcGFkZGluZzogMTRweCAyMHB4IDE0cHggMDtcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAganVzdGlmeS1jb250ZW50OiBzcGFjZS1iZXR3ZWVuO1xuICB3aWR0aDogMTAwJTtcbmA7XG5cbmNvbnN0IEhlYWRpbmdXcmFwcGVyID0gc3R5bGVkLmgyYFxuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICAke2ZvbnRzLnNpemVzKCcxOHB4JywgJzMycHgnKX07XG4gIG1hcmdpbjogMDtcbiAgZm9udC13ZWlnaHQ6ICR7Zm9udHMud2VpZ2h0LnNlbWlib2xkfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBDb21wZXRlbmNlR29hbHNEaWFsb2cgPSAoeyBjaGlsZHJlbiwgaXNPcGVuLCBvbkNsb3NlLCBzdWJqZWN0TmFtZSwgbW9kYWxQcm9wcyB9KSA9PiB7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcbiAgcmV0dXJuIChcbiAgICA8TW9kYWxcbiAgICAgIHsuLi5tb2RhbFByb3BzfVxuICAgICAgY29udHJvbGxhYmxlXG4gICAgICBpc09wZW49e2lzT3Blbn1cbiAgICAgIG9uQ2xvc2U9e29uQ2xvc2V9XG4gICAgICBzaXplPVwiZnVsbHNjcmVlblwiXG4gICAgICBhbmltYXRpb249XCJzbGlkZS11cFwiXG4gICAgICBiYWNrZ3JvdW5kQ29sb3I9XCJsaWdodC1ncmFkaWVudFwiXG4gICAgICBuYXJyb3c+XG4gICAgICB7KGNsb3NlKSA9PiAoXG4gICAgICAgIDxGcmFnbWVudD5cbiAgICAgICAgICA8TW9kYWxIZWFkZXIgbW9kaWZpZXI9XCJtZW51XCI+XG4gICAgICAgICAgICA8SGVhZGVyV3JhcHBlcj5cbiAgICAgICAgICAgICAgPEhlYWRpbmdXcmFwcGVyPlxuICAgICAgICAgICAgICAgIDxGb290ZXJIZWFkZXJJY29uIHNpemU9XCIyNHB4XCIgc3R5bGU9e3sgbWFyZ2luUmlnaHQ6ICcyMHB4JyB9fSAvPlxuICAgICAgICAgICAgICAgIHsnVXRmb3JzayBsw6ZyZXBsYW5rb2JsaW5nZXInfSB7c3ViamVjdE5hbWUgJiYgYCBcXHUyMDIyICR7c3ViamVjdE5hbWV9YH1cbiAgICAgICAgICAgICAgPC9IZWFkaW5nV3JhcHBlcj5cbiAgICAgICAgICAgICAgPE1vZGFsQ2xvc2VCdXR0b24gb25DbGljaz17Y2xvc2V9IHRpdGxlPXt0KCdjb21wZXRlbmNlR29hbHMuY29tcGV0ZW5jZUdvYWxDbG9zZScpfSAvPlxuICAgICAgICAgICAgPC9IZWFkZXJXcmFwcGVyPlxuICAgICAgICAgIDwvTW9kYWxIZWFkZXI+XG4gICAgICAgICAgPE1vZGFsQm9keT5cbiAgICAgICAgICAgIDxkaXYgey4uLmNsYXNzZXMoKX0gY2xhc3NOYW1lPVwiYy1jb21wZXRlbmNlLWdvYWxzXCI+XG4gICAgICAgICAgICAgIHtjaGlsZHJlbn1cbiAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgIDwvTW9kYWxCb2R5PlxuICAgICAgICA8L0ZyYWdtZW50PlxuICAgICAgKX1cbiAgICA8L01vZGFsPlxuICApO1xufTtcblxuQ29tcGV0ZW5jZUdvYWxzRGlhbG9nLnByb3BUeXBlcyA9IHtcbiAgY3VycmljdWx1bXM6IFByb3BUeXBlcy5hcnJheU9mKFxuICAgIFByb3BUeXBlcy5zaGFwZSh7XG4gICAgICBpZDogUHJvcFR5cGVzLnN0cmluZy5pc1JlcXVpcmVkLFxuICAgICAgbmFtZTogUHJvcFR5cGVzLnN0cmluZy5pc1JlcXVpcmVkLFxuICAgICAgZ29hbHM6IFByb3BUeXBlcy5hcnJheU9mKFxuICAgICAgICBQcm9wVHlwZXMuc2hhcGUoe1xuICAgICAgICAgIGlkOiBQcm9wVHlwZXMuc3RyaW5nLmlzUmVxdWlyZWQsXG4gICAgICAgICAgbmFtZTogUHJvcFR5cGVzLnN0cmluZy5pc1JlcXVpcmVkLFxuICAgICAgICB9KSxcbiAgICAgICksXG4gICAgfSksXG4gICksXG4gIHN1YmplY3ROYW1lOiBQcm9wVHlwZXMuc3RyaW5nLFxufTtcblxuZXhwb3J0IGRlZmF1bHQgQ29tcGV0ZW5jZUdvYWxzRGlhbG9nO1xuIl19 */",
47
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNvbXBldGVuY2VHb2Fsc0RpYWxvZy5qc3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBaUJnQyIsImZpbGUiOiJDb21wZXRlbmNlR29hbHNEaWFsb2cuanN4Iiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIENvcHlyaWdodCAoYykgMjAxOC1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCwgeyBGcmFnbWVudCB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5pbXBvcnQgeyB1c2VUcmFuc2xhdGlvbiB9IGZyb20gJ3JlYWN0LWkxOG5leHQnO1xuaW1wb3J0IHsgZm9udHMgfSBmcm9tICdAbmRsYS9jb3JlJztcbmltcG9ydCBNb2RhbCwgeyBNb2RhbEhlYWRlciwgTW9kYWxCb2R5LCBNb2RhbENsb3NlQnV0dG9uIH0gZnJvbSAnQG5kbGEvbW9kYWwnO1xuaW1wb3J0IHsgRm9vdGVySGVhZGVySWNvbiB9IGZyb20gJ0BuZGxhL2ljb25zL2NvbW1vbic7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBjbGFzc2VzIH0gZnJvbSAnLi9Db21wZXRlbmNlR29hbHMnO1xuXG5jb25zdCBIZWFkZXJXcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgcGFkZGluZzogMTRweCAyMHB4IDE0cHggMDtcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAganVzdGlmeS1jb250ZW50OiBzcGFjZS1iZXR3ZWVuO1xuICB3aWR0aDogMTAwJTtcbmA7XG5cbmNvbnN0IEhlYWRpbmdXcmFwcGVyID0gc3R5bGVkLmgyYFxuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICAke2ZvbnRzLnNpemVzKCcxOHB4JywgJzMycHgnKX07XG4gIG1hcmdpbjogMDtcbiAgZm9udC13ZWlnaHQ6ICR7Zm9udHMud2VpZ2h0LnNlbWlib2xkfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBDb21wZXRlbmNlR29hbHNEaWFsb2cgPSAoeyBjaGlsZHJlbiwgaXNPcGVuLCBvbkNsb3NlLCBzdWJqZWN0TmFtZSwgbW9kYWxQcm9wcyB9KSA9PiB7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcbiAgY29uc3QgaWNvbklkID0gJ3BvcHVwQ29tcGV0ZW5jZUdvYWxzJztcblxuICByZXR1cm4gKFxuICAgIDxNb2RhbFxuICAgICAgbGFiZWxsZWRCeT17aWNvbklkfVxuICAgICAgey4uLm1vZGFsUHJvcHN9XG4gICAgICBjb250cm9sbGFibGVcbiAgICAgIGlzT3Blbj17aXNPcGVufVxuICAgICAgb25DbG9zZT17b25DbG9zZX1cbiAgICAgIHNpemU9XCJmdWxsc2NyZWVuXCJcbiAgICAgIGFuaW1hdGlvbj1cInNsaWRlLXVwXCJcbiAgICAgIGJhY2tncm91bmRDb2xvcj1cImxpZ2h0LWdyYWRpZW50XCJcbiAgICAgIG5hcnJvdz5cbiAgICAgIHsoY2xvc2UpID0+IChcbiAgICAgICAgPEZyYWdtZW50PlxuICAgICAgICAgIDxNb2RhbEhlYWRlciBtb2RpZmllcj1cIm1lbnVcIj5cbiAgICAgICAgICAgIDxIZWFkZXJXcmFwcGVyPlxuICAgICAgICAgICAgICA8SGVhZGluZ1dyYXBwZXI+XG4gICAgICAgICAgICAgICAgPEZvb3RlckhlYWRlckljb24gaWQ9e2ljb25JZH0gc2l6ZT1cIjI0cHhcIiBzdHlsZT17eyBtYXJnaW5SaWdodDogJzIwcHgnIH19IC8+XG4gICAgICAgICAgICAgICAge3QoJ2NvbXBldGVuY2VHb2Fscy5tb2RhbFRleHQnKX0ge3N1YmplY3ROYW1lICYmIGAgXFx1MjAyMiAke3N1YmplY3ROYW1lfWB9XG4gICAgICAgICAgICAgIDwvSGVhZGluZ1dyYXBwZXI+XG4gICAgICAgICAgICAgIDxNb2RhbENsb3NlQnV0dG9uIG9uQ2xpY2s9e2Nsb3NlfSB0aXRsZT17dCgnY29tcGV0ZW5jZUdvYWxzLmNvbXBldGVuY2VHb2FsQ2xvc2UnKX0gLz5cbiAgICAgICAgICAgIDwvSGVhZGVyV3JhcHBlcj5cbiAgICAgICAgICA8L01vZGFsSGVhZGVyPlxuICAgICAgICAgIDxNb2RhbEJvZHk+XG4gICAgICAgICAgICA8ZGl2IHsuLi5jbGFzc2VzKCl9IGNsYXNzTmFtZT1cImMtY29tcGV0ZW5jZS1nb2Fsc1wiPlxuICAgICAgICAgICAgICB7Y2hpbGRyZW59XG4gICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICA8L01vZGFsQm9keT5cbiAgICAgICAgPC9GcmFnbWVudD5cbiAgICAgICl9XG4gICAgPC9Nb2RhbD5cbiAgKTtcbn07XG5cbkNvbXBldGVuY2VHb2Fsc0RpYWxvZy5wcm9wVHlwZXMgPSB7XG4gIGN1cnJpY3VsdW1zOiBQcm9wVHlwZXMuYXJyYXlPZihcbiAgICBQcm9wVHlwZXMuc2hhcGUoe1xuICAgICAgaWQ6IFByb3BUeXBlcy5zdHJpbmcuaXNSZXF1aXJlZCxcbiAgICAgIG5hbWU6IFByb3BUeXBlcy5zdHJpbmcuaXNSZXF1aXJlZCxcbiAgICAgIGdvYWxzOiBQcm9wVHlwZXMuYXJyYXlPZihcbiAgICAgICAgUHJvcFR5cGVzLnNoYXBlKHtcbiAgICAgICAgICBpZDogUHJvcFR5cGVzLnN0cmluZy5pc1JlcXVpcmVkLFxuICAgICAgICAgIG5hbWU6IFByb3BUeXBlcy5zdHJpbmcuaXNSZXF1aXJlZCxcbiAgICAgICAgfSksXG4gICAgICApLFxuICAgIH0pLFxuICApLFxuICBzdWJqZWN0TmFtZTogUHJvcFR5cGVzLnN0cmluZyxcbn07XG5cbmV4cG9ydCBkZWZhdWx0IENvbXBldGVuY2VHb2Fsc0RpYWxvZztcbiJdfQ== */",
48
48
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
49
49
  });
50
50
  var HeadingWrapper = (0, _styledBase["default"])("h2", {
51
51
  target: "e183787v1",
52
52
  label: "HeadingWrapper"
53
- })("display:flex;align-items:center;", _core.fonts.sizes('18px', '32px'), ";margin:0;font-weight:", _core.fonts.weight.semibold, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNvbXBldGVuY2VHb2Fsc0RpYWxvZy5qc3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBeUJnQyIsImZpbGUiOiJDb21wZXRlbmNlR29hbHNEaWFsb2cuanN4Iiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIENvcHlyaWdodCAoYykgMjAxOC1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCwgeyBGcmFnbWVudCB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5pbXBvcnQgeyB1c2VUcmFuc2xhdGlvbiB9IGZyb20gJ3JlYWN0LWkxOG5leHQnO1xuaW1wb3J0IHsgZm9udHMgfSBmcm9tICdAbmRsYS9jb3JlJztcbmltcG9ydCBNb2RhbCwgeyBNb2RhbEhlYWRlciwgTW9kYWxCb2R5LCBNb2RhbENsb3NlQnV0dG9uIH0gZnJvbSAnQG5kbGEvbW9kYWwnO1xuaW1wb3J0IHsgRm9vdGVySGVhZGVySWNvbiB9IGZyb20gJ0BuZGxhL2ljb25zL2NvbW1vbic7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBjbGFzc2VzIH0gZnJvbSAnLi9Db21wZXRlbmNlR29hbHMnO1xuXG5jb25zdCBIZWFkZXJXcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgcGFkZGluZzogMTRweCAyMHB4IDE0cHggMDtcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAganVzdGlmeS1jb250ZW50OiBzcGFjZS1iZXR3ZWVuO1xuICB3aWR0aDogMTAwJTtcbmA7XG5cbmNvbnN0IEhlYWRpbmdXcmFwcGVyID0gc3R5bGVkLmgyYFxuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICAke2ZvbnRzLnNpemVzKCcxOHB4JywgJzMycHgnKX07XG4gIG1hcmdpbjogMDtcbiAgZm9udC13ZWlnaHQ6ICR7Zm9udHMud2VpZ2h0LnNlbWlib2xkfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBDb21wZXRlbmNlR29hbHNEaWFsb2cgPSAoeyBjaGlsZHJlbiwgaXNPcGVuLCBvbkNsb3NlLCBzdWJqZWN0TmFtZSwgbW9kYWxQcm9wcyB9KSA9PiB7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcbiAgcmV0dXJuIChcbiAgICA8TW9kYWxcbiAgICAgIHsuLi5tb2RhbFByb3BzfVxuICAgICAgY29udHJvbGxhYmxlXG4gICAgICBpc09wZW49e2lzT3Blbn1cbiAgICAgIG9uQ2xvc2U9e29uQ2xvc2V9XG4gICAgICBzaXplPVwiZnVsbHNjcmVlblwiXG4gICAgICBhbmltYXRpb249XCJzbGlkZS11cFwiXG4gICAgICBiYWNrZ3JvdW5kQ29sb3I9XCJsaWdodC1ncmFkaWVudFwiXG4gICAgICBuYXJyb3c+XG4gICAgICB7KGNsb3NlKSA9PiAoXG4gICAgICAgIDxGcmFnbWVudD5cbiAgICAgICAgICA8TW9kYWxIZWFkZXIgbW9kaWZpZXI9XCJtZW51XCI+XG4gICAgICAgICAgICA8SGVhZGVyV3JhcHBlcj5cbiAgICAgICAgICAgICAgPEhlYWRpbmdXcmFwcGVyPlxuICAgICAgICAgICAgICAgIDxGb290ZXJIZWFkZXJJY29uIHNpemU9XCIyNHB4XCIgc3R5bGU9e3sgbWFyZ2luUmlnaHQ6ICcyMHB4JyB9fSAvPlxuICAgICAgICAgICAgICAgIHsnVXRmb3JzayBsw6ZyZXBsYW5rb2JsaW5nZXInfSB7c3ViamVjdE5hbWUgJiYgYCBcXHUyMDIyICR7c3ViamVjdE5hbWV9YH1cbiAgICAgICAgICAgICAgPC9IZWFkaW5nV3JhcHBlcj5cbiAgICAgICAgICAgICAgPE1vZGFsQ2xvc2VCdXR0b24gb25DbGljaz17Y2xvc2V9IHRpdGxlPXt0KCdjb21wZXRlbmNlR29hbHMuY29tcGV0ZW5jZUdvYWxDbG9zZScpfSAvPlxuICAgICAgICAgICAgPC9IZWFkZXJXcmFwcGVyPlxuICAgICAgICAgIDwvTW9kYWxIZWFkZXI+XG4gICAgICAgICAgPE1vZGFsQm9keT5cbiAgICAgICAgICAgIDxkaXYgey4uLmNsYXNzZXMoKX0gY2xhc3NOYW1lPVwiYy1jb21wZXRlbmNlLWdvYWxzXCI+XG4gICAgICAgICAgICAgIHtjaGlsZHJlbn1cbiAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgIDwvTW9kYWxCb2R5PlxuICAgICAgICA8L0ZyYWdtZW50PlxuICAgICAgKX1cbiAgICA8L01vZGFsPlxuICApO1xufTtcblxuQ29tcGV0ZW5jZUdvYWxzRGlhbG9nLnByb3BUeXBlcyA9IHtcbiAgY3VycmljdWx1bXM6IFByb3BUeXBlcy5hcnJheU9mKFxuICAgIFByb3BUeXBlcy5zaGFwZSh7XG4gICAgICBpZDogUHJvcFR5cGVzLnN0cmluZy5pc1JlcXVpcmVkLFxuICAgICAgbmFtZTogUHJvcFR5cGVzLnN0cmluZy5pc1JlcXVpcmVkLFxuICAgICAgZ29hbHM6IFByb3BUeXBlcy5hcnJheU9mKFxuICAgICAgICBQcm9wVHlwZXMuc2hhcGUoe1xuICAgICAgICAgIGlkOiBQcm9wVHlwZXMuc3RyaW5nLmlzUmVxdWlyZWQsXG4gICAgICAgICAgbmFtZTogUHJvcFR5cGVzLnN0cmluZy5pc1JlcXVpcmVkLFxuICAgICAgICB9KSxcbiAgICAgICksXG4gICAgfSksXG4gICksXG4gIHN1YmplY3ROYW1lOiBQcm9wVHlwZXMuc3RyaW5nLFxufTtcblxuZXhwb3J0IGRlZmF1bHQgQ29tcGV0ZW5jZUdvYWxzRGlhbG9nO1xuIl19 */"));
53
+ })("display:flex;align-items:center;", _core.fonts.sizes('18px', '32px'), ";margin:0;font-weight:", _core.fonts.weight.semibold, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNvbXBldGVuY2VHb2Fsc0RpYWxvZy5qc3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBeUJnQyIsImZpbGUiOiJDb21wZXRlbmNlR29hbHNEaWFsb2cuanN4Iiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIENvcHlyaWdodCAoYykgMjAxOC1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCwgeyBGcmFnbWVudCB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5pbXBvcnQgeyB1c2VUcmFuc2xhdGlvbiB9IGZyb20gJ3JlYWN0LWkxOG5leHQnO1xuaW1wb3J0IHsgZm9udHMgfSBmcm9tICdAbmRsYS9jb3JlJztcbmltcG9ydCBNb2RhbCwgeyBNb2RhbEhlYWRlciwgTW9kYWxCb2R5LCBNb2RhbENsb3NlQnV0dG9uIH0gZnJvbSAnQG5kbGEvbW9kYWwnO1xuaW1wb3J0IHsgRm9vdGVySGVhZGVySWNvbiB9IGZyb20gJ0BuZGxhL2ljb25zL2NvbW1vbic7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBjbGFzc2VzIH0gZnJvbSAnLi9Db21wZXRlbmNlR29hbHMnO1xuXG5jb25zdCBIZWFkZXJXcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgcGFkZGluZzogMTRweCAyMHB4IDE0cHggMDtcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAganVzdGlmeS1jb250ZW50OiBzcGFjZS1iZXR3ZWVuO1xuICB3aWR0aDogMTAwJTtcbmA7XG5cbmNvbnN0IEhlYWRpbmdXcmFwcGVyID0gc3R5bGVkLmgyYFxuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICAke2ZvbnRzLnNpemVzKCcxOHB4JywgJzMycHgnKX07XG4gIG1hcmdpbjogMDtcbiAgZm9udC13ZWlnaHQ6ICR7Zm9udHMud2VpZ2h0LnNlbWlib2xkfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBDb21wZXRlbmNlR29hbHNEaWFsb2cgPSAoeyBjaGlsZHJlbiwgaXNPcGVuLCBvbkNsb3NlLCBzdWJqZWN0TmFtZSwgbW9kYWxQcm9wcyB9KSA9PiB7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcbiAgY29uc3QgaWNvbklkID0gJ3BvcHVwQ29tcGV0ZW5jZUdvYWxzJztcblxuICByZXR1cm4gKFxuICAgIDxNb2RhbFxuICAgICAgbGFiZWxsZWRCeT17aWNvbklkfVxuICAgICAgey4uLm1vZGFsUHJvcHN9XG4gICAgICBjb250cm9sbGFibGVcbiAgICAgIGlzT3Blbj17aXNPcGVufVxuICAgICAgb25DbG9zZT17b25DbG9zZX1cbiAgICAgIHNpemU9XCJmdWxsc2NyZWVuXCJcbiAgICAgIGFuaW1hdGlvbj1cInNsaWRlLXVwXCJcbiAgICAgIGJhY2tncm91bmRDb2xvcj1cImxpZ2h0LWdyYWRpZW50XCJcbiAgICAgIG5hcnJvdz5cbiAgICAgIHsoY2xvc2UpID0+IChcbiAgICAgICAgPEZyYWdtZW50PlxuICAgICAgICAgIDxNb2RhbEhlYWRlciBtb2RpZmllcj1cIm1lbnVcIj5cbiAgICAgICAgICAgIDxIZWFkZXJXcmFwcGVyPlxuICAgICAgICAgICAgICA8SGVhZGluZ1dyYXBwZXI+XG4gICAgICAgICAgICAgICAgPEZvb3RlckhlYWRlckljb24gaWQ9e2ljb25JZH0gc2l6ZT1cIjI0cHhcIiBzdHlsZT17eyBtYXJnaW5SaWdodDogJzIwcHgnIH19IC8+XG4gICAgICAgICAgICAgICAge3QoJ2NvbXBldGVuY2VHb2Fscy5tb2RhbFRleHQnKX0ge3N1YmplY3ROYW1lICYmIGAgXFx1MjAyMiAke3N1YmplY3ROYW1lfWB9XG4gICAgICAgICAgICAgIDwvSGVhZGluZ1dyYXBwZXI+XG4gICAgICAgICAgICAgIDxNb2RhbENsb3NlQnV0dG9uIG9uQ2xpY2s9e2Nsb3NlfSB0aXRsZT17dCgnY29tcGV0ZW5jZUdvYWxzLmNvbXBldGVuY2VHb2FsQ2xvc2UnKX0gLz5cbiAgICAgICAgICAgIDwvSGVhZGVyV3JhcHBlcj5cbiAgICAgICAgICA8L01vZGFsSGVhZGVyPlxuICAgICAgICAgIDxNb2RhbEJvZHk+XG4gICAgICAgICAgICA8ZGl2IHsuLi5jbGFzc2VzKCl9IGNsYXNzTmFtZT1cImMtY29tcGV0ZW5jZS1nb2Fsc1wiPlxuICAgICAgICAgICAgICB7Y2hpbGRyZW59XG4gICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICA8L01vZGFsQm9keT5cbiAgICAgICAgPC9GcmFnbWVudD5cbiAgICAgICl9XG4gICAgPC9Nb2RhbD5cbiAgKTtcbn07XG5cbkNvbXBldGVuY2VHb2Fsc0RpYWxvZy5wcm9wVHlwZXMgPSB7XG4gIGN1cnJpY3VsdW1zOiBQcm9wVHlwZXMuYXJyYXlPZihcbiAgICBQcm9wVHlwZXMuc2hhcGUoe1xuICAgICAgaWQ6IFByb3BUeXBlcy5zdHJpbmcuaXNSZXF1aXJlZCxcbiAgICAgIG5hbWU6IFByb3BUeXBlcy5zdHJpbmcuaXNSZXF1aXJlZCxcbiAgICAgIGdvYWxzOiBQcm9wVHlwZXMuYXJyYXlPZihcbiAgICAgICAgUHJvcFR5cGVzLnNoYXBlKHtcbiAgICAgICAgICBpZDogUHJvcFR5cGVzLnN0cmluZy5pc1JlcXVpcmVkLFxuICAgICAgICAgIG5hbWU6IFByb3BUeXBlcy5zdHJpbmcuaXNSZXF1aXJlZCxcbiAgICAgICAgfSksXG4gICAgICApLFxuICAgIH0pLFxuICApLFxuICBzdWJqZWN0TmFtZTogUHJvcFR5cGVzLnN0cmluZyxcbn07XG5cbmV4cG9ydCBkZWZhdWx0IENvbXBldGVuY2VHb2Fsc0RpYWxvZztcbiJdfQ== */"));
54
54
 
55
55
  var CompetenceGoalsDialog = function CompetenceGoalsDialog(_ref) {
56
56
  var children = _ref.children,
@@ -62,7 +62,10 @@ var CompetenceGoalsDialog = function CompetenceGoalsDialog(_ref) {
62
62
  var _useTranslation = (0, _reactI18next.useTranslation)(),
63
63
  t = _useTranslation.t;
64
64
 
65
- return (0, _core2.jsx)(_modal["default"], _extends({}, modalProps, {
65
+ var iconId = 'popupCompetenceGoals';
66
+ return (0, _core2.jsx)(_modal["default"], _extends({
67
+ labelledBy: iconId
68
+ }, modalProps, {
66
69
  controllable: true,
67
70
  isOpen: isOpen,
68
71
  onClose: onClose,
@@ -74,11 +77,12 @@ var CompetenceGoalsDialog = function CompetenceGoalsDialog(_ref) {
74
77
  return (0, _core2.jsx)(_react.Fragment, null, (0, _core2.jsx)(_modal.ModalHeader, {
75
78
  modifier: "menu"
76
79
  }, (0, _core2.jsx)(HeaderWrapper, null, (0, _core2.jsx)(HeadingWrapper, null, (0, _core2.jsx)(_common.FooterHeaderIcon, {
80
+ id: iconId,
77
81
  size: "24px",
78
82
  style: {
79
83
  marginRight: '20px'
80
84
  }
81
- }), 'Utforsk læreplankoblinger', " ", subjectName && " \u2022 ".concat(subjectName)), (0, _core2.jsx)(_modal.ModalCloseButton, {
85
+ }), t('competenceGoals.modalText'), " ", subjectName && " \u2022 ".concat(subjectName)), (0, _core2.jsx)(_modal.ModalCloseButton, {
82
86
  onClick: close,
83
87
  title: t('competenceGoals.competenceGoalClose')
84
88
  }))), (0, _core2.jsx)(_modal.ModalBody, null, (0, _core2.jsx)("div", _extends({}, (0, _CompetenceGoals.classes)(), {
@@ -5,16 +5,12 @@
5
5
  * LICENSE file in the root directory of this source tree.
6
6
  *
7
7
  */
8
- import { ReactNode } from 'react';
9
- interface Props {
8
+ import { ReactNode, SVGProps } from 'react';
9
+ interface Props extends Omit<SVGProps<SVGSVGElement>, 'viewBox'> {
10
10
  children?: ReactNode;
11
- speed?: number;
12
- width?: number;
13
- height?: number;
14
11
  primaryColor?: string;
15
12
  secondaryColor?: string;
16
- preserveAspectRatio?: string;
17
- className?: string;
13
+ viewBox?: string | null;
18
14
  }
19
- declare const ContentLoader: ({ children, width, height, preserveAspectRatio, className, primaryColor, secondaryColor, speed, ...rest }: Props) => JSX.Element;
15
+ declare const ContentLoader: ({ children, width, height, preserveAspectRatio, className, primaryColor, secondaryColor, speed, viewBox: viewBoxProp, ...rest }: Props) => JSX.Element;
20
16
  export default ContentLoader;
@@ -35,16 +35,21 @@ var ContentLoader = function ContentLoader(_ref) {
35
35
  secondaryColor = _ref$secondaryColor === void 0 ? '#e0e0e0' : _ref$secondaryColor,
36
36
  _ref$speed = _ref.speed,
37
37
  speed = _ref$speed === void 0 ? 2 : _ref$speed,
38
- rest = _objectWithoutProperties(_ref, ["children", "width", "height", "preserveAspectRatio", "className", "primaryColor", "secondaryColor", "speed"]);
38
+ viewBoxProp = _ref.viewBox,
39
+ rest = _objectWithoutProperties(_ref, ["children", "width", "height", "preserveAspectRatio", "className", "primaryColor", "secondaryColor", "speed", "viewBox"]);
39
40
 
40
41
  var idClip = (0, _util.uuid)();
41
42
  var idGradient = (0, _util.uuid)();
43
+ var viewBox = viewBoxProp === undefined ? "0 0 ".concat(width, " ").concat(height) : viewBoxProp;
42
44
  return (0, _core.jsx)("svg", _extends({
43
- viewBox: "0 0 ".concat(width, " ").concat(height),
45
+ viewBox: viewBox !== null && viewBox !== void 0 ? viewBox : undefined,
44
46
  version: "1.1",
45
47
  preserveAspectRatio: preserveAspectRatio,
46
48
  className: className
47
- }, rest), (0, _core.jsx)("rect", {
49
+ }, rest, {
50
+ height: typeof height === 'string' ? height : undefined,
51
+ width: typeof width === 'string' ? width : undefined
52
+ }), (0, _core.jsx)("rect", {
48
53
  style: {
49
54
  fill: "url(#".concat(idGradient, ")")
50
55
  },
@@ -50,7 +50,7 @@ function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringif
50
50
  var StyledHeading = (0, _styledBase["default"])("h3", {
51
51
  target: "e1yaxziw0",
52
52
  label: "StyledHeading"
53
- })(_core.fonts.sizes('16px', '32px'), ";margin:0 0 ", _core.spacing.small, ";color:", _core.colors.text.light, ";font-weight:", _core.fonts.weight.semibold, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilterButtons.tsx"],"names":[],"mappings":"AAkB+B","file":"FilterButtons.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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 */\nimport React, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\n// @ts-ignore\nimport ToggleItem from './ToggleItem';\nimport FilterCarousel from './FilterCarousel';\n\nconst StyledHeading = styled.h3`\n  ${fonts.sizes('16px', '32px')};\n  margin: 0 0 ${spacing.small};\n  color: ${colors.text.light};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledButtonsWrapper = styled.div`\n  display: inline-flex;\n  flex-wrap: wrap;\n`;\n\nconst StyledButtonElementWrapper = styled.div`\n  margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n  break-inside: avoid;\n  flex-shrink: 0;\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    column-count: 2;\n    column-gap: 20px;\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    column-count: 3;\n    column-gap: 20px;\n  }\n`;\nconst StyledListItem = styled.li`\n  margin-bottom: 0;\n  break-inside: avoid;\n`;\n\nconst StyledButtonContent = styled.span``;\n\nconst StyledButtonContentSelected = styled.span`\n  margin-left: ${spacing.small};\n  display: inline-flex;\n  align-items: center;\n`;\n\nconst StyledRemoveWrapper = styled.div`\n  margin-top: ${spacing.xsmall};\n  margin-left: 10px;\n`;\n\nconst ButtonRemoveText = styled.span`\n  ${fonts.sizes('16px', '32px')};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nexport type ItemProps = {\n  label: string;\n  value: string;\n  selected?: boolean;\n};\nexport type FilterButtonsProps = {\n  heading?: string;\n  items: ItemProps[];\n  onFilterToggle: (value: string) => void;\n  onRemoveAllFilters: () => void;\n  labels: {\n    openFilter: string;\n  };\n};\n\nexport const FilterButtons = ({ heading, items, onFilterToggle, onRemoveAllFilters, labels }: FilterButtonsProps) => {\n  const { t } = useTranslation();\n  const [isNarrowScreen, setIsNarrowScreen] = useState(false);\n\n  useEffect(() => {\n    const isNarrowScreenMatch = window.matchMedia('(max-width: 767px)');\n    const handleChange = (e: MediaQueryListEvent | MediaQueryList) => {\n      setIsNarrowScreen(e.matches);\n    };\n    isNarrowScreenMatch.addEventListener('change', handleChange);\n    handleChange(isNarrowScreenMatch);\n    return () => {\n      isNarrowScreenMatch.removeEventListener('change', handleChange);\n    };\n  }, []);\n\n  const hasSelectedFilters = items.some((item) => {\n    return item.selected;\n  });\n\n  const activeItems = items.filter((item) => item.selected);\n\n  return (\n    <>\n      {isNarrowScreen && (\n        <StyledButtonsWrapper>\n          {activeItems.map((item: ItemProps) => (\n            <StyledButtonElementWrapper key={item.value}>\n              <Button\n                type=\"button\"\n                size=\"normal\"\n                borderShape=\"rounded\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}>\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </Button>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal\n            size=\"fullscreen\"\n            animation=\"subtle\"\n            backgroundColor=\"white\"\n            activateButton={\n              <StyledButtonElementWrapper>\n                <Button type=\"button\" size=\"normal\" light borderShape=\"rounded\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </Button>\n              </StyledButtonElementWrapper>\n            }>\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier={['left-align']}>\n                  <h1>{heading}</h1>\n                  <ModalCloseButton title={t('modal.closeModal')} onClick={onClose} />\n                </ModalHeader>\n                <ModalBody modifier=\"slide-in-left\">\n                  <StyledList>\n                    {items.map((item: ItemProps) => (\n                      <StyledListItem key={item.value}>\n                        <ToggleItem\n                          id={item.value}\n                          value={item.value}\n                          checked={item.selected}\n                          label={item.label}\n                          component=\"div\"\n                          onChange={() => onFilterToggle(item.value)}\n                        />\n                      </StyledListItem>\n                    ))}\n                  </StyledList>\n                </ModalBody>\n              </>\n            )}\n          </Modal>\n        </StyledButtonsWrapper>\n      )}\n      {!isNarrowScreen && (\n        <>\n          {heading && <StyledHeading>{heading}</StyledHeading>}\n          <FilterCarousel>\n            {items.map((item: ItemProps) => (\n              <StyledButtonElementWrapper key={item.value}>\n                <Button\n                  type=\"button\"\n                  size=\"normal\"\n                  greyLighter={!item.selected}\n                  borderShape=\"rounded\"\n                  onClick={() => onFilterToggle(item.value)}>\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </Button>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <Button onClick={onRemoveAllFilters} link>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </Button>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */"));
53
+ })(_core.fonts.sizes('16px', '32px'), ";margin:0 0 ", _core.spacing.small, ";color:", _core.colors.text.light, ";font-weight:", _core.fonts.weight.semibold, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilterButtons.tsx"],"names":[],"mappings":"AAkB+B","file":"FilterButtons.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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 */\nimport React, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\n// @ts-ignore\nimport ToggleItem from './ToggleItem';\nimport FilterCarousel from './FilterCarousel';\n\nconst StyledHeading = styled.h3`\n  ${fonts.sizes('16px', '32px')};\n  margin: 0 0 ${spacing.small};\n  color: ${colors.text.light};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledButtonsWrapper = styled.div`\n  display: inline-flex;\n  flex-wrap: wrap;\n`;\n\nconst StyledButtonElementWrapper = styled.div`\n  margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n  break-inside: avoid;\n  flex-shrink: 0;\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    column-count: 2;\n    column-gap: 20px;\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    column-count: 3;\n    column-gap: 20px;\n  }\n`;\nconst StyledListItem = styled.li`\n  margin-bottom: 0;\n  break-inside: avoid;\n`;\n\nconst StyledButtonContent = styled.span``;\n\nconst StyledButtonContentSelected = styled.span`\n  margin-left: ${spacing.small};\n  display: inline-flex;\n  align-items: center;\n`;\n\nconst StyledRemoveWrapper = styled.div`\n  margin-top: ${spacing.xsmall};\n  margin-left: 10px;\n`;\n\nconst ButtonRemoveText = styled.span`\n  ${fonts.sizes('16px', '32px')};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nexport type ItemProps = {\n  label: string;\n  value: string;\n  selected?: boolean;\n};\nexport type FilterButtonsProps = {\n  heading?: string;\n  items: ItemProps[];\n  onFilterToggle: (value: string) => void;\n  onRemoveAllFilters: () => void;\n  labels: {\n    openFilter: string;\n  };\n};\n\nexport const FilterButtons = ({ heading, items, onFilterToggle, onRemoveAllFilters, labels }: FilterButtonsProps) => {\n  const { t } = useTranslation();\n  const [isNarrowScreen, setIsNarrowScreen] = useState(false);\n\n  useEffect(() => {\n    const isNarrowScreenMatch = window.matchMedia('(max-width: 767px)');\n    const handleChange = (e: MediaQueryListEvent | MediaQueryList) => {\n      setIsNarrowScreen(e.matches);\n    };\n    isNarrowScreenMatch.addEventListener('change', handleChange);\n    handleChange(isNarrowScreenMatch);\n    return () => {\n      isNarrowScreenMatch.removeEventListener('change', handleChange);\n    };\n  }, []);\n\n  const hasSelectedFilters = items.some((item) => {\n    return item.selected;\n  });\n\n  const activeItems = items.filter((item) => item.selected);\n\n  return (\n    <>\n      {isNarrowScreen && (\n        <StyledButtonsWrapper>\n          {activeItems.map((item: ItemProps) => (\n            <StyledButtonElementWrapper key={item.value}>\n              <Button\n                type=\"button\"\n                size=\"normal\"\n                borderShape=\"rounded\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}>\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </Button>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal\n            label={t('searchPage.searchFilterMessages.resourceTypeFilter.button')}\n            size=\"fullscreen\"\n            animation=\"subtle\"\n            backgroundColor=\"white\"\n            activateButton={\n              <StyledButtonElementWrapper>\n                <Button type=\"button\" size=\"normal\" light borderShape=\"rounded\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </Button>\n              </StyledButtonElementWrapper>\n            }>\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier={['left-align']}>\n                  <h1>{heading}</h1>\n                  <ModalCloseButton title={t('modal.closeModal')} onClick={onClose} />\n                </ModalHeader>\n                <ModalBody modifier=\"slide-in-left\">\n                  <StyledList>\n                    {items.map((item: ItemProps) => (\n                      <StyledListItem key={item.value}>\n                        <ToggleItem\n                          id={item.value}\n                          value={item.value}\n                          checked={item.selected}\n                          label={item.label}\n                          component=\"div\"\n                          onChange={() => onFilterToggle(item.value)}\n                        />\n                      </StyledListItem>\n                    ))}\n                  </StyledList>\n                </ModalBody>\n              </>\n            )}\n          </Modal>\n        </StyledButtonsWrapper>\n      )}\n      {!isNarrowScreen && (\n        <>\n          {heading && <StyledHeading>{heading}</StyledHeading>}\n          <FilterCarousel>\n            {items.map((item: ItemProps) => (\n              <StyledButtonElementWrapper key={item.value}>\n                <Button\n                  type=\"button\"\n                  size=\"normal\"\n                  greyLighter={!item.selected}\n                  borderShape=\"rounded\"\n                  onClick={() => onFilterToggle(item.value)}>\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </Button>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <Button onClick={onRemoveAllFilters} link>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </Button>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */"));
54
54
  var StyledButtonsWrapper = (0, _styledBase["default"])("div", {
55
55
  target: "e1yaxziw1",
56
56
  label: "StyledButtonsWrapper"
@@ -60,13 +60,13 @@ var StyledButtonsWrapper = (0, _styledBase["default"])("div", {
60
60
  } : {
61
61
  name: "ao5xof",
62
62
  styles: "display:inline-flex;flex-wrap:wrap;",
63
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilterButtons.tsx"],"names":[],"mappings":"AAyBuC","file":"FilterButtons.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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 */\nimport React, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\n// @ts-ignore\nimport ToggleItem from './ToggleItem';\nimport FilterCarousel from './FilterCarousel';\n\nconst StyledHeading = styled.h3`\n  ${fonts.sizes('16px', '32px')};\n  margin: 0 0 ${spacing.small};\n  color: ${colors.text.light};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledButtonsWrapper = styled.div`\n  display: inline-flex;\n  flex-wrap: wrap;\n`;\n\nconst StyledButtonElementWrapper = styled.div`\n  margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n  break-inside: avoid;\n  flex-shrink: 0;\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    column-count: 2;\n    column-gap: 20px;\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    column-count: 3;\n    column-gap: 20px;\n  }\n`;\nconst StyledListItem = styled.li`\n  margin-bottom: 0;\n  break-inside: avoid;\n`;\n\nconst StyledButtonContent = styled.span``;\n\nconst StyledButtonContentSelected = styled.span`\n  margin-left: ${spacing.small};\n  display: inline-flex;\n  align-items: center;\n`;\n\nconst StyledRemoveWrapper = styled.div`\n  margin-top: ${spacing.xsmall};\n  margin-left: 10px;\n`;\n\nconst ButtonRemoveText = styled.span`\n  ${fonts.sizes('16px', '32px')};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nexport type ItemProps = {\n  label: string;\n  value: string;\n  selected?: boolean;\n};\nexport type FilterButtonsProps = {\n  heading?: string;\n  items: ItemProps[];\n  onFilterToggle: (value: string) => void;\n  onRemoveAllFilters: () => void;\n  labels: {\n    openFilter: string;\n  };\n};\n\nexport const FilterButtons = ({ heading, items, onFilterToggle, onRemoveAllFilters, labels }: FilterButtonsProps) => {\n  const { t } = useTranslation();\n  const [isNarrowScreen, setIsNarrowScreen] = useState(false);\n\n  useEffect(() => {\n    const isNarrowScreenMatch = window.matchMedia('(max-width: 767px)');\n    const handleChange = (e: MediaQueryListEvent | MediaQueryList) => {\n      setIsNarrowScreen(e.matches);\n    };\n    isNarrowScreenMatch.addEventListener('change', handleChange);\n    handleChange(isNarrowScreenMatch);\n    return () => {\n      isNarrowScreenMatch.removeEventListener('change', handleChange);\n    };\n  }, []);\n\n  const hasSelectedFilters = items.some((item) => {\n    return item.selected;\n  });\n\n  const activeItems = items.filter((item) => item.selected);\n\n  return (\n    <>\n      {isNarrowScreen && (\n        <StyledButtonsWrapper>\n          {activeItems.map((item: ItemProps) => (\n            <StyledButtonElementWrapper key={item.value}>\n              <Button\n                type=\"button\"\n                size=\"normal\"\n                borderShape=\"rounded\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}>\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </Button>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal\n            size=\"fullscreen\"\n            animation=\"subtle\"\n            backgroundColor=\"white\"\n            activateButton={\n              <StyledButtonElementWrapper>\n                <Button type=\"button\" size=\"normal\" light borderShape=\"rounded\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </Button>\n              </StyledButtonElementWrapper>\n            }>\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier={['left-align']}>\n                  <h1>{heading}</h1>\n                  <ModalCloseButton title={t('modal.closeModal')} onClick={onClose} />\n                </ModalHeader>\n                <ModalBody modifier=\"slide-in-left\">\n                  <StyledList>\n                    {items.map((item: ItemProps) => (\n                      <StyledListItem key={item.value}>\n                        <ToggleItem\n                          id={item.value}\n                          value={item.value}\n                          checked={item.selected}\n                          label={item.label}\n                          component=\"div\"\n                          onChange={() => onFilterToggle(item.value)}\n                        />\n                      </StyledListItem>\n                    ))}\n                  </StyledList>\n                </ModalBody>\n              </>\n            )}\n          </Modal>\n        </StyledButtonsWrapper>\n      )}\n      {!isNarrowScreen && (\n        <>\n          {heading && <StyledHeading>{heading}</StyledHeading>}\n          <FilterCarousel>\n            {items.map((item: ItemProps) => (\n              <StyledButtonElementWrapper key={item.value}>\n                <Button\n                  type=\"button\"\n                  size=\"normal\"\n                  greyLighter={!item.selected}\n                  borderShape=\"rounded\"\n                  onClick={() => onFilterToggle(item.value)}>\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </Button>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <Button onClick={onRemoveAllFilters} link>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </Button>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */",
63
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilterButtons.tsx"],"names":[],"mappings":"AAyBuC","file":"FilterButtons.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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 */\nimport React, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\n// @ts-ignore\nimport ToggleItem from './ToggleItem';\nimport FilterCarousel from './FilterCarousel';\n\nconst StyledHeading = styled.h3`\n  ${fonts.sizes('16px', '32px')};\n  margin: 0 0 ${spacing.small};\n  color: ${colors.text.light};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledButtonsWrapper = styled.div`\n  display: inline-flex;\n  flex-wrap: wrap;\n`;\n\nconst StyledButtonElementWrapper = styled.div`\n  margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n  break-inside: avoid;\n  flex-shrink: 0;\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    column-count: 2;\n    column-gap: 20px;\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    column-count: 3;\n    column-gap: 20px;\n  }\n`;\nconst StyledListItem = styled.li`\n  margin-bottom: 0;\n  break-inside: avoid;\n`;\n\nconst StyledButtonContent = styled.span``;\n\nconst StyledButtonContentSelected = styled.span`\n  margin-left: ${spacing.small};\n  display: inline-flex;\n  align-items: center;\n`;\n\nconst StyledRemoveWrapper = styled.div`\n  margin-top: ${spacing.xsmall};\n  margin-left: 10px;\n`;\n\nconst ButtonRemoveText = styled.span`\n  ${fonts.sizes('16px', '32px')};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nexport type ItemProps = {\n  label: string;\n  value: string;\n  selected?: boolean;\n};\nexport type FilterButtonsProps = {\n  heading?: string;\n  items: ItemProps[];\n  onFilterToggle: (value: string) => void;\n  onRemoveAllFilters: () => void;\n  labels: {\n    openFilter: string;\n  };\n};\n\nexport const FilterButtons = ({ heading, items, onFilterToggle, onRemoveAllFilters, labels }: FilterButtonsProps) => {\n  const { t } = useTranslation();\n  const [isNarrowScreen, setIsNarrowScreen] = useState(false);\n\n  useEffect(() => {\n    const isNarrowScreenMatch = window.matchMedia('(max-width: 767px)');\n    const handleChange = (e: MediaQueryListEvent | MediaQueryList) => {\n      setIsNarrowScreen(e.matches);\n    };\n    isNarrowScreenMatch.addEventListener('change', handleChange);\n    handleChange(isNarrowScreenMatch);\n    return () => {\n      isNarrowScreenMatch.removeEventListener('change', handleChange);\n    };\n  }, []);\n\n  const hasSelectedFilters = items.some((item) => {\n    return item.selected;\n  });\n\n  const activeItems = items.filter((item) => item.selected);\n\n  return (\n    <>\n      {isNarrowScreen && (\n        <StyledButtonsWrapper>\n          {activeItems.map((item: ItemProps) => (\n            <StyledButtonElementWrapper key={item.value}>\n              <Button\n                type=\"button\"\n                size=\"normal\"\n                borderShape=\"rounded\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}>\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </Button>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal\n            label={t('searchPage.searchFilterMessages.resourceTypeFilter.button')}\n            size=\"fullscreen\"\n            animation=\"subtle\"\n            backgroundColor=\"white\"\n            activateButton={\n              <StyledButtonElementWrapper>\n                <Button type=\"button\" size=\"normal\" light borderShape=\"rounded\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </Button>\n              </StyledButtonElementWrapper>\n            }>\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier={['left-align']}>\n                  <h1>{heading}</h1>\n                  <ModalCloseButton title={t('modal.closeModal')} onClick={onClose} />\n                </ModalHeader>\n                <ModalBody modifier=\"slide-in-left\">\n                  <StyledList>\n                    {items.map((item: ItemProps) => (\n                      <StyledListItem key={item.value}>\n                        <ToggleItem\n                          id={item.value}\n                          value={item.value}\n                          checked={item.selected}\n                          label={item.label}\n                          component=\"div\"\n                          onChange={() => onFilterToggle(item.value)}\n                        />\n                      </StyledListItem>\n                    ))}\n                  </StyledList>\n                </ModalBody>\n              </>\n            )}\n          </Modal>\n        </StyledButtonsWrapper>\n      )}\n      {!isNarrowScreen && (\n        <>\n          {heading && <StyledHeading>{heading}</StyledHeading>}\n          <FilterCarousel>\n            {items.map((item: ItemProps) => (\n              <StyledButtonElementWrapper key={item.value}>\n                <Button\n                  type=\"button\"\n                  size=\"normal\"\n                  greyLighter={!item.selected}\n                  borderShape=\"rounded\"\n                  onClick={() => onFilterToggle(item.value)}>\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </Button>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <Button onClick={onRemoveAllFilters} link>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </Button>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */",
64
64
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
65
65
  });
66
66
  var StyledButtonElementWrapper = (0, _styledBase["default"])("div", {
67
67
  target: "e1yaxziw2",
68
68
  label: "StyledButtonElementWrapper"
69
- })("margin:0 ", _core.spacing.xsmall, " ", _core.spacing.xsmall, " 0;break-inside:avoid;flex-shrink:0;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilterButtons.tsx"],"names":[],"mappings":"AA8B6C","file":"FilterButtons.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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 */\nimport React, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\n// @ts-ignore\nimport ToggleItem from './ToggleItem';\nimport FilterCarousel from './FilterCarousel';\n\nconst StyledHeading = styled.h3`\n  ${fonts.sizes('16px', '32px')};\n  margin: 0 0 ${spacing.small};\n  color: ${colors.text.light};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledButtonsWrapper = styled.div`\n  display: inline-flex;\n  flex-wrap: wrap;\n`;\n\nconst StyledButtonElementWrapper = styled.div`\n  margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n  break-inside: avoid;\n  flex-shrink: 0;\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    column-count: 2;\n    column-gap: 20px;\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    column-count: 3;\n    column-gap: 20px;\n  }\n`;\nconst StyledListItem = styled.li`\n  margin-bottom: 0;\n  break-inside: avoid;\n`;\n\nconst StyledButtonContent = styled.span``;\n\nconst StyledButtonContentSelected = styled.span`\n  margin-left: ${spacing.small};\n  display: inline-flex;\n  align-items: center;\n`;\n\nconst StyledRemoveWrapper = styled.div`\n  margin-top: ${spacing.xsmall};\n  margin-left: 10px;\n`;\n\nconst ButtonRemoveText = styled.span`\n  ${fonts.sizes('16px', '32px')};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nexport type ItemProps = {\n  label: string;\n  value: string;\n  selected?: boolean;\n};\nexport type FilterButtonsProps = {\n  heading?: string;\n  items: ItemProps[];\n  onFilterToggle: (value: string) => void;\n  onRemoveAllFilters: () => void;\n  labels: {\n    openFilter: string;\n  };\n};\n\nexport const FilterButtons = ({ heading, items, onFilterToggle, onRemoveAllFilters, labels }: FilterButtonsProps) => {\n  const { t } = useTranslation();\n  const [isNarrowScreen, setIsNarrowScreen] = useState(false);\n\n  useEffect(() => {\n    const isNarrowScreenMatch = window.matchMedia('(max-width: 767px)');\n    const handleChange = (e: MediaQueryListEvent | MediaQueryList) => {\n      setIsNarrowScreen(e.matches);\n    };\n    isNarrowScreenMatch.addEventListener('change', handleChange);\n    handleChange(isNarrowScreenMatch);\n    return () => {\n      isNarrowScreenMatch.removeEventListener('change', handleChange);\n    };\n  }, []);\n\n  const hasSelectedFilters = items.some((item) => {\n    return item.selected;\n  });\n\n  const activeItems = items.filter((item) => item.selected);\n\n  return (\n    <>\n      {isNarrowScreen && (\n        <StyledButtonsWrapper>\n          {activeItems.map((item: ItemProps) => (\n            <StyledButtonElementWrapper key={item.value}>\n              <Button\n                type=\"button\"\n                size=\"normal\"\n                borderShape=\"rounded\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}>\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </Button>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal\n            size=\"fullscreen\"\n            animation=\"subtle\"\n            backgroundColor=\"white\"\n            activateButton={\n              <StyledButtonElementWrapper>\n                <Button type=\"button\" size=\"normal\" light borderShape=\"rounded\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </Button>\n              </StyledButtonElementWrapper>\n            }>\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier={['left-align']}>\n                  <h1>{heading}</h1>\n                  <ModalCloseButton title={t('modal.closeModal')} onClick={onClose} />\n                </ModalHeader>\n                <ModalBody modifier=\"slide-in-left\">\n                  <StyledList>\n                    {items.map((item: ItemProps) => (\n                      <StyledListItem key={item.value}>\n                        <ToggleItem\n                          id={item.value}\n                          value={item.value}\n                          checked={item.selected}\n                          label={item.label}\n                          component=\"div\"\n                          onChange={() => onFilterToggle(item.value)}\n                        />\n                      </StyledListItem>\n                    ))}\n                  </StyledList>\n                </ModalBody>\n              </>\n            )}\n          </Modal>\n        </StyledButtonsWrapper>\n      )}\n      {!isNarrowScreen && (\n        <>\n          {heading && <StyledHeading>{heading}</StyledHeading>}\n          <FilterCarousel>\n            {items.map((item: ItemProps) => (\n              <StyledButtonElementWrapper key={item.value}>\n                <Button\n                  type=\"button\"\n                  size=\"normal\"\n                  greyLighter={!item.selected}\n                  borderShape=\"rounded\"\n                  onClick={() => onFilterToggle(item.value)}>\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </Button>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <Button onClick={onRemoveAllFilters} link>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </Button>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */"));
69
+ })("margin:0 ", _core.spacing.xsmall, " ", _core.spacing.xsmall, " 0;break-inside:avoid;flex-shrink:0;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilterButtons.tsx"],"names":[],"mappings":"AA8B6C","file":"FilterButtons.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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 */\nimport React, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\n// @ts-ignore\nimport ToggleItem from './ToggleItem';\nimport FilterCarousel from './FilterCarousel';\n\nconst StyledHeading = styled.h3`\n  ${fonts.sizes('16px', '32px')};\n  margin: 0 0 ${spacing.small};\n  color: ${colors.text.light};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledButtonsWrapper = styled.div`\n  display: inline-flex;\n  flex-wrap: wrap;\n`;\n\nconst StyledButtonElementWrapper = styled.div`\n  margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n  break-inside: avoid;\n  flex-shrink: 0;\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    column-count: 2;\n    column-gap: 20px;\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    column-count: 3;\n    column-gap: 20px;\n  }\n`;\nconst StyledListItem = styled.li`\n  margin-bottom: 0;\n  break-inside: avoid;\n`;\n\nconst StyledButtonContent = styled.span``;\n\nconst StyledButtonContentSelected = styled.span`\n  margin-left: ${spacing.small};\n  display: inline-flex;\n  align-items: center;\n`;\n\nconst StyledRemoveWrapper = styled.div`\n  margin-top: ${spacing.xsmall};\n  margin-left: 10px;\n`;\n\nconst ButtonRemoveText = styled.span`\n  ${fonts.sizes('16px', '32px')};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nexport type ItemProps = {\n  label: string;\n  value: string;\n  selected?: boolean;\n};\nexport type FilterButtonsProps = {\n  heading?: string;\n  items: ItemProps[];\n  onFilterToggle: (value: string) => void;\n  onRemoveAllFilters: () => void;\n  labels: {\n    openFilter: string;\n  };\n};\n\nexport const FilterButtons = ({ heading, items, onFilterToggle, onRemoveAllFilters, labels }: FilterButtonsProps) => {\n  const { t } = useTranslation();\n  const [isNarrowScreen, setIsNarrowScreen] = useState(false);\n\n  useEffect(() => {\n    const isNarrowScreenMatch = window.matchMedia('(max-width: 767px)');\n    const handleChange = (e: MediaQueryListEvent | MediaQueryList) => {\n      setIsNarrowScreen(e.matches);\n    };\n    isNarrowScreenMatch.addEventListener('change', handleChange);\n    handleChange(isNarrowScreenMatch);\n    return () => {\n      isNarrowScreenMatch.removeEventListener('change', handleChange);\n    };\n  }, []);\n\n  const hasSelectedFilters = items.some((item) => {\n    return item.selected;\n  });\n\n  const activeItems = items.filter((item) => item.selected);\n\n  return (\n    <>\n      {isNarrowScreen && (\n        <StyledButtonsWrapper>\n          {activeItems.map((item: ItemProps) => (\n            <StyledButtonElementWrapper key={item.value}>\n              <Button\n                type=\"button\"\n                size=\"normal\"\n                borderShape=\"rounded\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}>\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </Button>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal\n            label={t('searchPage.searchFilterMessages.resourceTypeFilter.button')}\n            size=\"fullscreen\"\n            animation=\"subtle\"\n            backgroundColor=\"white\"\n            activateButton={\n              <StyledButtonElementWrapper>\n                <Button type=\"button\" size=\"normal\" light borderShape=\"rounded\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </Button>\n              </StyledButtonElementWrapper>\n            }>\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier={['left-align']}>\n                  <h1>{heading}</h1>\n                  <ModalCloseButton title={t('modal.closeModal')} onClick={onClose} />\n                </ModalHeader>\n                <ModalBody modifier=\"slide-in-left\">\n                  <StyledList>\n                    {items.map((item: ItemProps) => (\n                      <StyledListItem key={item.value}>\n                        <ToggleItem\n                          id={item.value}\n                          value={item.value}\n                          checked={item.selected}\n                          label={item.label}\n                          component=\"div\"\n                          onChange={() => onFilterToggle(item.value)}\n                        />\n                      </StyledListItem>\n                    ))}\n                  </StyledList>\n                </ModalBody>\n              </>\n            )}\n          </Modal>\n        </StyledButtonsWrapper>\n      )}\n      {!isNarrowScreen && (\n        <>\n          {heading && <StyledHeading>{heading}</StyledHeading>}\n          <FilterCarousel>\n            {items.map((item: ItemProps) => (\n              <StyledButtonElementWrapper key={item.value}>\n                <Button\n                  type=\"button\"\n                  size=\"normal\"\n                  greyLighter={!item.selected}\n                  borderShape=\"rounded\"\n                  onClick={() => onFilterToggle(item.value)}>\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </Button>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <Button onClick={onRemoveAllFilters} link>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </Button>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */"));
70
70
  var StyledList = (0, _styledBase["default"])("ul", {
71
71
  target: "e1yaxziw3",
72
72
  label: "StyledList"
@@ -74,7 +74,7 @@ var StyledList = (0, _styledBase["default"])("ul", {
74
74
  from: _core.breakpoints.tablet
75
75
  }), "{column-count:2;column-gap:20px;}", _core.mq.range({
76
76
  from: _core.breakpoints.tabletWide
77
- }), "{column-count:3;column-gap:20px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilterButtons.tsx"],"names":[],"mappings":"AAoC4B","file":"FilterButtons.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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 */\nimport React, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\n// @ts-ignore\nimport ToggleItem from './ToggleItem';\nimport FilterCarousel from './FilterCarousel';\n\nconst StyledHeading = styled.h3`\n  ${fonts.sizes('16px', '32px')};\n  margin: 0 0 ${spacing.small};\n  color: ${colors.text.light};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledButtonsWrapper = styled.div`\n  display: inline-flex;\n  flex-wrap: wrap;\n`;\n\nconst StyledButtonElementWrapper = styled.div`\n  margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n  break-inside: avoid;\n  flex-shrink: 0;\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    column-count: 2;\n    column-gap: 20px;\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    column-count: 3;\n    column-gap: 20px;\n  }\n`;\nconst StyledListItem = styled.li`\n  margin-bottom: 0;\n  break-inside: avoid;\n`;\n\nconst StyledButtonContent = styled.span``;\n\nconst StyledButtonContentSelected = styled.span`\n  margin-left: ${spacing.small};\n  display: inline-flex;\n  align-items: center;\n`;\n\nconst StyledRemoveWrapper = styled.div`\n  margin-top: ${spacing.xsmall};\n  margin-left: 10px;\n`;\n\nconst ButtonRemoveText = styled.span`\n  ${fonts.sizes('16px', '32px')};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nexport type ItemProps = {\n  label: string;\n  value: string;\n  selected?: boolean;\n};\nexport type FilterButtonsProps = {\n  heading?: string;\n  items: ItemProps[];\n  onFilterToggle: (value: string) => void;\n  onRemoveAllFilters: () => void;\n  labels: {\n    openFilter: string;\n  };\n};\n\nexport const FilterButtons = ({ heading, items, onFilterToggle, onRemoveAllFilters, labels }: FilterButtonsProps) => {\n  const { t } = useTranslation();\n  const [isNarrowScreen, setIsNarrowScreen] = useState(false);\n\n  useEffect(() => {\n    const isNarrowScreenMatch = window.matchMedia('(max-width: 767px)');\n    const handleChange = (e: MediaQueryListEvent | MediaQueryList) => {\n      setIsNarrowScreen(e.matches);\n    };\n    isNarrowScreenMatch.addEventListener('change', handleChange);\n    handleChange(isNarrowScreenMatch);\n    return () => {\n      isNarrowScreenMatch.removeEventListener('change', handleChange);\n    };\n  }, []);\n\n  const hasSelectedFilters = items.some((item) => {\n    return item.selected;\n  });\n\n  const activeItems = items.filter((item) => item.selected);\n\n  return (\n    <>\n      {isNarrowScreen && (\n        <StyledButtonsWrapper>\n          {activeItems.map((item: ItemProps) => (\n            <StyledButtonElementWrapper key={item.value}>\n              <Button\n                type=\"button\"\n                size=\"normal\"\n                borderShape=\"rounded\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}>\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </Button>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal\n            size=\"fullscreen\"\n            animation=\"subtle\"\n            backgroundColor=\"white\"\n            activateButton={\n              <StyledButtonElementWrapper>\n                <Button type=\"button\" size=\"normal\" light borderShape=\"rounded\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </Button>\n              </StyledButtonElementWrapper>\n            }>\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier={['left-align']}>\n                  <h1>{heading}</h1>\n                  <ModalCloseButton title={t('modal.closeModal')} onClick={onClose} />\n                </ModalHeader>\n                <ModalBody modifier=\"slide-in-left\">\n                  <StyledList>\n                    {items.map((item: ItemProps) => (\n                      <StyledListItem key={item.value}>\n                        <ToggleItem\n                          id={item.value}\n                          value={item.value}\n                          checked={item.selected}\n                          label={item.label}\n                          component=\"div\"\n                          onChange={() => onFilterToggle(item.value)}\n                        />\n                      </StyledListItem>\n                    ))}\n                  </StyledList>\n                </ModalBody>\n              </>\n            )}\n          </Modal>\n        </StyledButtonsWrapper>\n      )}\n      {!isNarrowScreen && (\n        <>\n          {heading && <StyledHeading>{heading}</StyledHeading>}\n          <FilterCarousel>\n            {items.map((item: ItemProps) => (\n              <StyledButtonElementWrapper key={item.value}>\n                <Button\n                  type=\"button\"\n                  size=\"normal\"\n                  greyLighter={!item.selected}\n                  borderShape=\"rounded\"\n                  onClick={() => onFilterToggle(item.value)}>\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </Button>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <Button onClick={onRemoveAllFilters} link>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </Button>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */"));
77
+ }), "{column-count:3;column-gap:20px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilterButtons.tsx"],"names":[],"mappings":"AAoC4B","file":"FilterButtons.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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 */\nimport React, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\n// @ts-ignore\nimport ToggleItem from './ToggleItem';\nimport FilterCarousel from './FilterCarousel';\n\nconst StyledHeading = styled.h3`\n  ${fonts.sizes('16px', '32px')};\n  margin: 0 0 ${spacing.small};\n  color: ${colors.text.light};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledButtonsWrapper = styled.div`\n  display: inline-flex;\n  flex-wrap: wrap;\n`;\n\nconst StyledButtonElementWrapper = styled.div`\n  margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n  break-inside: avoid;\n  flex-shrink: 0;\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    column-count: 2;\n    column-gap: 20px;\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    column-count: 3;\n    column-gap: 20px;\n  }\n`;\nconst StyledListItem = styled.li`\n  margin-bottom: 0;\n  break-inside: avoid;\n`;\n\nconst StyledButtonContent = styled.span``;\n\nconst StyledButtonContentSelected = styled.span`\n  margin-left: ${spacing.small};\n  display: inline-flex;\n  align-items: center;\n`;\n\nconst StyledRemoveWrapper = styled.div`\n  margin-top: ${spacing.xsmall};\n  margin-left: 10px;\n`;\n\nconst ButtonRemoveText = styled.span`\n  ${fonts.sizes('16px', '32px')};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nexport type ItemProps = {\n  label: string;\n  value: string;\n  selected?: boolean;\n};\nexport type FilterButtonsProps = {\n  heading?: string;\n  items: ItemProps[];\n  onFilterToggle: (value: string) => void;\n  onRemoveAllFilters: () => void;\n  labels: {\n    openFilter: string;\n  };\n};\n\nexport const FilterButtons = ({ heading, items, onFilterToggle, onRemoveAllFilters, labels }: FilterButtonsProps) => {\n  const { t } = useTranslation();\n  const [isNarrowScreen, setIsNarrowScreen] = useState(false);\n\n  useEffect(() => {\n    const isNarrowScreenMatch = window.matchMedia('(max-width: 767px)');\n    const handleChange = (e: MediaQueryListEvent | MediaQueryList) => {\n      setIsNarrowScreen(e.matches);\n    };\n    isNarrowScreenMatch.addEventListener('change', handleChange);\n    handleChange(isNarrowScreenMatch);\n    return () => {\n      isNarrowScreenMatch.removeEventListener('change', handleChange);\n    };\n  }, []);\n\n  const hasSelectedFilters = items.some((item) => {\n    return item.selected;\n  });\n\n  const activeItems = items.filter((item) => item.selected);\n\n  return (\n    <>\n      {isNarrowScreen && (\n        <StyledButtonsWrapper>\n          {activeItems.map((item: ItemProps) => (\n            <StyledButtonElementWrapper key={item.value}>\n              <Button\n                type=\"button\"\n                size=\"normal\"\n                borderShape=\"rounded\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}>\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </Button>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal\n            label={t('searchPage.searchFilterMessages.resourceTypeFilter.button')}\n            size=\"fullscreen\"\n            animation=\"subtle\"\n            backgroundColor=\"white\"\n            activateButton={\n              <StyledButtonElementWrapper>\n                <Button type=\"button\" size=\"normal\" light borderShape=\"rounded\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </Button>\n              </StyledButtonElementWrapper>\n            }>\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier={['left-align']}>\n                  <h1>{heading}</h1>\n                  <ModalCloseButton title={t('modal.closeModal')} onClick={onClose} />\n                </ModalHeader>\n                <ModalBody modifier=\"slide-in-left\">\n                  <StyledList>\n                    {items.map((item: ItemProps) => (\n                      <StyledListItem key={item.value}>\n                        <ToggleItem\n                          id={item.value}\n                          value={item.value}\n                          checked={item.selected}\n                          label={item.label}\n                          component=\"div\"\n                          onChange={() => onFilterToggle(item.value)}\n                        />\n                      </StyledListItem>\n                    ))}\n                  </StyledList>\n                </ModalBody>\n              </>\n            )}\n          </Modal>\n        </StyledButtonsWrapper>\n      )}\n      {!isNarrowScreen && (\n        <>\n          {heading && <StyledHeading>{heading}</StyledHeading>}\n          <FilterCarousel>\n            {items.map((item: ItemProps) => (\n              <StyledButtonElementWrapper key={item.value}>\n                <Button\n                  type=\"button\"\n                  size=\"normal\"\n                  greyLighter={!item.selected}\n                  borderShape=\"rounded\"\n                  onClick={() => onFilterToggle(item.value)}>\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </Button>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <Button onClick={onRemoveAllFilters} link>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </Button>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */"));
78
78
  var StyledListItem = (0, _styledBase["default"])("li", {
79
79
  target: "e1yaxziw4",
80
80
  label: "StyledListItem"
@@ -84,25 +84,25 @@ var StyledListItem = (0, _styledBase["default"])("li", {
84
84
  } : {
85
85
  name: "1gj47mt",
86
86
  styles: "margin-bottom:0;break-inside:avoid;",
87
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilterButtons.tsx"],"names":[],"mappings":"AAiDgC","file":"FilterButtons.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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 */\nimport React, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\n// @ts-ignore\nimport ToggleItem from './ToggleItem';\nimport FilterCarousel from './FilterCarousel';\n\nconst StyledHeading = styled.h3`\n  ${fonts.sizes('16px', '32px')};\n  margin: 0 0 ${spacing.small};\n  color: ${colors.text.light};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledButtonsWrapper = styled.div`\n  display: inline-flex;\n  flex-wrap: wrap;\n`;\n\nconst StyledButtonElementWrapper = styled.div`\n  margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n  break-inside: avoid;\n  flex-shrink: 0;\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    column-count: 2;\n    column-gap: 20px;\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    column-count: 3;\n    column-gap: 20px;\n  }\n`;\nconst StyledListItem = styled.li`\n  margin-bottom: 0;\n  break-inside: avoid;\n`;\n\nconst StyledButtonContent = styled.span``;\n\nconst StyledButtonContentSelected = styled.span`\n  margin-left: ${spacing.small};\n  display: inline-flex;\n  align-items: center;\n`;\n\nconst StyledRemoveWrapper = styled.div`\n  margin-top: ${spacing.xsmall};\n  margin-left: 10px;\n`;\n\nconst ButtonRemoveText = styled.span`\n  ${fonts.sizes('16px', '32px')};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nexport type ItemProps = {\n  label: string;\n  value: string;\n  selected?: boolean;\n};\nexport type FilterButtonsProps = {\n  heading?: string;\n  items: ItemProps[];\n  onFilterToggle: (value: string) => void;\n  onRemoveAllFilters: () => void;\n  labels: {\n    openFilter: string;\n  };\n};\n\nexport const FilterButtons = ({ heading, items, onFilterToggle, onRemoveAllFilters, labels }: FilterButtonsProps) => {\n  const { t } = useTranslation();\n  const [isNarrowScreen, setIsNarrowScreen] = useState(false);\n\n  useEffect(() => {\n    const isNarrowScreenMatch = window.matchMedia('(max-width: 767px)');\n    const handleChange = (e: MediaQueryListEvent | MediaQueryList) => {\n      setIsNarrowScreen(e.matches);\n    };\n    isNarrowScreenMatch.addEventListener('change', handleChange);\n    handleChange(isNarrowScreenMatch);\n    return () => {\n      isNarrowScreenMatch.removeEventListener('change', handleChange);\n    };\n  }, []);\n\n  const hasSelectedFilters = items.some((item) => {\n    return item.selected;\n  });\n\n  const activeItems = items.filter((item) => item.selected);\n\n  return (\n    <>\n      {isNarrowScreen && (\n        <StyledButtonsWrapper>\n          {activeItems.map((item: ItemProps) => (\n            <StyledButtonElementWrapper key={item.value}>\n              <Button\n                type=\"button\"\n                size=\"normal\"\n                borderShape=\"rounded\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}>\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </Button>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal\n            size=\"fullscreen\"\n            animation=\"subtle\"\n            backgroundColor=\"white\"\n            activateButton={\n              <StyledButtonElementWrapper>\n                <Button type=\"button\" size=\"normal\" light borderShape=\"rounded\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </Button>\n              </StyledButtonElementWrapper>\n            }>\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier={['left-align']}>\n                  <h1>{heading}</h1>\n                  <ModalCloseButton title={t('modal.closeModal')} onClick={onClose} />\n                </ModalHeader>\n                <ModalBody modifier=\"slide-in-left\">\n                  <StyledList>\n                    {items.map((item: ItemProps) => (\n                      <StyledListItem key={item.value}>\n                        <ToggleItem\n                          id={item.value}\n                          value={item.value}\n                          checked={item.selected}\n                          label={item.label}\n                          component=\"div\"\n                          onChange={() => onFilterToggle(item.value)}\n                        />\n                      </StyledListItem>\n                    ))}\n                  </StyledList>\n                </ModalBody>\n              </>\n            )}\n          </Modal>\n        </StyledButtonsWrapper>\n      )}\n      {!isNarrowScreen && (\n        <>\n          {heading && <StyledHeading>{heading}</StyledHeading>}\n          <FilterCarousel>\n            {items.map((item: ItemProps) => (\n              <StyledButtonElementWrapper key={item.value}>\n                <Button\n                  type=\"button\"\n                  size=\"normal\"\n                  greyLighter={!item.selected}\n                  borderShape=\"rounded\"\n                  onClick={() => onFilterToggle(item.value)}>\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </Button>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <Button onClick={onRemoveAllFilters} link>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </Button>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */",
87
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilterButtons.tsx"],"names":[],"mappings":"AAiDgC","file":"FilterButtons.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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 */\nimport React, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\n// @ts-ignore\nimport ToggleItem from './ToggleItem';\nimport FilterCarousel from './FilterCarousel';\n\nconst StyledHeading = styled.h3`\n  ${fonts.sizes('16px', '32px')};\n  margin: 0 0 ${spacing.small};\n  color: ${colors.text.light};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledButtonsWrapper = styled.div`\n  display: inline-flex;\n  flex-wrap: wrap;\n`;\n\nconst StyledButtonElementWrapper = styled.div`\n  margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n  break-inside: avoid;\n  flex-shrink: 0;\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    column-count: 2;\n    column-gap: 20px;\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    column-count: 3;\n    column-gap: 20px;\n  }\n`;\nconst StyledListItem = styled.li`\n  margin-bottom: 0;\n  break-inside: avoid;\n`;\n\nconst StyledButtonContent = styled.span``;\n\nconst StyledButtonContentSelected = styled.span`\n  margin-left: ${spacing.small};\n  display: inline-flex;\n  align-items: center;\n`;\n\nconst StyledRemoveWrapper = styled.div`\n  margin-top: ${spacing.xsmall};\n  margin-left: 10px;\n`;\n\nconst ButtonRemoveText = styled.span`\n  ${fonts.sizes('16px', '32px')};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nexport type ItemProps = {\n  label: string;\n  value: string;\n  selected?: boolean;\n};\nexport type FilterButtonsProps = {\n  heading?: string;\n  items: ItemProps[];\n  onFilterToggle: (value: string) => void;\n  onRemoveAllFilters: () => void;\n  labels: {\n    openFilter: string;\n  };\n};\n\nexport const FilterButtons = ({ heading, items, onFilterToggle, onRemoveAllFilters, labels }: FilterButtonsProps) => {\n  const { t } = useTranslation();\n  const [isNarrowScreen, setIsNarrowScreen] = useState(false);\n\n  useEffect(() => {\n    const isNarrowScreenMatch = window.matchMedia('(max-width: 767px)');\n    const handleChange = (e: MediaQueryListEvent | MediaQueryList) => {\n      setIsNarrowScreen(e.matches);\n    };\n    isNarrowScreenMatch.addEventListener('change', handleChange);\n    handleChange(isNarrowScreenMatch);\n    return () => {\n      isNarrowScreenMatch.removeEventListener('change', handleChange);\n    };\n  }, []);\n\n  const hasSelectedFilters = items.some((item) => {\n    return item.selected;\n  });\n\n  const activeItems = items.filter((item) => item.selected);\n\n  return (\n    <>\n      {isNarrowScreen && (\n        <StyledButtonsWrapper>\n          {activeItems.map((item: ItemProps) => (\n            <StyledButtonElementWrapper key={item.value}>\n              <Button\n                type=\"button\"\n                size=\"normal\"\n                borderShape=\"rounded\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}>\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </Button>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal\n            label={t('searchPage.searchFilterMessages.resourceTypeFilter.button')}\n            size=\"fullscreen\"\n            animation=\"subtle\"\n            backgroundColor=\"white\"\n            activateButton={\n              <StyledButtonElementWrapper>\n                <Button type=\"button\" size=\"normal\" light borderShape=\"rounded\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </Button>\n              </StyledButtonElementWrapper>\n            }>\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier={['left-align']}>\n                  <h1>{heading}</h1>\n                  <ModalCloseButton title={t('modal.closeModal')} onClick={onClose} />\n                </ModalHeader>\n                <ModalBody modifier=\"slide-in-left\">\n                  <StyledList>\n                    {items.map((item: ItemProps) => (\n                      <StyledListItem key={item.value}>\n                        <ToggleItem\n                          id={item.value}\n                          value={item.value}\n                          checked={item.selected}\n                          label={item.label}\n                          component=\"div\"\n                          onChange={() => onFilterToggle(item.value)}\n                        />\n                      </StyledListItem>\n                    ))}\n                  </StyledList>\n                </ModalBody>\n              </>\n            )}\n          </Modal>\n        </StyledButtonsWrapper>\n      )}\n      {!isNarrowScreen && (\n        <>\n          {heading && <StyledHeading>{heading}</StyledHeading>}\n          <FilterCarousel>\n            {items.map((item: ItemProps) => (\n              <StyledButtonElementWrapper key={item.value}>\n                <Button\n                  type=\"button\"\n                  size=\"normal\"\n                  greyLighter={!item.selected}\n                  borderShape=\"rounded\"\n                  onClick={() => onFilterToggle(item.value)}>\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </Button>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <Button onClick={onRemoveAllFilters} link>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </Button>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */",
88
88
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
89
89
  });
90
90
  var StyledButtonContent = (0, _styledBase["default"])("span", {
91
91
  target: "e1yaxziw5",
92
92
  label: "StyledButtonContent"
93
- })(process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilterButtons.tsx"],"names":[],"mappings":"AAsDuC","file":"FilterButtons.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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 */\nimport React, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\n// @ts-ignore\nimport ToggleItem from './ToggleItem';\nimport FilterCarousel from './FilterCarousel';\n\nconst StyledHeading = styled.h3`\n  ${fonts.sizes('16px', '32px')};\n  margin: 0 0 ${spacing.small};\n  color: ${colors.text.light};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledButtonsWrapper = styled.div`\n  display: inline-flex;\n  flex-wrap: wrap;\n`;\n\nconst StyledButtonElementWrapper = styled.div`\n  margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n  break-inside: avoid;\n  flex-shrink: 0;\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    column-count: 2;\n    column-gap: 20px;\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    column-count: 3;\n    column-gap: 20px;\n  }\n`;\nconst StyledListItem = styled.li`\n  margin-bottom: 0;\n  break-inside: avoid;\n`;\n\nconst StyledButtonContent = styled.span``;\n\nconst StyledButtonContentSelected = styled.span`\n  margin-left: ${spacing.small};\n  display: inline-flex;\n  align-items: center;\n`;\n\nconst StyledRemoveWrapper = styled.div`\n  margin-top: ${spacing.xsmall};\n  margin-left: 10px;\n`;\n\nconst ButtonRemoveText = styled.span`\n  ${fonts.sizes('16px', '32px')};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nexport type ItemProps = {\n  label: string;\n  value: string;\n  selected?: boolean;\n};\nexport type FilterButtonsProps = {\n  heading?: string;\n  items: ItemProps[];\n  onFilterToggle: (value: string) => void;\n  onRemoveAllFilters: () => void;\n  labels: {\n    openFilter: string;\n  };\n};\n\nexport const FilterButtons = ({ heading, items, onFilterToggle, onRemoveAllFilters, labels }: FilterButtonsProps) => {\n  const { t } = useTranslation();\n  const [isNarrowScreen, setIsNarrowScreen] = useState(false);\n\n  useEffect(() => {\n    const isNarrowScreenMatch = window.matchMedia('(max-width: 767px)');\n    const handleChange = (e: MediaQueryListEvent | MediaQueryList) => {\n      setIsNarrowScreen(e.matches);\n    };\n    isNarrowScreenMatch.addEventListener('change', handleChange);\n    handleChange(isNarrowScreenMatch);\n    return () => {\n      isNarrowScreenMatch.removeEventListener('change', handleChange);\n    };\n  }, []);\n\n  const hasSelectedFilters = items.some((item) => {\n    return item.selected;\n  });\n\n  const activeItems = items.filter((item) => item.selected);\n\n  return (\n    <>\n      {isNarrowScreen && (\n        <StyledButtonsWrapper>\n          {activeItems.map((item: ItemProps) => (\n            <StyledButtonElementWrapper key={item.value}>\n              <Button\n                type=\"button\"\n                size=\"normal\"\n                borderShape=\"rounded\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}>\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </Button>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal\n            size=\"fullscreen\"\n            animation=\"subtle\"\n            backgroundColor=\"white\"\n            activateButton={\n              <StyledButtonElementWrapper>\n                <Button type=\"button\" size=\"normal\" light borderShape=\"rounded\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </Button>\n              </StyledButtonElementWrapper>\n            }>\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier={['left-align']}>\n                  <h1>{heading}</h1>\n                  <ModalCloseButton title={t('modal.closeModal')} onClick={onClose} />\n                </ModalHeader>\n                <ModalBody modifier=\"slide-in-left\">\n                  <StyledList>\n                    {items.map((item: ItemProps) => (\n                      <StyledListItem key={item.value}>\n                        <ToggleItem\n                          id={item.value}\n                          value={item.value}\n                          checked={item.selected}\n                          label={item.label}\n                          component=\"div\"\n                          onChange={() => onFilterToggle(item.value)}\n                        />\n                      </StyledListItem>\n                    ))}\n                  </StyledList>\n                </ModalBody>\n              </>\n            )}\n          </Modal>\n        </StyledButtonsWrapper>\n      )}\n      {!isNarrowScreen && (\n        <>\n          {heading && <StyledHeading>{heading}</StyledHeading>}\n          <FilterCarousel>\n            {items.map((item: ItemProps) => (\n              <StyledButtonElementWrapper key={item.value}>\n                <Button\n                  type=\"button\"\n                  size=\"normal\"\n                  greyLighter={!item.selected}\n                  borderShape=\"rounded\"\n                  onClick={() => onFilterToggle(item.value)}>\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </Button>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <Button onClick={onRemoveAllFilters} link>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </Button>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */");
93
+ })(process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilterButtons.tsx"],"names":[],"mappings":"AAsDuC","file":"FilterButtons.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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 */\nimport React, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\n// @ts-ignore\nimport ToggleItem from './ToggleItem';\nimport FilterCarousel from './FilterCarousel';\n\nconst StyledHeading = styled.h3`\n  ${fonts.sizes('16px', '32px')};\n  margin: 0 0 ${spacing.small};\n  color: ${colors.text.light};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledButtonsWrapper = styled.div`\n  display: inline-flex;\n  flex-wrap: wrap;\n`;\n\nconst StyledButtonElementWrapper = styled.div`\n  margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n  break-inside: avoid;\n  flex-shrink: 0;\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    column-count: 2;\n    column-gap: 20px;\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    column-count: 3;\n    column-gap: 20px;\n  }\n`;\nconst StyledListItem = styled.li`\n  margin-bottom: 0;\n  break-inside: avoid;\n`;\n\nconst StyledButtonContent = styled.span``;\n\nconst StyledButtonContentSelected = styled.span`\n  margin-left: ${spacing.small};\n  display: inline-flex;\n  align-items: center;\n`;\n\nconst StyledRemoveWrapper = styled.div`\n  margin-top: ${spacing.xsmall};\n  margin-left: 10px;\n`;\n\nconst ButtonRemoveText = styled.span`\n  ${fonts.sizes('16px', '32px')};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nexport type ItemProps = {\n  label: string;\n  value: string;\n  selected?: boolean;\n};\nexport type FilterButtonsProps = {\n  heading?: string;\n  items: ItemProps[];\n  onFilterToggle: (value: string) => void;\n  onRemoveAllFilters: () => void;\n  labels: {\n    openFilter: string;\n  };\n};\n\nexport const FilterButtons = ({ heading, items, onFilterToggle, onRemoveAllFilters, labels }: FilterButtonsProps) => {\n  const { t } = useTranslation();\n  const [isNarrowScreen, setIsNarrowScreen] = useState(false);\n\n  useEffect(() => {\n    const isNarrowScreenMatch = window.matchMedia('(max-width: 767px)');\n    const handleChange = (e: MediaQueryListEvent | MediaQueryList) => {\n      setIsNarrowScreen(e.matches);\n    };\n    isNarrowScreenMatch.addEventListener('change', handleChange);\n    handleChange(isNarrowScreenMatch);\n    return () => {\n      isNarrowScreenMatch.removeEventListener('change', handleChange);\n    };\n  }, []);\n\n  const hasSelectedFilters = items.some((item) => {\n    return item.selected;\n  });\n\n  const activeItems = items.filter((item) => item.selected);\n\n  return (\n    <>\n      {isNarrowScreen && (\n        <StyledButtonsWrapper>\n          {activeItems.map((item: ItemProps) => (\n            <StyledButtonElementWrapper key={item.value}>\n              <Button\n                type=\"button\"\n                size=\"normal\"\n                borderShape=\"rounded\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}>\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </Button>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal\n            label={t('searchPage.searchFilterMessages.resourceTypeFilter.button')}\n            size=\"fullscreen\"\n            animation=\"subtle\"\n            backgroundColor=\"white\"\n            activateButton={\n              <StyledButtonElementWrapper>\n                <Button type=\"button\" size=\"normal\" light borderShape=\"rounded\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </Button>\n              </StyledButtonElementWrapper>\n            }>\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier={['left-align']}>\n                  <h1>{heading}</h1>\n                  <ModalCloseButton title={t('modal.closeModal')} onClick={onClose} />\n                </ModalHeader>\n                <ModalBody modifier=\"slide-in-left\">\n                  <StyledList>\n                    {items.map((item: ItemProps) => (\n                      <StyledListItem key={item.value}>\n                        <ToggleItem\n                          id={item.value}\n                          value={item.value}\n                          checked={item.selected}\n                          label={item.label}\n                          component=\"div\"\n                          onChange={() => onFilterToggle(item.value)}\n                        />\n                      </StyledListItem>\n                    ))}\n                  </StyledList>\n                </ModalBody>\n              </>\n            )}\n          </Modal>\n        </StyledButtonsWrapper>\n      )}\n      {!isNarrowScreen && (\n        <>\n          {heading && <StyledHeading>{heading}</StyledHeading>}\n          <FilterCarousel>\n            {items.map((item: ItemProps) => (\n              <StyledButtonElementWrapper key={item.value}>\n                <Button\n                  type=\"button\"\n                  size=\"normal\"\n                  greyLighter={!item.selected}\n                  borderShape=\"rounded\"\n                  onClick={() => onFilterToggle(item.value)}>\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </Button>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <Button onClick={onRemoveAllFilters} link>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </Button>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */");
94
94
  var StyledButtonContentSelected = (0, _styledBase["default"])("span", {
95
95
  target: "e1yaxziw6",
96
96
  label: "StyledButtonContentSelected"
97
- })("margin-left:", _core.spacing.small, ";display:inline-flex;align-items:center;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilterButtons.tsx"],"names":[],"mappings":"AAwD+C","file":"FilterButtons.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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 */\nimport React, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\n// @ts-ignore\nimport ToggleItem from './ToggleItem';\nimport FilterCarousel from './FilterCarousel';\n\nconst StyledHeading = styled.h3`\n  ${fonts.sizes('16px', '32px')};\n  margin: 0 0 ${spacing.small};\n  color: ${colors.text.light};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledButtonsWrapper = styled.div`\n  display: inline-flex;\n  flex-wrap: wrap;\n`;\n\nconst StyledButtonElementWrapper = styled.div`\n  margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n  break-inside: avoid;\n  flex-shrink: 0;\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    column-count: 2;\n    column-gap: 20px;\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    column-count: 3;\n    column-gap: 20px;\n  }\n`;\nconst StyledListItem = styled.li`\n  margin-bottom: 0;\n  break-inside: avoid;\n`;\n\nconst StyledButtonContent = styled.span``;\n\nconst StyledButtonContentSelected = styled.span`\n  margin-left: ${spacing.small};\n  display: inline-flex;\n  align-items: center;\n`;\n\nconst StyledRemoveWrapper = styled.div`\n  margin-top: ${spacing.xsmall};\n  margin-left: 10px;\n`;\n\nconst ButtonRemoveText = styled.span`\n  ${fonts.sizes('16px', '32px')};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nexport type ItemProps = {\n  label: string;\n  value: string;\n  selected?: boolean;\n};\nexport type FilterButtonsProps = {\n  heading?: string;\n  items: ItemProps[];\n  onFilterToggle: (value: string) => void;\n  onRemoveAllFilters: () => void;\n  labels: {\n    openFilter: string;\n  };\n};\n\nexport const FilterButtons = ({ heading, items, onFilterToggle, onRemoveAllFilters, labels }: FilterButtonsProps) => {\n  const { t } = useTranslation();\n  const [isNarrowScreen, setIsNarrowScreen] = useState(false);\n\n  useEffect(() => {\n    const isNarrowScreenMatch = window.matchMedia('(max-width: 767px)');\n    const handleChange = (e: MediaQueryListEvent | MediaQueryList) => {\n      setIsNarrowScreen(e.matches);\n    };\n    isNarrowScreenMatch.addEventListener('change', handleChange);\n    handleChange(isNarrowScreenMatch);\n    return () => {\n      isNarrowScreenMatch.removeEventListener('change', handleChange);\n    };\n  }, []);\n\n  const hasSelectedFilters = items.some((item) => {\n    return item.selected;\n  });\n\n  const activeItems = items.filter((item) => item.selected);\n\n  return (\n    <>\n      {isNarrowScreen && (\n        <StyledButtonsWrapper>\n          {activeItems.map((item: ItemProps) => (\n            <StyledButtonElementWrapper key={item.value}>\n              <Button\n                type=\"button\"\n                size=\"normal\"\n                borderShape=\"rounded\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}>\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </Button>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal\n            size=\"fullscreen\"\n            animation=\"subtle\"\n            backgroundColor=\"white\"\n            activateButton={\n              <StyledButtonElementWrapper>\n                <Button type=\"button\" size=\"normal\" light borderShape=\"rounded\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </Button>\n              </StyledButtonElementWrapper>\n            }>\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier={['left-align']}>\n                  <h1>{heading}</h1>\n                  <ModalCloseButton title={t('modal.closeModal')} onClick={onClose} />\n                </ModalHeader>\n                <ModalBody modifier=\"slide-in-left\">\n                  <StyledList>\n                    {items.map((item: ItemProps) => (\n                      <StyledListItem key={item.value}>\n                        <ToggleItem\n                          id={item.value}\n                          value={item.value}\n                          checked={item.selected}\n                          label={item.label}\n                          component=\"div\"\n                          onChange={() => onFilterToggle(item.value)}\n                        />\n                      </StyledListItem>\n                    ))}\n                  </StyledList>\n                </ModalBody>\n              </>\n            )}\n          </Modal>\n        </StyledButtonsWrapper>\n      )}\n      {!isNarrowScreen && (\n        <>\n          {heading && <StyledHeading>{heading}</StyledHeading>}\n          <FilterCarousel>\n            {items.map((item: ItemProps) => (\n              <StyledButtonElementWrapper key={item.value}>\n                <Button\n                  type=\"button\"\n                  size=\"normal\"\n                  greyLighter={!item.selected}\n                  borderShape=\"rounded\"\n                  onClick={() => onFilterToggle(item.value)}>\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </Button>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <Button onClick={onRemoveAllFilters} link>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </Button>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */"));
97
+ })("margin-left:", _core.spacing.small, ";display:inline-flex;align-items:center;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilterButtons.tsx"],"names":[],"mappings":"AAwD+C","file":"FilterButtons.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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 */\nimport React, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\n// @ts-ignore\nimport ToggleItem from './ToggleItem';\nimport FilterCarousel from './FilterCarousel';\n\nconst StyledHeading = styled.h3`\n  ${fonts.sizes('16px', '32px')};\n  margin: 0 0 ${spacing.small};\n  color: ${colors.text.light};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledButtonsWrapper = styled.div`\n  display: inline-flex;\n  flex-wrap: wrap;\n`;\n\nconst StyledButtonElementWrapper = styled.div`\n  margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n  break-inside: avoid;\n  flex-shrink: 0;\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    column-count: 2;\n    column-gap: 20px;\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    column-count: 3;\n    column-gap: 20px;\n  }\n`;\nconst StyledListItem = styled.li`\n  margin-bottom: 0;\n  break-inside: avoid;\n`;\n\nconst StyledButtonContent = styled.span``;\n\nconst StyledButtonContentSelected = styled.span`\n  margin-left: ${spacing.small};\n  display: inline-flex;\n  align-items: center;\n`;\n\nconst StyledRemoveWrapper = styled.div`\n  margin-top: ${spacing.xsmall};\n  margin-left: 10px;\n`;\n\nconst ButtonRemoveText = styled.span`\n  ${fonts.sizes('16px', '32px')};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nexport type ItemProps = {\n  label: string;\n  value: string;\n  selected?: boolean;\n};\nexport type FilterButtonsProps = {\n  heading?: string;\n  items: ItemProps[];\n  onFilterToggle: (value: string) => void;\n  onRemoveAllFilters: () => void;\n  labels: {\n    openFilter: string;\n  };\n};\n\nexport const FilterButtons = ({ heading, items, onFilterToggle, onRemoveAllFilters, labels }: FilterButtonsProps) => {\n  const { t } = useTranslation();\n  const [isNarrowScreen, setIsNarrowScreen] = useState(false);\n\n  useEffect(() => {\n    const isNarrowScreenMatch = window.matchMedia('(max-width: 767px)');\n    const handleChange = (e: MediaQueryListEvent | MediaQueryList) => {\n      setIsNarrowScreen(e.matches);\n    };\n    isNarrowScreenMatch.addEventListener('change', handleChange);\n    handleChange(isNarrowScreenMatch);\n    return () => {\n      isNarrowScreenMatch.removeEventListener('change', handleChange);\n    };\n  }, []);\n\n  const hasSelectedFilters = items.some((item) => {\n    return item.selected;\n  });\n\n  const activeItems = items.filter((item) => item.selected);\n\n  return (\n    <>\n      {isNarrowScreen && (\n        <StyledButtonsWrapper>\n          {activeItems.map((item: ItemProps) => (\n            <StyledButtonElementWrapper key={item.value}>\n              <Button\n                type=\"button\"\n                size=\"normal\"\n                borderShape=\"rounded\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}>\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </Button>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal\n            label={t('searchPage.searchFilterMessages.resourceTypeFilter.button')}\n            size=\"fullscreen\"\n            animation=\"subtle\"\n            backgroundColor=\"white\"\n            activateButton={\n              <StyledButtonElementWrapper>\n                <Button type=\"button\" size=\"normal\" light borderShape=\"rounded\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </Button>\n              </StyledButtonElementWrapper>\n            }>\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier={['left-align']}>\n                  <h1>{heading}</h1>\n                  <ModalCloseButton title={t('modal.closeModal')} onClick={onClose} />\n                </ModalHeader>\n                <ModalBody modifier=\"slide-in-left\">\n                  <StyledList>\n                    {items.map((item: ItemProps) => (\n                      <StyledListItem key={item.value}>\n                        <ToggleItem\n                          id={item.value}\n                          value={item.value}\n                          checked={item.selected}\n                          label={item.label}\n                          component=\"div\"\n                          onChange={() => onFilterToggle(item.value)}\n                        />\n                      </StyledListItem>\n                    ))}\n                  </StyledList>\n                </ModalBody>\n              </>\n            )}\n          </Modal>\n        </StyledButtonsWrapper>\n      )}\n      {!isNarrowScreen && (\n        <>\n          {heading && <StyledHeading>{heading}</StyledHeading>}\n          <FilterCarousel>\n            {items.map((item: ItemProps) => (\n              <StyledButtonElementWrapper key={item.value}>\n                <Button\n                  type=\"button\"\n                  size=\"normal\"\n                  greyLighter={!item.selected}\n                  borderShape=\"rounded\"\n                  onClick={() => onFilterToggle(item.value)}>\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </Button>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <Button onClick={onRemoveAllFilters} link>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </Button>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */"));
98
98
  var StyledRemoveWrapper = (0, _styledBase["default"])("div", {
99
99
  target: "e1yaxziw7",
100
100
  label: "StyledRemoveWrapper"
101
- })("margin-top:", _core.spacing.xsmall, ";margin-left:10px;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilterButtons.tsx"],"names":[],"mappings":"AA8DsC","file":"FilterButtons.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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 */\nimport React, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\n// @ts-ignore\nimport ToggleItem from './ToggleItem';\nimport FilterCarousel from './FilterCarousel';\n\nconst StyledHeading = styled.h3`\n  ${fonts.sizes('16px', '32px')};\n  margin: 0 0 ${spacing.small};\n  color: ${colors.text.light};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledButtonsWrapper = styled.div`\n  display: inline-flex;\n  flex-wrap: wrap;\n`;\n\nconst StyledButtonElementWrapper = styled.div`\n  margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n  break-inside: avoid;\n  flex-shrink: 0;\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    column-count: 2;\n    column-gap: 20px;\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    column-count: 3;\n    column-gap: 20px;\n  }\n`;\nconst StyledListItem = styled.li`\n  margin-bottom: 0;\n  break-inside: avoid;\n`;\n\nconst StyledButtonContent = styled.span``;\n\nconst StyledButtonContentSelected = styled.span`\n  margin-left: ${spacing.small};\n  display: inline-flex;\n  align-items: center;\n`;\n\nconst StyledRemoveWrapper = styled.div`\n  margin-top: ${spacing.xsmall};\n  margin-left: 10px;\n`;\n\nconst ButtonRemoveText = styled.span`\n  ${fonts.sizes('16px', '32px')};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nexport type ItemProps = {\n  label: string;\n  value: string;\n  selected?: boolean;\n};\nexport type FilterButtonsProps = {\n  heading?: string;\n  items: ItemProps[];\n  onFilterToggle: (value: string) => void;\n  onRemoveAllFilters: () => void;\n  labels: {\n    openFilter: string;\n  };\n};\n\nexport const FilterButtons = ({ heading, items, onFilterToggle, onRemoveAllFilters, labels }: FilterButtonsProps) => {\n  const { t } = useTranslation();\n  const [isNarrowScreen, setIsNarrowScreen] = useState(false);\n\n  useEffect(() => {\n    const isNarrowScreenMatch = window.matchMedia('(max-width: 767px)');\n    const handleChange = (e: MediaQueryListEvent | MediaQueryList) => {\n      setIsNarrowScreen(e.matches);\n    };\n    isNarrowScreenMatch.addEventListener('change', handleChange);\n    handleChange(isNarrowScreenMatch);\n    return () => {\n      isNarrowScreenMatch.removeEventListener('change', handleChange);\n    };\n  }, []);\n\n  const hasSelectedFilters = items.some((item) => {\n    return item.selected;\n  });\n\n  const activeItems = items.filter((item) => item.selected);\n\n  return (\n    <>\n      {isNarrowScreen && (\n        <StyledButtonsWrapper>\n          {activeItems.map((item: ItemProps) => (\n            <StyledButtonElementWrapper key={item.value}>\n              <Button\n                type=\"button\"\n                size=\"normal\"\n                borderShape=\"rounded\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}>\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </Button>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal\n            size=\"fullscreen\"\n            animation=\"subtle\"\n            backgroundColor=\"white\"\n            activateButton={\n              <StyledButtonElementWrapper>\n                <Button type=\"button\" size=\"normal\" light borderShape=\"rounded\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </Button>\n              </StyledButtonElementWrapper>\n            }>\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier={['left-align']}>\n                  <h1>{heading}</h1>\n                  <ModalCloseButton title={t('modal.closeModal')} onClick={onClose} />\n                </ModalHeader>\n                <ModalBody modifier=\"slide-in-left\">\n                  <StyledList>\n                    {items.map((item: ItemProps) => (\n                      <StyledListItem key={item.value}>\n                        <ToggleItem\n                          id={item.value}\n                          value={item.value}\n                          checked={item.selected}\n                          label={item.label}\n                          component=\"div\"\n                          onChange={() => onFilterToggle(item.value)}\n                        />\n                      </StyledListItem>\n                    ))}\n                  </StyledList>\n                </ModalBody>\n              </>\n            )}\n          </Modal>\n        </StyledButtonsWrapper>\n      )}\n      {!isNarrowScreen && (\n        <>\n          {heading && <StyledHeading>{heading}</StyledHeading>}\n          <FilterCarousel>\n            {items.map((item: ItemProps) => (\n              <StyledButtonElementWrapper key={item.value}>\n                <Button\n                  type=\"button\"\n                  size=\"normal\"\n                  greyLighter={!item.selected}\n                  borderShape=\"rounded\"\n                  onClick={() => onFilterToggle(item.value)}>\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </Button>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <Button onClick={onRemoveAllFilters} link>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </Button>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */"));
101
+ })("margin-top:", _core.spacing.xsmall, ";margin-left:10px;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilterButtons.tsx"],"names":[],"mappings":"AA8DsC","file":"FilterButtons.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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 */\nimport React, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\n// @ts-ignore\nimport ToggleItem from './ToggleItem';\nimport FilterCarousel from './FilterCarousel';\n\nconst StyledHeading = styled.h3`\n  ${fonts.sizes('16px', '32px')};\n  margin: 0 0 ${spacing.small};\n  color: ${colors.text.light};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledButtonsWrapper = styled.div`\n  display: inline-flex;\n  flex-wrap: wrap;\n`;\n\nconst StyledButtonElementWrapper = styled.div`\n  margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n  break-inside: avoid;\n  flex-shrink: 0;\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    column-count: 2;\n    column-gap: 20px;\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    column-count: 3;\n    column-gap: 20px;\n  }\n`;\nconst StyledListItem = styled.li`\n  margin-bottom: 0;\n  break-inside: avoid;\n`;\n\nconst StyledButtonContent = styled.span``;\n\nconst StyledButtonContentSelected = styled.span`\n  margin-left: ${spacing.small};\n  display: inline-flex;\n  align-items: center;\n`;\n\nconst StyledRemoveWrapper = styled.div`\n  margin-top: ${spacing.xsmall};\n  margin-left: 10px;\n`;\n\nconst ButtonRemoveText = styled.span`\n  ${fonts.sizes('16px', '32px')};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nexport type ItemProps = {\n  label: string;\n  value: string;\n  selected?: boolean;\n};\nexport type FilterButtonsProps = {\n  heading?: string;\n  items: ItemProps[];\n  onFilterToggle: (value: string) => void;\n  onRemoveAllFilters: () => void;\n  labels: {\n    openFilter: string;\n  };\n};\n\nexport const FilterButtons = ({ heading, items, onFilterToggle, onRemoveAllFilters, labels }: FilterButtonsProps) => {\n  const { t } = useTranslation();\n  const [isNarrowScreen, setIsNarrowScreen] = useState(false);\n\n  useEffect(() => {\n    const isNarrowScreenMatch = window.matchMedia('(max-width: 767px)');\n    const handleChange = (e: MediaQueryListEvent | MediaQueryList) => {\n      setIsNarrowScreen(e.matches);\n    };\n    isNarrowScreenMatch.addEventListener('change', handleChange);\n    handleChange(isNarrowScreenMatch);\n    return () => {\n      isNarrowScreenMatch.removeEventListener('change', handleChange);\n    };\n  }, []);\n\n  const hasSelectedFilters = items.some((item) => {\n    return item.selected;\n  });\n\n  const activeItems = items.filter((item) => item.selected);\n\n  return (\n    <>\n      {isNarrowScreen && (\n        <StyledButtonsWrapper>\n          {activeItems.map((item: ItemProps) => (\n            <StyledButtonElementWrapper key={item.value}>\n              <Button\n                type=\"button\"\n                size=\"normal\"\n                borderShape=\"rounded\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}>\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </Button>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal\n            label={t('searchPage.searchFilterMessages.resourceTypeFilter.button')}\n            size=\"fullscreen\"\n            animation=\"subtle\"\n            backgroundColor=\"white\"\n            activateButton={\n              <StyledButtonElementWrapper>\n                <Button type=\"button\" size=\"normal\" light borderShape=\"rounded\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </Button>\n              </StyledButtonElementWrapper>\n            }>\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier={['left-align']}>\n                  <h1>{heading}</h1>\n                  <ModalCloseButton title={t('modal.closeModal')} onClick={onClose} />\n                </ModalHeader>\n                <ModalBody modifier=\"slide-in-left\">\n                  <StyledList>\n                    {items.map((item: ItemProps) => (\n                      <StyledListItem key={item.value}>\n                        <ToggleItem\n                          id={item.value}\n                          value={item.value}\n                          checked={item.selected}\n                          label={item.label}\n                          component=\"div\"\n                          onChange={() => onFilterToggle(item.value)}\n                        />\n                      </StyledListItem>\n                    ))}\n                  </StyledList>\n                </ModalBody>\n              </>\n            )}\n          </Modal>\n        </StyledButtonsWrapper>\n      )}\n      {!isNarrowScreen && (\n        <>\n          {heading && <StyledHeading>{heading}</StyledHeading>}\n          <FilterCarousel>\n            {items.map((item: ItemProps) => (\n              <StyledButtonElementWrapper key={item.value}>\n                <Button\n                  type=\"button\"\n                  size=\"normal\"\n                  greyLighter={!item.selected}\n                  borderShape=\"rounded\"\n                  onClick={() => onFilterToggle(item.value)}>\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </Button>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <Button onClick={onRemoveAllFilters} link>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </Button>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */"));
102
102
  var ButtonRemoveText = (0, _styledBase["default"])("span", {
103
103
  target: "e1yaxziw8",
104
104
  label: "ButtonRemoveText"
105
- })(_core.fonts.sizes('16px', '32px'), ";font-weight:", _core.fonts.weight.semibold, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilterButtons.tsx"],"names":[],"mappings":"AAmEoC","file":"FilterButtons.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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 */\nimport React, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\n// @ts-ignore\nimport ToggleItem from './ToggleItem';\nimport FilterCarousel from './FilterCarousel';\n\nconst StyledHeading = styled.h3`\n  ${fonts.sizes('16px', '32px')};\n  margin: 0 0 ${spacing.small};\n  color: ${colors.text.light};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledButtonsWrapper = styled.div`\n  display: inline-flex;\n  flex-wrap: wrap;\n`;\n\nconst StyledButtonElementWrapper = styled.div`\n  margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n  break-inside: avoid;\n  flex-shrink: 0;\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    column-count: 2;\n    column-gap: 20px;\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    column-count: 3;\n    column-gap: 20px;\n  }\n`;\nconst StyledListItem = styled.li`\n  margin-bottom: 0;\n  break-inside: avoid;\n`;\n\nconst StyledButtonContent = styled.span``;\n\nconst StyledButtonContentSelected = styled.span`\n  margin-left: ${spacing.small};\n  display: inline-flex;\n  align-items: center;\n`;\n\nconst StyledRemoveWrapper = styled.div`\n  margin-top: ${spacing.xsmall};\n  margin-left: 10px;\n`;\n\nconst ButtonRemoveText = styled.span`\n  ${fonts.sizes('16px', '32px')};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nexport type ItemProps = {\n  label: string;\n  value: string;\n  selected?: boolean;\n};\nexport type FilterButtonsProps = {\n  heading?: string;\n  items: ItemProps[];\n  onFilterToggle: (value: string) => void;\n  onRemoveAllFilters: () => void;\n  labels: {\n    openFilter: string;\n  };\n};\n\nexport const FilterButtons = ({ heading, items, onFilterToggle, onRemoveAllFilters, labels }: FilterButtonsProps) => {\n  const { t } = useTranslation();\n  const [isNarrowScreen, setIsNarrowScreen] = useState(false);\n\n  useEffect(() => {\n    const isNarrowScreenMatch = window.matchMedia('(max-width: 767px)');\n    const handleChange = (e: MediaQueryListEvent | MediaQueryList) => {\n      setIsNarrowScreen(e.matches);\n    };\n    isNarrowScreenMatch.addEventListener('change', handleChange);\n    handleChange(isNarrowScreenMatch);\n    return () => {\n      isNarrowScreenMatch.removeEventListener('change', handleChange);\n    };\n  }, []);\n\n  const hasSelectedFilters = items.some((item) => {\n    return item.selected;\n  });\n\n  const activeItems = items.filter((item) => item.selected);\n\n  return (\n    <>\n      {isNarrowScreen && (\n        <StyledButtonsWrapper>\n          {activeItems.map((item: ItemProps) => (\n            <StyledButtonElementWrapper key={item.value}>\n              <Button\n                type=\"button\"\n                size=\"normal\"\n                borderShape=\"rounded\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}>\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </Button>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal\n            size=\"fullscreen\"\n            animation=\"subtle\"\n            backgroundColor=\"white\"\n            activateButton={\n              <StyledButtonElementWrapper>\n                <Button type=\"button\" size=\"normal\" light borderShape=\"rounded\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </Button>\n              </StyledButtonElementWrapper>\n            }>\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier={['left-align']}>\n                  <h1>{heading}</h1>\n                  <ModalCloseButton title={t('modal.closeModal')} onClick={onClose} />\n                </ModalHeader>\n                <ModalBody modifier=\"slide-in-left\">\n                  <StyledList>\n                    {items.map((item: ItemProps) => (\n                      <StyledListItem key={item.value}>\n                        <ToggleItem\n                          id={item.value}\n                          value={item.value}\n                          checked={item.selected}\n                          label={item.label}\n                          component=\"div\"\n                          onChange={() => onFilterToggle(item.value)}\n                        />\n                      </StyledListItem>\n                    ))}\n                  </StyledList>\n                </ModalBody>\n              </>\n            )}\n          </Modal>\n        </StyledButtonsWrapper>\n      )}\n      {!isNarrowScreen && (\n        <>\n          {heading && <StyledHeading>{heading}</StyledHeading>}\n          <FilterCarousel>\n            {items.map((item: ItemProps) => (\n              <StyledButtonElementWrapper key={item.value}>\n                <Button\n                  type=\"button\"\n                  size=\"normal\"\n                  greyLighter={!item.selected}\n                  borderShape=\"rounded\"\n                  onClick={() => onFilterToggle(item.value)}>\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </Button>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <Button onClick={onRemoveAllFilters} link>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </Button>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */"));
105
+ })(_core.fonts.sizes('16px', '32px'), ";font-weight:", _core.fonts.weight.semibold, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilterButtons.tsx"],"names":[],"mappings":"AAmEoC","file":"FilterButtons.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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 */\nimport React, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\n// @ts-ignore\nimport ToggleItem from './ToggleItem';\nimport FilterCarousel from './FilterCarousel';\n\nconst StyledHeading = styled.h3`\n  ${fonts.sizes('16px', '32px')};\n  margin: 0 0 ${spacing.small};\n  color: ${colors.text.light};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledButtonsWrapper = styled.div`\n  display: inline-flex;\n  flex-wrap: wrap;\n`;\n\nconst StyledButtonElementWrapper = styled.div`\n  margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n  break-inside: avoid;\n  flex-shrink: 0;\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    column-count: 2;\n    column-gap: 20px;\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    column-count: 3;\n    column-gap: 20px;\n  }\n`;\nconst StyledListItem = styled.li`\n  margin-bottom: 0;\n  break-inside: avoid;\n`;\n\nconst StyledButtonContent = styled.span``;\n\nconst StyledButtonContentSelected = styled.span`\n  margin-left: ${spacing.small};\n  display: inline-flex;\n  align-items: center;\n`;\n\nconst StyledRemoveWrapper = styled.div`\n  margin-top: ${spacing.xsmall};\n  margin-left: 10px;\n`;\n\nconst ButtonRemoveText = styled.span`\n  ${fonts.sizes('16px', '32px')};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nexport type ItemProps = {\n  label: string;\n  value: string;\n  selected?: boolean;\n};\nexport type FilterButtonsProps = {\n  heading?: string;\n  items: ItemProps[];\n  onFilterToggle: (value: string) => void;\n  onRemoveAllFilters: () => void;\n  labels: {\n    openFilter: string;\n  };\n};\n\nexport const FilterButtons = ({ heading, items, onFilterToggle, onRemoveAllFilters, labels }: FilterButtonsProps) => {\n  const { t } = useTranslation();\n  const [isNarrowScreen, setIsNarrowScreen] = useState(false);\n\n  useEffect(() => {\n    const isNarrowScreenMatch = window.matchMedia('(max-width: 767px)');\n    const handleChange = (e: MediaQueryListEvent | MediaQueryList) => {\n      setIsNarrowScreen(e.matches);\n    };\n    isNarrowScreenMatch.addEventListener('change', handleChange);\n    handleChange(isNarrowScreenMatch);\n    return () => {\n      isNarrowScreenMatch.removeEventListener('change', handleChange);\n    };\n  }, []);\n\n  const hasSelectedFilters = items.some((item) => {\n    return item.selected;\n  });\n\n  const activeItems = items.filter((item) => item.selected);\n\n  return (\n    <>\n      {isNarrowScreen && (\n        <StyledButtonsWrapper>\n          {activeItems.map((item: ItemProps) => (\n            <StyledButtonElementWrapper key={item.value}>\n              <Button\n                type=\"button\"\n                size=\"normal\"\n                borderShape=\"rounded\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}>\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </Button>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal\n            label={t('searchPage.searchFilterMessages.resourceTypeFilter.button')}\n            size=\"fullscreen\"\n            animation=\"subtle\"\n            backgroundColor=\"white\"\n            activateButton={\n              <StyledButtonElementWrapper>\n                <Button type=\"button\" size=\"normal\" light borderShape=\"rounded\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </Button>\n              </StyledButtonElementWrapper>\n            }>\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier={['left-align']}>\n                  <h1>{heading}</h1>\n                  <ModalCloseButton title={t('modal.closeModal')} onClick={onClose} />\n                </ModalHeader>\n                <ModalBody modifier=\"slide-in-left\">\n                  <StyledList>\n                    {items.map((item: ItemProps) => (\n                      <StyledListItem key={item.value}>\n                        <ToggleItem\n                          id={item.value}\n                          value={item.value}\n                          checked={item.selected}\n                          label={item.label}\n                          component=\"div\"\n                          onChange={() => onFilterToggle(item.value)}\n                        />\n                      </StyledListItem>\n                    ))}\n                  </StyledList>\n                </ModalBody>\n              </>\n            )}\n          </Modal>\n        </StyledButtonsWrapper>\n      )}\n      {!isNarrowScreen && (\n        <>\n          {heading && <StyledHeading>{heading}</StyledHeading>}\n          <FilterCarousel>\n            {items.map((item: ItemProps) => (\n              <StyledButtonElementWrapper key={item.value}>\n                <Button\n                  type=\"button\"\n                  size=\"normal\"\n                  greyLighter={!item.selected}\n                  borderShape=\"rounded\"\n                  onClick={() => onFilterToggle(item.value)}>\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </Button>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <Button onClick={onRemoveAllFilters} link>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </Button>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */"));
106
106
 
107
107
  var FilterButtons = function FilterButtons(_ref) {
108
108
  var heading = _ref.heading,
@@ -150,6 +150,7 @@ var FilterButtons = function FilterButtons(_ref) {
150
150
  }
151
151
  }, (0, _core2.jsx)(StyledButtonContent, null, item.label), (0, _core2.jsx)(StyledButtonContentSelected, null, (0, _core2.jsx)(_action.Cross, null))));
152
152
  }), (0, _core2.jsx)(_modal["default"], {
153
+ label: t('searchPage.searchFilterMessages.resourceTypeFilter.button'),
153
154
  size: "fullscreen",
154
155
  animation: "subtle",
155
156
  backgroundColor: "white",