@ndla/ui 13.1.1 → 13.2.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (42) hide show
  1. package/es/Article/Article.js +1 -1
  2. package/es/Article/ArticleHeaderWrapper.js +4 -4
  3. package/es/Frontpage/FrontpageAllSubjects.js +8 -8
  4. package/es/Notion/ConceptNotion.js +26 -1
  5. package/es/Notion/FigureNotion.js +28 -20
  6. package/es/Notion/NotionVisualElement.js +3 -2
  7. package/es/SearchTypeResult/SearchViewType.js +5 -5
  8. package/es/locale/messages-en.js +4 -4
  9. package/es/locale/messages-nb.js +4 -4
  10. package/es/locale/messages-nn.js +4 -4
  11. package/es/locale/messages-se.js +4 -4
  12. package/es/locale/messages-sma.js +4 -4
  13. package/lib/Article/Article.d.ts +2 -2
  14. package/lib/Article/Article.js +1 -1
  15. package/lib/Article/ArticleHeaderWrapper.d.ts +1 -1
  16. package/lib/Article/ArticleHeaderWrapper.js +4 -4
  17. package/lib/Frontpage/FrontpageAllSubjects.js +8 -8
  18. package/lib/Notion/ConceptNotion.js +26 -2
  19. package/lib/Notion/FigureNotion.d.ts +1 -1
  20. package/lib/Notion/FigureNotion.js +26 -19
  21. package/lib/Notion/NotionVisualElement.js +3 -2
  22. package/lib/SearchTypeResult/SearchViewType.js +5 -5
  23. package/lib/locale/messages-en.js +4 -4
  24. package/lib/locale/messages-nb.js +4 -4
  25. package/lib/locale/messages-nn.js +4 -4
  26. package/lib/locale/messages-se.js +4 -4
  27. package/lib/locale/messages-sma.js +4 -4
  28. package/lib/types.d.ts +1 -1
  29. package/package.json +3 -3
  30. package/src/Article/Article.tsx +2 -1
  31. package/src/Article/ArticleHeaderWrapper.tsx +1 -0
  32. package/src/Frontpage/FrontpageAllSubjects.tsx +1 -1
  33. package/src/Notion/ConceptNotion.tsx +18 -2
  34. package/src/Notion/FigureNotion.tsx +16 -15
  35. package/src/Notion/NotionVisualElement.tsx +1 -1
  36. package/src/SearchTypeResult/SearchViewType.tsx +1 -1
  37. package/src/locale/messages-en.ts +4 -4
  38. package/src/locale/messages-nb.ts +4 -4
  39. package/src/locale/messages-nn.ts +4 -4
  40. package/src/locale/messages-se.ts +4 -4
  41. package/src/locale/messages-sma.ts +4 -4
  42. package/src/types.ts +1 -1
@@ -81,13 +81,13 @@ var CompetenceWrapper = (0, _styledBase["default"])("div", {
81
81
  } : {
82
82
  name: "70qvj9",
83
83
  styles: "display:flex;align-items:center;",
84
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkFydGljbGVIZWFkZXJXcmFwcGVyLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFvQ29DIiwiZmlsZSI6IkFydGljbGVIZWFkZXJXcmFwcGVyLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE2LXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IFJlYWN0LCB7IENvbXBvbmVudCwgQ29tcG9uZW50VHlwZSwgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IEJFTUhlbHBlciBmcm9tICdyZWFjdC1iZW0taGVscGVyJztcbmltcG9ydCB7IHdpdGhUcmFuc2xhdGlvbiwgV2l0aFRyYW5zbGF0aW9uIH0gZnJvbSAncmVhY3QtaTE4bmV4dCc7XG5pbXBvcnQgQnV0dG9uIGZyb20gJ0BuZGxhL2J1dHRvbic7XG5pbXBvcnQgeyBpc01vYmlsZSB9IGZyb20gJ3JlYWN0LWRldmljZS1kZXRlY3QnO1xuaW1wb3J0IHsgZm9udHMsIGNvbG9ycyB9IGZyb20gJ0BuZGxhL2NvcmUnO1xuXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBGb290ZXJIZWFkZXJJY29uIH0gZnJvbSAnQG5kbGEvaWNvbnMvY29tbW9uJztcbi8vIEB0cy1pZ25vcmVcbmltcG9ydCBDb21wZXRlbmNlR29hbHNEaWFsb2cgZnJvbSAnLi4vQ29tcGV0ZW5jZUdvYWxzL0NvbXBldGVuY2VHb2Fsc0RpYWxvZyc7XG5cbmNvbnN0IGNsYXNzZXMgPSBuZXcgQkVNSGVscGVyKHtcbiAgbmFtZTogJ2FydGljbGUnLFxuICBwcmVmaXg6ICdjLScsXG59KTtcblxudHlwZSBPcGVuQnV0dG9uUHJvcHMgPSB7XG4gIG9uQ2xpY2s6ICgpID0+IHZvaWQ7XG4gIGNoaWxkcmVuOiBSZWFjdE5vZGU7XG59O1xuXG5leHBvcnQgY29uc3QgT3BlbkJ1dHRvbiA9ICh7IGNoaWxkcmVuLCBvbkNsaWNrIH06IE9wZW5CdXR0b25Qcm9wcykgPT4gKFxuICA8QnV0dG9uIHNpemU9XCJ4c21hbGxcIiBsaWdodGVyIGJvcmRlclNoYXBlPVwicm91bmRlZFwiIG9uQ2xpY2s9e29uQ2xpY2t9PlxuICAgIHtjaGlsZHJlbn1cbiAgPC9CdXR0b24+XG4pO1xuXG5jb25zdCBDb21wZXRlbmNlV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5gO1xuXG5jb25zdCBDb21wZXRlbmNlQmFkZ2UgPSBzdHlsZWQuc3BhbmBcbiAgZGlzcGxheTogaW5saW5lLWJsb2NrO1xuICBiYWNrZ3JvdW5kOiAke2NvbG9ycy5icmFuZC5ncmV5TGlnaHRlcn07XG4gIGJvcmRlci1yYWRpdXM6IDM2cHg7XG4gIGZvbnQtd2VpZ2h0OiAke2ZvbnRzLndlaWdodC5zZW1pYm9sZH07XG4gICR7Zm9udHMuc2l6ZXMoJzEycHgnLCAnMTVweCcpfTtcbiAgZGlzcGxheTogaW5saW5lLWZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGNvbG9yOiAke2NvbG9ycy50ZXh0LnByaW1hcnl9O1xuICBmb250LWZhbWlseTogJHtmb250cy5zYW5zfTtcbiAgcGFkZGluZzogMCA2cHg7XG4gIGhlaWdodDogMjVweDtcbiAgbWFyZ2luLXJpZ2h0OiA3cHg7XG5gO1xuXG5jb25zdCBDb21wZXRlbmNlQmFkZ2VUZXh0ID0gc3R5bGVkLnNwYW5gXG4gIHBhZGRpbmc6IDAgNXB4O1xuYDtcblxudHlwZSBDb21wZXRlbmNlQnV0dG9uV3JhcHBlclByb3BzID0ge1xuICBhZGRTcGFjZTogYm9vbGVhbiB8IHVuZGVmaW5lZDtcbn07XG5cbmNvbnN0IENvbXBldGVuY2VCdXR0b25XcmFwcGVyID0gc3R5bGVkLmRpdjxDb21wZXRlbmNlQnV0dG9uV3JhcHBlclByb3BzPmBcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgJHsocHJvcHMpID0+IHByb3BzLmFkZFNwYWNlICYmIGBwYWRkaW5nLWxlZnQ6IDEycHg7YH1cbmA7XG5cbnR5cGUgUHJvcHMgPSB7XG4gIGNvbXBldGVuY2VHb2Fscz86XG4gICAgfCAoKGlucDogeyBEaWFsb2c6IENvbXBvbmVudFR5cGU7IGRpYWxvZ1Byb3BzOiB7IGlzT3BlbjogYm9vbGVhbjsgb25DbG9zZTogKCkgPT4gdm9pZCB9IH0pID0+IFJlYWN0Tm9kZSlcbiAgICB8IG51bGw7XG4gIGNvbXBldGVuY2VHb2FsVHlwZXM/OiBzdHJpbmdbXTtcbiAgY2hpbGRyZW46IFJlYWN0Tm9kZTtcbn07XG5cbmludGVyZmFjZSBTdGF0ZSB7XG4gIGlzT3BlbjogYm9vbGVhbjtcbn1cblxuY2xhc3MgQXJ0aWNsZUhlYWRlcldyYXBwZXIgZXh0ZW5kcyBDb21wb25lbnQ8UHJvcHMgJiBXaXRoVHJhbnNsYXRpb24sIFN0YXRlPiB7XG4gIGNvbnN0cnVjdG9yKHByb3BzOiBQcm9wcyAmIFdpdGhUcmFuc2xhdGlvbikge1xuICAgIHN1cGVyKHByb3BzKTtcbiAgICB0aGlzLnN0YXRlID0geyBpc09wZW46IGZhbHNlIH07XG4gICAgdGhpcy5jbG9zZURpYWxvZyA9IHRoaXMuY2xvc2VEaWFsb2cuYmluZCh0aGlzKTtcbiAgICB0aGlzLm9wZW5EaWFsb2cgPSB0aGlzLm9wZW5EaWFsb2cuYmluZCh0aGlzKTtcbiAgfVxuXG4gIGNvbXBvbmVudERpZE1vdW50KCkge1xuICAgIGlmIChpc01vYmlsZSkge1xuICAgICAgY29uc3QgaGVyb0NvbnRlbnRMaXN0OiBOb2RlTGlzdE9mPEhUTUxFbGVtZW50PiA9IGRvY3VtZW50LnF1ZXJ5U2VsZWN0b3JBbGwoJy5jLWFydGljbGVfX2hlYWRlcicpO1xuICAgICAgaWYgKGhlcm9Db250ZW50TGlzdC5sZW5ndGggPT09IDEpIHtcbiAgICAgICAgaGVyb0NvbnRlbnRMaXN0WzBdLnNjcm9sbEludG9WaWV3KHRydWUpO1xuICAgICAgICB3aW5kb3cuc2Nyb2xsQnkoMCwgaGVyb0NvbnRlbnRMaXN0WzBdLm9mZnNldFRvcCAtIDEyMCk7IC8vIEFkanVzdCBmb3IgaGVhZGVyXG4gICAgICB9XG4gICAgfVxuICB9XG5cbiAgb3BlbkRpYWxvZygpIHtcbiAgICB0aGlzLnNldFN0YXRlKHsgaXNPcGVuOiB0cnVlIH0pO1xuICB9XG5cbiAgY2xvc2VEaWFsb2coKSB7XG4gICAgdGhpcy5zZXRTdGF0ZSh7IGlzT3BlbjogZmFsc2UgfSk7XG4gIH1cblxuICByZW5kZXIoKSB7XG4gICAgY29uc3QgeyBjaGlsZHJlbiwgY29tcGV0ZW5jZUdvYWxzLCBjb21wZXRlbmNlR29hbFR5cGVzLCB0IH0gPSB0aGlzLnByb3BzO1xuICAgIGlmICghY29tcGV0ZW5jZUdvYWxzKSB7XG4gICAgICByZXR1cm4gPGRpdiB7Li4uY2xhc3NlcygnaGVhZGVyJyl9PntjaGlsZHJlbn08L2Rpdj47XG4gICAgfVxuXG4gICAgY29uc3QgZGlhbG9nID1cbiAgICAgIHR5cGVvZiBjb21wZXRlbmNlR29hbHMgPT09ICdmdW5jdGlvbicgPyAoXG4gICAgICAgIGNvbXBldGVuY2VHb2Fscyh7XG4gICAgICAgICAgRGlhbG9nOiBDb21wZXRlbmNlR29hbHNEaWFsb2csXG4gICAgICAgICAgZGlhbG9nUHJvcHM6IHtcbiAgICAgICAgICAgIGlzT3BlbjogdGhpcy5zdGF0ZS5pc09wZW4sXG4gICAgICAgICAgICBvbkNsb3NlOiB0aGlzLmNsb3NlRGlhbG9nLFxuICAgICAgICAgIH0sXG4gICAgICAgIH0pXG4gICAgICApIDogKFxuICAgICAgICA8Q29tcGV0ZW5jZUdvYWxzRGlhbG9nIG9uQ2xvc2U9e3RoaXMuY2xvc2VEaWFsb2d9IGlzT3Blbj17dGhpcy5zdGF0ZS5pc09wZW59PlxuICAgICAgICAgIHtjb21wZXRlbmNlR29hbHN9XG4gICAgICAgIDwvQ29tcGV0ZW5jZUdvYWxzRGlhbG9nPlxuICAgICAgKTtcbiAgICByZXR1cm4gKFxuICAgICAgPGRpdiB7Li4uY2xhc3NlcygnaGVhZGVyJyl9PlxuICAgICAgICB7Y2hpbGRyZW59XG4gICAgICAgIDxDb21wZXRlbmNlV3JhcHBlcj5cbiAgICAgICAgICB7Y29tcGV0ZW5jZUdvYWxUeXBlcyAmJlxuICAgICAgICAgICAgY29tcGV0ZW5jZUdvYWxUeXBlcy5tYXAoKHR5cGUpID0+IChcbiAgICAgICAgICAgICAgPENvbXBldGVuY2VCYWRnZSBrZXk9e3R5cGV9PlxuICAgICAgICAgICAgICAgIDxGb290ZXJIZWFkZXJJY29uIC8+XG4gICAgICAgICAgICAgICAgPENvbXBldGVuY2VCYWRnZVRleHQ+e3R5cGV9PC9Db21wZXRlbmNlQmFkZ2VUZXh0PlxuICAgICAgICAgICAgICA8L0NvbXBldGVuY2VCYWRnZT5cbiAgICAgICAgICAgICkpfVxuICAgICAgICAgIDxDb21wZXRlbmNlQnV0dG9uV3JhcHBlciBhZGRTcGFjZT17Y29tcGV0ZW5jZUdvYWxUeXBlcyAmJiBjb21wZXRlbmNlR29hbFR5cGVzLmxlbmd0aCA+IDB9PlxuICAgICAgICAgICAgPE9wZW5CdXR0b24gb25DbGljaz17dGhpcy5vcGVuRGlhbG9nfT5cbiAgICAgICAgICAgICAgPEZvb3RlckhlYWRlckljb24gLz5cbiAgICAgICAgICAgICAgPENvbXBldGVuY2VCYWRnZVRleHQ+e3QoJ2NvbXBldGVuY2VHb2Fscy5zaG93Q29tcGV0ZW5jZUdvYWxzJyl9PC9Db21wZXRlbmNlQmFkZ2VUZXh0PlxuICAgICAgICAgICAgPC9PcGVuQnV0dG9uPlxuICAgICAgICAgIDwvQ29tcGV0ZW5jZUJ1dHRvbldyYXBwZXI+XG4gICAgICAgIDwvQ29tcGV0ZW5jZVdyYXBwZXI+XG4gICAgICAgIHtkaWFsb2d9XG4gICAgICA8L2Rpdj5cbiAgICApO1xuICB9XG59XG5cbmV4cG9ydCBkZWZhdWx0IHdpdGhUcmFuc2xhdGlvbigpKEFydGljbGVIZWFkZXJXcmFwcGVyKTtcbiJdfQ== */",
84
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkFydGljbGVIZWFkZXJXcmFwcGVyLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFvQ29DIiwiZmlsZSI6IkFydGljbGVIZWFkZXJXcmFwcGVyLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE2LXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IFJlYWN0LCB7IENvbXBvbmVudCwgQ29tcG9uZW50VHlwZSwgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IEJFTUhlbHBlciBmcm9tICdyZWFjdC1iZW0taGVscGVyJztcbmltcG9ydCB7IHdpdGhUcmFuc2xhdGlvbiwgV2l0aFRyYW5zbGF0aW9uIH0gZnJvbSAncmVhY3QtaTE4bmV4dCc7XG5pbXBvcnQgQnV0dG9uIGZyb20gJ0BuZGxhL2J1dHRvbic7XG5pbXBvcnQgeyBpc01vYmlsZSB9IGZyb20gJ3JlYWN0LWRldmljZS1kZXRlY3QnO1xuaW1wb3J0IHsgZm9udHMsIGNvbG9ycyB9IGZyb20gJ0BuZGxhL2NvcmUnO1xuXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBGb290ZXJIZWFkZXJJY29uIH0gZnJvbSAnQG5kbGEvaWNvbnMvY29tbW9uJztcbi8vIEB0cy1pZ25vcmVcbmltcG9ydCBDb21wZXRlbmNlR29hbHNEaWFsb2cgZnJvbSAnLi4vQ29tcGV0ZW5jZUdvYWxzL0NvbXBldGVuY2VHb2Fsc0RpYWxvZyc7XG5cbmNvbnN0IGNsYXNzZXMgPSBuZXcgQkVNSGVscGVyKHtcbiAgbmFtZTogJ2FydGljbGUnLFxuICBwcmVmaXg6ICdjLScsXG59KTtcblxudHlwZSBPcGVuQnV0dG9uUHJvcHMgPSB7XG4gIG9uQ2xpY2s6ICgpID0+IHZvaWQ7XG4gIGNoaWxkcmVuOiBSZWFjdE5vZGU7XG59O1xuXG5leHBvcnQgY29uc3QgT3BlbkJ1dHRvbiA9ICh7IGNoaWxkcmVuLCBvbkNsaWNrIH06IE9wZW5CdXR0b25Qcm9wcykgPT4gKFxuICA8QnV0dG9uIHNpemU9XCJ4c21hbGxcIiBsaWdodGVyIGJvcmRlclNoYXBlPVwicm91bmRlZFwiIG9uQ2xpY2s9e29uQ2xpY2t9PlxuICAgIHtjaGlsZHJlbn1cbiAgPC9CdXR0b24+XG4pO1xuXG5jb25zdCBDb21wZXRlbmNlV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5gO1xuXG5jb25zdCBDb21wZXRlbmNlQmFkZ2UgPSBzdHlsZWQuc3BhbmBcbiAgZGlzcGxheTogaW5saW5lLWJsb2NrO1xuICBiYWNrZ3JvdW5kOiAke2NvbG9ycy5icmFuZC5ncmV5TGlnaHRlcn07XG4gIGJvcmRlci1yYWRpdXM6IDM2cHg7XG4gIGZvbnQtd2VpZ2h0OiAke2ZvbnRzLndlaWdodC5zZW1pYm9sZH07XG4gICR7Zm9udHMuc2l6ZXMoJzEycHgnLCAnMTVweCcpfTtcbiAgZGlzcGxheTogaW5saW5lLWZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGNvbG9yOiAke2NvbG9ycy50ZXh0LnByaW1hcnl9O1xuICBmb250LWZhbWlseTogJHtmb250cy5zYW5zfTtcbiAgcGFkZGluZzogMCA2cHg7XG4gIGhlaWdodDogMjVweDtcbiAgbWFyZ2luLXJpZ2h0OiA3cHg7XG5gO1xuXG5jb25zdCBDb21wZXRlbmNlQmFkZ2VUZXh0ID0gc3R5bGVkLnNwYW5gXG4gIHBhZGRpbmc6IDAgNXB4O1xuYDtcblxudHlwZSBDb21wZXRlbmNlQnV0dG9uV3JhcHBlclByb3BzID0ge1xuICBhZGRTcGFjZTogYm9vbGVhbiB8IHVuZGVmaW5lZDtcbn07XG5cbmNvbnN0IENvbXBldGVuY2VCdXR0b25XcmFwcGVyID0gc3R5bGVkLmRpdjxDb21wZXRlbmNlQnV0dG9uV3JhcHBlclByb3BzPmBcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgJHsocHJvcHMpID0+IHByb3BzLmFkZFNwYWNlICYmIGBwYWRkaW5nLWxlZnQ6IDEycHg7YH1cbmA7XG5cbnR5cGUgUHJvcHMgPSB7XG4gIGNvbXBldGVuY2VHb2Fscz86XG4gICAgfCAoKGlucDogeyBEaWFsb2c6IENvbXBvbmVudFR5cGU7IGRpYWxvZ1Byb3BzOiB7IGlzT3BlbjogYm9vbGVhbjsgb25DbG9zZTogKCkgPT4gdm9pZCB9IH0pID0+IFJlYWN0Tm9kZSlcbiAgICB8IFJlYWN0Tm9kZVxuICAgIHwgbnVsbDtcbiAgY29tcGV0ZW5jZUdvYWxUeXBlcz86IHN0cmluZ1tdO1xuICBjaGlsZHJlbjogUmVhY3ROb2RlO1xufTtcblxuaW50ZXJmYWNlIFN0YXRlIHtcbiAgaXNPcGVuOiBib29sZWFuO1xufVxuXG5jbGFzcyBBcnRpY2xlSGVhZGVyV3JhcHBlciBleHRlbmRzIENvbXBvbmVudDxQcm9wcyAmIFdpdGhUcmFuc2xhdGlvbiwgU3RhdGU+IHtcbiAgY29uc3RydWN0b3IocHJvcHM6IFByb3BzICYgV2l0aFRyYW5zbGF0aW9uKSB7XG4gICAgc3VwZXIocHJvcHMpO1xuICAgIHRoaXMuc3RhdGUgPSB7IGlzT3BlbjogZmFsc2UgfTtcbiAgICB0aGlzLmNsb3NlRGlhbG9nID0gdGhpcy5jbG9zZURpYWxvZy5iaW5kKHRoaXMpO1xuICAgIHRoaXMub3BlbkRpYWxvZyA9IHRoaXMub3BlbkRpYWxvZy5iaW5kKHRoaXMpO1xuICB9XG5cbiAgY29tcG9uZW50RGlkTW91bnQoKSB7XG4gICAgaWYgKGlzTW9iaWxlKSB7XG4gICAgICBjb25zdCBoZXJvQ29udGVudExpc3Q6IE5vZGVMaXN0T2Y8SFRNTEVsZW1lbnQ+ID0gZG9jdW1lbnQucXVlcnlTZWxlY3RvckFsbCgnLmMtYXJ0aWNsZV9faGVhZGVyJyk7XG4gICAgICBpZiAoaGVyb0NvbnRlbnRMaXN0Lmxlbmd0aCA9PT0gMSkge1xuICAgICAgICBoZXJvQ29udGVudExpc3RbMF0uc2Nyb2xsSW50b1ZpZXcodHJ1ZSk7XG4gICAgICAgIHdpbmRvdy5zY3JvbGxCeSgwLCBoZXJvQ29udGVudExpc3RbMF0ub2Zmc2V0VG9wIC0gMTIwKTsgLy8gQWRqdXN0IGZvciBoZWFkZXJcbiAgICAgIH1cbiAgICB9XG4gIH1cblxuICBvcGVuRGlhbG9nKCkge1xuICAgIHRoaXMuc2V0U3RhdGUoeyBpc09wZW46IHRydWUgfSk7XG4gIH1cblxuICBjbG9zZURpYWxvZygpIHtcbiAgICB0aGlzLnNldFN0YXRlKHsgaXNPcGVuOiBmYWxzZSB9KTtcbiAgfVxuXG4gIHJlbmRlcigpIHtcbiAgICBjb25zdCB7IGNoaWxkcmVuLCBjb21wZXRlbmNlR29hbHMsIGNvbXBldGVuY2VHb2FsVHlwZXMsIHQgfSA9IHRoaXMucHJvcHM7XG4gICAgaWYgKCFjb21wZXRlbmNlR29hbHMpIHtcbiAgICAgIHJldHVybiA8ZGl2IHsuLi5jbGFzc2VzKCdoZWFkZXInKX0+e2NoaWxkcmVufTwvZGl2PjtcbiAgICB9XG5cbiAgICBjb25zdCBkaWFsb2cgPVxuICAgICAgdHlwZW9mIGNvbXBldGVuY2VHb2FscyA9PT0gJ2Z1bmN0aW9uJyA/IChcbiAgICAgICAgY29tcGV0ZW5jZUdvYWxzKHtcbiAgICAgICAgICBEaWFsb2c6IENvbXBldGVuY2VHb2Fsc0RpYWxvZyxcbiAgICAgICAgICBkaWFsb2dQcm9wczoge1xuICAgICAgICAgICAgaXNPcGVuOiB0aGlzLnN0YXRlLmlzT3BlbixcbiAgICAgICAgICAgIG9uQ2xvc2U6IHRoaXMuY2xvc2VEaWFsb2csXG4gICAgICAgICAgfSxcbiAgICAgICAgfSlcbiAgICAgICkgOiAoXG4gICAgICAgIDxDb21wZXRlbmNlR29hbHNEaWFsb2cgb25DbG9zZT17dGhpcy5jbG9zZURpYWxvZ30gaXNPcGVuPXt0aGlzLnN0YXRlLmlzT3Blbn0+XG4gICAgICAgICAge2NvbXBldGVuY2VHb2Fsc31cbiAgICAgICAgPC9Db21wZXRlbmNlR29hbHNEaWFsb2c+XG4gICAgICApO1xuICAgIHJldHVybiAoXG4gICAgICA8ZGl2IHsuLi5jbGFzc2VzKCdoZWFkZXInKX0+XG4gICAgICAgIHtjaGlsZHJlbn1cbiAgICAgICAgPENvbXBldGVuY2VXcmFwcGVyPlxuICAgICAgICAgIHtjb21wZXRlbmNlR29hbFR5cGVzICYmXG4gICAgICAgICAgICBjb21wZXRlbmNlR29hbFR5cGVzLm1hcCgodHlwZSkgPT4gKFxuICAgICAgICAgICAgICA8Q29tcGV0ZW5jZUJhZGdlIGtleT17dHlwZX0+XG4gICAgICAgICAgICAgICAgPEZvb3RlckhlYWRlckljb24gLz5cbiAgICAgICAgICAgICAgICA8Q29tcGV0ZW5jZUJhZGdlVGV4dD57dHlwZX08L0NvbXBldGVuY2VCYWRnZVRleHQ+XG4gICAgICAgICAgICAgIDwvQ29tcGV0ZW5jZUJhZGdlPlxuICAgICAgICAgICAgKSl9XG4gICAgICAgICAgPENvbXBldGVuY2VCdXR0b25XcmFwcGVyIGFkZFNwYWNlPXtjb21wZXRlbmNlR29hbFR5cGVzICYmIGNvbXBldGVuY2VHb2FsVHlwZXMubGVuZ3RoID4gMH0+XG4gICAgICAgICAgICA8T3BlbkJ1dHRvbiBvbkNsaWNrPXt0aGlzLm9wZW5EaWFsb2d9PlxuICAgICAgICAgICAgICA8Rm9vdGVySGVhZGVySWNvbiAvPlxuICAgICAgICAgICAgICA8Q29tcGV0ZW5jZUJhZGdlVGV4dD57dCgnY29tcGV0ZW5jZUdvYWxzLnNob3dDb21wZXRlbmNlR29hbHMnKX08L0NvbXBldGVuY2VCYWRnZVRleHQ+XG4gICAgICAgICAgICA8L09wZW5CdXR0b24+XG4gICAgICAgICAgPC9Db21wZXRlbmNlQnV0dG9uV3JhcHBlcj5cbiAgICAgICAgPC9Db21wZXRlbmNlV3JhcHBlcj5cbiAgICAgICAge2RpYWxvZ31cbiAgICAgIDwvZGl2PlxuICAgICk7XG4gIH1cbn1cblxuZXhwb3J0IGRlZmF1bHQgd2l0aFRyYW5zbGF0aW9uKCkoQXJ0aWNsZUhlYWRlcldyYXBwZXIpO1xuIl19 */",
85
85
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
86
86
  });
87
87
  var CompetenceBadge = (0, _styledBase["default"])("span", {
88
88
  target: "e1daii1f1",
89
89
  label: "CompetenceBadge"
90
- })("display:inline-block;background:", _core.colors.brand.greyLighter, ";border-radius:36px;font-weight:", _core.fonts.weight.semibold, ";", _core.fonts.sizes('12px', '15px'), ";display:inline-flex;align-items:center;color:", _core.colors.text.primary, ";font-family:", _core.fonts.sans, ";padding:0 6px;height:25px;margin-right:7px;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkFydGljbGVIZWFkZXJXcmFwcGVyLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF5Q21DIiwiZmlsZSI6IkFydGljbGVIZWFkZXJXcmFwcGVyLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE2LXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IFJlYWN0LCB7IENvbXBvbmVudCwgQ29tcG9uZW50VHlwZSwgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IEJFTUhlbHBlciBmcm9tICdyZWFjdC1iZW0taGVscGVyJztcbmltcG9ydCB7IHdpdGhUcmFuc2xhdGlvbiwgV2l0aFRyYW5zbGF0aW9uIH0gZnJvbSAncmVhY3QtaTE4bmV4dCc7XG5pbXBvcnQgQnV0dG9uIGZyb20gJ0BuZGxhL2J1dHRvbic7XG5pbXBvcnQgeyBpc01vYmlsZSB9IGZyb20gJ3JlYWN0LWRldmljZS1kZXRlY3QnO1xuaW1wb3J0IHsgZm9udHMsIGNvbG9ycyB9IGZyb20gJ0BuZGxhL2NvcmUnO1xuXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBGb290ZXJIZWFkZXJJY29uIH0gZnJvbSAnQG5kbGEvaWNvbnMvY29tbW9uJztcbi8vIEB0cy1pZ25vcmVcbmltcG9ydCBDb21wZXRlbmNlR29hbHNEaWFsb2cgZnJvbSAnLi4vQ29tcGV0ZW5jZUdvYWxzL0NvbXBldGVuY2VHb2Fsc0RpYWxvZyc7XG5cbmNvbnN0IGNsYXNzZXMgPSBuZXcgQkVNSGVscGVyKHtcbiAgbmFtZTogJ2FydGljbGUnLFxuICBwcmVmaXg6ICdjLScsXG59KTtcblxudHlwZSBPcGVuQnV0dG9uUHJvcHMgPSB7XG4gIG9uQ2xpY2s6ICgpID0+IHZvaWQ7XG4gIGNoaWxkcmVuOiBSZWFjdE5vZGU7XG59O1xuXG5leHBvcnQgY29uc3QgT3BlbkJ1dHRvbiA9ICh7IGNoaWxkcmVuLCBvbkNsaWNrIH06IE9wZW5CdXR0b25Qcm9wcykgPT4gKFxuICA8QnV0dG9uIHNpemU9XCJ4c21hbGxcIiBsaWdodGVyIGJvcmRlclNoYXBlPVwicm91bmRlZFwiIG9uQ2xpY2s9e29uQ2xpY2t9PlxuICAgIHtjaGlsZHJlbn1cbiAgPC9CdXR0b24+XG4pO1xuXG5jb25zdCBDb21wZXRlbmNlV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5gO1xuXG5jb25zdCBDb21wZXRlbmNlQmFkZ2UgPSBzdHlsZWQuc3BhbmBcbiAgZGlzcGxheTogaW5saW5lLWJsb2NrO1xuICBiYWNrZ3JvdW5kOiAke2NvbG9ycy5icmFuZC5ncmV5TGlnaHRlcn07XG4gIGJvcmRlci1yYWRpdXM6IDM2cHg7XG4gIGZvbnQtd2VpZ2h0OiAke2ZvbnRzLndlaWdodC5zZW1pYm9sZH07XG4gICR7Zm9udHMuc2l6ZXMoJzEycHgnLCAnMTVweCcpfTtcbiAgZGlzcGxheTogaW5saW5lLWZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGNvbG9yOiAke2NvbG9ycy50ZXh0LnByaW1hcnl9O1xuICBmb250LWZhbWlseTogJHtmb250cy5zYW5zfTtcbiAgcGFkZGluZzogMCA2cHg7XG4gIGhlaWdodDogMjVweDtcbiAgbWFyZ2luLXJpZ2h0OiA3cHg7XG5gO1xuXG5jb25zdCBDb21wZXRlbmNlQmFkZ2VUZXh0ID0gc3R5bGVkLnNwYW5gXG4gIHBhZGRpbmc6IDAgNXB4O1xuYDtcblxudHlwZSBDb21wZXRlbmNlQnV0dG9uV3JhcHBlclByb3BzID0ge1xuICBhZGRTcGFjZTogYm9vbGVhbiB8IHVuZGVmaW5lZDtcbn07XG5cbmNvbnN0IENvbXBldGVuY2VCdXR0b25XcmFwcGVyID0gc3R5bGVkLmRpdjxDb21wZXRlbmNlQnV0dG9uV3JhcHBlclByb3BzPmBcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgJHsocHJvcHMpID0+IHByb3BzLmFkZFNwYWNlICYmIGBwYWRkaW5nLWxlZnQ6IDEycHg7YH1cbmA7XG5cbnR5cGUgUHJvcHMgPSB7XG4gIGNvbXBldGVuY2VHb2Fscz86XG4gICAgfCAoKGlucDogeyBEaWFsb2c6IENvbXBvbmVudFR5cGU7IGRpYWxvZ1Byb3BzOiB7IGlzT3BlbjogYm9vbGVhbjsgb25DbG9zZTogKCkgPT4gdm9pZCB9IH0pID0+IFJlYWN0Tm9kZSlcbiAgICB8IG51bGw7XG4gIGNvbXBldGVuY2VHb2FsVHlwZXM/OiBzdHJpbmdbXTtcbiAgY2hpbGRyZW46IFJlYWN0Tm9kZTtcbn07XG5cbmludGVyZmFjZSBTdGF0ZSB7XG4gIGlzT3BlbjogYm9vbGVhbjtcbn1cblxuY2xhc3MgQXJ0aWNsZUhlYWRlcldyYXBwZXIgZXh0ZW5kcyBDb21wb25lbnQ8UHJvcHMgJiBXaXRoVHJhbnNsYXRpb24sIFN0YXRlPiB7XG4gIGNvbnN0cnVjdG9yKHByb3BzOiBQcm9wcyAmIFdpdGhUcmFuc2xhdGlvbikge1xuICAgIHN1cGVyKHByb3BzKTtcbiAgICB0aGlzLnN0YXRlID0geyBpc09wZW46IGZhbHNlIH07XG4gICAgdGhpcy5jbG9zZURpYWxvZyA9IHRoaXMuY2xvc2VEaWFsb2cuYmluZCh0aGlzKTtcbiAgICB0aGlzLm9wZW5EaWFsb2cgPSB0aGlzLm9wZW5EaWFsb2cuYmluZCh0aGlzKTtcbiAgfVxuXG4gIGNvbXBvbmVudERpZE1vdW50KCkge1xuICAgIGlmIChpc01vYmlsZSkge1xuICAgICAgY29uc3QgaGVyb0NvbnRlbnRMaXN0OiBOb2RlTGlzdE9mPEhUTUxFbGVtZW50PiA9IGRvY3VtZW50LnF1ZXJ5U2VsZWN0b3JBbGwoJy5jLWFydGljbGVfX2hlYWRlcicpO1xuICAgICAgaWYgKGhlcm9Db250ZW50TGlzdC5sZW5ndGggPT09IDEpIHtcbiAgICAgICAgaGVyb0NvbnRlbnRMaXN0WzBdLnNjcm9sbEludG9WaWV3KHRydWUpO1xuICAgICAgICB3aW5kb3cuc2Nyb2xsQnkoMCwgaGVyb0NvbnRlbnRMaXN0WzBdLm9mZnNldFRvcCAtIDEyMCk7IC8vIEFkanVzdCBmb3IgaGVhZGVyXG4gICAgICB9XG4gICAgfVxuICB9XG5cbiAgb3BlbkRpYWxvZygpIHtcbiAgICB0aGlzLnNldFN0YXRlKHsgaXNPcGVuOiB0cnVlIH0pO1xuICB9XG5cbiAgY2xvc2VEaWFsb2coKSB7XG4gICAgdGhpcy5zZXRTdGF0ZSh7IGlzT3BlbjogZmFsc2UgfSk7XG4gIH1cblxuICByZW5kZXIoKSB7XG4gICAgY29uc3QgeyBjaGlsZHJlbiwgY29tcGV0ZW5jZUdvYWxzLCBjb21wZXRlbmNlR29hbFR5cGVzLCB0IH0gPSB0aGlzLnByb3BzO1xuICAgIGlmICghY29tcGV0ZW5jZUdvYWxzKSB7XG4gICAgICByZXR1cm4gPGRpdiB7Li4uY2xhc3NlcygnaGVhZGVyJyl9PntjaGlsZHJlbn08L2Rpdj47XG4gICAgfVxuXG4gICAgY29uc3QgZGlhbG9nID1cbiAgICAgIHR5cGVvZiBjb21wZXRlbmNlR29hbHMgPT09ICdmdW5jdGlvbicgPyAoXG4gICAgICAgIGNvbXBldGVuY2VHb2Fscyh7XG4gICAgICAgICAgRGlhbG9nOiBDb21wZXRlbmNlR29hbHNEaWFsb2csXG4gICAgICAgICAgZGlhbG9nUHJvcHM6IHtcbiAgICAgICAgICAgIGlzT3BlbjogdGhpcy5zdGF0ZS5pc09wZW4sXG4gICAgICAgICAgICBvbkNsb3NlOiB0aGlzLmNsb3NlRGlhbG9nLFxuICAgICAgICAgIH0sXG4gICAgICAgIH0pXG4gICAgICApIDogKFxuICAgICAgICA8Q29tcGV0ZW5jZUdvYWxzRGlhbG9nIG9uQ2xvc2U9e3RoaXMuY2xvc2VEaWFsb2d9IGlzT3Blbj17dGhpcy5zdGF0ZS5pc09wZW59PlxuICAgICAgICAgIHtjb21wZXRlbmNlR29hbHN9XG4gICAgICAgIDwvQ29tcGV0ZW5jZUdvYWxzRGlhbG9nPlxuICAgICAgKTtcbiAgICByZXR1cm4gKFxuICAgICAgPGRpdiB7Li4uY2xhc3NlcygnaGVhZGVyJyl9PlxuICAgICAgICB7Y2hpbGRyZW59XG4gICAgICAgIDxDb21wZXRlbmNlV3JhcHBlcj5cbiAgICAgICAgICB7Y29tcGV0ZW5jZUdvYWxUeXBlcyAmJlxuICAgICAgICAgICAgY29tcGV0ZW5jZUdvYWxUeXBlcy5tYXAoKHR5cGUpID0+IChcbiAgICAgICAgICAgICAgPENvbXBldGVuY2VCYWRnZSBrZXk9e3R5cGV9PlxuICAgICAgICAgICAgICAgIDxGb290ZXJIZWFkZXJJY29uIC8+XG4gICAgICAgICAgICAgICAgPENvbXBldGVuY2VCYWRnZVRleHQ+e3R5cGV9PC9Db21wZXRlbmNlQmFkZ2VUZXh0PlxuICAgICAgICAgICAgICA8L0NvbXBldGVuY2VCYWRnZT5cbiAgICAgICAgICAgICkpfVxuICAgICAgICAgIDxDb21wZXRlbmNlQnV0dG9uV3JhcHBlciBhZGRTcGFjZT17Y29tcGV0ZW5jZUdvYWxUeXBlcyAmJiBjb21wZXRlbmNlR29hbFR5cGVzLmxlbmd0aCA+IDB9PlxuICAgICAgICAgICAgPE9wZW5CdXR0b24gb25DbGljaz17dGhpcy5vcGVuRGlhbG9nfT5cbiAgICAgICAgICAgICAgPEZvb3RlckhlYWRlckljb24gLz5cbiAgICAgICAgICAgICAgPENvbXBldGVuY2VCYWRnZVRleHQ+e3QoJ2NvbXBldGVuY2VHb2Fscy5zaG93Q29tcGV0ZW5jZUdvYWxzJyl9PC9Db21wZXRlbmNlQmFkZ2VUZXh0PlxuICAgICAgICAgICAgPC9PcGVuQnV0dG9uPlxuICAgICAgICAgIDwvQ29tcGV0ZW5jZUJ1dHRvbldyYXBwZXI+XG4gICAgICAgIDwvQ29tcGV0ZW5jZVdyYXBwZXI+XG4gICAgICAgIHtkaWFsb2d9XG4gICAgICA8L2Rpdj5cbiAgICApO1xuICB9XG59XG5cbmV4cG9ydCBkZWZhdWx0IHdpdGhUcmFuc2xhdGlvbigpKEFydGljbGVIZWFkZXJXcmFwcGVyKTtcbiJdfQ== */"));
90
+ })("display:inline-block;background:", _core.colors.brand.greyLighter, ";border-radius:36px;font-weight:", _core.fonts.weight.semibold, ";", _core.fonts.sizes('12px', '15px'), ";display:inline-flex;align-items:center;color:", _core.colors.text.primary, ";font-family:", _core.fonts.sans, ";padding:0 6px;height:25px;margin-right:7px;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkFydGljbGVIZWFkZXJXcmFwcGVyLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF5Q21DIiwiZmlsZSI6IkFydGljbGVIZWFkZXJXcmFwcGVyLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE2LXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IFJlYWN0LCB7IENvbXBvbmVudCwgQ29tcG9uZW50VHlwZSwgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IEJFTUhlbHBlciBmcm9tICdyZWFjdC1iZW0taGVscGVyJztcbmltcG9ydCB7IHdpdGhUcmFuc2xhdGlvbiwgV2l0aFRyYW5zbGF0aW9uIH0gZnJvbSAncmVhY3QtaTE4bmV4dCc7XG5pbXBvcnQgQnV0dG9uIGZyb20gJ0BuZGxhL2J1dHRvbic7XG5pbXBvcnQgeyBpc01vYmlsZSB9IGZyb20gJ3JlYWN0LWRldmljZS1kZXRlY3QnO1xuaW1wb3J0IHsgZm9udHMsIGNvbG9ycyB9IGZyb20gJ0BuZGxhL2NvcmUnO1xuXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBGb290ZXJIZWFkZXJJY29uIH0gZnJvbSAnQG5kbGEvaWNvbnMvY29tbW9uJztcbi8vIEB0cy1pZ25vcmVcbmltcG9ydCBDb21wZXRlbmNlR29hbHNEaWFsb2cgZnJvbSAnLi4vQ29tcGV0ZW5jZUdvYWxzL0NvbXBldGVuY2VHb2Fsc0RpYWxvZyc7XG5cbmNvbnN0IGNsYXNzZXMgPSBuZXcgQkVNSGVscGVyKHtcbiAgbmFtZTogJ2FydGljbGUnLFxuICBwcmVmaXg6ICdjLScsXG59KTtcblxudHlwZSBPcGVuQnV0dG9uUHJvcHMgPSB7XG4gIG9uQ2xpY2s6ICgpID0+IHZvaWQ7XG4gIGNoaWxkcmVuOiBSZWFjdE5vZGU7XG59O1xuXG5leHBvcnQgY29uc3QgT3BlbkJ1dHRvbiA9ICh7IGNoaWxkcmVuLCBvbkNsaWNrIH06IE9wZW5CdXR0b25Qcm9wcykgPT4gKFxuICA8QnV0dG9uIHNpemU9XCJ4c21hbGxcIiBsaWdodGVyIGJvcmRlclNoYXBlPVwicm91bmRlZFwiIG9uQ2xpY2s9e29uQ2xpY2t9PlxuICAgIHtjaGlsZHJlbn1cbiAgPC9CdXR0b24+XG4pO1xuXG5jb25zdCBDb21wZXRlbmNlV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5gO1xuXG5jb25zdCBDb21wZXRlbmNlQmFkZ2UgPSBzdHlsZWQuc3BhbmBcbiAgZGlzcGxheTogaW5saW5lLWJsb2NrO1xuICBiYWNrZ3JvdW5kOiAke2NvbG9ycy5icmFuZC5ncmV5TGlnaHRlcn07XG4gIGJvcmRlci1yYWRpdXM6IDM2cHg7XG4gIGZvbnQtd2VpZ2h0OiAke2ZvbnRzLndlaWdodC5zZW1pYm9sZH07XG4gICR7Zm9udHMuc2l6ZXMoJzEycHgnLCAnMTVweCcpfTtcbiAgZGlzcGxheTogaW5saW5lLWZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGNvbG9yOiAke2NvbG9ycy50ZXh0LnByaW1hcnl9O1xuICBmb250LWZhbWlseTogJHtmb250cy5zYW5zfTtcbiAgcGFkZGluZzogMCA2cHg7XG4gIGhlaWdodDogMjVweDtcbiAgbWFyZ2luLXJpZ2h0OiA3cHg7XG5gO1xuXG5jb25zdCBDb21wZXRlbmNlQmFkZ2VUZXh0ID0gc3R5bGVkLnNwYW5gXG4gIHBhZGRpbmc6IDAgNXB4O1xuYDtcblxudHlwZSBDb21wZXRlbmNlQnV0dG9uV3JhcHBlclByb3BzID0ge1xuICBhZGRTcGFjZTogYm9vbGVhbiB8IHVuZGVmaW5lZDtcbn07XG5cbmNvbnN0IENvbXBldGVuY2VCdXR0b25XcmFwcGVyID0gc3R5bGVkLmRpdjxDb21wZXRlbmNlQnV0dG9uV3JhcHBlclByb3BzPmBcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgJHsocHJvcHMpID0+IHByb3BzLmFkZFNwYWNlICYmIGBwYWRkaW5nLWxlZnQ6IDEycHg7YH1cbmA7XG5cbnR5cGUgUHJvcHMgPSB7XG4gIGNvbXBldGVuY2VHb2Fscz86XG4gICAgfCAoKGlucDogeyBEaWFsb2c6IENvbXBvbmVudFR5cGU7IGRpYWxvZ1Byb3BzOiB7IGlzT3BlbjogYm9vbGVhbjsgb25DbG9zZTogKCkgPT4gdm9pZCB9IH0pID0+IFJlYWN0Tm9kZSlcbiAgICB8IFJlYWN0Tm9kZVxuICAgIHwgbnVsbDtcbiAgY29tcGV0ZW5jZUdvYWxUeXBlcz86IHN0cmluZ1tdO1xuICBjaGlsZHJlbjogUmVhY3ROb2RlO1xufTtcblxuaW50ZXJmYWNlIFN0YXRlIHtcbiAgaXNPcGVuOiBib29sZWFuO1xufVxuXG5jbGFzcyBBcnRpY2xlSGVhZGVyV3JhcHBlciBleHRlbmRzIENvbXBvbmVudDxQcm9wcyAmIFdpdGhUcmFuc2xhdGlvbiwgU3RhdGU+IHtcbiAgY29uc3RydWN0b3IocHJvcHM6IFByb3BzICYgV2l0aFRyYW5zbGF0aW9uKSB7XG4gICAgc3VwZXIocHJvcHMpO1xuICAgIHRoaXMuc3RhdGUgPSB7IGlzT3BlbjogZmFsc2UgfTtcbiAgICB0aGlzLmNsb3NlRGlhbG9nID0gdGhpcy5jbG9zZURpYWxvZy5iaW5kKHRoaXMpO1xuICAgIHRoaXMub3BlbkRpYWxvZyA9IHRoaXMub3BlbkRpYWxvZy5iaW5kKHRoaXMpO1xuICB9XG5cbiAgY29tcG9uZW50RGlkTW91bnQoKSB7XG4gICAgaWYgKGlzTW9iaWxlKSB7XG4gICAgICBjb25zdCBoZXJvQ29udGVudExpc3Q6IE5vZGVMaXN0T2Y8SFRNTEVsZW1lbnQ+ID0gZG9jdW1lbnQucXVlcnlTZWxlY3RvckFsbCgnLmMtYXJ0aWNsZV9faGVhZGVyJyk7XG4gICAgICBpZiAoaGVyb0NvbnRlbnRMaXN0Lmxlbmd0aCA9PT0gMSkge1xuICAgICAgICBoZXJvQ29udGVudExpc3RbMF0uc2Nyb2xsSW50b1ZpZXcodHJ1ZSk7XG4gICAgICAgIHdpbmRvdy5zY3JvbGxCeSgwLCBoZXJvQ29udGVudExpc3RbMF0ub2Zmc2V0VG9wIC0gMTIwKTsgLy8gQWRqdXN0IGZvciBoZWFkZXJcbiAgICAgIH1cbiAgICB9XG4gIH1cblxuICBvcGVuRGlhbG9nKCkge1xuICAgIHRoaXMuc2V0U3RhdGUoeyBpc09wZW46IHRydWUgfSk7XG4gIH1cblxuICBjbG9zZURpYWxvZygpIHtcbiAgICB0aGlzLnNldFN0YXRlKHsgaXNPcGVuOiBmYWxzZSB9KTtcbiAgfVxuXG4gIHJlbmRlcigpIHtcbiAgICBjb25zdCB7IGNoaWxkcmVuLCBjb21wZXRlbmNlR29hbHMsIGNvbXBldGVuY2VHb2FsVHlwZXMsIHQgfSA9IHRoaXMucHJvcHM7XG4gICAgaWYgKCFjb21wZXRlbmNlR29hbHMpIHtcbiAgICAgIHJldHVybiA8ZGl2IHsuLi5jbGFzc2VzKCdoZWFkZXInKX0+e2NoaWxkcmVufTwvZGl2PjtcbiAgICB9XG5cbiAgICBjb25zdCBkaWFsb2cgPVxuICAgICAgdHlwZW9mIGNvbXBldGVuY2VHb2FscyA9PT0gJ2Z1bmN0aW9uJyA/IChcbiAgICAgICAgY29tcGV0ZW5jZUdvYWxzKHtcbiAgICAgICAgICBEaWFsb2c6IENvbXBldGVuY2VHb2Fsc0RpYWxvZyxcbiAgICAgICAgICBkaWFsb2dQcm9wczoge1xuICAgICAgICAgICAgaXNPcGVuOiB0aGlzLnN0YXRlLmlzT3BlbixcbiAgICAgICAgICAgIG9uQ2xvc2U6IHRoaXMuY2xvc2VEaWFsb2csXG4gICAgICAgICAgfSxcbiAgICAgICAgfSlcbiAgICAgICkgOiAoXG4gICAgICAgIDxDb21wZXRlbmNlR29hbHNEaWFsb2cgb25DbG9zZT17dGhpcy5jbG9zZURpYWxvZ30gaXNPcGVuPXt0aGlzLnN0YXRlLmlzT3Blbn0+XG4gICAgICAgICAge2NvbXBldGVuY2VHb2Fsc31cbiAgICAgICAgPC9Db21wZXRlbmNlR29hbHNEaWFsb2c+XG4gICAgICApO1xuICAgIHJldHVybiAoXG4gICAgICA8ZGl2IHsuLi5jbGFzc2VzKCdoZWFkZXInKX0+XG4gICAgICAgIHtjaGlsZHJlbn1cbiAgICAgICAgPENvbXBldGVuY2VXcmFwcGVyPlxuICAgICAgICAgIHtjb21wZXRlbmNlR29hbFR5cGVzICYmXG4gICAgICAgICAgICBjb21wZXRlbmNlR29hbFR5cGVzLm1hcCgodHlwZSkgPT4gKFxuICAgICAgICAgICAgICA8Q29tcGV0ZW5jZUJhZGdlIGtleT17dHlwZX0+XG4gICAgICAgICAgICAgICAgPEZvb3RlckhlYWRlckljb24gLz5cbiAgICAgICAgICAgICAgICA8Q29tcGV0ZW5jZUJhZGdlVGV4dD57dHlwZX08L0NvbXBldGVuY2VCYWRnZVRleHQ+XG4gICAgICAgICAgICAgIDwvQ29tcGV0ZW5jZUJhZGdlPlxuICAgICAgICAgICAgKSl9XG4gICAgICAgICAgPENvbXBldGVuY2VCdXR0b25XcmFwcGVyIGFkZFNwYWNlPXtjb21wZXRlbmNlR29hbFR5cGVzICYmIGNvbXBldGVuY2VHb2FsVHlwZXMubGVuZ3RoID4gMH0+XG4gICAgICAgICAgICA8T3BlbkJ1dHRvbiBvbkNsaWNrPXt0aGlzLm9wZW5EaWFsb2d9PlxuICAgICAgICAgICAgICA8Rm9vdGVySGVhZGVySWNvbiAvPlxuICAgICAgICAgICAgICA8Q29tcGV0ZW5jZUJhZGdlVGV4dD57dCgnY29tcGV0ZW5jZUdvYWxzLnNob3dDb21wZXRlbmNlR29hbHMnKX08L0NvbXBldGVuY2VCYWRnZVRleHQ+XG4gICAgICAgICAgICA8L09wZW5CdXR0b24+XG4gICAgICAgICAgPC9Db21wZXRlbmNlQnV0dG9uV3JhcHBlcj5cbiAgICAgICAgPC9Db21wZXRlbmNlV3JhcHBlcj5cbiAgICAgICAge2RpYWxvZ31cbiAgICAgIDwvZGl2PlxuICAgICk7XG4gIH1cbn1cblxuZXhwb3J0IGRlZmF1bHQgd2l0aFRyYW5zbGF0aW9uKCkoQXJ0aWNsZUhlYWRlcldyYXBwZXIpO1xuIl19 */"));
91
91
  var CompetenceBadgeText = (0, _styledBase["default"])("span", {
92
92
  target: "e1daii1f2",
93
93
  label: "CompetenceBadgeText"
@@ -97,7 +97,7 @@ var CompetenceBadgeText = (0, _styledBase["default"])("span", {
97
97
  } : {
98
98
  name: "5030pi",
99
99
  styles: "padding:0 5px;",
100
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkFydGljbGVIZWFkZXJXcmFwcGVyLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF3RHVDIiwiZmlsZSI6IkFydGljbGVIZWFkZXJXcmFwcGVyLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE2LXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IFJlYWN0LCB7IENvbXBvbmVudCwgQ29tcG9uZW50VHlwZSwgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IEJFTUhlbHBlciBmcm9tICdyZWFjdC1iZW0taGVscGVyJztcbmltcG9ydCB7IHdpdGhUcmFuc2xhdGlvbiwgV2l0aFRyYW5zbGF0aW9uIH0gZnJvbSAncmVhY3QtaTE4bmV4dCc7XG5pbXBvcnQgQnV0dG9uIGZyb20gJ0BuZGxhL2J1dHRvbic7XG5pbXBvcnQgeyBpc01vYmlsZSB9IGZyb20gJ3JlYWN0LWRldmljZS1kZXRlY3QnO1xuaW1wb3J0IHsgZm9udHMsIGNvbG9ycyB9IGZyb20gJ0BuZGxhL2NvcmUnO1xuXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBGb290ZXJIZWFkZXJJY29uIH0gZnJvbSAnQG5kbGEvaWNvbnMvY29tbW9uJztcbi8vIEB0cy1pZ25vcmVcbmltcG9ydCBDb21wZXRlbmNlR29hbHNEaWFsb2cgZnJvbSAnLi4vQ29tcGV0ZW5jZUdvYWxzL0NvbXBldGVuY2VHb2Fsc0RpYWxvZyc7XG5cbmNvbnN0IGNsYXNzZXMgPSBuZXcgQkVNSGVscGVyKHtcbiAgbmFtZTogJ2FydGljbGUnLFxuICBwcmVmaXg6ICdjLScsXG59KTtcblxudHlwZSBPcGVuQnV0dG9uUHJvcHMgPSB7XG4gIG9uQ2xpY2s6ICgpID0+IHZvaWQ7XG4gIGNoaWxkcmVuOiBSZWFjdE5vZGU7XG59O1xuXG5leHBvcnQgY29uc3QgT3BlbkJ1dHRvbiA9ICh7IGNoaWxkcmVuLCBvbkNsaWNrIH06IE9wZW5CdXR0b25Qcm9wcykgPT4gKFxuICA8QnV0dG9uIHNpemU9XCJ4c21hbGxcIiBsaWdodGVyIGJvcmRlclNoYXBlPVwicm91bmRlZFwiIG9uQ2xpY2s9e29uQ2xpY2t9PlxuICAgIHtjaGlsZHJlbn1cbiAgPC9CdXR0b24+XG4pO1xuXG5jb25zdCBDb21wZXRlbmNlV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5gO1xuXG5jb25zdCBDb21wZXRlbmNlQmFkZ2UgPSBzdHlsZWQuc3BhbmBcbiAgZGlzcGxheTogaW5saW5lLWJsb2NrO1xuICBiYWNrZ3JvdW5kOiAke2NvbG9ycy5icmFuZC5ncmV5TGlnaHRlcn07XG4gIGJvcmRlci1yYWRpdXM6IDM2cHg7XG4gIGZvbnQtd2VpZ2h0OiAke2ZvbnRzLndlaWdodC5zZW1pYm9sZH07XG4gICR7Zm9udHMuc2l6ZXMoJzEycHgnLCAnMTVweCcpfTtcbiAgZGlzcGxheTogaW5saW5lLWZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGNvbG9yOiAke2NvbG9ycy50ZXh0LnByaW1hcnl9O1xuICBmb250LWZhbWlseTogJHtmb250cy5zYW5zfTtcbiAgcGFkZGluZzogMCA2cHg7XG4gIGhlaWdodDogMjVweDtcbiAgbWFyZ2luLXJpZ2h0OiA3cHg7XG5gO1xuXG5jb25zdCBDb21wZXRlbmNlQmFkZ2VUZXh0ID0gc3R5bGVkLnNwYW5gXG4gIHBhZGRpbmc6IDAgNXB4O1xuYDtcblxudHlwZSBDb21wZXRlbmNlQnV0dG9uV3JhcHBlclByb3BzID0ge1xuICBhZGRTcGFjZTogYm9vbGVhbiB8IHVuZGVmaW5lZDtcbn07XG5cbmNvbnN0IENvbXBldGVuY2VCdXR0b25XcmFwcGVyID0gc3R5bGVkLmRpdjxDb21wZXRlbmNlQnV0dG9uV3JhcHBlclByb3BzPmBcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgJHsocHJvcHMpID0+IHByb3BzLmFkZFNwYWNlICYmIGBwYWRkaW5nLWxlZnQ6IDEycHg7YH1cbmA7XG5cbnR5cGUgUHJvcHMgPSB7XG4gIGNvbXBldGVuY2VHb2Fscz86XG4gICAgfCAoKGlucDogeyBEaWFsb2c6IENvbXBvbmVudFR5cGU7IGRpYWxvZ1Byb3BzOiB7IGlzT3BlbjogYm9vbGVhbjsgb25DbG9zZTogKCkgPT4gdm9pZCB9IH0pID0+IFJlYWN0Tm9kZSlcbiAgICB8IG51bGw7XG4gIGNvbXBldGVuY2VHb2FsVHlwZXM/OiBzdHJpbmdbXTtcbiAgY2hpbGRyZW46IFJlYWN0Tm9kZTtcbn07XG5cbmludGVyZmFjZSBTdGF0ZSB7XG4gIGlzT3BlbjogYm9vbGVhbjtcbn1cblxuY2xhc3MgQXJ0aWNsZUhlYWRlcldyYXBwZXIgZXh0ZW5kcyBDb21wb25lbnQ8UHJvcHMgJiBXaXRoVHJhbnNsYXRpb24sIFN0YXRlPiB7XG4gIGNvbnN0cnVjdG9yKHByb3BzOiBQcm9wcyAmIFdpdGhUcmFuc2xhdGlvbikge1xuICAgIHN1cGVyKHByb3BzKTtcbiAgICB0aGlzLnN0YXRlID0geyBpc09wZW46IGZhbHNlIH07XG4gICAgdGhpcy5jbG9zZURpYWxvZyA9IHRoaXMuY2xvc2VEaWFsb2cuYmluZCh0aGlzKTtcbiAgICB0aGlzLm9wZW5EaWFsb2cgPSB0aGlzLm9wZW5EaWFsb2cuYmluZCh0aGlzKTtcbiAgfVxuXG4gIGNvbXBvbmVudERpZE1vdW50KCkge1xuICAgIGlmIChpc01vYmlsZSkge1xuICAgICAgY29uc3QgaGVyb0NvbnRlbnRMaXN0OiBOb2RlTGlzdE9mPEhUTUxFbGVtZW50PiA9IGRvY3VtZW50LnF1ZXJ5U2VsZWN0b3JBbGwoJy5jLWFydGljbGVfX2hlYWRlcicpO1xuICAgICAgaWYgKGhlcm9Db250ZW50TGlzdC5sZW5ndGggPT09IDEpIHtcbiAgICAgICAgaGVyb0NvbnRlbnRMaXN0WzBdLnNjcm9sbEludG9WaWV3KHRydWUpO1xuICAgICAgICB3aW5kb3cuc2Nyb2xsQnkoMCwgaGVyb0NvbnRlbnRMaXN0WzBdLm9mZnNldFRvcCAtIDEyMCk7IC8vIEFkanVzdCBmb3IgaGVhZGVyXG4gICAgICB9XG4gICAgfVxuICB9XG5cbiAgb3BlbkRpYWxvZygpIHtcbiAgICB0aGlzLnNldFN0YXRlKHsgaXNPcGVuOiB0cnVlIH0pO1xuICB9XG5cbiAgY2xvc2VEaWFsb2coKSB7XG4gICAgdGhpcy5zZXRTdGF0ZSh7IGlzT3BlbjogZmFsc2UgfSk7XG4gIH1cblxuICByZW5kZXIoKSB7XG4gICAgY29uc3QgeyBjaGlsZHJlbiwgY29tcGV0ZW5jZUdvYWxzLCBjb21wZXRlbmNlR29hbFR5cGVzLCB0IH0gPSB0aGlzLnByb3BzO1xuICAgIGlmICghY29tcGV0ZW5jZUdvYWxzKSB7XG4gICAgICByZXR1cm4gPGRpdiB7Li4uY2xhc3NlcygnaGVhZGVyJyl9PntjaGlsZHJlbn08L2Rpdj47XG4gICAgfVxuXG4gICAgY29uc3QgZGlhbG9nID1cbiAgICAgIHR5cGVvZiBjb21wZXRlbmNlR29hbHMgPT09ICdmdW5jdGlvbicgPyAoXG4gICAgICAgIGNvbXBldGVuY2VHb2Fscyh7XG4gICAgICAgICAgRGlhbG9nOiBDb21wZXRlbmNlR29hbHNEaWFsb2csXG4gICAgICAgICAgZGlhbG9nUHJvcHM6IHtcbiAgICAgICAgICAgIGlzT3BlbjogdGhpcy5zdGF0ZS5pc09wZW4sXG4gICAgICAgICAgICBvbkNsb3NlOiB0aGlzLmNsb3NlRGlhbG9nLFxuICAgICAgICAgIH0sXG4gICAgICAgIH0pXG4gICAgICApIDogKFxuICAgICAgICA8Q29tcGV0ZW5jZUdvYWxzRGlhbG9nIG9uQ2xvc2U9e3RoaXMuY2xvc2VEaWFsb2d9IGlzT3Blbj17dGhpcy5zdGF0ZS5pc09wZW59PlxuICAgICAgICAgIHtjb21wZXRlbmNlR29hbHN9XG4gICAgICAgIDwvQ29tcGV0ZW5jZUdvYWxzRGlhbG9nPlxuICAgICAgKTtcbiAgICByZXR1cm4gKFxuICAgICAgPGRpdiB7Li4uY2xhc3NlcygnaGVhZGVyJyl9PlxuICAgICAgICB7Y2hpbGRyZW59XG4gICAgICAgIDxDb21wZXRlbmNlV3JhcHBlcj5cbiAgICAgICAgICB7Y29tcGV0ZW5jZUdvYWxUeXBlcyAmJlxuICAgICAgICAgICAgY29tcGV0ZW5jZUdvYWxUeXBlcy5tYXAoKHR5cGUpID0+IChcbiAgICAgICAgICAgICAgPENvbXBldGVuY2VCYWRnZSBrZXk9e3R5cGV9PlxuICAgICAgICAgICAgICAgIDxGb290ZXJIZWFkZXJJY29uIC8+XG4gICAgICAgICAgICAgICAgPENvbXBldGVuY2VCYWRnZVRleHQ+e3R5cGV9PC9Db21wZXRlbmNlQmFkZ2VUZXh0PlxuICAgICAgICAgICAgICA8L0NvbXBldGVuY2VCYWRnZT5cbiAgICAgICAgICAgICkpfVxuICAgICAgICAgIDxDb21wZXRlbmNlQnV0dG9uV3JhcHBlciBhZGRTcGFjZT17Y29tcGV0ZW5jZUdvYWxUeXBlcyAmJiBjb21wZXRlbmNlR29hbFR5cGVzLmxlbmd0aCA+IDB9PlxuICAgICAgICAgICAgPE9wZW5CdXR0b24gb25DbGljaz17dGhpcy5vcGVuRGlhbG9nfT5cbiAgICAgICAgICAgICAgPEZvb3RlckhlYWRlckljb24gLz5cbiAgICAgICAgICAgICAgPENvbXBldGVuY2VCYWRnZVRleHQ+e3QoJ2NvbXBldGVuY2VHb2Fscy5zaG93Q29tcGV0ZW5jZUdvYWxzJyl9PC9Db21wZXRlbmNlQmFkZ2VUZXh0PlxuICAgICAgICAgICAgPC9PcGVuQnV0dG9uPlxuICAgICAgICAgIDwvQ29tcGV0ZW5jZUJ1dHRvbldyYXBwZXI+XG4gICAgICAgIDwvQ29tcGV0ZW5jZVdyYXBwZXI+XG4gICAgICAgIHtkaWFsb2d9XG4gICAgICA8L2Rpdj5cbiAgICApO1xuICB9XG59XG5cbmV4cG9ydCBkZWZhdWx0IHdpdGhUcmFuc2xhdGlvbigpKEFydGljbGVIZWFkZXJXcmFwcGVyKTtcbiJdfQ== */",
100
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkFydGljbGVIZWFkZXJXcmFwcGVyLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF3RHVDIiwiZmlsZSI6IkFydGljbGVIZWFkZXJXcmFwcGVyLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE2LXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IFJlYWN0LCB7IENvbXBvbmVudCwgQ29tcG9uZW50VHlwZSwgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IEJFTUhlbHBlciBmcm9tICdyZWFjdC1iZW0taGVscGVyJztcbmltcG9ydCB7IHdpdGhUcmFuc2xhdGlvbiwgV2l0aFRyYW5zbGF0aW9uIH0gZnJvbSAncmVhY3QtaTE4bmV4dCc7XG5pbXBvcnQgQnV0dG9uIGZyb20gJ0BuZGxhL2J1dHRvbic7XG5pbXBvcnQgeyBpc01vYmlsZSB9IGZyb20gJ3JlYWN0LWRldmljZS1kZXRlY3QnO1xuaW1wb3J0IHsgZm9udHMsIGNvbG9ycyB9IGZyb20gJ0BuZGxhL2NvcmUnO1xuXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBGb290ZXJIZWFkZXJJY29uIH0gZnJvbSAnQG5kbGEvaWNvbnMvY29tbW9uJztcbi8vIEB0cy1pZ25vcmVcbmltcG9ydCBDb21wZXRlbmNlR29hbHNEaWFsb2cgZnJvbSAnLi4vQ29tcGV0ZW5jZUdvYWxzL0NvbXBldGVuY2VHb2Fsc0RpYWxvZyc7XG5cbmNvbnN0IGNsYXNzZXMgPSBuZXcgQkVNSGVscGVyKHtcbiAgbmFtZTogJ2FydGljbGUnLFxuICBwcmVmaXg6ICdjLScsXG59KTtcblxudHlwZSBPcGVuQnV0dG9uUHJvcHMgPSB7XG4gIG9uQ2xpY2s6ICgpID0+IHZvaWQ7XG4gIGNoaWxkcmVuOiBSZWFjdE5vZGU7XG59O1xuXG5leHBvcnQgY29uc3QgT3BlbkJ1dHRvbiA9ICh7IGNoaWxkcmVuLCBvbkNsaWNrIH06IE9wZW5CdXR0b25Qcm9wcykgPT4gKFxuICA8QnV0dG9uIHNpemU9XCJ4c21hbGxcIiBsaWdodGVyIGJvcmRlclNoYXBlPVwicm91bmRlZFwiIG9uQ2xpY2s9e29uQ2xpY2t9PlxuICAgIHtjaGlsZHJlbn1cbiAgPC9CdXR0b24+XG4pO1xuXG5jb25zdCBDb21wZXRlbmNlV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5gO1xuXG5jb25zdCBDb21wZXRlbmNlQmFkZ2UgPSBzdHlsZWQuc3BhbmBcbiAgZGlzcGxheTogaW5saW5lLWJsb2NrO1xuICBiYWNrZ3JvdW5kOiAke2NvbG9ycy5icmFuZC5ncmV5TGlnaHRlcn07XG4gIGJvcmRlci1yYWRpdXM6IDM2cHg7XG4gIGZvbnQtd2VpZ2h0OiAke2ZvbnRzLndlaWdodC5zZW1pYm9sZH07XG4gICR7Zm9udHMuc2l6ZXMoJzEycHgnLCAnMTVweCcpfTtcbiAgZGlzcGxheTogaW5saW5lLWZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGNvbG9yOiAke2NvbG9ycy50ZXh0LnByaW1hcnl9O1xuICBmb250LWZhbWlseTogJHtmb250cy5zYW5zfTtcbiAgcGFkZGluZzogMCA2cHg7XG4gIGhlaWdodDogMjVweDtcbiAgbWFyZ2luLXJpZ2h0OiA3cHg7XG5gO1xuXG5jb25zdCBDb21wZXRlbmNlQmFkZ2VUZXh0ID0gc3R5bGVkLnNwYW5gXG4gIHBhZGRpbmc6IDAgNXB4O1xuYDtcblxudHlwZSBDb21wZXRlbmNlQnV0dG9uV3JhcHBlclByb3BzID0ge1xuICBhZGRTcGFjZTogYm9vbGVhbiB8IHVuZGVmaW5lZDtcbn07XG5cbmNvbnN0IENvbXBldGVuY2VCdXR0b25XcmFwcGVyID0gc3R5bGVkLmRpdjxDb21wZXRlbmNlQnV0dG9uV3JhcHBlclByb3BzPmBcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgJHsocHJvcHMpID0+IHByb3BzLmFkZFNwYWNlICYmIGBwYWRkaW5nLWxlZnQ6IDEycHg7YH1cbmA7XG5cbnR5cGUgUHJvcHMgPSB7XG4gIGNvbXBldGVuY2VHb2Fscz86XG4gICAgfCAoKGlucDogeyBEaWFsb2c6IENvbXBvbmVudFR5cGU7IGRpYWxvZ1Byb3BzOiB7IGlzT3BlbjogYm9vbGVhbjsgb25DbG9zZTogKCkgPT4gdm9pZCB9IH0pID0+IFJlYWN0Tm9kZSlcbiAgICB8IFJlYWN0Tm9kZVxuICAgIHwgbnVsbDtcbiAgY29tcGV0ZW5jZUdvYWxUeXBlcz86IHN0cmluZ1tdO1xuICBjaGlsZHJlbjogUmVhY3ROb2RlO1xufTtcblxuaW50ZXJmYWNlIFN0YXRlIHtcbiAgaXNPcGVuOiBib29sZWFuO1xufVxuXG5jbGFzcyBBcnRpY2xlSGVhZGVyV3JhcHBlciBleHRlbmRzIENvbXBvbmVudDxQcm9wcyAmIFdpdGhUcmFuc2xhdGlvbiwgU3RhdGU+IHtcbiAgY29uc3RydWN0b3IocHJvcHM6IFByb3BzICYgV2l0aFRyYW5zbGF0aW9uKSB7XG4gICAgc3VwZXIocHJvcHMpO1xuICAgIHRoaXMuc3RhdGUgPSB7IGlzT3BlbjogZmFsc2UgfTtcbiAgICB0aGlzLmNsb3NlRGlhbG9nID0gdGhpcy5jbG9zZURpYWxvZy5iaW5kKHRoaXMpO1xuICAgIHRoaXMub3BlbkRpYWxvZyA9IHRoaXMub3BlbkRpYWxvZy5iaW5kKHRoaXMpO1xuICB9XG5cbiAgY29tcG9uZW50RGlkTW91bnQoKSB7XG4gICAgaWYgKGlzTW9iaWxlKSB7XG4gICAgICBjb25zdCBoZXJvQ29udGVudExpc3Q6IE5vZGVMaXN0T2Y8SFRNTEVsZW1lbnQ+ID0gZG9jdW1lbnQucXVlcnlTZWxlY3RvckFsbCgnLmMtYXJ0aWNsZV9faGVhZGVyJyk7XG4gICAgICBpZiAoaGVyb0NvbnRlbnRMaXN0Lmxlbmd0aCA9PT0gMSkge1xuICAgICAgICBoZXJvQ29udGVudExpc3RbMF0uc2Nyb2xsSW50b1ZpZXcodHJ1ZSk7XG4gICAgICAgIHdpbmRvdy5zY3JvbGxCeSgwLCBoZXJvQ29udGVudExpc3RbMF0ub2Zmc2V0VG9wIC0gMTIwKTsgLy8gQWRqdXN0IGZvciBoZWFkZXJcbiAgICAgIH1cbiAgICB9XG4gIH1cblxuICBvcGVuRGlhbG9nKCkge1xuICAgIHRoaXMuc2V0U3RhdGUoeyBpc09wZW46IHRydWUgfSk7XG4gIH1cblxuICBjbG9zZURpYWxvZygpIHtcbiAgICB0aGlzLnNldFN0YXRlKHsgaXNPcGVuOiBmYWxzZSB9KTtcbiAgfVxuXG4gIHJlbmRlcigpIHtcbiAgICBjb25zdCB7IGNoaWxkcmVuLCBjb21wZXRlbmNlR29hbHMsIGNvbXBldGVuY2VHb2FsVHlwZXMsIHQgfSA9IHRoaXMucHJvcHM7XG4gICAgaWYgKCFjb21wZXRlbmNlR29hbHMpIHtcbiAgICAgIHJldHVybiA8ZGl2IHsuLi5jbGFzc2VzKCdoZWFkZXInKX0+e2NoaWxkcmVufTwvZGl2PjtcbiAgICB9XG5cbiAgICBjb25zdCBkaWFsb2cgPVxuICAgICAgdHlwZW9mIGNvbXBldGVuY2VHb2FscyA9PT0gJ2Z1bmN0aW9uJyA/IChcbiAgICAgICAgY29tcGV0ZW5jZUdvYWxzKHtcbiAgICAgICAgICBEaWFsb2c6IENvbXBldGVuY2VHb2Fsc0RpYWxvZyxcbiAgICAgICAgICBkaWFsb2dQcm9wczoge1xuICAgICAgICAgICAgaXNPcGVuOiB0aGlzLnN0YXRlLmlzT3BlbixcbiAgICAgICAgICAgIG9uQ2xvc2U6IHRoaXMuY2xvc2VEaWFsb2csXG4gICAgICAgICAgfSxcbiAgICAgICAgfSlcbiAgICAgICkgOiAoXG4gICAgICAgIDxDb21wZXRlbmNlR29hbHNEaWFsb2cgb25DbG9zZT17dGhpcy5jbG9zZURpYWxvZ30gaXNPcGVuPXt0aGlzLnN0YXRlLmlzT3Blbn0+XG4gICAgICAgICAge2NvbXBldGVuY2VHb2Fsc31cbiAgICAgICAgPC9Db21wZXRlbmNlR29hbHNEaWFsb2c+XG4gICAgICApO1xuICAgIHJldHVybiAoXG4gICAgICA8ZGl2IHsuLi5jbGFzc2VzKCdoZWFkZXInKX0+XG4gICAgICAgIHtjaGlsZHJlbn1cbiAgICAgICAgPENvbXBldGVuY2VXcmFwcGVyPlxuICAgICAgICAgIHtjb21wZXRlbmNlR29hbFR5cGVzICYmXG4gICAgICAgICAgICBjb21wZXRlbmNlR29hbFR5cGVzLm1hcCgodHlwZSkgPT4gKFxuICAgICAgICAgICAgICA8Q29tcGV0ZW5jZUJhZGdlIGtleT17dHlwZX0+XG4gICAgICAgICAgICAgICAgPEZvb3RlckhlYWRlckljb24gLz5cbiAgICAgICAgICAgICAgICA8Q29tcGV0ZW5jZUJhZGdlVGV4dD57dHlwZX08L0NvbXBldGVuY2VCYWRnZVRleHQ+XG4gICAgICAgICAgICAgIDwvQ29tcGV0ZW5jZUJhZGdlPlxuICAgICAgICAgICAgKSl9XG4gICAgICAgICAgPENvbXBldGVuY2VCdXR0b25XcmFwcGVyIGFkZFNwYWNlPXtjb21wZXRlbmNlR29hbFR5cGVzICYmIGNvbXBldGVuY2VHb2FsVHlwZXMubGVuZ3RoID4gMH0+XG4gICAgICAgICAgICA8T3BlbkJ1dHRvbiBvbkNsaWNrPXt0aGlzLm9wZW5EaWFsb2d9PlxuICAgICAgICAgICAgICA8Rm9vdGVySGVhZGVySWNvbiAvPlxuICAgICAgICAgICAgICA8Q29tcGV0ZW5jZUJhZGdlVGV4dD57dCgnY29tcGV0ZW5jZUdvYWxzLnNob3dDb21wZXRlbmNlR29hbHMnKX08L0NvbXBldGVuY2VCYWRnZVRleHQ+XG4gICAgICAgICAgICA8L09wZW5CdXR0b24+XG4gICAgICAgICAgPC9Db21wZXRlbmNlQnV0dG9uV3JhcHBlcj5cbiAgICAgICAgPC9Db21wZXRlbmNlV3JhcHBlcj5cbiAgICAgICAge2RpYWxvZ31cbiAgICAgIDwvZGl2PlxuICAgICk7XG4gIH1cbn1cblxuZXhwb3J0IGRlZmF1bHQgd2l0aFRyYW5zbGF0aW9uKCkoQXJ0aWNsZUhlYWRlcldyYXBwZXIpO1xuIl19 */",
101
101
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
102
102
  });
103
103
  var CompetenceButtonWrapper = (0, _styledBase["default"])("div", {
@@ -105,7 +105,7 @@ var CompetenceButtonWrapper = (0, _styledBase["default"])("div", {
105
105
  label: "CompetenceButtonWrapper"
106
106
  })("display:flex;align-items:center;", function (props) {
107
107
  return props.addSpace && "padding-left: 12px;";
108
- }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkFydGljbGVIZWFkZXJXcmFwcGVyLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFnRXdFIiwiZmlsZSI6IkFydGljbGVIZWFkZXJXcmFwcGVyLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE2LXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IFJlYWN0LCB7IENvbXBvbmVudCwgQ29tcG9uZW50VHlwZSwgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IEJFTUhlbHBlciBmcm9tICdyZWFjdC1iZW0taGVscGVyJztcbmltcG9ydCB7IHdpdGhUcmFuc2xhdGlvbiwgV2l0aFRyYW5zbGF0aW9uIH0gZnJvbSAncmVhY3QtaTE4bmV4dCc7XG5pbXBvcnQgQnV0dG9uIGZyb20gJ0BuZGxhL2J1dHRvbic7XG5pbXBvcnQgeyBpc01vYmlsZSB9IGZyb20gJ3JlYWN0LWRldmljZS1kZXRlY3QnO1xuaW1wb3J0IHsgZm9udHMsIGNvbG9ycyB9IGZyb20gJ0BuZGxhL2NvcmUnO1xuXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBGb290ZXJIZWFkZXJJY29uIH0gZnJvbSAnQG5kbGEvaWNvbnMvY29tbW9uJztcbi8vIEB0cy1pZ25vcmVcbmltcG9ydCBDb21wZXRlbmNlR29hbHNEaWFsb2cgZnJvbSAnLi4vQ29tcGV0ZW5jZUdvYWxzL0NvbXBldGVuY2VHb2Fsc0RpYWxvZyc7XG5cbmNvbnN0IGNsYXNzZXMgPSBuZXcgQkVNSGVscGVyKHtcbiAgbmFtZTogJ2FydGljbGUnLFxuICBwcmVmaXg6ICdjLScsXG59KTtcblxudHlwZSBPcGVuQnV0dG9uUHJvcHMgPSB7XG4gIG9uQ2xpY2s6ICgpID0+IHZvaWQ7XG4gIGNoaWxkcmVuOiBSZWFjdE5vZGU7XG59O1xuXG5leHBvcnQgY29uc3QgT3BlbkJ1dHRvbiA9ICh7IGNoaWxkcmVuLCBvbkNsaWNrIH06IE9wZW5CdXR0b25Qcm9wcykgPT4gKFxuICA8QnV0dG9uIHNpemU9XCJ4c21hbGxcIiBsaWdodGVyIGJvcmRlclNoYXBlPVwicm91bmRlZFwiIG9uQ2xpY2s9e29uQ2xpY2t9PlxuICAgIHtjaGlsZHJlbn1cbiAgPC9CdXR0b24+XG4pO1xuXG5jb25zdCBDb21wZXRlbmNlV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5gO1xuXG5jb25zdCBDb21wZXRlbmNlQmFkZ2UgPSBzdHlsZWQuc3BhbmBcbiAgZGlzcGxheTogaW5saW5lLWJsb2NrO1xuICBiYWNrZ3JvdW5kOiAke2NvbG9ycy5icmFuZC5ncmV5TGlnaHRlcn07XG4gIGJvcmRlci1yYWRpdXM6IDM2cHg7XG4gIGZvbnQtd2VpZ2h0OiAke2ZvbnRzLndlaWdodC5zZW1pYm9sZH07XG4gICR7Zm9udHMuc2l6ZXMoJzEycHgnLCAnMTVweCcpfTtcbiAgZGlzcGxheTogaW5saW5lLWZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGNvbG9yOiAke2NvbG9ycy50ZXh0LnByaW1hcnl9O1xuICBmb250LWZhbWlseTogJHtmb250cy5zYW5zfTtcbiAgcGFkZGluZzogMCA2cHg7XG4gIGhlaWdodDogMjVweDtcbiAgbWFyZ2luLXJpZ2h0OiA3cHg7XG5gO1xuXG5jb25zdCBDb21wZXRlbmNlQmFkZ2VUZXh0ID0gc3R5bGVkLnNwYW5gXG4gIHBhZGRpbmc6IDAgNXB4O1xuYDtcblxudHlwZSBDb21wZXRlbmNlQnV0dG9uV3JhcHBlclByb3BzID0ge1xuICBhZGRTcGFjZTogYm9vbGVhbiB8IHVuZGVmaW5lZDtcbn07XG5cbmNvbnN0IENvbXBldGVuY2VCdXR0b25XcmFwcGVyID0gc3R5bGVkLmRpdjxDb21wZXRlbmNlQnV0dG9uV3JhcHBlclByb3BzPmBcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgJHsocHJvcHMpID0+IHByb3BzLmFkZFNwYWNlICYmIGBwYWRkaW5nLWxlZnQ6IDEycHg7YH1cbmA7XG5cbnR5cGUgUHJvcHMgPSB7XG4gIGNvbXBldGVuY2VHb2Fscz86XG4gICAgfCAoKGlucDogeyBEaWFsb2c6IENvbXBvbmVudFR5cGU7IGRpYWxvZ1Byb3BzOiB7IGlzT3BlbjogYm9vbGVhbjsgb25DbG9zZTogKCkgPT4gdm9pZCB9IH0pID0+IFJlYWN0Tm9kZSlcbiAgICB8IG51bGw7XG4gIGNvbXBldGVuY2VHb2FsVHlwZXM/OiBzdHJpbmdbXTtcbiAgY2hpbGRyZW46IFJlYWN0Tm9kZTtcbn07XG5cbmludGVyZmFjZSBTdGF0ZSB7XG4gIGlzT3BlbjogYm9vbGVhbjtcbn1cblxuY2xhc3MgQXJ0aWNsZUhlYWRlcldyYXBwZXIgZXh0ZW5kcyBDb21wb25lbnQ8UHJvcHMgJiBXaXRoVHJhbnNsYXRpb24sIFN0YXRlPiB7XG4gIGNvbnN0cnVjdG9yKHByb3BzOiBQcm9wcyAmIFdpdGhUcmFuc2xhdGlvbikge1xuICAgIHN1cGVyKHByb3BzKTtcbiAgICB0aGlzLnN0YXRlID0geyBpc09wZW46IGZhbHNlIH07XG4gICAgdGhpcy5jbG9zZURpYWxvZyA9IHRoaXMuY2xvc2VEaWFsb2cuYmluZCh0aGlzKTtcbiAgICB0aGlzLm9wZW5EaWFsb2cgPSB0aGlzLm9wZW5EaWFsb2cuYmluZCh0aGlzKTtcbiAgfVxuXG4gIGNvbXBvbmVudERpZE1vdW50KCkge1xuICAgIGlmIChpc01vYmlsZSkge1xuICAgICAgY29uc3QgaGVyb0NvbnRlbnRMaXN0OiBOb2RlTGlzdE9mPEhUTUxFbGVtZW50PiA9IGRvY3VtZW50LnF1ZXJ5U2VsZWN0b3JBbGwoJy5jLWFydGljbGVfX2hlYWRlcicpO1xuICAgICAgaWYgKGhlcm9Db250ZW50TGlzdC5sZW5ndGggPT09IDEpIHtcbiAgICAgICAgaGVyb0NvbnRlbnRMaXN0WzBdLnNjcm9sbEludG9WaWV3KHRydWUpO1xuICAgICAgICB3aW5kb3cuc2Nyb2xsQnkoMCwgaGVyb0NvbnRlbnRMaXN0WzBdLm9mZnNldFRvcCAtIDEyMCk7IC8vIEFkanVzdCBmb3IgaGVhZGVyXG4gICAgICB9XG4gICAgfVxuICB9XG5cbiAgb3BlbkRpYWxvZygpIHtcbiAgICB0aGlzLnNldFN0YXRlKHsgaXNPcGVuOiB0cnVlIH0pO1xuICB9XG5cbiAgY2xvc2VEaWFsb2coKSB7XG4gICAgdGhpcy5zZXRTdGF0ZSh7IGlzT3BlbjogZmFsc2UgfSk7XG4gIH1cblxuICByZW5kZXIoKSB7XG4gICAgY29uc3QgeyBjaGlsZHJlbiwgY29tcGV0ZW5jZUdvYWxzLCBjb21wZXRlbmNlR29hbFR5cGVzLCB0IH0gPSB0aGlzLnByb3BzO1xuICAgIGlmICghY29tcGV0ZW5jZUdvYWxzKSB7XG4gICAgICByZXR1cm4gPGRpdiB7Li4uY2xhc3NlcygnaGVhZGVyJyl9PntjaGlsZHJlbn08L2Rpdj47XG4gICAgfVxuXG4gICAgY29uc3QgZGlhbG9nID1cbiAgICAgIHR5cGVvZiBjb21wZXRlbmNlR29hbHMgPT09ICdmdW5jdGlvbicgPyAoXG4gICAgICAgIGNvbXBldGVuY2VHb2Fscyh7XG4gICAgICAgICAgRGlhbG9nOiBDb21wZXRlbmNlR29hbHNEaWFsb2csXG4gICAgICAgICAgZGlhbG9nUHJvcHM6IHtcbiAgICAgICAgICAgIGlzT3BlbjogdGhpcy5zdGF0ZS5pc09wZW4sXG4gICAgICAgICAgICBvbkNsb3NlOiB0aGlzLmNsb3NlRGlhbG9nLFxuICAgICAgICAgIH0sXG4gICAgICAgIH0pXG4gICAgICApIDogKFxuICAgICAgICA8Q29tcGV0ZW5jZUdvYWxzRGlhbG9nIG9uQ2xvc2U9e3RoaXMuY2xvc2VEaWFsb2d9IGlzT3Blbj17dGhpcy5zdGF0ZS5pc09wZW59PlxuICAgICAgICAgIHtjb21wZXRlbmNlR29hbHN9XG4gICAgICAgIDwvQ29tcGV0ZW5jZUdvYWxzRGlhbG9nPlxuICAgICAgKTtcbiAgICByZXR1cm4gKFxuICAgICAgPGRpdiB7Li4uY2xhc3NlcygnaGVhZGVyJyl9PlxuICAgICAgICB7Y2hpbGRyZW59XG4gICAgICAgIDxDb21wZXRlbmNlV3JhcHBlcj5cbiAgICAgICAgICB7Y29tcGV0ZW5jZUdvYWxUeXBlcyAmJlxuICAgICAgICAgICAgY29tcGV0ZW5jZUdvYWxUeXBlcy5tYXAoKHR5cGUpID0+IChcbiAgICAgICAgICAgICAgPENvbXBldGVuY2VCYWRnZSBrZXk9e3R5cGV9PlxuICAgICAgICAgICAgICAgIDxGb290ZXJIZWFkZXJJY29uIC8+XG4gICAgICAgICAgICAgICAgPENvbXBldGVuY2VCYWRnZVRleHQ+e3R5cGV9PC9Db21wZXRlbmNlQmFkZ2VUZXh0PlxuICAgICAgICAgICAgICA8L0NvbXBldGVuY2VCYWRnZT5cbiAgICAgICAgICAgICkpfVxuICAgICAgICAgIDxDb21wZXRlbmNlQnV0dG9uV3JhcHBlciBhZGRTcGFjZT17Y29tcGV0ZW5jZUdvYWxUeXBlcyAmJiBjb21wZXRlbmNlR29hbFR5cGVzLmxlbmd0aCA+IDB9PlxuICAgICAgICAgICAgPE9wZW5CdXR0b24gb25DbGljaz17dGhpcy5vcGVuRGlhbG9nfT5cbiAgICAgICAgICAgICAgPEZvb3RlckhlYWRlckljb24gLz5cbiAgICAgICAgICAgICAgPENvbXBldGVuY2VCYWRnZVRleHQ+e3QoJ2NvbXBldGVuY2VHb2Fscy5zaG93Q29tcGV0ZW5jZUdvYWxzJyl9PC9Db21wZXRlbmNlQmFkZ2VUZXh0PlxuICAgICAgICAgICAgPC9PcGVuQnV0dG9uPlxuICAgICAgICAgIDwvQ29tcGV0ZW5jZUJ1dHRvbldyYXBwZXI+XG4gICAgICAgIDwvQ29tcGV0ZW5jZVdyYXBwZXI+XG4gICAgICAgIHtkaWFsb2d9XG4gICAgICA8L2Rpdj5cbiAgICApO1xuICB9XG59XG5cbmV4cG9ydCBkZWZhdWx0IHdpdGhUcmFuc2xhdGlvbigpKEFydGljbGVIZWFkZXJXcmFwcGVyKTtcbiJdfQ== */");
108
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkFydGljbGVIZWFkZXJXcmFwcGVyLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFnRXdFIiwiZmlsZSI6IkFydGljbGVIZWFkZXJXcmFwcGVyLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE2LXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IFJlYWN0LCB7IENvbXBvbmVudCwgQ29tcG9uZW50VHlwZSwgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IEJFTUhlbHBlciBmcm9tICdyZWFjdC1iZW0taGVscGVyJztcbmltcG9ydCB7IHdpdGhUcmFuc2xhdGlvbiwgV2l0aFRyYW5zbGF0aW9uIH0gZnJvbSAncmVhY3QtaTE4bmV4dCc7XG5pbXBvcnQgQnV0dG9uIGZyb20gJ0BuZGxhL2J1dHRvbic7XG5pbXBvcnQgeyBpc01vYmlsZSB9IGZyb20gJ3JlYWN0LWRldmljZS1kZXRlY3QnO1xuaW1wb3J0IHsgZm9udHMsIGNvbG9ycyB9IGZyb20gJ0BuZGxhL2NvcmUnO1xuXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBGb290ZXJIZWFkZXJJY29uIH0gZnJvbSAnQG5kbGEvaWNvbnMvY29tbW9uJztcbi8vIEB0cy1pZ25vcmVcbmltcG9ydCBDb21wZXRlbmNlR29hbHNEaWFsb2cgZnJvbSAnLi4vQ29tcGV0ZW5jZUdvYWxzL0NvbXBldGVuY2VHb2Fsc0RpYWxvZyc7XG5cbmNvbnN0IGNsYXNzZXMgPSBuZXcgQkVNSGVscGVyKHtcbiAgbmFtZTogJ2FydGljbGUnLFxuICBwcmVmaXg6ICdjLScsXG59KTtcblxudHlwZSBPcGVuQnV0dG9uUHJvcHMgPSB7XG4gIG9uQ2xpY2s6ICgpID0+IHZvaWQ7XG4gIGNoaWxkcmVuOiBSZWFjdE5vZGU7XG59O1xuXG5leHBvcnQgY29uc3QgT3BlbkJ1dHRvbiA9ICh7IGNoaWxkcmVuLCBvbkNsaWNrIH06IE9wZW5CdXR0b25Qcm9wcykgPT4gKFxuICA8QnV0dG9uIHNpemU9XCJ4c21hbGxcIiBsaWdodGVyIGJvcmRlclNoYXBlPVwicm91bmRlZFwiIG9uQ2xpY2s9e29uQ2xpY2t9PlxuICAgIHtjaGlsZHJlbn1cbiAgPC9CdXR0b24+XG4pO1xuXG5jb25zdCBDb21wZXRlbmNlV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5gO1xuXG5jb25zdCBDb21wZXRlbmNlQmFkZ2UgPSBzdHlsZWQuc3BhbmBcbiAgZGlzcGxheTogaW5saW5lLWJsb2NrO1xuICBiYWNrZ3JvdW5kOiAke2NvbG9ycy5icmFuZC5ncmV5TGlnaHRlcn07XG4gIGJvcmRlci1yYWRpdXM6IDM2cHg7XG4gIGZvbnQtd2VpZ2h0OiAke2ZvbnRzLndlaWdodC5zZW1pYm9sZH07XG4gICR7Zm9udHMuc2l6ZXMoJzEycHgnLCAnMTVweCcpfTtcbiAgZGlzcGxheTogaW5saW5lLWZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGNvbG9yOiAke2NvbG9ycy50ZXh0LnByaW1hcnl9O1xuICBmb250LWZhbWlseTogJHtmb250cy5zYW5zfTtcbiAgcGFkZGluZzogMCA2cHg7XG4gIGhlaWdodDogMjVweDtcbiAgbWFyZ2luLXJpZ2h0OiA3cHg7XG5gO1xuXG5jb25zdCBDb21wZXRlbmNlQmFkZ2VUZXh0ID0gc3R5bGVkLnNwYW5gXG4gIHBhZGRpbmc6IDAgNXB4O1xuYDtcblxudHlwZSBDb21wZXRlbmNlQnV0dG9uV3JhcHBlclByb3BzID0ge1xuICBhZGRTcGFjZTogYm9vbGVhbiB8IHVuZGVmaW5lZDtcbn07XG5cbmNvbnN0IENvbXBldGVuY2VCdXR0b25XcmFwcGVyID0gc3R5bGVkLmRpdjxDb21wZXRlbmNlQnV0dG9uV3JhcHBlclByb3BzPmBcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgJHsocHJvcHMpID0+IHByb3BzLmFkZFNwYWNlICYmIGBwYWRkaW5nLWxlZnQ6IDEycHg7YH1cbmA7XG5cbnR5cGUgUHJvcHMgPSB7XG4gIGNvbXBldGVuY2VHb2Fscz86XG4gICAgfCAoKGlucDogeyBEaWFsb2c6IENvbXBvbmVudFR5cGU7IGRpYWxvZ1Byb3BzOiB7IGlzT3BlbjogYm9vbGVhbjsgb25DbG9zZTogKCkgPT4gdm9pZCB9IH0pID0+IFJlYWN0Tm9kZSlcbiAgICB8IFJlYWN0Tm9kZVxuICAgIHwgbnVsbDtcbiAgY29tcGV0ZW5jZUdvYWxUeXBlcz86IHN0cmluZ1tdO1xuICBjaGlsZHJlbjogUmVhY3ROb2RlO1xufTtcblxuaW50ZXJmYWNlIFN0YXRlIHtcbiAgaXNPcGVuOiBib29sZWFuO1xufVxuXG5jbGFzcyBBcnRpY2xlSGVhZGVyV3JhcHBlciBleHRlbmRzIENvbXBvbmVudDxQcm9wcyAmIFdpdGhUcmFuc2xhdGlvbiwgU3RhdGU+IHtcbiAgY29uc3RydWN0b3IocHJvcHM6IFByb3BzICYgV2l0aFRyYW5zbGF0aW9uKSB7XG4gICAgc3VwZXIocHJvcHMpO1xuICAgIHRoaXMuc3RhdGUgPSB7IGlzT3BlbjogZmFsc2UgfTtcbiAgICB0aGlzLmNsb3NlRGlhbG9nID0gdGhpcy5jbG9zZURpYWxvZy5iaW5kKHRoaXMpO1xuICAgIHRoaXMub3BlbkRpYWxvZyA9IHRoaXMub3BlbkRpYWxvZy5iaW5kKHRoaXMpO1xuICB9XG5cbiAgY29tcG9uZW50RGlkTW91bnQoKSB7XG4gICAgaWYgKGlzTW9iaWxlKSB7XG4gICAgICBjb25zdCBoZXJvQ29udGVudExpc3Q6IE5vZGVMaXN0T2Y8SFRNTEVsZW1lbnQ+ID0gZG9jdW1lbnQucXVlcnlTZWxlY3RvckFsbCgnLmMtYXJ0aWNsZV9faGVhZGVyJyk7XG4gICAgICBpZiAoaGVyb0NvbnRlbnRMaXN0Lmxlbmd0aCA9PT0gMSkge1xuICAgICAgICBoZXJvQ29udGVudExpc3RbMF0uc2Nyb2xsSW50b1ZpZXcodHJ1ZSk7XG4gICAgICAgIHdpbmRvdy5zY3JvbGxCeSgwLCBoZXJvQ29udGVudExpc3RbMF0ub2Zmc2V0VG9wIC0gMTIwKTsgLy8gQWRqdXN0IGZvciBoZWFkZXJcbiAgICAgIH1cbiAgICB9XG4gIH1cblxuICBvcGVuRGlhbG9nKCkge1xuICAgIHRoaXMuc2V0U3RhdGUoeyBpc09wZW46IHRydWUgfSk7XG4gIH1cblxuICBjbG9zZURpYWxvZygpIHtcbiAgICB0aGlzLnNldFN0YXRlKHsgaXNPcGVuOiBmYWxzZSB9KTtcbiAgfVxuXG4gIHJlbmRlcigpIHtcbiAgICBjb25zdCB7IGNoaWxkcmVuLCBjb21wZXRlbmNlR29hbHMsIGNvbXBldGVuY2VHb2FsVHlwZXMsIHQgfSA9IHRoaXMucHJvcHM7XG4gICAgaWYgKCFjb21wZXRlbmNlR29hbHMpIHtcbiAgICAgIHJldHVybiA8ZGl2IHsuLi5jbGFzc2VzKCdoZWFkZXInKX0+e2NoaWxkcmVufTwvZGl2PjtcbiAgICB9XG5cbiAgICBjb25zdCBkaWFsb2cgPVxuICAgICAgdHlwZW9mIGNvbXBldGVuY2VHb2FscyA9PT0gJ2Z1bmN0aW9uJyA/IChcbiAgICAgICAgY29tcGV0ZW5jZUdvYWxzKHtcbiAgICAgICAgICBEaWFsb2c6IENvbXBldGVuY2VHb2Fsc0RpYWxvZyxcbiAgICAgICAgICBkaWFsb2dQcm9wczoge1xuICAgICAgICAgICAgaXNPcGVuOiB0aGlzLnN0YXRlLmlzT3BlbixcbiAgICAgICAgICAgIG9uQ2xvc2U6IHRoaXMuY2xvc2VEaWFsb2csXG4gICAgICAgICAgfSxcbiAgICAgICAgfSlcbiAgICAgICkgOiAoXG4gICAgICAgIDxDb21wZXRlbmNlR29hbHNEaWFsb2cgb25DbG9zZT17dGhpcy5jbG9zZURpYWxvZ30gaXNPcGVuPXt0aGlzLnN0YXRlLmlzT3Blbn0+XG4gICAgICAgICAge2NvbXBldGVuY2VHb2Fsc31cbiAgICAgICAgPC9Db21wZXRlbmNlR29hbHNEaWFsb2c+XG4gICAgICApO1xuICAgIHJldHVybiAoXG4gICAgICA8ZGl2IHsuLi5jbGFzc2VzKCdoZWFkZXInKX0+XG4gICAgICAgIHtjaGlsZHJlbn1cbiAgICAgICAgPENvbXBldGVuY2VXcmFwcGVyPlxuICAgICAgICAgIHtjb21wZXRlbmNlR29hbFR5cGVzICYmXG4gICAgICAgICAgICBjb21wZXRlbmNlR29hbFR5cGVzLm1hcCgodHlwZSkgPT4gKFxuICAgICAgICAgICAgICA8Q29tcGV0ZW5jZUJhZGdlIGtleT17dHlwZX0+XG4gICAgICAgICAgICAgICAgPEZvb3RlckhlYWRlckljb24gLz5cbiAgICAgICAgICAgICAgICA8Q29tcGV0ZW5jZUJhZGdlVGV4dD57dHlwZX08L0NvbXBldGVuY2VCYWRnZVRleHQ+XG4gICAgICAgICAgICAgIDwvQ29tcGV0ZW5jZUJhZGdlPlxuICAgICAgICAgICAgKSl9XG4gICAgICAgICAgPENvbXBldGVuY2VCdXR0b25XcmFwcGVyIGFkZFNwYWNlPXtjb21wZXRlbmNlR29hbFR5cGVzICYmIGNvbXBldGVuY2VHb2FsVHlwZXMubGVuZ3RoID4gMH0+XG4gICAgICAgICAgICA8T3BlbkJ1dHRvbiBvbkNsaWNrPXt0aGlzLm9wZW5EaWFsb2d9PlxuICAgICAgICAgICAgICA8Rm9vdGVySGVhZGVySWNvbiAvPlxuICAgICAgICAgICAgICA8Q29tcGV0ZW5jZUJhZGdlVGV4dD57dCgnY29tcGV0ZW5jZUdvYWxzLnNob3dDb21wZXRlbmNlR29hbHMnKX08L0NvbXBldGVuY2VCYWRnZVRleHQ+XG4gICAgICAgICAgICA8L09wZW5CdXR0b24+XG4gICAgICAgICAgPC9Db21wZXRlbmNlQnV0dG9uV3JhcHBlcj5cbiAgICAgICAgPC9Db21wZXRlbmNlV3JhcHBlcj5cbiAgICAgICAge2RpYWxvZ31cbiAgICAgIDwvZGl2PlxuICAgICk7XG4gIH1cbn1cblxuZXhwb3J0IGRlZmF1bHQgd2l0aFRyYW5zbGF0aW9uKCkoQXJ0aWNsZUhlYWRlcldyYXBwZXIpO1xuIl19 */");
109
109
 
110
110
  var ArticleHeaderWrapper = /*#__PURE__*/function (_Component) {
111
111
  _inherits(ArticleHeaderWrapper, _Component);
@@ -50,7 +50,7 @@ var StyledWrapper = (0, _styledBase["default"])("nav", {
50
50
  label: "StyledWrapper"
51
51
  })("margin:32px 0 0;.c-tabs--subjects{margin:0;}.c-tabs__list--subjects{margin:0;}.c-tabs__tab--subjects{", _core.mq.range({
52
52
  until: _core.breakpoints.tablet
53
- }), "{margin:0;font-size:12px;padding-left:8px;padding-right:8px;:first-of-type{padding-left:0;}:last-of-type{padding-right:0;}}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FrontpageAllSubjects.tsx"],"names":[],"mappings":"AAUgC","file":"FrontpageAllSubjects.tsx","sourcesContent":["import React, { Fragment } from 'react';\nimport styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport Tabs from '@ndla/tabs';\nimport SafeLink from '@ndla/safelink';\nimport { colors, fonts, mq, breakpoints } from '@ndla/core';\nimport { MessageBox } from '../MessageBox';\n// @ts-ignore\nimport { ToggleItem } from '../Filter';\n\nconst StyledWrapper = styled.nav`\n  margin: 32px 0 0;\n  .c-tabs--subjects {\n    margin: 0;\n  }\n  .c-tabs__list--subjects {\n    margin: 0;\n  }\n  .c-tabs__tab--subjects {\n    ${mq.range({ until: breakpoints.tablet })} {\n      margin: 0;\n      font-size: 12px;\n      padding-left: 8px;\n      padding-right: 8px;\n      :first-of-type {\n        padding-left: 0;\n      }\n      :last-of-type {\n        padding-right: 0;\n      }\n    }\n  }\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 40px 0 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 StyledLetterItem = styled.span<{ subjectViewType?: string }>`\n  display: block;\n  ${fonts.sizes(30, 1)};\n  font-weight: ${fonts.weight.bold};\n  color: ${colors.brand.primary};\n  margin-bottom: 8px;\n  ${(props) => props.subjectViewType === 'checkbox' && `margin-left:37px;`}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 10px;\n`;\n\nconst StyledLetterSpacing = styled.span`\n  display: block;\n  height: 16px;\n`;\n\nconst MessageBoxWrapper = styled.div`\n  padding-top: 20px;\n`;\n\ntype subjectProps = {\n  name: string;\n  url?: string;\n  path?: string;\n  id?: string;\n};\ntype categoryProps = {\n  type?: string;\n  name?: string;\n  visible?: boolean;\n  subjects: subjectProps[];\n};\n\nexport type subjectsProps = {\n  categories: categoryProps[];\n  subjectViewType?: 'link' | 'checkbox';\n  onToggleSubject?: (id: string) => void;\n  onNavigate?: () => void;\n  selectedSubjects?: string[];\n};\n\ntype letterCategories = {\n  letter: string;\n  items: subjectProps[];\n};\n\nconst sortAlphabetically = (subjects: subjectProps[], locale: string = 'nb') => {\n  const subjectsSorted = subjects.sort((a, b) => a.name.localeCompare(b.name, locale));\n  const subjectsLetterCategories: letterCategories[] = [];\n  let previousLetter = '';\n  let letterItems: subjectProps[] = [];\n  subjectsSorted.forEach((subject: subjectProps) => {\n    const currentLetter = subject.name.substr(0, 1);\n    const isNewLetter = currentLetter.localeCompare(previousLetter, locale) === 1;\n    if (isNewLetter && letterItems.length) {\n      subjectsLetterCategories.push({\n        letter: previousLetter,\n        items: letterItems,\n      });\n      letterItems = [];\n    }\n    previousLetter = currentLetter;\n    letterItems.push(subject);\n  });\n  // Add last letter\n  if (previousLetter && letterItems.length) {\n    subjectsLetterCategories.push({\n      letter: previousLetter,\n      items: letterItems,\n    });\n  }\n  return subjectsLetterCategories;\n};\n\nconst renderList = (\n  subjects: subjectProps[],\n  onNavigate?: () => void,\n  onToggleSubject?: subjectsProps['onToggleSubject'],\n  subjectViewType?: subjectsProps['subjectViewType'],\n  selectedSubjects: subjectsProps['selectedSubjects'] = [],\n) => (\n  <StyledList>\n    {sortAlphabetically(subjects).map((letter: any) => {\n      return (\n        <Fragment key={letter.letter}>\n          {letter.items.map((subject: subjectProps, index: number) => (\n            <Fragment key={subject.name}>\n              <StyledListItem>\n                {index === 0 && <StyledLetterItem subjectViewType={subjectViewType}>{letter.letter}</StyledLetterItem>}\n                {subjectViewType === 'checkbox' && subject.id ? (\n                  <ToggleItem\n                    id={subject.id}\n                    value={subject.id}\n                    checked={selectedSubjects.includes(subject.id)}\n                    label={subject.name}\n                    component=\"div\"\n                    onChange={() => {\n                      if (onToggleSubject && subject.id) {\n                        onToggleSubject(subject.id);\n                      }\n                    }}\n                  />\n                ) : (\n                  <>\n                    <SafeLink\n                      onClick={() => {\n                        if (onNavigate) {\n                          onNavigate();\n                        }\n                      }}\n                      to={subject.url || subject.path || ''}>\n                      {subject.name}\n                    </SafeLink>\n                    <StyledSpacingElement />\n                  </>\n                )}\n                {letter.items.length - 1 === index && <StyledLetterSpacing />}\n              </StyledListItem>\n            </Fragment>\n          ))}\n        </Fragment>\n      );\n    })}\n  </StyledList>\n);\n\nconst FrontpageAllSubjects = ({\n  categories,\n  onNavigate,\n  onToggleSubject,\n  subjectViewType,\n  selectedSubjects,\n}: subjectsProps) => {\n  const allSubjects: subjectProps[] = [];\n  const data: any = [];\n  const { t } = useTranslation();\n\n  categories.forEach((category: categoryProps) => {\n    allSubjects.push(...category.subjects);\n    category.visible &&\n      data.push({\n        title: category.name || t(`subjectCategories.${category.type}`),\n        content: (\n          <>\n            {/* Should be persistent til fall 2022 */}\n            {category.name === t('subjectCategories.beta') && (\n              <MessageBoxWrapper>\n                <MessageBox>{t('messageBoxInfo.frontPageBeta')}</MessageBox>\n              </MessageBoxWrapper>\n            )}\n            {category.name === t('subjectCategories.archive') && (\n              <MessageBoxWrapper>\n                <MessageBox>{t('messageBoxInfo.frontPageExpired')}</MessageBox>\n              </MessageBoxWrapper>\n            )}\n\n            {renderList(category.subjects, onNavigate, onToggleSubject, subjectViewType, selectedSubjects)}\n          </>\n        ),\n      });\n  });\n\n  data.unshift({\n    title: t('frontpageMenu.allsubjects'),\n    content: renderList(allSubjects, onNavigate, onToggleSubject, subjectViewType, selectedSubjects),\n  });\n\n  return (\n    <StyledWrapper>\n      <Tabs modifier=\"subjects\" tabs={data} />\n    </StyledWrapper>\n  );\n};\n\nexport default FrontpageAllSubjects;\n"]} */"));
53
+ }), "{margin:0;font-size:12px;padding-left:8px;padding-right:8px;:first-of-type{padding-left:0;}:last-of-type{padding-right:0;}}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FrontpageAllSubjects.tsx"],"names":[],"mappings":"AAUgC","file":"FrontpageAllSubjects.tsx","sourcesContent":["import React, { Fragment } from 'react';\nimport styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport Tabs from '@ndla/tabs';\nimport SafeLink from '@ndla/safelink';\nimport { colors, fonts, mq, breakpoints } from '@ndla/core';\nimport { MessageBox } from '../MessageBox';\n// @ts-ignore\nimport { ToggleItem } from '../Filter';\n\nconst StyledWrapper = styled.nav`\n  margin: 32px 0 0;\n  .c-tabs--subjects {\n    margin: 0;\n  }\n  .c-tabs__list--subjects {\n    margin: 0;\n  }\n  .c-tabs__tab--subjects {\n    ${mq.range({ until: breakpoints.tablet })} {\n      margin: 0;\n      font-size: 12px;\n      padding-left: 8px;\n      padding-right: 8px;\n      :first-of-type {\n        padding-left: 0;\n      }\n      :last-of-type {\n        padding-right: 0;\n      }\n    }\n  }\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 40px 0 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 StyledLetterItem = styled.span<{ subjectViewType?: string }>`\n  display: block;\n  ${fonts.sizes(30, 1)};\n  font-weight: ${fonts.weight.bold};\n  color: ${colors.brand.primary};\n  margin-bottom: 8px;\n  ${(props) => props.subjectViewType === 'checkbox' && `margin-left:37px;`}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 10px;\n`;\n\nconst StyledLetterSpacing = styled.span`\n  display: block;\n  height: 16px;\n`;\n\nconst MessageBoxWrapper = styled.div`\n  padding-top: 20px;\n`;\n\ntype subjectProps = {\n  name: string;\n  url?: string;\n  path?: string;\n  id?: string;\n};\ntype categoryProps = {\n  type?: string;\n  name?: string;\n  visible?: boolean;\n  subjects: subjectProps[];\n};\n\nexport type subjectsProps = {\n  categories: categoryProps[];\n  subjectViewType?: 'link' | 'checkbox';\n  onToggleSubject?: (id: string) => void;\n  onNavigate?: () => void;\n  selectedSubjects?: string[];\n};\n\ntype letterCategories = {\n  letter: string;\n  items: subjectProps[];\n};\n\nconst sortAlphabetically = (subjects: subjectProps[], locale: string = 'nb') => {\n  const subjectsSorted = subjects.sort((a, b) => a.name.localeCompare(b.name, locale));\n  const subjectsLetterCategories: letterCategories[] = [];\n  let previousLetter = '';\n  let letterItems: subjectProps[] = [];\n  subjectsSorted.forEach((subject: subjectProps) => {\n    const currentLetter = subject.name.substr(0, 1);\n    const isNewLetter = currentLetter.localeCompare(previousLetter, locale) === 1;\n    if (isNewLetter && letterItems.length) {\n      subjectsLetterCategories.push({\n        letter: previousLetter,\n        items: letterItems,\n      });\n      letterItems = [];\n    }\n    previousLetter = currentLetter;\n    letterItems.push(subject);\n  });\n  // Add last letter\n  if (previousLetter && letterItems.length) {\n    subjectsLetterCategories.push({\n      letter: previousLetter,\n      items: letterItems,\n    });\n  }\n  return subjectsLetterCategories;\n};\n\nconst renderList = (\n  subjects: subjectProps[],\n  onNavigate?: () => void,\n  onToggleSubject?: subjectsProps['onToggleSubject'],\n  subjectViewType?: subjectsProps['subjectViewType'],\n  selectedSubjects: subjectsProps['selectedSubjects'] = [],\n) => (\n  <StyledList>\n    {sortAlphabetically(subjects).map((letter: any) => {\n      return (\n        <Fragment key={letter.letter}>\n          {letter.items.map((subject: subjectProps, index: number) => (\n            <Fragment key={subject.name}>\n              <StyledListItem>\n                {index === 0 && <StyledLetterItem subjectViewType={subjectViewType}>{letter.letter}</StyledLetterItem>}\n                {subjectViewType === 'checkbox' && subject.id ? (\n                  <ToggleItem\n                    id={subject.id}\n                    value={subject.id}\n                    checked={selectedSubjects.includes(subject.id)}\n                    label={subject.name}\n                    component=\"div\"\n                    onChange={() => {\n                      if (onToggleSubject && subject.id) {\n                        onToggleSubject(subject.id);\n                      }\n                    }}\n                  />\n                ) : (\n                  <>\n                    <SafeLink\n                      onClick={() => {\n                        if (onNavigate) {\n                          onNavigate();\n                        }\n                      }}\n                      to={subject.url || subject.path || ''}>\n                      {subject.name}\n                    </SafeLink>\n                    <StyledSpacingElement />\n                  </>\n                )}\n                {letter.items.length - 1 === index && <StyledLetterSpacing />}\n              </StyledListItem>\n            </Fragment>\n          ))}\n        </Fragment>\n      );\n    })}\n  </StyledList>\n);\n\nconst FrontpageAllSubjects = ({\n  categories,\n  onNavigate,\n  onToggleSubject,\n  subjectViewType,\n  selectedSubjects,\n}: subjectsProps) => {\n  const allSubjects: subjectProps[] = [];\n  const data: any = [];\n  const { t } = useTranslation();\n\n  categories.forEach((category: categoryProps) => {\n    allSubjects.push(...category.subjects);\n    category.visible &&\n      data.push({\n        title: category.name || t(`subjectCategories.${category.type}`),\n        content: (\n          <>\n            {/* Should be persistent til fall 2022 */}\n            {category.name === t('subjectCategories.beta') && (\n              <MessageBoxWrapper>\n                <MessageBox>{t('messageBoxInfo.frontPageBeta')}</MessageBox>\n              </MessageBoxWrapper>\n            )}\n            {category.name === t('subjectCategories.archive') && (\n              <MessageBoxWrapper>\n                <MessageBox>{t('messageBoxInfo.frontPageExpired')}</MessageBox>\n              </MessageBoxWrapper>\n            )}\n\n            {renderList(category.subjects, onNavigate, onToggleSubject, subjectViewType, selectedSubjects)}\n          </>\n        ),\n      });\n  });\n\n  data.push({\n    title: t('frontpageMenu.allsubjects'),\n    content: renderList(allSubjects, onNavigate, onToggleSubject, subjectViewType, selectedSubjects),\n  });\n\n  return (\n    <StyledWrapper>\n      <Tabs modifier=\"subjects\" tabs={data} />\n    </StyledWrapper>\n  );\n};\n\nexport default FrontpageAllSubjects;\n"]} */"));
54
54
  var StyledList = (0, _styledBase["default"])("ul", {
55
55
  target: "e1kk5ejg1",
56
56
  label: "StyledList"
@@ -58,7 +58,7 @@ var StyledList = (0, _styledBase["default"])("ul", {
58
58
  from: _core.breakpoints.tablet
59
59
  }), "{column-count:2;column-gap:20px;}", _core.mq.range({
60
60
  from: _core.breakpoints.tabletWide
61
- }), "{column-count:3;column-gap:20px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FrontpageAllSubjects.tsx"],"names":[],"mappings":"AAkC4B","file":"FrontpageAllSubjects.tsx","sourcesContent":["import React, { Fragment } from 'react';\nimport styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport Tabs from '@ndla/tabs';\nimport SafeLink from '@ndla/safelink';\nimport { colors, fonts, mq, breakpoints } from '@ndla/core';\nimport { MessageBox } from '../MessageBox';\n// @ts-ignore\nimport { ToggleItem } from '../Filter';\n\nconst StyledWrapper = styled.nav`\n  margin: 32px 0 0;\n  .c-tabs--subjects {\n    margin: 0;\n  }\n  .c-tabs__list--subjects {\n    margin: 0;\n  }\n  .c-tabs__tab--subjects {\n    ${mq.range({ until: breakpoints.tablet })} {\n      margin: 0;\n      font-size: 12px;\n      padding-left: 8px;\n      padding-right: 8px;\n      :first-of-type {\n        padding-left: 0;\n      }\n      :last-of-type {\n        padding-right: 0;\n      }\n    }\n  }\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 40px 0 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 StyledLetterItem = styled.span<{ subjectViewType?: string }>`\n  display: block;\n  ${fonts.sizes(30, 1)};\n  font-weight: ${fonts.weight.bold};\n  color: ${colors.brand.primary};\n  margin-bottom: 8px;\n  ${(props) => props.subjectViewType === 'checkbox' && `margin-left:37px;`}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 10px;\n`;\n\nconst StyledLetterSpacing = styled.span`\n  display: block;\n  height: 16px;\n`;\n\nconst MessageBoxWrapper = styled.div`\n  padding-top: 20px;\n`;\n\ntype subjectProps = {\n  name: string;\n  url?: string;\n  path?: string;\n  id?: string;\n};\ntype categoryProps = {\n  type?: string;\n  name?: string;\n  visible?: boolean;\n  subjects: subjectProps[];\n};\n\nexport type subjectsProps = {\n  categories: categoryProps[];\n  subjectViewType?: 'link' | 'checkbox';\n  onToggleSubject?: (id: string) => void;\n  onNavigate?: () => void;\n  selectedSubjects?: string[];\n};\n\ntype letterCategories = {\n  letter: string;\n  items: subjectProps[];\n};\n\nconst sortAlphabetically = (subjects: subjectProps[], locale: string = 'nb') => {\n  const subjectsSorted = subjects.sort((a, b) => a.name.localeCompare(b.name, locale));\n  const subjectsLetterCategories: letterCategories[] = [];\n  let previousLetter = '';\n  let letterItems: subjectProps[] = [];\n  subjectsSorted.forEach((subject: subjectProps) => {\n    const currentLetter = subject.name.substr(0, 1);\n    const isNewLetter = currentLetter.localeCompare(previousLetter, locale) === 1;\n    if (isNewLetter && letterItems.length) {\n      subjectsLetterCategories.push({\n        letter: previousLetter,\n        items: letterItems,\n      });\n      letterItems = [];\n    }\n    previousLetter = currentLetter;\n    letterItems.push(subject);\n  });\n  // Add last letter\n  if (previousLetter && letterItems.length) {\n    subjectsLetterCategories.push({\n      letter: previousLetter,\n      items: letterItems,\n    });\n  }\n  return subjectsLetterCategories;\n};\n\nconst renderList = (\n  subjects: subjectProps[],\n  onNavigate?: () => void,\n  onToggleSubject?: subjectsProps['onToggleSubject'],\n  subjectViewType?: subjectsProps['subjectViewType'],\n  selectedSubjects: subjectsProps['selectedSubjects'] = [],\n) => (\n  <StyledList>\n    {sortAlphabetically(subjects).map((letter: any) => {\n      return (\n        <Fragment key={letter.letter}>\n          {letter.items.map((subject: subjectProps, index: number) => (\n            <Fragment key={subject.name}>\n              <StyledListItem>\n                {index === 0 && <StyledLetterItem subjectViewType={subjectViewType}>{letter.letter}</StyledLetterItem>}\n                {subjectViewType === 'checkbox' && subject.id ? (\n                  <ToggleItem\n                    id={subject.id}\n                    value={subject.id}\n                    checked={selectedSubjects.includes(subject.id)}\n                    label={subject.name}\n                    component=\"div\"\n                    onChange={() => {\n                      if (onToggleSubject && subject.id) {\n                        onToggleSubject(subject.id);\n                      }\n                    }}\n                  />\n                ) : (\n                  <>\n                    <SafeLink\n                      onClick={() => {\n                        if (onNavigate) {\n                          onNavigate();\n                        }\n                      }}\n                      to={subject.url || subject.path || ''}>\n                      {subject.name}\n                    </SafeLink>\n                    <StyledSpacingElement />\n                  </>\n                )}\n                {letter.items.length - 1 === index && <StyledLetterSpacing />}\n              </StyledListItem>\n            </Fragment>\n          ))}\n        </Fragment>\n      );\n    })}\n  </StyledList>\n);\n\nconst FrontpageAllSubjects = ({\n  categories,\n  onNavigate,\n  onToggleSubject,\n  subjectViewType,\n  selectedSubjects,\n}: subjectsProps) => {\n  const allSubjects: subjectProps[] = [];\n  const data: any = [];\n  const { t } = useTranslation();\n\n  categories.forEach((category: categoryProps) => {\n    allSubjects.push(...category.subjects);\n    category.visible &&\n      data.push({\n        title: category.name || t(`subjectCategories.${category.type}`),\n        content: (\n          <>\n            {/* Should be persistent til fall 2022 */}\n            {category.name === t('subjectCategories.beta') && (\n              <MessageBoxWrapper>\n                <MessageBox>{t('messageBoxInfo.frontPageBeta')}</MessageBox>\n              </MessageBoxWrapper>\n            )}\n            {category.name === t('subjectCategories.archive') && (\n              <MessageBoxWrapper>\n                <MessageBox>{t('messageBoxInfo.frontPageExpired')}</MessageBox>\n              </MessageBoxWrapper>\n            )}\n\n            {renderList(category.subjects, onNavigate, onToggleSubject, subjectViewType, selectedSubjects)}\n          </>\n        ),\n      });\n  });\n\n  data.unshift({\n    title: t('frontpageMenu.allsubjects'),\n    content: renderList(allSubjects, onNavigate, onToggleSubject, subjectViewType, selectedSubjects),\n  });\n\n  return (\n    <StyledWrapper>\n      <Tabs modifier=\"subjects\" tabs={data} />\n    </StyledWrapper>\n  );\n};\n\nexport default FrontpageAllSubjects;\n"]} */"));
61
+ }), "{column-count:3;column-gap:20px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FrontpageAllSubjects.tsx"],"names":[],"mappings":"AAkC4B","file":"FrontpageAllSubjects.tsx","sourcesContent":["import React, { Fragment } from 'react';\nimport styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport Tabs from '@ndla/tabs';\nimport SafeLink from '@ndla/safelink';\nimport { colors, fonts, mq, breakpoints } from '@ndla/core';\nimport { MessageBox } from '../MessageBox';\n// @ts-ignore\nimport { ToggleItem } from '../Filter';\n\nconst StyledWrapper = styled.nav`\n  margin: 32px 0 0;\n  .c-tabs--subjects {\n    margin: 0;\n  }\n  .c-tabs__list--subjects {\n    margin: 0;\n  }\n  .c-tabs__tab--subjects {\n    ${mq.range({ until: breakpoints.tablet })} {\n      margin: 0;\n      font-size: 12px;\n      padding-left: 8px;\n      padding-right: 8px;\n      :first-of-type {\n        padding-left: 0;\n      }\n      :last-of-type {\n        padding-right: 0;\n      }\n    }\n  }\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 40px 0 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 StyledLetterItem = styled.span<{ subjectViewType?: string }>`\n  display: block;\n  ${fonts.sizes(30, 1)};\n  font-weight: ${fonts.weight.bold};\n  color: ${colors.brand.primary};\n  margin-bottom: 8px;\n  ${(props) => props.subjectViewType === 'checkbox' && `margin-left:37px;`}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 10px;\n`;\n\nconst StyledLetterSpacing = styled.span`\n  display: block;\n  height: 16px;\n`;\n\nconst MessageBoxWrapper = styled.div`\n  padding-top: 20px;\n`;\n\ntype subjectProps = {\n  name: string;\n  url?: string;\n  path?: string;\n  id?: string;\n};\ntype categoryProps = {\n  type?: string;\n  name?: string;\n  visible?: boolean;\n  subjects: subjectProps[];\n};\n\nexport type subjectsProps = {\n  categories: categoryProps[];\n  subjectViewType?: 'link' | 'checkbox';\n  onToggleSubject?: (id: string) => void;\n  onNavigate?: () => void;\n  selectedSubjects?: string[];\n};\n\ntype letterCategories = {\n  letter: string;\n  items: subjectProps[];\n};\n\nconst sortAlphabetically = (subjects: subjectProps[], locale: string = 'nb') => {\n  const subjectsSorted = subjects.sort((a, b) => a.name.localeCompare(b.name, locale));\n  const subjectsLetterCategories: letterCategories[] = [];\n  let previousLetter = '';\n  let letterItems: subjectProps[] = [];\n  subjectsSorted.forEach((subject: subjectProps) => {\n    const currentLetter = subject.name.substr(0, 1);\n    const isNewLetter = currentLetter.localeCompare(previousLetter, locale) === 1;\n    if (isNewLetter && letterItems.length) {\n      subjectsLetterCategories.push({\n        letter: previousLetter,\n        items: letterItems,\n      });\n      letterItems = [];\n    }\n    previousLetter = currentLetter;\n    letterItems.push(subject);\n  });\n  // Add last letter\n  if (previousLetter && letterItems.length) {\n    subjectsLetterCategories.push({\n      letter: previousLetter,\n      items: letterItems,\n    });\n  }\n  return subjectsLetterCategories;\n};\n\nconst renderList = (\n  subjects: subjectProps[],\n  onNavigate?: () => void,\n  onToggleSubject?: subjectsProps['onToggleSubject'],\n  subjectViewType?: subjectsProps['subjectViewType'],\n  selectedSubjects: subjectsProps['selectedSubjects'] = [],\n) => (\n  <StyledList>\n    {sortAlphabetically(subjects).map((letter: any) => {\n      return (\n        <Fragment key={letter.letter}>\n          {letter.items.map((subject: subjectProps, index: number) => (\n            <Fragment key={subject.name}>\n              <StyledListItem>\n                {index === 0 && <StyledLetterItem subjectViewType={subjectViewType}>{letter.letter}</StyledLetterItem>}\n                {subjectViewType === 'checkbox' && subject.id ? (\n                  <ToggleItem\n                    id={subject.id}\n                    value={subject.id}\n                    checked={selectedSubjects.includes(subject.id)}\n                    label={subject.name}\n                    component=\"div\"\n                    onChange={() => {\n                      if (onToggleSubject && subject.id) {\n                        onToggleSubject(subject.id);\n                      }\n                    }}\n                  />\n                ) : (\n                  <>\n                    <SafeLink\n                      onClick={() => {\n                        if (onNavigate) {\n                          onNavigate();\n                        }\n                      }}\n                      to={subject.url || subject.path || ''}>\n                      {subject.name}\n                    </SafeLink>\n                    <StyledSpacingElement />\n                  </>\n                )}\n                {letter.items.length - 1 === index && <StyledLetterSpacing />}\n              </StyledListItem>\n            </Fragment>\n          ))}\n        </Fragment>\n      );\n    })}\n  </StyledList>\n);\n\nconst FrontpageAllSubjects = ({\n  categories,\n  onNavigate,\n  onToggleSubject,\n  subjectViewType,\n  selectedSubjects,\n}: subjectsProps) => {\n  const allSubjects: subjectProps[] = [];\n  const data: any = [];\n  const { t } = useTranslation();\n\n  categories.forEach((category: categoryProps) => {\n    allSubjects.push(...category.subjects);\n    category.visible &&\n      data.push({\n        title: category.name || t(`subjectCategories.${category.type}`),\n        content: (\n          <>\n            {/* Should be persistent til fall 2022 */}\n            {category.name === t('subjectCategories.beta') && (\n              <MessageBoxWrapper>\n                <MessageBox>{t('messageBoxInfo.frontPageBeta')}</MessageBox>\n              </MessageBoxWrapper>\n            )}\n            {category.name === t('subjectCategories.archive') && (\n              <MessageBoxWrapper>\n                <MessageBox>{t('messageBoxInfo.frontPageExpired')}</MessageBox>\n              </MessageBoxWrapper>\n            )}\n\n            {renderList(category.subjects, onNavigate, onToggleSubject, subjectViewType, selectedSubjects)}\n          </>\n        ),\n      });\n  });\n\n  data.push({\n    title: t('frontpageMenu.allsubjects'),\n    content: renderList(allSubjects, onNavigate, onToggleSubject, subjectViewType, selectedSubjects),\n  });\n\n  return (\n    <StyledWrapper>\n      <Tabs modifier=\"subjects\" tabs={data} />\n    </StyledWrapper>\n  );\n};\n\nexport default FrontpageAllSubjects;\n"]} */"));
62
62
  var StyledListItem = (0, _styledBase["default"])("li", {
63
63
  target: "e1kk5ejg2",
64
64
  label: "StyledListItem"
@@ -68,7 +68,7 @@ var StyledListItem = (0, _styledBase["default"])("li", {
68
68
  } : {
69
69
  name: "1gj47mt",
70
70
  styles: "margin-bottom:0;break-inside:avoid;",
71
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FrontpageAllSubjects.tsx"],"names":[],"mappings":"AA+CgC","file":"FrontpageAllSubjects.tsx","sourcesContent":["import React, { Fragment } from 'react';\nimport styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport Tabs from '@ndla/tabs';\nimport SafeLink from '@ndla/safelink';\nimport { colors, fonts, mq, breakpoints } from '@ndla/core';\nimport { MessageBox } from '../MessageBox';\n// @ts-ignore\nimport { ToggleItem } from '../Filter';\n\nconst StyledWrapper = styled.nav`\n  margin: 32px 0 0;\n  .c-tabs--subjects {\n    margin: 0;\n  }\n  .c-tabs__list--subjects {\n    margin: 0;\n  }\n  .c-tabs__tab--subjects {\n    ${mq.range({ until: breakpoints.tablet })} {\n      margin: 0;\n      font-size: 12px;\n      padding-left: 8px;\n      padding-right: 8px;\n      :first-of-type {\n        padding-left: 0;\n      }\n      :last-of-type {\n        padding-right: 0;\n      }\n    }\n  }\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 40px 0 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 StyledLetterItem = styled.span<{ subjectViewType?: string }>`\n  display: block;\n  ${fonts.sizes(30, 1)};\n  font-weight: ${fonts.weight.bold};\n  color: ${colors.brand.primary};\n  margin-bottom: 8px;\n  ${(props) => props.subjectViewType === 'checkbox' && `margin-left:37px;`}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 10px;\n`;\n\nconst StyledLetterSpacing = styled.span`\n  display: block;\n  height: 16px;\n`;\n\nconst MessageBoxWrapper = styled.div`\n  padding-top: 20px;\n`;\n\ntype subjectProps = {\n  name: string;\n  url?: string;\n  path?: string;\n  id?: string;\n};\ntype categoryProps = {\n  type?: string;\n  name?: string;\n  visible?: boolean;\n  subjects: subjectProps[];\n};\n\nexport type subjectsProps = {\n  categories: categoryProps[];\n  subjectViewType?: 'link' | 'checkbox';\n  onToggleSubject?: (id: string) => void;\n  onNavigate?: () => void;\n  selectedSubjects?: string[];\n};\n\ntype letterCategories = {\n  letter: string;\n  items: subjectProps[];\n};\n\nconst sortAlphabetically = (subjects: subjectProps[], locale: string = 'nb') => {\n  const subjectsSorted = subjects.sort((a, b) => a.name.localeCompare(b.name, locale));\n  const subjectsLetterCategories: letterCategories[] = [];\n  let previousLetter = '';\n  let letterItems: subjectProps[] = [];\n  subjectsSorted.forEach((subject: subjectProps) => {\n    const currentLetter = subject.name.substr(0, 1);\n    const isNewLetter = currentLetter.localeCompare(previousLetter, locale) === 1;\n    if (isNewLetter && letterItems.length) {\n      subjectsLetterCategories.push({\n        letter: previousLetter,\n        items: letterItems,\n      });\n      letterItems = [];\n    }\n    previousLetter = currentLetter;\n    letterItems.push(subject);\n  });\n  // Add last letter\n  if (previousLetter && letterItems.length) {\n    subjectsLetterCategories.push({\n      letter: previousLetter,\n      items: letterItems,\n    });\n  }\n  return subjectsLetterCategories;\n};\n\nconst renderList = (\n  subjects: subjectProps[],\n  onNavigate?: () => void,\n  onToggleSubject?: subjectsProps['onToggleSubject'],\n  subjectViewType?: subjectsProps['subjectViewType'],\n  selectedSubjects: subjectsProps['selectedSubjects'] = [],\n) => (\n  <StyledList>\n    {sortAlphabetically(subjects).map((letter: any) => {\n      return (\n        <Fragment key={letter.letter}>\n          {letter.items.map((subject: subjectProps, index: number) => (\n            <Fragment key={subject.name}>\n              <StyledListItem>\n                {index === 0 && <StyledLetterItem subjectViewType={subjectViewType}>{letter.letter}</StyledLetterItem>}\n                {subjectViewType === 'checkbox' && subject.id ? (\n                  <ToggleItem\n                    id={subject.id}\n                    value={subject.id}\n                    checked={selectedSubjects.includes(subject.id)}\n                    label={subject.name}\n                    component=\"div\"\n                    onChange={() => {\n                      if (onToggleSubject && subject.id) {\n                        onToggleSubject(subject.id);\n                      }\n                    }}\n                  />\n                ) : (\n                  <>\n                    <SafeLink\n                      onClick={() => {\n                        if (onNavigate) {\n                          onNavigate();\n                        }\n                      }}\n                      to={subject.url || subject.path || ''}>\n                      {subject.name}\n                    </SafeLink>\n                    <StyledSpacingElement />\n                  </>\n                )}\n                {letter.items.length - 1 === index && <StyledLetterSpacing />}\n              </StyledListItem>\n            </Fragment>\n          ))}\n        </Fragment>\n      );\n    })}\n  </StyledList>\n);\n\nconst FrontpageAllSubjects = ({\n  categories,\n  onNavigate,\n  onToggleSubject,\n  subjectViewType,\n  selectedSubjects,\n}: subjectsProps) => {\n  const allSubjects: subjectProps[] = [];\n  const data: any = [];\n  const { t } = useTranslation();\n\n  categories.forEach((category: categoryProps) => {\n    allSubjects.push(...category.subjects);\n    category.visible &&\n      data.push({\n        title: category.name || t(`subjectCategories.${category.type}`),\n        content: (\n          <>\n            {/* Should be persistent til fall 2022 */}\n            {category.name === t('subjectCategories.beta') && (\n              <MessageBoxWrapper>\n                <MessageBox>{t('messageBoxInfo.frontPageBeta')}</MessageBox>\n              </MessageBoxWrapper>\n            )}\n            {category.name === t('subjectCategories.archive') && (\n              <MessageBoxWrapper>\n                <MessageBox>{t('messageBoxInfo.frontPageExpired')}</MessageBox>\n              </MessageBoxWrapper>\n            )}\n\n            {renderList(category.subjects, onNavigate, onToggleSubject, subjectViewType, selectedSubjects)}\n          </>\n        ),\n      });\n  });\n\n  data.unshift({\n    title: t('frontpageMenu.allsubjects'),\n    content: renderList(allSubjects, onNavigate, onToggleSubject, subjectViewType, selectedSubjects),\n  });\n\n  return (\n    <StyledWrapper>\n      <Tabs modifier=\"subjects\" tabs={data} />\n    </StyledWrapper>\n  );\n};\n\nexport default FrontpageAllSubjects;\n"]} */",
71
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FrontpageAllSubjects.tsx"],"names":[],"mappings":"AA+CgC","file":"FrontpageAllSubjects.tsx","sourcesContent":["import React, { Fragment } from 'react';\nimport styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport Tabs from '@ndla/tabs';\nimport SafeLink from '@ndla/safelink';\nimport { colors, fonts, mq, breakpoints } from '@ndla/core';\nimport { MessageBox } from '../MessageBox';\n// @ts-ignore\nimport { ToggleItem } from '../Filter';\n\nconst StyledWrapper = styled.nav`\n  margin: 32px 0 0;\n  .c-tabs--subjects {\n    margin: 0;\n  }\n  .c-tabs__list--subjects {\n    margin: 0;\n  }\n  .c-tabs__tab--subjects {\n    ${mq.range({ until: breakpoints.tablet })} {\n      margin: 0;\n      font-size: 12px;\n      padding-left: 8px;\n      padding-right: 8px;\n      :first-of-type {\n        padding-left: 0;\n      }\n      :last-of-type {\n        padding-right: 0;\n      }\n    }\n  }\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 40px 0 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 StyledLetterItem = styled.span<{ subjectViewType?: string }>`\n  display: block;\n  ${fonts.sizes(30, 1)};\n  font-weight: ${fonts.weight.bold};\n  color: ${colors.brand.primary};\n  margin-bottom: 8px;\n  ${(props) => props.subjectViewType === 'checkbox' && `margin-left:37px;`}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 10px;\n`;\n\nconst StyledLetterSpacing = styled.span`\n  display: block;\n  height: 16px;\n`;\n\nconst MessageBoxWrapper = styled.div`\n  padding-top: 20px;\n`;\n\ntype subjectProps = {\n  name: string;\n  url?: string;\n  path?: string;\n  id?: string;\n};\ntype categoryProps = {\n  type?: string;\n  name?: string;\n  visible?: boolean;\n  subjects: subjectProps[];\n};\n\nexport type subjectsProps = {\n  categories: categoryProps[];\n  subjectViewType?: 'link' | 'checkbox';\n  onToggleSubject?: (id: string) => void;\n  onNavigate?: () => void;\n  selectedSubjects?: string[];\n};\n\ntype letterCategories = {\n  letter: string;\n  items: subjectProps[];\n};\n\nconst sortAlphabetically = (subjects: subjectProps[], locale: string = 'nb') => {\n  const subjectsSorted = subjects.sort((a, b) => a.name.localeCompare(b.name, locale));\n  const subjectsLetterCategories: letterCategories[] = [];\n  let previousLetter = '';\n  let letterItems: subjectProps[] = [];\n  subjectsSorted.forEach((subject: subjectProps) => {\n    const currentLetter = subject.name.substr(0, 1);\n    const isNewLetter = currentLetter.localeCompare(previousLetter, locale) === 1;\n    if (isNewLetter && letterItems.length) {\n      subjectsLetterCategories.push({\n        letter: previousLetter,\n        items: letterItems,\n      });\n      letterItems = [];\n    }\n    previousLetter = currentLetter;\n    letterItems.push(subject);\n  });\n  // Add last letter\n  if (previousLetter && letterItems.length) {\n    subjectsLetterCategories.push({\n      letter: previousLetter,\n      items: letterItems,\n    });\n  }\n  return subjectsLetterCategories;\n};\n\nconst renderList = (\n  subjects: subjectProps[],\n  onNavigate?: () => void,\n  onToggleSubject?: subjectsProps['onToggleSubject'],\n  subjectViewType?: subjectsProps['subjectViewType'],\n  selectedSubjects: subjectsProps['selectedSubjects'] = [],\n) => (\n  <StyledList>\n    {sortAlphabetically(subjects).map((letter: any) => {\n      return (\n        <Fragment key={letter.letter}>\n          {letter.items.map((subject: subjectProps, index: number) => (\n            <Fragment key={subject.name}>\n              <StyledListItem>\n                {index === 0 && <StyledLetterItem subjectViewType={subjectViewType}>{letter.letter}</StyledLetterItem>}\n                {subjectViewType === 'checkbox' && subject.id ? (\n                  <ToggleItem\n                    id={subject.id}\n                    value={subject.id}\n                    checked={selectedSubjects.includes(subject.id)}\n                    label={subject.name}\n                    component=\"div\"\n                    onChange={() => {\n                      if (onToggleSubject && subject.id) {\n                        onToggleSubject(subject.id);\n                      }\n                    }}\n                  />\n                ) : (\n                  <>\n                    <SafeLink\n                      onClick={() => {\n                        if (onNavigate) {\n                          onNavigate();\n                        }\n                      }}\n                      to={subject.url || subject.path || ''}>\n                      {subject.name}\n                    </SafeLink>\n                    <StyledSpacingElement />\n                  </>\n                )}\n                {letter.items.length - 1 === index && <StyledLetterSpacing />}\n              </StyledListItem>\n            </Fragment>\n          ))}\n        </Fragment>\n      );\n    })}\n  </StyledList>\n);\n\nconst FrontpageAllSubjects = ({\n  categories,\n  onNavigate,\n  onToggleSubject,\n  subjectViewType,\n  selectedSubjects,\n}: subjectsProps) => {\n  const allSubjects: subjectProps[] = [];\n  const data: any = [];\n  const { t } = useTranslation();\n\n  categories.forEach((category: categoryProps) => {\n    allSubjects.push(...category.subjects);\n    category.visible &&\n      data.push({\n        title: category.name || t(`subjectCategories.${category.type}`),\n        content: (\n          <>\n            {/* Should be persistent til fall 2022 */}\n            {category.name === t('subjectCategories.beta') && (\n              <MessageBoxWrapper>\n                <MessageBox>{t('messageBoxInfo.frontPageBeta')}</MessageBox>\n              </MessageBoxWrapper>\n            )}\n            {category.name === t('subjectCategories.archive') && (\n              <MessageBoxWrapper>\n                <MessageBox>{t('messageBoxInfo.frontPageExpired')}</MessageBox>\n              </MessageBoxWrapper>\n            )}\n\n            {renderList(category.subjects, onNavigate, onToggleSubject, subjectViewType, selectedSubjects)}\n          </>\n        ),\n      });\n  });\n\n  data.push({\n    title: t('frontpageMenu.allsubjects'),\n    content: renderList(allSubjects, onNavigate, onToggleSubject, subjectViewType, selectedSubjects),\n  });\n\n  return (\n    <StyledWrapper>\n      <Tabs modifier=\"subjects\" tabs={data} />\n    </StyledWrapper>\n  );\n};\n\nexport default FrontpageAllSubjects;\n"]} */",
72
72
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
73
73
  });
74
74
  var StyledLetterItem = (0, _styledBase["default"])("span", {
@@ -76,7 +76,7 @@ var StyledLetterItem = (0, _styledBase["default"])("span", {
76
76
  label: "StyledLetterItem"
77
77
  })("display:block;", _core.fonts.sizes(30, 1), ";font-weight:", _core.fonts.weight.bold, ";color:", _core.colors.brand.primary, ";margin-bottom:8px;", function (props) {
78
78
  return props.subjectViewType === 'checkbox' && "margin-left:37px;";
79
- }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FrontpageAllSubjects.tsx"],"names":[],"mappings":"AAoDkE","file":"FrontpageAllSubjects.tsx","sourcesContent":["import React, { Fragment } from 'react';\nimport styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport Tabs from '@ndla/tabs';\nimport SafeLink from '@ndla/safelink';\nimport { colors, fonts, mq, breakpoints } from '@ndla/core';\nimport { MessageBox } from '../MessageBox';\n// @ts-ignore\nimport { ToggleItem } from '../Filter';\n\nconst StyledWrapper = styled.nav`\n  margin: 32px 0 0;\n  .c-tabs--subjects {\n    margin: 0;\n  }\n  .c-tabs__list--subjects {\n    margin: 0;\n  }\n  .c-tabs__tab--subjects {\n    ${mq.range({ until: breakpoints.tablet })} {\n      margin: 0;\n      font-size: 12px;\n      padding-left: 8px;\n      padding-right: 8px;\n      :first-of-type {\n        padding-left: 0;\n      }\n      :last-of-type {\n        padding-right: 0;\n      }\n    }\n  }\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 40px 0 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 StyledLetterItem = styled.span<{ subjectViewType?: string }>`\n  display: block;\n  ${fonts.sizes(30, 1)};\n  font-weight: ${fonts.weight.bold};\n  color: ${colors.brand.primary};\n  margin-bottom: 8px;\n  ${(props) => props.subjectViewType === 'checkbox' && `margin-left:37px;`}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 10px;\n`;\n\nconst StyledLetterSpacing = styled.span`\n  display: block;\n  height: 16px;\n`;\n\nconst MessageBoxWrapper = styled.div`\n  padding-top: 20px;\n`;\n\ntype subjectProps = {\n  name: string;\n  url?: string;\n  path?: string;\n  id?: string;\n};\ntype categoryProps = {\n  type?: string;\n  name?: string;\n  visible?: boolean;\n  subjects: subjectProps[];\n};\n\nexport type subjectsProps = {\n  categories: categoryProps[];\n  subjectViewType?: 'link' | 'checkbox';\n  onToggleSubject?: (id: string) => void;\n  onNavigate?: () => void;\n  selectedSubjects?: string[];\n};\n\ntype letterCategories = {\n  letter: string;\n  items: subjectProps[];\n};\n\nconst sortAlphabetically = (subjects: subjectProps[], locale: string = 'nb') => {\n  const subjectsSorted = subjects.sort((a, b) => a.name.localeCompare(b.name, locale));\n  const subjectsLetterCategories: letterCategories[] = [];\n  let previousLetter = '';\n  let letterItems: subjectProps[] = [];\n  subjectsSorted.forEach((subject: subjectProps) => {\n    const currentLetter = subject.name.substr(0, 1);\n    const isNewLetter = currentLetter.localeCompare(previousLetter, locale) === 1;\n    if (isNewLetter && letterItems.length) {\n      subjectsLetterCategories.push({\n        letter: previousLetter,\n        items: letterItems,\n      });\n      letterItems = [];\n    }\n    previousLetter = currentLetter;\n    letterItems.push(subject);\n  });\n  // Add last letter\n  if (previousLetter && letterItems.length) {\n    subjectsLetterCategories.push({\n      letter: previousLetter,\n      items: letterItems,\n    });\n  }\n  return subjectsLetterCategories;\n};\n\nconst renderList = (\n  subjects: subjectProps[],\n  onNavigate?: () => void,\n  onToggleSubject?: subjectsProps['onToggleSubject'],\n  subjectViewType?: subjectsProps['subjectViewType'],\n  selectedSubjects: subjectsProps['selectedSubjects'] = [],\n) => (\n  <StyledList>\n    {sortAlphabetically(subjects).map((letter: any) => {\n      return (\n        <Fragment key={letter.letter}>\n          {letter.items.map((subject: subjectProps, index: number) => (\n            <Fragment key={subject.name}>\n              <StyledListItem>\n                {index === 0 && <StyledLetterItem subjectViewType={subjectViewType}>{letter.letter}</StyledLetterItem>}\n                {subjectViewType === 'checkbox' && subject.id ? (\n                  <ToggleItem\n                    id={subject.id}\n                    value={subject.id}\n                    checked={selectedSubjects.includes(subject.id)}\n                    label={subject.name}\n                    component=\"div\"\n                    onChange={() => {\n                      if (onToggleSubject && subject.id) {\n                        onToggleSubject(subject.id);\n                      }\n                    }}\n                  />\n                ) : (\n                  <>\n                    <SafeLink\n                      onClick={() => {\n                        if (onNavigate) {\n                          onNavigate();\n                        }\n                      }}\n                      to={subject.url || subject.path || ''}>\n                      {subject.name}\n                    </SafeLink>\n                    <StyledSpacingElement />\n                  </>\n                )}\n                {letter.items.length - 1 === index && <StyledLetterSpacing />}\n              </StyledListItem>\n            </Fragment>\n          ))}\n        </Fragment>\n      );\n    })}\n  </StyledList>\n);\n\nconst FrontpageAllSubjects = ({\n  categories,\n  onNavigate,\n  onToggleSubject,\n  subjectViewType,\n  selectedSubjects,\n}: subjectsProps) => {\n  const allSubjects: subjectProps[] = [];\n  const data: any = [];\n  const { t } = useTranslation();\n\n  categories.forEach((category: categoryProps) => {\n    allSubjects.push(...category.subjects);\n    category.visible &&\n      data.push({\n        title: category.name || t(`subjectCategories.${category.type}`),\n        content: (\n          <>\n            {/* Should be persistent til fall 2022 */}\n            {category.name === t('subjectCategories.beta') && (\n              <MessageBoxWrapper>\n                <MessageBox>{t('messageBoxInfo.frontPageBeta')}</MessageBox>\n              </MessageBoxWrapper>\n            )}\n            {category.name === t('subjectCategories.archive') && (\n              <MessageBoxWrapper>\n                <MessageBox>{t('messageBoxInfo.frontPageExpired')}</MessageBox>\n              </MessageBoxWrapper>\n            )}\n\n            {renderList(category.subjects, onNavigate, onToggleSubject, subjectViewType, selectedSubjects)}\n          </>\n        ),\n      });\n  });\n\n  data.unshift({\n    title: t('frontpageMenu.allsubjects'),\n    content: renderList(allSubjects, onNavigate, onToggleSubject, subjectViewType, selectedSubjects),\n  });\n\n  return (\n    <StyledWrapper>\n      <Tabs modifier=\"subjects\" tabs={data} />\n    </StyledWrapper>\n  );\n};\n\nexport default FrontpageAllSubjects;\n"]} */");
79
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FrontpageAllSubjects.tsx"],"names":[],"mappings":"AAoDkE","file":"FrontpageAllSubjects.tsx","sourcesContent":["import React, { Fragment } from 'react';\nimport styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport Tabs from '@ndla/tabs';\nimport SafeLink from '@ndla/safelink';\nimport { colors, fonts, mq, breakpoints } from '@ndla/core';\nimport { MessageBox } from '../MessageBox';\n// @ts-ignore\nimport { ToggleItem } from '../Filter';\n\nconst StyledWrapper = styled.nav`\n  margin: 32px 0 0;\n  .c-tabs--subjects {\n    margin: 0;\n  }\n  .c-tabs__list--subjects {\n    margin: 0;\n  }\n  .c-tabs__tab--subjects {\n    ${mq.range({ until: breakpoints.tablet })} {\n      margin: 0;\n      font-size: 12px;\n      padding-left: 8px;\n      padding-right: 8px;\n      :first-of-type {\n        padding-left: 0;\n      }\n      :last-of-type {\n        padding-right: 0;\n      }\n    }\n  }\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 40px 0 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 StyledLetterItem = styled.span<{ subjectViewType?: string }>`\n  display: block;\n  ${fonts.sizes(30, 1)};\n  font-weight: ${fonts.weight.bold};\n  color: ${colors.brand.primary};\n  margin-bottom: 8px;\n  ${(props) => props.subjectViewType === 'checkbox' && `margin-left:37px;`}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 10px;\n`;\n\nconst StyledLetterSpacing = styled.span`\n  display: block;\n  height: 16px;\n`;\n\nconst MessageBoxWrapper = styled.div`\n  padding-top: 20px;\n`;\n\ntype subjectProps = {\n  name: string;\n  url?: string;\n  path?: string;\n  id?: string;\n};\ntype categoryProps = {\n  type?: string;\n  name?: string;\n  visible?: boolean;\n  subjects: subjectProps[];\n};\n\nexport type subjectsProps = {\n  categories: categoryProps[];\n  subjectViewType?: 'link' | 'checkbox';\n  onToggleSubject?: (id: string) => void;\n  onNavigate?: () => void;\n  selectedSubjects?: string[];\n};\n\ntype letterCategories = {\n  letter: string;\n  items: subjectProps[];\n};\n\nconst sortAlphabetically = (subjects: subjectProps[], locale: string = 'nb') => {\n  const subjectsSorted = subjects.sort((a, b) => a.name.localeCompare(b.name, locale));\n  const subjectsLetterCategories: letterCategories[] = [];\n  let previousLetter = '';\n  let letterItems: subjectProps[] = [];\n  subjectsSorted.forEach((subject: subjectProps) => {\n    const currentLetter = subject.name.substr(0, 1);\n    const isNewLetter = currentLetter.localeCompare(previousLetter, locale) === 1;\n    if (isNewLetter && letterItems.length) {\n      subjectsLetterCategories.push({\n        letter: previousLetter,\n        items: letterItems,\n      });\n      letterItems = [];\n    }\n    previousLetter = currentLetter;\n    letterItems.push(subject);\n  });\n  // Add last letter\n  if (previousLetter && letterItems.length) {\n    subjectsLetterCategories.push({\n      letter: previousLetter,\n      items: letterItems,\n    });\n  }\n  return subjectsLetterCategories;\n};\n\nconst renderList = (\n  subjects: subjectProps[],\n  onNavigate?: () => void,\n  onToggleSubject?: subjectsProps['onToggleSubject'],\n  subjectViewType?: subjectsProps['subjectViewType'],\n  selectedSubjects: subjectsProps['selectedSubjects'] = [],\n) => (\n  <StyledList>\n    {sortAlphabetically(subjects).map((letter: any) => {\n      return (\n        <Fragment key={letter.letter}>\n          {letter.items.map((subject: subjectProps, index: number) => (\n            <Fragment key={subject.name}>\n              <StyledListItem>\n                {index === 0 && <StyledLetterItem subjectViewType={subjectViewType}>{letter.letter}</StyledLetterItem>}\n                {subjectViewType === 'checkbox' && subject.id ? (\n                  <ToggleItem\n                    id={subject.id}\n                    value={subject.id}\n                    checked={selectedSubjects.includes(subject.id)}\n                    label={subject.name}\n                    component=\"div\"\n                    onChange={() => {\n                      if (onToggleSubject && subject.id) {\n                        onToggleSubject(subject.id);\n                      }\n                    }}\n                  />\n                ) : (\n                  <>\n                    <SafeLink\n                      onClick={() => {\n                        if (onNavigate) {\n                          onNavigate();\n                        }\n                      }}\n                      to={subject.url || subject.path || ''}>\n                      {subject.name}\n                    </SafeLink>\n                    <StyledSpacingElement />\n                  </>\n                )}\n                {letter.items.length - 1 === index && <StyledLetterSpacing />}\n              </StyledListItem>\n            </Fragment>\n          ))}\n        </Fragment>\n      );\n    })}\n  </StyledList>\n);\n\nconst FrontpageAllSubjects = ({\n  categories,\n  onNavigate,\n  onToggleSubject,\n  subjectViewType,\n  selectedSubjects,\n}: subjectsProps) => {\n  const allSubjects: subjectProps[] = [];\n  const data: any = [];\n  const { t } = useTranslation();\n\n  categories.forEach((category: categoryProps) => {\n    allSubjects.push(...category.subjects);\n    category.visible &&\n      data.push({\n        title: category.name || t(`subjectCategories.${category.type}`),\n        content: (\n          <>\n            {/* Should be persistent til fall 2022 */}\n            {category.name === t('subjectCategories.beta') && (\n              <MessageBoxWrapper>\n                <MessageBox>{t('messageBoxInfo.frontPageBeta')}</MessageBox>\n              </MessageBoxWrapper>\n            )}\n            {category.name === t('subjectCategories.archive') && (\n              <MessageBoxWrapper>\n                <MessageBox>{t('messageBoxInfo.frontPageExpired')}</MessageBox>\n              </MessageBoxWrapper>\n            )}\n\n            {renderList(category.subjects, onNavigate, onToggleSubject, subjectViewType, selectedSubjects)}\n          </>\n        ),\n      });\n  });\n\n  data.push({\n    title: t('frontpageMenu.allsubjects'),\n    content: renderList(allSubjects, onNavigate, onToggleSubject, subjectViewType, selectedSubjects),\n  });\n\n  return (\n    <StyledWrapper>\n      <Tabs modifier=\"subjects\" tabs={data} />\n    </StyledWrapper>\n  );\n};\n\nexport default FrontpageAllSubjects;\n"]} */");
80
80
  var StyledSpacingElement = (0, _styledBase["default"])("span", {
81
81
  target: "e1kk5ejg4",
82
82
  label: "StyledSpacingElement"
@@ -86,7 +86,7 @@ var StyledSpacingElement = (0, _styledBase["default"])("span", {
86
86
  } : {
87
87
  name: "mdpz57",
88
88
  styles: "display:block;width:100%;height:10px;",
89
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FrontpageAllSubjects.tsx"],"names":[],"mappings":"AA6DwC","file":"FrontpageAllSubjects.tsx","sourcesContent":["import React, { Fragment } from 'react';\nimport styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport Tabs from '@ndla/tabs';\nimport SafeLink from '@ndla/safelink';\nimport { colors, fonts, mq, breakpoints } from '@ndla/core';\nimport { MessageBox } from '../MessageBox';\n// @ts-ignore\nimport { ToggleItem } from '../Filter';\n\nconst StyledWrapper = styled.nav`\n  margin: 32px 0 0;\n  .c-tabs--subjects {\n    margin: 0;\n  }\n  .c-tabs__list--subjects {\n    margin: 0;\n  }\n  .c-tabs__tab--subjects {\n    ${mq.range({ until: breakpoints.tablet })} {\n      margin: 0;\n      font-size: 12px;\n      padding-left: 8px;\n      padding-right: 8px;\n      :first-of-type {\n        padding-left: 0;\n      }\n      :last-of-type {\n        padding-right: 0;\n      }\n    }\n  }\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 40px 0 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 StyledLetterItem = styled.span<{ subjectViewType?: string }>`\n  display: block;\n  ${fonts.sizes(30, 1)};\n  font-weight: ${fonts.weight.bold};\n  color: ${colors.brand.primary};\n  margin-bottom: 8px;\n  ${(props) => props.subjectViewType === 'checkbox' && `margin-left:37px;`}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 10px;\n`;\n\nconst StyledLetterSpacing = styled.span`\n  display: block;\n  height: 16px;\n`;\n\nconst MessageBoxWrapper = styled.div`\n  padding-top: 20px;\n`;\n\ntype subjectProps = {\n  name: string;\n  url?: string;\n  path?: string;\n  id?: string;\n};\ntype categoryProps = {\n  type?: string;\n  name?: string;\n  visible?: boolean;\n  subjects: subjectProps[];\n};\n\nexport type subjectsProps = {\n  categories: categoryProps[];\n  subjectViewType?: 'link' | 'checkbox';\n  onToggleSubject?: (id: string) => void;\n  onNavigate?: () => void;\n  selectedSubjects?: string[];\n};\n\ntype letterCategories = {\n  letter: string;\n  items: subjectProps[];\n};\n\nconst sortAlphabetically = (subjects: subjectProps[], locale: string = 'nb') => {\n  const subjectsSorted = subjects.sort((a, b) => a.name.localeCompare(b.name, locale));\n  const subjectsLetterCategories: letterCategories[] = [];\n  let previousLetter = '';\n  let letterItems: subjectProps[] = [];\n  subjectsSorted.forEach((subject: subjectProps) => {\n    const currentLetter = subject.name.substr(0, 1);\n    const isNewLetter = currentLetter.localeCompare(previousLetter, locale) === 1;\n    if (isNewLetter && letterItems.length) {\n      subjectsLetterCategories.push({\n        letter: previousLetter,\n        items: letterItems,\n      });\n      letterItems = [];\n    }\n    previousLetter = currentLetter;\n    letterItems.push(subject);\n  });\n  // Add last letter\n  if (previousLetter && letterItems.length) {\n    subjectsLetterCategories.push({\n      letter: previousLetter,\n      items: letterItems,\n    });\n  }\n  return subjectsLetterCategories;\n};\n\nconst renderList = (\n  subjects: subjectProps[],\n  onNavigate?: () => void,\n  onToggleSubject?: subjectsProps['onToggleSubject'],\n  subjectViewType?: subjectsProps['subjectViewType'],\n  selectedSubjects: subjectsProps['selectedSubjects'] = [],\n) => (\n  <StyledList>\n    {sortAlphabetically(subjects).map((letter: any) => {\n      return (\n        <Fragment key={letter.letter}>\n          {letter.items.map((subject: subjectProps, index: number) => (\n            <Fragment key={subject.name}>\n              <StyledListItem>\n                {index === 0 && <StyledLetterItem subjectViewType={subjectViewType}>{letter.letter}</StyledLetterItem>}\n                {subjectViewType === 'checkbox' && subject.id ? (\n                  <ToggleItem\n                    id={subject.id}\n                    value={subject.id}\n                    checked={selectedSubjects.includes(subject.id)}\n                    label={subject.name}\n                    component=\"div\"\n                    onChange={() => {\n                      if (onToggleSubject && subject.id) {\n                        onToggleSubject(subject.id);\n                      }\n                    }}\n                  />\n                ) : (\n                  <>\n                    <SafeLink\n                      onClick={() => {\n                        if (onNavigate) {\n                          onNavigate();\n                        }\n                      }}\n                      to={subject.url || subject.path || ''}>\n                      {subject.name}\n                    </SafeLink>\n                    <StyledSpacingElement />\n                  </>\n                )}\n                {letter.items.length - 1 === index && <StyledLetterSpacing />}\n              </StyledListItem>\n            </Fragment>\n          ))}\n        </Fragment>\n      );\n    })}\n  </StyledList>\n);\n\nconst FrontpageAllSubjects = ({\n  categories,\n  onNavigate,\n  onToggleSubject,\n  subjectViewType,\n  selectedSubjects,\n}: subjectsProps) => {\n  const allSubjects: subjectProps[] = [];\n  const data: any = [];\n  const { t } = useTranslation();\n\n  categories.forEach((category: categoryProps) => {\n    allSubjects.push(...category.subjects);\n    category.visible &&\n      data.push({\n        title: category.name || t(`subjectCategories.${category.type}`),\n        content: (\n          <>\n            {/* Should be persistent til fall 2022 */}\n            {category.name === t('subjectCategories.beta') && (\n              <MessageBoxWrapper>\n                <MessageBox>{t('messageBoxInfo.frontPageBeta')}</MessageBox>\n              </MessageBoxWrapper>\n            )}\n            {category.name === t('subjectCategories.archive') && (\n              <MessageBoxWrapper>\n                <MessageBox>{t('messageBoxInfo.frontPageExpired')}</MessageBox>\n              </MessageBoxWrapper>\n            )}\n\n            {renderList(category.subjects, onNavigate, onToggleSubject, subjectViewType, selectedSubjects)}\n          </>\n        ),\n      });\n  });\n\n  data.unshift({\n    title: t('frontpageMenu.allsubjects'),\n    content: renderList(allSubjects, onNavigate, onToggleSubject, subjectViewType, selectedSubjects),\n  });\n\n  return (\n    <StyledWrapper>\n      <Tabs modifier=\"subjects\" tabs={data} />\n    </StyledWrapper>\n  );\n};\n\nexport default FrontpageAllSubjects;\n"]} */",
89
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FrontpageAllSubjects.tsx"],"names":[],"mappings":"AA6DwC","file":"FrontpageAllSubjects.tsx","sourcesContent":["import React, { Fragment } from 'react';\nimport styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport Tabs from '@ndla/tabs';\nimport SafeLink from '@ndla/safelink';\nimport { colors, fonts, mq, breakpoints } from '@ndla/core';\nimport { MessageBox } from '../MessageBox';\n// @ts-ignore\nimport { ToggleItem } from '../Filter';\n\nconst StyledWrapper = styled.nav`\n  margin: 32px 0 0;\n  .c-tabs--subjects {\n    margin: 0;\n  }\n  .c-tabs__list--subjects {\n    margin: 0;\n  }\n  .c-tabs__tab--subjects {\n    ${mq.range({ until: breakpoints.tablet })} {\n      margin: 0;\n      font-size: 12px;\n      padding-left: 8px;\n      padding-right: 8px;\n      :first-of-type {\n        padding-left: 0;\n      }\n      :last-of-type {\n        padding-right: 0;\n      }\n    }\n  }\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 40px 0 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 StyledLetterItem = styled.span<{ subjectViewType?: string }>`\n  display: block;\n  ${fonts.sizes(30, 1)};\n  font-weight: ${fonts.weight.bold};\n  color: ${colors.brand.primary};\n  margin-bottom: 8px;\n  ${(props) => props.subjectViewType === 'checkbox' && `margin-left:37px;`}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 10px;\n`;\n\nconst StyledLetterSpacing = styled.span`\n  display: block;\n  height: 16px;\n`;\n\nconst MessageBoxWrapper = styled.div`\n  padding-top: 20px;\n`;\n\ntype subjectProps = {\n  name: string;\n  url?: string;\n  path?: string;\n  id?: string;\n};\ntype categoryProps = {\n  type?: string;\n  name?: string;\n  visible?: boolean;\n  subjects: subjectProps[];\n};\n\nexport type subjectsProps = {\n  categories: categoryProps[];\n  subjectViewType?: 'link' | 'checkbox';\n  onToggleSubject?: (id: string) => void;\n  onNavigate?: () => void;\n  selectedSubjects?: string[];\n};\n\ntype letterCategories = {\n  letter: string;\n  items: subjectProps[];\n};\n\nconst sortAlphabetically = (subjects: subjectProps[], locale: string = 'nb') => {\n  const subjectsSorted = subjects.sort((a, b) => a.name.localeCompare(b.name, locale));\n  const subjectsLetterCategories: letterCategories[] = [];\n  let previousLetter = '';\n  let letterItems: subjectProps[] = [];\n  subjectsSorted.forEach((subject: subjectProps) => {\n    const currentLetter = subject.name.substr(0, 1);\n    const isNewLetter = currentLetter.localeCompare(previousLetter, locale) === 1;\n    if (isNewLetter && letterItems.length) {\n      subjectsLetterCategories.push({\n        letter: previousLetter,\n        items: letterItems,\n      });\n      letterItems = [];\n    }\n    previousLetter = currentLetter;\n    letterItems.push(subject);\n  });\n  // Add last letter\n  if (previousLetter && letterItems.length) {\n    subjectsLetterCategories.push({\n      letter: previousLetter,\n      items: letterItems,\n    });\n  }\n  return subjectsLetterCategories;\n};\n\nconst renderList = (\n  subjects: subjectProps[],\n  onNavigate?: () => void,\n  onToggleSubject?: subjectsProps['onToggleSubject'],\n  subjectViewType?: subjectsProps['subjectViewType'],\n  selectedSubjects: subjectsProps['selectedSubjects'] = [],\n) => (\n  <StyledList>\n    {sortAlphabetically(subjects).map((letter: any) => {\n      return (\n        <Fragment key={letter.letter}>\n          {letter.items.map((subject: subjectProps, index: number) => (\n            <Fragment key={subject.name}>\n              <StyledListItem>\n                {index === 0 && <StyledLetterItem subjectViewType={subjectViewType}>{letter.letter}</StyledLetterItem>}\n                {subjectViewType === 'checkbox' && subject.id ? (\n                  <ToggleItem\n                    id={subject.id}\n                    value={subject.id}\n                    checked={selectedSubjects.includes(subject.id)}\n                    label={subject.name}\n                    component=\"div\"\n                    onChange={() => {\n                      if (onToggleSubject && subject.id) {\n                        onToggleSubject(subject.id);\n                      }\n                    }}\n                  />\n                ) : (\n                  <>\n                    <SafeLink\n                      onClick={() => {\n                        if (onNavigate) {\n                          onNavigate();\n                        }\n                      }}\n                      to={subject.url || subject.path || ''}>\n                      {subject.name}\n                    </SafeLink>\n                    <StyledSpacingElement />\n                  </>\n                )}\n                {letter.items.length - 1 === index && <StyledLetterSpacing />}\n              </StyledListItem>\n            </Fragment>\n          ))}\n        </Fragment>\n      );\n    })}\n  </StyledList>\n);\n\nconst FrontpageAllSubjects = ({\n  categories,\n  onNavigate,\n  onToggleSubject,\n  subjectViewType,\n  selectedSubjects,\n}: subjectsProps) => {\n  const allSubjects: subjectProps[] = [];\n  const data: any = [];\n  const { t } = useTranslation();\n\n  categories.forEach((category: categoryProps) => {\n    allSubjects.push(...category.subjects);\n    category.visible &&\n      data.push({\n        title: category.name || t(`subjectCategories.${category.type}`),\n        content: (\n          <>\n            {/* Should be persistent til fall 2022 */}\n            {category.name === t('subjectCategories.beta') && (\n              <MessageBoxWrapper>\n                <MessageBox>{t('messageBoxInfo.frontPageBeta')}</MessageBox>\n              </MessageBoxWrapper>\n            )}\n            {category.name === t('subjectCategories.archive') && (\n              <MessageBoxWrapper>\n                <MessageBox>{t('messageBoxInfo.frontPageExpired')}</MessageBox>\n              </MessageBoxWrapper>\n            )}\n\n            {renderList(category.subjects, onNavigate, onToggleSubject, subjectViewType, selectedSubjects)}\n          </>\n        ),\n      });\n  });\n\n  data.push({\n    title: t('frontpageMenu.allsubjects'),\n    content: renderList(allSubjects, onNavigate, onToggleSubject, subjectViewType, selectedSubjects),\n  });\n\n  return (\n    <StyledWrapper>\n      <Tabs modifier=\"subjects\" tabs={data} />\n    </StyledWrapper>\n  );\n};\n\nexport default FrontpageAllSubjects;\n"]} */",
90
90
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
91
91
  });
92
92
  var StyledLetterSpacing = (0, _styledBase["default"])("span", {
@@ -98,7 +98,7 @@ var StyledLetterSpacing = (0, _styledBase["default"])("span", {
98
98
  } : {
99
99
  name: "idyyz2",
100
100
  styles: "display:block;height:16px;",
101
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FrontpageAllSubjects.tsx"],"names":[],"mappings":"AAmEuC","file":"FrontpageAllSubjects.tsx","sourcesContent":["import React, { Fragment } from 'react';\nimport styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport Tabs from '@ndla/tabs';\nimport SafeLink from '@ndla/safelink';\nimport { colors, fonts, mq, breakpoints } from '@ndla/core';\nimport { MessageBox } from '../MessageBox';\n// @ts-ignore\nimport { ToggleItem } from '../Filter';\n\nconst StyledWrapper = styled.nav`\n  margin: 32px 0 0;\n  .c-tabs--subjects {\n    margin: 0;\n  }\n  .c-tabs__list--subjects {\n    margin: 0;\n  }\n  .c-tabs__tab--subjects {\n    ${mq.range({ until: breakpoints.tablet })} {\n      margin: 0;\n      font-size: 12px;\n      padding-left: 8px;\n      padding-right: 8px;\n      :first-of-type {\n        padding-left: 0;\n      }\n      :last-of-type {\n        padding-right: 0;\n      }\n    }\n  }\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 40px 0 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 StyledLetterItem = styled.span<{ subjectViewType?: string }>`\n  display: block;\n  ${fonts.sizes(30, 1)};\n  font-weight: ${fonts.weight.bold};\n  color: ${colors.brand.primary};\n  margin-bottom: 8px;\n  ${(props) => props.subjectViewType === 'checkbox' && `margin-left:37px;`}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 10px;\n`;\n\nconst StyledLetterSpacing = styled.span`\n  display: block;\n  height: 16px;\n`;\n\nconst MessageBoxWrapper = styled.div`\n  padding-top: 20px;\n`;\n\ntype subjectProps = {\n  name: string;\n  url?: string;\n  path?: string;\n  id?: string;\n};\ntype categoryProps = {\n  type?: string;\n  name?: string;\n  visible?: boolean;\n  subjects: subjectProps[];\n};\n\nexport type subjectsProps = {\n  categories: categoryProps[];\n  subjectViewType?: 'link' | 'checkbox';\n  onToggleSubject?: (id: string) => void;\n  onNavigate?: () => void;\n  selectedSubjects?: string[];\n};\n\ntype letterCategories = {\n  letter: string;\n  items: subjectProps[];\n};\n\nconst sortAlphabetically = (subjects: subjectProps[], locale: string = 'nb') => {\n  const subjectsSorted = subjects.sort((a, b) => a.name.localeCompare(b.name, locale));\n  const subjectsLetterCategories: letterCategories[] = [];\n  let previousLetter = '';\n  let letterItems: subjectProps[] = [];\n  subjectsSorted.forEach((subject: subjectProps) => {\n    const currentLetter = subject.name.substr(0, 1);\n    const isNewLetter = currentLetter.localeCompare(previousLetter, locale) === 1;\n    if (isNewLetter && letterItems.length) {\n      subjectsLetterCategories.push({\n        letter: previousLetter,\n        items: letterItems,\n      });\n      letterItems = [];\n    }\n    previousLetter = currentLetter;\n    letterItems.push(subject);\n  });\n  // Add last letter\n  if (previousLetter && letterItems.length) {\n    subjectsLetterCategories.push({\n      letter: previousLetter,\n      items: letterItems,\n    });\n  }\n  return subjectsLetterCategories;\n};\n\nconst renderList = (\n  subjects: subjectProps[],\n  onNavigate?: () => void,\n  onToggleSubject?: subjectsProps['onToggleSubject'],\n  subjectViewType?: subjectsProps['subjectViewType'],\n  selectedSubjects: subjectsProps['selectedSubjects'] = [],\n) => (\n  <StyledList>\n    {sortAlphabetically(subjects).map((letter: any) => {\n      return (\n        <Fragment key={letter.letter}>\n          {letter.items.map((subject: subjectProps, index: number) => (\n            <Fragment key={subject.name}>\n              <StyledListItem>\n                {index === 0 && <StyledLetterItem subjectViewType={subjectViewType}>{letter.letter}</StyledLetterItem>}\n                {subjectViewType === 'checkbox' && subject.id ? (\n                  <ToggleItem\n                    id={subject.id}\n                    value={subject.id}\n                    checked={selectedSubjects.includes(subject.id)}\n                    label={subject.name}\n                    component=\"div\"\n                    onChange={() => {\n                      if (onToggleSubject && subject.id) {\n                        onToggleSubject(subject.id);\n                      }\n                    }}\n                  />\n                ) : (\n                  <>\n                    <SafeLink\n                      onClick={() => {\n                        if (onNavigate) {\n                          onNavigate();\n                        }\n                      }}\n                      to={subject.url || subject.path || ''}>\n                      {subject.name}\n                    </SafeLink>\n                    <StyledSpacingElement />\n                  </>\n                )}\n                {letter.items.length - 1 === index && <StyledLetterSpacing />}\n              </StyledListItem>\n            </Fragment>\n          ))}\n        </Fragment>\n      );\n    })}\n  </StyledList>\n);\n\nconst FrontpageAllSubjects = ({\n  categories,\n  onNavigate,\n  onToggleSubject,\n  subjectViewType,\n  selectedSubjects,\n}: subjectsProps) => {\n  const allSubjects: subjectProps[] = [];\n  const data: any = [];\n  const { t } = useTranslation();\n\n  categories.forEach((category: categoryProps) => {\n    allSubjects.push(...category.subjects);\n    category.visible &&\n      data.push({\n        title: category.name || t(`subjectCategories.${category.type}`),\n        content: (\n          <>\n            {/* Should be persistent til fall 2022 */}\n            {category.name === t('subjectCategories.beta') && (\n              <MessageBoxWrapper>\n                <MessageBox>{t('messageBoxInfo.frontPageBeta')}</MessageBox>\n              </MessageBoxWrapper>\n            )}\n            {category.name === t('subjectCategories.archive') && (\n              <MessageBoxWrapper>\n                <MessageBox>{t('messageBoxInfo.frontPageExpired')}</MessageBox>\n              </MessageBoxWrapper>\n            )}\n\n            {renderList(category.subjects, onNavigate, onToggleSubject, subjectViewType, selectedSubjects)}\n          </>\n        ),\n      });\n  });\n\n  data.unshift({\n    title: t('frontpageMenu.allsubjects'),\n    content: renderList(allSubjects, onNavigate, onToggleSubject, subjectViewType, selectedSubjects),\n  });\n\n  return (\n    <StyledWrapper>\n      <Tabs modifier=\"subjects\" tabs={data} />\n    </StyledWrapper>\n  );\n};\n\nexport default FrontpageAllSubjects;\n"]} */",
101
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FrontpageAllSubjects.tsx"],"names":[],"mappings":"AAmEuC","file":"FrontpageAllSubjects.tsx","sourcesContent":["import React, { Fragment } from 'react';\nimport styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport Tabs from '@ndla/tabs';\nimport SafeLink from '@ndla/safelink';\nimport { colors, fonts, mq, breakpoints } from '@ndla/core';\nimport { MessageBox } from '../MessageBox';\n// @ts-ignore\nimport { ToggleItem } from '../Filter';\n\nconst StyledWrapper = styled.nav`\n  margin: 32px 0 0;\n  .c-tabs--subjects {\n    margin: 0;\n  }\n  .c-tabs__list--subjects {\n    margin: 0;\n  }\n  .c-tabs__tab--subjects {\n    ${mq.range({ until: breakpoints.tablet })} {\n      margin: 0;\n      font-size: 12px;\n      padding-left: 8px;\n      padding-right: 8px;\n      :first-of-type {\n        padding-left: 0;\n      }\n      :last-of-type {\n        padding-right: 0;\n      }\n    }\n  }\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 40px 0 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 StyledLetterItem = styled.span<{ subjectViewType?: string }>`\n  display: block;\n  ${fonts.sizes(30, 1)};\n  font-weight: ${fonts.weight.bold};\n  color: ${colors.brand.primary};\n  margin-bottom: 8px;\n  ${(props) => props.subjectViewType === 'checkbox' && `margin-left:37px;`}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 10px;\n`;\n\nconst StyledLetterSpacing = styled.span`\n  display: block;\n  height: 16px;\n`;\n\nconst MessageBoxWrapper = styled.div`\n  padding-top: 20px;\n`;\n\ntype subjectProps = {\n  name: string;\n  url?: string;\n  path?: string;\n  id?: string;\n};\ntype categoryProps = {\n  type?: string;\n  name?: string;\n  visible?: boolean;\n  subjects: subjectProps[];\n};\n\nexport type subjectsProps = {\n  categories: categoryProps[];\n  subjectViewType?: 'link' | 'checkbox';\n  onToggleSubject?: (id: string) => void;\n  onNavigate?: () => void;\n  selectedSubjects?: string[];\n};\n\ntype letterCategories = {\n  letter: string;\n  items: subjectProps[];\n};\n\nconst sortAlphabetically = (subjects: subjectProps[], locale: string = 'nb') => {\n  const subjectsSorted = subjects.sort((a, b) => a.name.localeCompare(b.name, locale));\n  const subjectsLetterCategories: letterCategories[] = [];\n  let previousLetter = '';\n  let letterItems: subjectProps[] = [];\n  subjectsSorted.forEach((subject: subjectProps) => {\n    const currentLetter = subject.name.substr(0, 1);\n    const isNewLetter = currentLetter.localeCompare(previousLetter, locale) === 1;\n    if (isNewLetter && letterItems.length) {\n      subjectsLetterCategories.push({\n        letter: previousLetter,\n        items: letterItems,\n      });\n      letterItems = [];\n    }\n    previousLetter = currentLetter;\n    letterItems.push(subject);\n  });\n  // Add last letter\n  if (previousLetter && letterItems.length) {\n    subjectsLetterCategories.push({\n      letter: previousLetter,\n      items: letterItems,\n    });\n  }\n  return subjectsLetterCategories;\n};\n\nconst renderList = (\n  subjects: subjectProps[],\n  onNavigate?: () => void,\n  onToggleSubject?: subjectsProps['onToggleSubject'],\n  subjectViewType?: subjectsProps['subjectViewType'],\n  selectedSubjects: subjectsProps['selectedSubjects'] = [],\n) => (\n  <StyledList>\n    {sortAlphabetically(subjects).map((letter: any) => {\n      return (\n        <Fragment key={letter.letter}>\n          {letter.items.map((subject: subjectProps, index: number) => (\n            <Fragment key={subject.name}>\n              <StyledListItem>\n                {index === 0 && <StyledLetterItem subjectViewType={subjectViewType}>{letter.letter}</StyledLetterItem>}\n                {subjectViewType === 'checkbox' && subject.id ? (\n                  <ToggleItem\n                    id={subject.id}\n                    value={subject.id}\n                    checked={selectedSubjects.includes(subject.id)}\n                    label={subject.name}\n                    component=\"div\"\n                    onChange={() => {\n                      if (onToggleSubject && subject.id) {\n                        onToggleSubject(subject.id);\n                      }\n                    }}\n                  />\n                ) : (\n                  <>\n                    <SafeLink\n                      onClick={() => {\n                        if (onNavigate) {\n                          onNavigate();\n                        }\n                      }}\n                      to={subject.url || subject.path || ''}>\n                      {subject.name}\n                    </SafeLink>\n                    <StyledSpacingElement />\n                  </>\n                )}\n                {letter.items.length - 1 === index && <StyledLetterSpacing />}\n              </StyledListItem>\n            </Fragment>\n          ))}\n        </Fragment>\n      );\n    })}\n  </StyledList>\n);\n\nconst FrontpageAllSubjects = ({\n  categories,\n  onNavigate,\n  onToggleSubject,\n  subjectViewType,\n  selectedSubjects,\n}: subjectsProps) => {\n  const allSubjects: subjectProps[] = [];\n  const data: any = [];\n  const { t } = useTranslation();\n\n  categories.forEach((category: categoryProps) => {\n    allSubjects.push(...category.subjects);\n    category.visible &&\n      data.push({\n        title: category.name || t(`subjectCategories.${category.type}`),\n        content: (\n          <>\n            {/* Should be persistent til fall 2022 */}\n            {category.name === t('subjectCategories.beta') && (\n              <MessageBoxWrapper>\n                <MessageBox>{t('messageBoxInfo.frontPageBeta')}</MessageBox>\n              </MessageBoxWrapper>\n            )}\n            {category.name === t('subjectCategories.archive') && (\n              <MessageBoxWrapper>\n                <MessageBox>{t('messageBoxInfo.frontPageExpired')}</MessageBox>\n              </MessageBoxWrapper>\n            )}\n\n            {renderList(category.subjects, onNavigate, onToggleSubject, subjectViewType, selectedSubjects)}\n          </>\n        ),\n      });\n  });\n\n  data.push({\n    title: t('frontpageMenu.allsubjects'),\n    content: renderList(allSubjects, onNavigate, onToggleSubject, subjectViewType, selectedSubjects),\n  });\n\n  return (\n    <StyledWrapper>\n      <Tabs modifier=\"subjects\" tabs={data} />\n    </StyledWrapper>\n  );\n};\n\nexport default FrontpageAllSubjects;\n"]} */",
102
102
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
103
103
  });
104
104
  var MessageBoxWrapper = (0, _styledBase["default"])("div", {
@@ -110,7 +110,7 @@ var MessageBoxWrapper = (0, _styledBase["default"])("div", {
110
110
  } : {
111
111
  name: "7w6khc",
112
112
  styles: "padding-top:20px;",
113
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FrontpageAllSubjects.tsx"],"names":[],"mappings":"AAwEoC","file":"FrontpageAllSubjects.tsx","sourcesContent":["import React, { Fragment } from 'react';\nimport styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport Tabs from '@ndla/tabs';\nimport SafeLink from '@ndla/safelink';\nimport { colors, fonts, mq, breakpoints } from '@ndla/core';\nimport { MessageBox } from '../MessageBox';\n// @ts-ignore\nimport { ToggleItem } from '../Filter';\n\nconst StyledWrapper = styled.nav`\n  margin: 32px 0 0;\n  .c-tabs--subjects {\n    margin: 0;\n  }\n  .c-tabs__list--subjects {\n    margin: 0;\n  }\n  .c-tabs__tab--subjects {\n    ${mq.range({ until: breakpoints.tablet })} {\n      margin: 0;\n      font-size: 12px;\n      padding-left: 8px;\n      padding-right: 8px;\n      :first-of-type {\n        padding-left: 0;\n      }\n      :last-of-type {\n        padding-right: 0;\n      }\n    }\n  }\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 40px 0 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 StyledLetterItem = styled.span<{ subjectViewType?: string }>`\n  display: block;\n  ${fonts.sizes(30, 1)};\n  font-weight: ${fonts.weight.bold};\n  color: ${colors.brand.primary};\n  margin-bottom: 8px;\n  ${(props) => props.subjectViewType === 'checkbox' && `margin-left:37px;`}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 10px;\n`;\n\nconst StyledLetterSpacing = styled.span`\n  display: block;\n  height: 16px;\n`;\n\nconst MessageBoxWrapper = styled.div`\n  padding-top: 20px;\n`;\n\ntype subjectProps = {\n  name: string;\n  url?: string;\n  path?: string;\n  id?: string;\n};\ntype categoryProps = {\n  type?: string;\n  name?: string;\n  visible?: boolean;\n  subjects: subjectProps[];\n};\n\nexport type subjectsProps = {\n  categories: categoryProps[];\n  subjectViewType?: 'link' | 'checkbox';\n  onToggleSubject?: (id: string) => void;\n  onNavigate?: () => void;\n  selectedSubjects?: string[];\n};\n\ntype letterCategories = {\n  letter: string;\n  items: subjectProps[];\n};\n\nconst sortAlphabetically = (subjects: subjectProps[], locale: string = 'nb') => {\n  const subjectsSorted = subjects.sort((a, b) => a.name.localeCompare(b.name, locale));\n  const subjectsLetterCategories: letterCategories[] = [];\n  let previousLetter = '';\n  let letterItems: subjectProps[] = [];\n  subjectsSorted.forEach((subject: subjectProps) => {\n    const currentLetter = subject.name.substr(0, 1);\n    const isNewLetter = currentLetter.localeCompare(previousLetter, locale) === 1;\n    if (isNewLetter && letterItems.length) {\n      subjectsLetterCategories.push({\n        letter: previousLetter,\n        items: letterItems,\n      });\n      letterItems = [];\n    }\n    previousLetter = currentLetter;\n    letterItems.push(subject);\n  });\n  // Add last letter\n  if (previousLetter && letterItems.length) {\n    subjectsLetterCategories.push({\n      letter: previousLetter,\n      items: letterItems,\n    });\n  }\n  return subjectsLetterCategories;\n};\n\nconst renderList = (\n  subjects: subjectProps[],\n  onNavigate?: () => void,\n  onToggleSubject?: subjectsProps['onToggleSubject'],\n  subjectViewType?: subjectsProps['subjectViewType'],\n  selectedSubjects: subjectsProps['selectedSubjects'] = [],\n) => (\n  <StyledList>\n    {sortAlphabetically(subjects).map((letter: any) => {\n      return (\n        <Fragment key={letter.letter}>\n          {letter.items.map((subject: subjectProps, index: number) => (\n            <Fragment key={subject.name}>\n              <StyledListItem>\n                {index === 0 && <StyledLetterItem subjectViewType={subjectViewType}>{letter.letter}</StyledLetterItem>}\n                {subjectViewType === 'checkbox' && subject.id ? (\n                  <ToggleItem\n                    id={subject.id}\n                    value={subject.id}\n                    checked={selectedSubjects.includes(subject.id)}\n                    label={subject.name}\n                    component=\"div\"\n                    onChange={() => {\n                      if (onToggleSubject && subject.id) {\n                        onToggleSubject(subject.id);\n                      }\n                    }}\n                  />\n                ) : (\n                  <>\n                    <SafeLink\n                      onClick={() => {\n                        if (onNavigate) {\n                          onNavigate();\n                        }\n                      }}\n                      to={subject.url || subject.path || ''}>\n                      {subject.name}\n                    </SafeLink>\n                    <StyledSpacingElement />\n                  </>\n                )}\n                {letter.items.length - 1 === index && <StyledLetterSpacing />}\n              </StyledListItem>\n            </Fragment>\n          ))}\n        </Fragment>\n      );\n    })}\n  </StyledList>\n);\n\nconst FrontpageAllSubjects = ({\n  categories,\n  onNavigate,\n  onToggleSubject,\n  subjectViewType,\n  selectedSubjects,\n}: subjectsProps) => {\n  const allSubjects: subjectProps[] = [];\n  const data: any = [];\n  const { t } = useTranslation();\n\n  categories.forEach((category: categoryProps) => {\n    allSubjects.push(...category.subjects);\n    category.visible &&\n      data.push({\n        title: category.name || t(`subjectCategories.${category.type}`),\n        content: (\n          <>\n            {/* Should be persistent til fall 2022 */}\n            {category.name === t('subjectCategories.beta') && (\n              <MessageBoxWrapper>\n                <MessageBox>{t('messageBoxInfo.frontPageBeta')}</MessageBox>\n              </MessageBoxWrapper>\n            )}\n            {category.name === t('subjectCategories.archive') && (\n              <MessageBoxWrapper>\n                <MessageBox>{t('messageBoxInfo.frontPageExpired')}</MessageBox>\n              </MessageBoxWrapper>\n            )}\n\n            {renderList(category.subjects, onNavigate, onToggleSubject, subjectViewType, selectedSubjects)}\n          </>\n        ),\n      });\n  });\n\n  data.unshift({\n    title: t('frontpageMenu.allsubjects'),\n    content: renderList(allSubjects, onNavigate, onToggleSubject, subjectViewType, selectedSubjects),\n  });\n\n  return (\n    <StyledWrapper>\n      <Tabs modifier=\"subjects\" tabs={data} />\n    </StyledWrapper>\n  );\n};\n\nexport default FrontpageAllSubjects;\n"]} */",
113
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FrontpageAllSubjects.tsx"],"names":[],"mappings":"AAwEoC","file":"FrontpageAllSubjects.tsx","sourcesContent":["import React, { Fragment } from 'react';\nimport styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport Tabs from '@ndla/tabs';\nimport SafeLink from '@ndla/safelink';\nimport { colors, fonts, mq, breakpoints } from '@ndla/core';\nimport { MessageBox } from '../MessageBox';\n// @ts-ignore\nimport { ToggleItem } from '../Filter';\n\nconst StyledWrapper = styled.nav`\n  margin: 32px 0 0;\n  .c-tabs--subjects {\n    margin: 0;\n  }\n  .c-tabs__list--subjects {\n    margin: 0;\n  }\n  .c-tabs__tab--subjects {\n    ${mq.range({ until: breakpoints.tablet })} {\n      margin: 0;\n      font-size: 12px;\n      padding-left: 8px;\n      padding-right: 8px;\n      :first-of-type {\n        padding-left: 0;\n      }\n      :last-of-type {\n        padding-right: 0;\n      }\n    }\n  }\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 40px 0 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 StyledLetterItem = styled.span<{ subjectViewType?: string }>`\n  display: block;\n  ${fonts.sizes(30, 1)};\n  font-weight: ${fonts.weight.bold};\n  color: ${colors.brand.primary};\n  margin-bottom: 8px;\n  ${(props) => props.subjectViewType === 'checkbox' && `margin-left:37px;`}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 10px;\n`;\n\nconst StyledLetterSpacing = styled.span`\n  display: block;\n  height: 16px;\n`;\n\nconst MessageBoxWrapper = styled.div`\n  padding-top: 20px;\n`;\n\ntype subjectProps = {\n  name: string;\n  url?: string;\n  path?: string;\n  id?: string;\n};\ntype categoryProps = {\n  type?: string;\n  name?: string;\n  visible?: boolean;\n  subjects: subjectProps[];\n};\n\nexport type subjectsProps = {\n  categories: categoryProps[];\n  subjectViewType?: 'link' | 'checkbox';\n  onToggleSubject?: (id: string) => void;\n  onNavigate?: () => void;\n  selectedSubjects?: string[];\n};\n\ntype letterCategories = {\n  letter: string;\n  items: subjectProps[];\n};\n\nconst sortAlphabetically = (subjects: subjectProps[], locale: string = 'nb') => {\n  const subjectsSorted = subjects.sort((a, b) => a.name.localeCompare(b.name, locale));\n  const subjectsLetterCategories: letterCategories[] = [];\n  let previousLetter = '';\n  let letterItems: subjectProps[] = [];\n  subjectsSorted.forEach((subject: subjectProps) => {\n    const currentLetter = subject.name.substr(0, 1);\n    const isNewLetter = currentLetter.localeCompare(previousLetter, locale) === 1;\n    if (isNewLetter && letterItems.length) {\n      subjectsLetterCategories.push({\n        letter: previousLetter,\n        items: letterItems,\n      });\n      letterItems = [];\n    }\n    previousLetter = currentLetter;\n    letterItems.push(subject);\n  });\n  // Add last letter\n  if (previousLetter && letterItems.length) {\n    subjectsLetterCategories.push({\n      letter: previousLetter,\n      items: letterItems,\n    });\n  }\n  return subjectsLetterCategories;\n};\n\nconst renderList = (\n  subjects: subjectProps[],\n  onNavigate?: () => void,\n  onToggleSubject?: subjectsProps['onToggleSubject'],\n  subjectViewType?: subjectsProps['subjectViewType'],\n  selectedSubjects: subjectsProps['selectedSubjects'] = [],\n) => (\n  <StyledList>\n    {sortAlphabetically(subjects).map((letter: any) => {\n      return (\n        <Fragment key={letter.letter}>\n          {letter.items.map((subject: subjectProps, index: number) => (\n            <Fragment key={subject.name}>\n              <StyledListItem>\n                {index === 0 && <StyledLetterItem subjectViewType={subjectViewType}>{letter.letter}</StyledLetterItem>}\n                {subjectViewType === 'checkbox' && subject.id ? (\n                  <ToggleItem\n                    id={subject.id}\n                    value={subject.id}\n                    checked={selectedSubjects.includes(subject.id)}\n                    label={subject.name}\n                    component=\"div\"\n                    onChange={() => {\n                      if (onToggleSubject && subject.id) {\n                        onToggleSubject(subject.id);\n                      }\n                    }}\n                  />\n                ) : (\n                  <>\n                    <SafeLink\n                      onClick={() => {\n                        if (onNavigate) {\n                          onNavigate();\n                        }\n                      }}\n                      to={subject.url || subject.path || ''}>\n                      {subject.name}\n                    </SafeLink>\n                    <StyledSpacingElement />\n                  </>\n                )}\n                {letter.items.length - 1 === index && <StyledLetterSpacing />}\n              </StyledListItem>\n            </Fragment>\n          ))}\n        </Fragment>\n      );\n    })}\n  </StyledList>\n);\n\nconst FrontpageAllSubjects = ({\n  categories,\n  onNavigate,\n  onToggleSubject,\n  subjectViewType,\n  selectedSubjects,\n}: subjectsProps) => {\n  const allSubjects: subjectProps[] = [];\n  const data: any = [];\n  const { t } = useTranslation();\n\n  categories.forEach((category: categoryProps) => {\n    allSubjects.push(...category.subjects);\n    category.visible &&\n      data.push({\n        title: category.name || t(`subjectCategories.${category.type}`),\n        content: (\n          <>\n            {/* Should be persistent til fall 2022 */}\n            {category.name === t('subjectCategories.beta') && (\n              <MessageBoxWrapper>\n                <MessageBox>{t('messageBoxInfo.frontPageBeta')}</MessageBox>\n              </MessageBoxWrapper>\n            )}\n            {category.name === t('subjectCategories.archive') && (\n              <MessageBoxWrapper>\n                <MessageBox>{t('messageBoxInfo.frontPageExpired')}</MessageBox>\n              </MessageBoxWrapper>\n            )}\n\n            {renderList(category.subjects, onNavigate, onToggleSubject, subjectViewType, selectedSubjects)}\n          </>\n        ),\n      });\n  });\n\n  data.push({\n    title: t('frontpageMenu.allsubjects'),\n    content: renderList(allSubjects, onNavigate, onToggleSubject, subjectViewType, selectedSubjects),\n  });\n\n  return (\n    <StyledWrapper>\n      <Tabs modifier=\"subjects\" tabs={data} />\n    </StyledWrapper>\n  );\n};\n\nexport default FrontpageAllSubjects;\n"]} */",
114
114
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
115
115
  });
116
116
 
@@ -200,7 +200,7 @@ var FrontpageAllSubjects = function FrontpageAllSubjects(_ref) {
200
200
  content: (0, _core2.jsx)(_react["default"].Fragment, null, category.name === t('subjectCategories.beta') && (0, _core2.jsx)(MessageBoxWrapper, null, (0, _core2.jsx)(_MessageBox.MessageBox, null, t('messageBoxInfo.frontPageBeta'))), category.name === t('subjectCategories.archive') && (0, _core2.jsx)(MessageBoxWrapper, null, (0, _core2.jsx)(_MessageBox.MessageBox, null, t('messageBoxInfo.frontPageExpired'))), renderList(category.subjects, onNavigate, onToggleSubject, subjectViewType, selectedSubjects))
201
201
  });
202
202
  });
203
- data.unshift({
203
+ data.push({
204
204
  title: t('frontpageMenu.allsubjects'),
205
205
  content: renderList(allSubjects, onNavigate, onToggleSubject, subjectViewType, selectedSubjects)
206
206
  });