@ndla/ui 32.1.0 → 33.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (49) hide show
  1. package/es/Article/Article.js +4 -4
  2. package/es/Frontpage/FrontpageAllSubjects.js +9 -17
  3. package/es/Image/Image.js +5 -5
  4. package/es/Image/ImageLink.js +5 -5
  5. package/es/SearchTypeResult/components/ItemTopicHeader.js +4 -4
  6. package/es/index.js +1 -0
  7. package/es/locale/messages-en.js +3 -2
  8. package/es/locale/messages-nb.js +3 -2
  9. package/es/locale/messages-nn.js +3 -2
  10. package/es/locale/messages-se.js +3 -2
  11. package/es/locale/messages-sma.js +3 -2
  12. package/es/model/SubjectCategories.js +2 -1
  13. package/lib/Article/Article.js +4 -4
  14. package/lib/Frontpage/FrontpageAllSubjects.d.ts +0 -2
  15. package/lib/Frontpage/FrontpageAllSubjects.js +9 -17
  16. package/lib/Image/Image.js +5 -5
  17. package/lib/Image/ImageLink.js +5 -5
  18. package/lib/SearchTypeResult/components/ItemTopicHeader.js +4 -4
  19. package/lib/index.d.ts +1 -0
  20. package/lib/index.js +8 -0
  21. package/lib/locale/messages-en.d.ts +3 -1
  22. package/lib/locale/messages-en.js +3 -2
  23. package/lib/locale/messages-nb.d.ts +3 -1
  24. package/lib/locale/messages-nb.js +3 -2
  25. package/lib/locale/messages-nn.d.ts +3 -1
  26. package/lib/locale/messages-nn.js +3 -2
  27. package/lib/locale/messages-se.d.ts +3 -1
  28. package/lib/locale/messages-se.js +3 -2
  29. package/lib/locale/messages-sma.d.ts +3 -1
  30. package/lib/locale/messages-sma.js +3 -2
  31. package/lib/model/SubjectCategories.d.ts +2 -1
  32. package/lib/model/SubjectCategories.js +5 -3
  33. package/package.json +4 -4
  34. package/src/Article/Article.tsx +2 -2
  35. package/src/Frontpage/FrontpageAllSubjects.tsx +2 -14
  36. package/src/Image/Image.tsx +2 -0
  37. package/src/Image/ImageLink.tsx +2 -0
  38. package/src/Image/__tests__/__snapshots__/Image-test.jsx.snap +6 -0
  39. package/src/MyNdla/Resource/Folder.stories.mdx +52 -0
  40. package/src/Resource/BlockResource.stories.mdx +58 -0
  41. package/src/Resource/Resource.stories.mdx +58 -0
  42. package/src/SearchTypeResult/components/ItemTopicHeader.tsx +1 -0
  43. package/src/index.ts +2 -0
  44. package/src/locale/messages-en.ts +4 -2
  45. package/src/locale/messages-nb.ts +4 -2
  46. package/src/locale/messages-nn.ts +4 -2
  47. package/src/locale/messages-se.ts +4 -2
  48. package/src/locale/messages-sma.ts +4 -2
  49. package/src/model/SubjectCategories.ts +2 -1
@@ -30,7 +30,7 @@ var StyledWrapper = /*#__PURE__*/(0, _base["default"])("nav", {
30
30
  label: "StyledWrapper"
31
31
  })("margin:32px 0 0;.c-tabs--subjects{margin:0;}.c-tabs__list--subjects{margin:0;}.c-tabs__tab--subjects{", _core.mq.range({
32
32
  until: _core.breakpoints.tablet
33
- }), "{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 ContentLoader from '../ContentLoader';\nimport { MessageBox } from '../Messages';\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  message?: string;\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  if (categories.flatMap((c) => c.subjects).length === 0) {\n    return (\n      <StyledWrapper>\n        <ContentLoader width={880} height={270}>\n          <rect x=\"0\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-1\" />\n          <rect x=\"110\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-2\" />\n          <rect x=\"220\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-3\" />\n          <rect x=\"330\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-4\" />\n\n          <rect x=\"0\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-1\" />\n          <rect x=\"300\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-2\" />\n          <rect x=\"600\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-3\" />\n        </ContentLoader>\n      </StyledWrapper>\n    );\n  }\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            {category.message && (\n              <MessageBoxWrapper>\n                <MessageBox>{category.message}</MessageBox>\n              </MessageBoxWrapper>\n            )}\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            {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"]} */"));
33
+ }), "{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 ContentLoader from '../ContentLoader';\nimport { MessageBox } from '../Messages';\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  path?: string;\n  id?: string;\n};\ntype categoryProps = {\n  type?: string;\n  visible?: boolean;\n  message?: string;\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.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  if (categories.flatMap((c) => c.subjects).length === 0) {\n    return (\n      <StyledWrapper>\n        <ContentLoader width={880} height={270}>\n          <rect x=\"0\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-1\" />\n          <rect x=\"110\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-2\" />\n          <rect x=\"220\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-3\" />\n          <rect x=\"330\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-4\" />\n\n          <rect x=\"0\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-1\" />\n          <rect x=\"300\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-2\" />\n          <rect x=\"600\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-3\" />\n        </ContentLoader>\n      </StyledWrapper>\n    );\n  }\n\n  categories.forEach((category: categoryProps) => {\n    allSubjects.push(...category.subjects);\n    category.visible &&\n      data.push({\n        title: t(`subjectCategories.${category.type}`),\n        content: (\n          <>\n            {category.message && (\n              <MessageBoxWrapper>\n                <MessageBox>{category.message}</MessageBox>\n              </MessageBoxWrapper>\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"]} */"));
34
34
  var StyledList = /*#__PURE__*/(0, _base["default"])("ul", {
35
35
  target: "e1kk5ejg5",
36
36
  label: "StyledList"
@@ -38,7 +38,7 @@ var StyledList = /*#__PURE__*/(0, _base["default"])("ul", {
38
38
  from: _core.breakpoints.tablet
39
39
  }), "{column-count:2;column-gap:20px;}", _core.mq.range({
40
40
  from: _core.breakpoints.tabletWide
41
- }), "{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 ContentLoader from '../ContentLoader';\nimport { MessageBox } from '../Messages';\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  message?: string;\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  if (categories.flatMap((c) => c.subjects).length === 0) {\n    return (\n      <StyledWrapper>\n        <ContentLoader width={880} height={270}>\n          <rect x=\"0\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-1\" />\n          <rect x=\"110\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-2\" />\n          <rect x=\"220\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-3\" />\n          <rect x=\"330\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-4\" />\n\n          <rect x=\"0\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-1\" />\n          <rect x=\"300\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-2\" />\n          <rect x=\"600\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-3\" />\n        </ContentLoader>\n      </StyledWrapper>\n    );\n  }\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            {category.message && (\n              <MessageBoxWrapper>\n                <MessageBox>{category.message}</MessageBox>\n              </MessageBoxWrapper>\n            )}\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            {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"]} */"));
41
+ }), "{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 ContentLoader from '../ContentLoader';\nimport { MessageBox } from '../Messages';\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  path?: string;\n  id?: string;\n};\ntype categoryProps = {\n  type?: string;\n  visible?: boolean;\n  message?: string;\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.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  if (categories.flatMap((c) => c.subjects).length === 0) {\n    return (\n      <StyledWrapper>\n        <ContentLoader width={880} height={270}>\n          <rect x=\"0\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-1\" />\n          <rect x=\"110\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-2\" />\n          <rect x=\"220\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-3\" />\n          <rect x=\"330\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-4\" />\n\n          <rect x=\"0\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-1\" />\n          <rect x=\"300\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-2\" />\n          <rect x=\"600\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-3\" />\n        </ContentLoader>\n      </StyledWrapper>\n    );\n  }\n\n  categories.forEach((category: categoryProps) => {\n    allSubjects.push(...category.subjects);\n    category.visible &&\n      data.push({\n        title: t(`subjectCategories.${category.type}`),\n        content: (\n          <>\n            {category.message && (\n              <MessageBoxWrapper>\n                <MessageBox>{category.message}</MessageBox>\n              </MessageBoxWrapper>\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"]} */"));
42
42
  var StyledListItem = /*#__PURE__*/(0, _base["default"])("li", {
43
43
  target: "e1kk5ejg4",
44
44
  label: "StyledListItem"
@@ -48,7 +48,7 @@ var StyledListItem = /*#__PURE__*/(0, _base["default"])("li", {
48
48
  } : {
49
49
  name: "19qqojn",
50
50
  styles: "margin-bottom:0;break-inside:avoid",
51
- 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 ContentLoader from '../ContentLoader';\nimport { MessageBox } from '../Messages';\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  message?: string;\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  if (categories.flatMap((c) => c.subjects).length === 0) {\n    return (\n      <StyledWrapper>\n        <ContentLoader width={880} height={270}>\n          <rect x=\"0\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-1\" />\n          <rect x=\"110\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-2\" />\n          <rect x=\"220\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-3\" />\n          <rect x=\"330\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-4\" />\n\n          <rect x=\"0\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-1\" />\n          <rect x=\"300\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-2\" />\n          <rect x=\"600\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-3\" />\n        </ContentLoader>\n      </StyledWrapper>\n    );\n  }\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            {category.message && (\n              <MessageBoxWrapper>\n                <MessageBox>{category.message}</MessageBox>\n              </MessageBoxWrapper>\n            )}\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            {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"]} */",
51
+ 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 ContentLoader from '../ContentLoader';\nimport { MessageBox } from '../Messages';\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  path?: string;\n  id?: string;\n};\ntype categoryProps = {\n  type?: string;\n  visible?: boolean;\n  message?: string;\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.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  if (categories.flatMap((c) => c.subjects).length === 0) {\n    return (\n      <StyledWrapper>\n        <ContentLoader width={880} height={270}>\n          <rect x=\"0\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-1\" />\n          <rect x=\"110\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-2\" />\n          <rect x=\"220\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-3\" />\n          <rect x=\"330\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-4\" />\n\n          <rect x=\"0\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-1\" />\n          <rect x=\"300\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-2\" />\n          <rect x=\"600\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-3\" />\n        </ContentLoader>\n      </StyledWrapper>\n    );\n  }\n\n  categories.forEach((category: categoryProps) => {\n    allSubjects.push(...category.subjects);\n    category.visible &&\n      data.push({\n        title: t(`subjectCategories.${category.type}`),\n        content: (\n          <>\n            {category.message && (\n              <MessageBoxWrapper>\n                <MessageBox>{category.message}</MessageBox>\n              </MessageBoxWrapper>\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"]} */",
52
52
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
53
53
  });
54
54
  var StyledLetterItem = /*#__PURE__*/(0, _base["default"])("span", {
@@ -56,7 +56,7 @@ var StyledLetterItem = /*#__PURE__*/(0, _base["default"])("span", {
56
56
  label: "StyledLetterItem"
57
57
  })("display:block;", _core.fonts.sizes(30, 1), ";font-weight:", _core.fonts.weight.bold, ";color:", _core.colors.brand.primary, ";margin-bottom:8px;", function (props) {
58
58
  return props.subjectViewType === 'checkbox' && "margin-left:37px;";
59
- }, ";" + (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 ContentLoader from '../ContentLoader';\nimport { MessageBox } from '../Messages';\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  message?: string;\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  if (categories.flatMap((c) => c.subjects).length === 0) {\n    return (\n      <StyledWrapper>\n        <ContentLoader width={880} height={270}>\n          <rect x=\"0\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-1\" />\n          <rect x=\"110\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-2\" />\n          <rect x=\"220\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-3\" />\n          <rect x=\"330\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-4\" />\n\n          <rect x=\"0\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-1\" />\n          <rect x=\"300\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-2\" />\n          <rect x=\"600\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-3\" />\n        </ContentLoader>\n      </StyledWrapper>\n    );\n  }\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            {category.message && (\n              <MessageBoxWrapper>\n                <MessageBox>{category.message}</MessageBox>\n              </MessageBoxWrapper>\n            )}\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            {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"]} */"));
59
+ }, ";" + (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 ContentLoader from '../ContentLoader';\nimport { MessageBox } from '../Messages';\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  path?: string;\n  id?: string;\n};\ntype categoryProps = {\n  type?: string;\n  visible?: boolean;\n  message?: string;\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.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  if (categories.flatMap((c) => c.subjects).length === 0) {\n    return (\n      <StyledWrapper>\n        <ContentLoader width={880} height={270}>\n          <rect x=\"0\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-1\" />\n          <rect x=\"110\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-2\" />\n          <rect x=\"220\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-3\" />\n          <rect x=\"330\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-4\" />\n\n          <rect x=\"0\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-1\" />\n          <rect x=\"300\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-2\" />\n          <rect x=\"600\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-3\" />\n        </ContentLoader>\n      </StyledWrapper>\n    );\n  }\n\n  categories.forEach((category: categoryProps) => {\n    allSubjects.push(...category.subjects);\n    category.visible &&\n      data.push({\n        title: t(`subjectCategories.${category.type}`),\n        content: (\n          <>\n            {category.message && (\n              <MessageBoxWrapper>\n                <MessageBox>{category.message}</MessageBox>\n              </MessageBoxWrapper>\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"]} */"));
60
60
  var StyledSpacingElement = /*#__PURE__*/(0, _base["default"])("span", {
61
61
  target: "e1kk5ejg2",
62
62
  label: "StyledSpacingElement"
@@ -66,7 +66,7 @@ var StyledSpacingElement = /*#__PURE__*/(0, _base["default"])("span", {
66
66
  } : {
67
67
  name: "wzb9li",
68
68
  styles: "display:block;width:100%;height:10px",
69
- 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 ContentLoader from '../ContentLoader';\nimport { MessageBox } from '../Messages';\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  message?: string;\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  if (categories.flatMap((c) => c.subjects).length === 0) {\n    return (\n      <StyledWrapper>\n        <ContentLoader width={880} height={270}>\n          <rect x=\"0\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-1\" />\n          <rect x=\"110\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-2\" />\n          <rect x=\"220\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-3\" />\n          <rect x=\"330\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-4\" />\n\n          <rect x=\"0\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-1\" />\n          <rect x=\"300\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-2\" />\n          <rect x=\"600\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-3\" />\n        </ContentLoader>\n      </StyledWrapper>\n    );\n  }\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            {category.message && (\n              <MessageBoxWrapper>\n                <MessageBox>{category.message}</MessageBox>\n              </MessageBoxWrapper>\n            )}\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            {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"]} */",
69
+ 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 ContentLoader from '../ContentLoader';\nimport { MessageBox } from '../Messages';\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  path?: string;\n  id?: string;\n};\ntype categoryProps = {\n  type?: string;\n  visible?: boolean;\n  message?: string;\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.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  if (categories.flatMap((c) => c.subjects).length === 0) {\n    return (\n      <StyledWrapper>\n        <ContentLoader width={880} height={270}>\n          <rect x=\"0\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-1\" />\n          <rect x=\"110\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-2\" />\n          <rect x=\"220\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-3\" />\n          <rect x=\"330\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-4\" />\n\n          <rect x=\"0\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-1\" />\n          <rect x=\"300\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-2\" />\n          <rect x=\"600\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-3\" />\n        </ContentLoader>\n      </StyledWrapper>\n    );\n  }\n\n  categories.forEach((category: categoryProps) => {\n    allSubjects.push(...category.subjects);\n    category.visible &&\n      data.push({\n        title: t(`subjectCategories.${category.type}`),\n        content: (\n          <>\n            {category.message && (\n              <MessageBoxWrapper>\n                <MessageBox>{category.message}</MessageBox>\n              </MessageBoxWrapper>\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"]} */",
70
70
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
71
71
  });
72
72
  var StyledLetterSpacing = /*#__PURE__*/(0, _base["default"])("span", {
@@ -78,7 +78,7 @@ var StyledLetterSpacing = /*#__PURE__*/(0, _base["default"])("span", {
78
78
  } : {
79
79
  name: "197vhxd",
80
80
  styles: "display:block;height:16px",
81
- 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 ContentLoader from '../ContentLoader';\nimport { MessageBox } from '../Messages';\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  message?: string;\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  if (categories.flatMap((c) => c.subjects).length === 0) {\n    return (\n      <StyledWrapper>\n        <ContentLoader width={880} height={270}>\n          <rect x=\"0\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-1\" />\n          <rect x=\"110\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-2\" />\n          <rect x=\"220\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-3\" />\n          <rect x=\"330\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-4\" />\n\n          <rect x=\"0\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-1\" />\n          <rect x=\"300\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-2\" />\n          <rect x=\"600\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-3\" />\n        </ContentLoader>\n      </StyledWrapper>\n    );\n  }\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            {category.message && (\n              <MessageBoxWrapper>\n                <MessageBox>{category.message}</MessageBox>\n              </MessageBoxWrapper>\n            )}\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            {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"]} */",
81
+ 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 ContentLoader from '../ContentLoader';\nimport { MessageBox } from '../Messages';\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  path?: string;\n  id?: string;\n};\ntype categoryProps = {\n  type?: string;\n  visible?: boolean;\n  message?: string;\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.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  if (categories.flatMap((c) => c.subjects).length === 0) {\n    return (\n      <StyledWrapper>\n        <ContentLoader width={880} height={270}>\n          <rect x=\"0\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-1\" />\n          <rect x=\"110\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-2\" />\n          <rect x=\"220\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-3\" />\n          <rect x=\"330\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-4\" />\n\n          <rect x=\"0\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-1\" />\n          <rect x=\"300\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-2\" />\n          <rect x=\"600\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-3\" />\n        </ContentLoader>\n      </StyledWrapper>\n    );\n  }\n\n  categories.forEach((category: categoryProps) => {\n    allSubjects.push(...category.subjects);\n    category.visible &&\n      data.push({\n        title: t(`subjectCategories.${category.type}`),\n        content: (\n          <>\n            {category.message && (\n              <MessageBoxWrapper>\n                <MessageBox>{category.message}</MessageBox>\n              </MessageBoxWrapper>\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"]} */",
82
82
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
83
83
  });
84
84
  var MessageBoxWrapper = /*#__PURE__*/(0, _base["default"])("div", {
@@ -90,7 +90,7 @@ var MessageBoxWrapper = /*#__PURE__*/(0, _base["default"])("div", {
90
90
  } : {
91
91
  name: "8qz8ia",
92
92
  styles: "padding-top:20px",
93
- 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 ContentLoader from '../ContentLoader';\nimport { MessageBox } from '../Messages';\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  message?: string;\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  if (categories.flatMap((c) => c.subjects).length === 0) {\n    return (\n      <StyledWrapper>\n        <ContentLoader width={880} height={270}>\n          <rect x=\"0\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-1\" />\n          <rect x=\"110\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-2\" />\n          <rect x=\"220\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-3\" />\n          <rect x=\"330\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-4\" />\n\n          <rect x=\"0\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-1\" />\n          <rect x=\"300\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-2\" />\n          <rect x=\"600\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-3\" />\n        </ContentLoader>\n      </StyledWrapper>\n    );\n  }\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            {category.message && (\n              <MessageBoxWrapper>\n                <MessageBox>{category.message}</MessageBox>\n              </MessageBoxWrapper>\n            )}\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            {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"]} */",
93
+ 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 ContentLoader from '../ContentLoader';\nimport { MessageBox } from '../Messages';\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  path?: string;\n  id?: string;\n};\ntype categoryProps = {\n  type?: string;\n  visible?: boolean;\n  message?: string;\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.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  if (categories.flatMap((c) => c.subjects).length === 0) {\n    return (\n      <StyledWrapper>\n        <ContentLoader width={880} height={270}>\n          <rect x=\"0\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-1\" />\n          <rect x=\"110\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-2\" />\n          <rect x=\"220\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-3\" />\n          <rect x=\"330\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-4\" />\n\n          <rect x=\"0\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-1\" />\n          <rect x=\"300\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-2\" />\n          <rect x=\"600\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-3\" />\n        </ContentLoader>\n      </StyledWrapper>\n    );\n  }\n\n  categories.forEach((category: categoryProps) => {\n    allSubjects.push(...category.subjects);\n    category.visible &&\n      data.push({\n        title: t(`subjectCategories.${category.type}`),\n        content: (\n          <>\n            {category.message && (\n              <MessageBoxWrapper>\n                <MessageBox>{category.message}</MessageBox>\n              </MessageBoxWrapper>\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"]} */",
94
94
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
95
95
  });
96
96
  var sortAlphabetically = function sortAlphabetically(subjects) {
@@ -152,7 +152,7 @@ var renderList = function renderList(subjects, onNavigate, onToggleSubject, subj
152
152
  onNavigate();
153
153
  }
154
154
  },
155
- to: subject.url || subject.path || '',
155
+ to: subject.path || '',
156
156
  children: subject.name
157
157
  }), (0, _jsxRuntime.jsx)(StyledSpacingElement, {})]
158
158
  }), letter.items.length - 1 === index && (0, _jsxRuntime.jsx)(StyledLetterSpacing, {})]
@@ -236,20 +236,12 @@ var FrontpageAllSubjects = function FrontpageAllSubjects(_ref) {
236
236
  categories.forEach(function (category) {
237
237
  allSubjects.push.apply(allSubjects, _toConsumableArray(category.subjects));
238
238
  category.visible && data.push({
239
- title: category.name || t("subjectCategories.".concat(category.type)),
239
+ title: t("subjectCategories.".concat(category.type)),
240
240
  content: (0, _jsxRuntime.jsxs)(_jsxRuntime.Fragment, {
241
241
  children: [category.message && (0, _jsxRuntime.jsx)(MessageBoxWrapper, {
242
242
  children: (0, _jsxRuntime.jsx)(_Messages.MessageBox, {
243
243
  children: category.message
244
244
  })
245
- }), category.name === t('subjectCategories.beta') && (0, _jsxRuntime.jsx)(MessageBoxWrapper, {
246
- children: (0, _jsxRuntime.jsx)(_Messages.MessageBox, {
247
- children: t('messageBoxInfo.frontPageBeta')
248
- })
249
- }), category.name === t('subjectCategories.archive') && (0, _jsxRuntime.jsx)(MessageBoxWrapper, {
250
- children: (0, _jsxRuntime.jsx)(_Messages.MessageBox, {
251
- children: t('messageBoxInfo.frontPageExpired')
252
- })
253
245
  }), renderList(category.subjects, onNavigate, onToggleSubject, subjectViewType, selectedSubjects)]
254
246
  })
255
247
  });
@@ -36,12 +36,12 @@ var StyledImageWrapper = /*#__PURE__*/(0, _base["default"])("div", {
36
36
  target: "ejtxxex0",
37
37
  label: "StyledImageWrapper"
38
38
  })(process.env.NODE_ENV === "production" ? {
39
- name: "bjn8wh",
40
- styles: "position:relative"
39
+ name: "zxsb69",
40
+ styles: "position:relative;width:100%;height:100%"
41
41
  } : {
42
- name: "bjn8wh",
43
- styles: "position:relative",
44
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkltYWdlLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF1Q3FDIiwiZmlsZSI6IkltYWdlLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE3LXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IFJlYWN0LCB7IFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCBMYXp5TG9hZEltYWdlIGZyb20gJy4vTGF6eUxvYWRJbWFnZSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgSW1hZ2VDcm9wIHtcbiAgc3RhcnRYOiBudW1iZXI7XG4gIHN0YXJ0WTogbnVtYmVyO1xuICBlbmRYOiBudW1iZXI7XG4gIGVuZFk6IG51bWJlcjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBJbWFnZUZvY2FsUG9pbnQge1xuICB4OiBudW1iZXI7XG4gIHk6IG51bWJlcjtcbn1cblxuZXhwb3J0IGNvbnN0IG1ha2VTcmNRdWVyeVN0cmluZyA9ICh3aWR0aDogbnVtYmVyIHwgdW5kZWZpbmVkLCBjcm9wPzogSW1hZ2VDcm9wLCBmb2NhbFBvaW50PzogSW1hZ2VGb2NhbFBvaW50KSA9PiB7XG4gIGNvbnN0IHdpZHRoUGFyYW1zID0gd2lkdGggJiYgYHdpZHRoPSR7d2lkdGh9YDtcbiAgY29uc3QgY3JvcFBhcmFtcyA9XG4gICAgY3JvcCAmJiBgY3JvcFN0YXJ0WD0ke2Nyb3Auc3RhcnRYfSZjcm9wRW5kWD0ke2Nyb3AuZW5kWH0mY3JvcFN0YXJ0WT0ke2Nyb3Auc3RhcnRZfSZjcm9wRW5kWT0ke2Nyb3AuZW5kWX1gO1xuICBjb25zdCBmb2NhbFBvaW50UGFyYW1zID0gZm9jYWxQb2ludCAmJiBgZm9jYWxYPSR7Zm9jYWxQb2ludC54fSZmb2NhbFk9JHtmb2NhbFBvaW50Lnl9YDtcbiAgY29uc3QgcGFyYW1zID0gW3dpZHRoUGFyYW1zLCBjcm9wUGFyYW1zLCBmb2NhbFBvaW50UGFyYW1zXS5maWx0ZXIoKHApID0+IHApLmpvaW4oJyYnKTtcblxuICByZXR1cm4gcGFyYW1zO1xufTtcblxuY29uc3QgZ2V0U3JjU2V0ID0gKHNyYzogc3RyaW5nLCBjcm9wOiBJbWFnZUNyb3AgfCB1bmRlZmluZWQsIGZvY2FsUG9pbnQ6IEltYWdlRm9jYWxQb2ludCB8IHVuZGVmaW5lZCkgPT4ge1xuICBjb25zdCB3aWR0aHMgPSBbMjcyMCwgMjA4MCwgMTc2MCwgMTQ0MCwgMTEyMCwgMTAwMCwgOTYwLCA4MDAsIDY0MCwgNDgwLCAzMjAsIDI0MCwgMTgwXTtcbiAgcmV0dXJuIHdpZHRocy5tYXAoKHdpZHRoKSA9PiBgJHtzcmN9PyR7bWFrZVNyY1F1ZXJ5U3RyaW5nKHdpZHRoLCBjcm9wLCBmb2NhbFBvaW50KX0gJHt3aWR0aH13YCkuam9pbignLCAnKTtcbn07XG5cbmNvbnN0IFN0eWxlZEltYWdlV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbmA7XG5pbnRlcmZhY2UgUHJvcHMge1xuICBhbHQ6IHN0cmluZztcbiAgc3JjOiBzdHJpbmc7XG4gIHNpemVzPzogc3RyaW5nO1xuICBmYWxsYmFja1dpZHRoPzogbnVtYmVyO1xuICBjb250ZW50VHlwZT86IHN0cmluZztcbiAgc3JjU2V0Pzogc3RyaW5nO1xuICBsYXp5TG9hZD86IGJvb2xlYW47XG4gIGxhenlMb2FkU3JjPzogc3RyaW5nO1xuICBleHBhbmRCdXR0b24/OiBSZWFjdE5vZGU7XG4gIGNyb3A/OiBJbWFnZUNyb3A7XG4gIGZvY2FsUG9pbnQ/OiBJbWFnZUZvY2FsUG9pbnQ7XG59XG5cbmNvbnN0IEltYWdlID0gKHtcbiAgYWx0LFxuICBzcmMsXG4gIGxhenlMb2FkLFxuICBsYXp5TG9hZFNyYyxcbiAgY3JvcCxcbiAgZm9jYWxQb2ludCxcbiAgY29udGVudFR5cGUsXG4gIHNpemVzID0gJyhtaW4td2lkdGg6IDEwMjRweCkgMTAyNHB4LCAxMDB2dycsXG4gIGV4cGFuZEJ1dHRvbixcbiAgZmFsbGJhY2tXaWR0aCA9IDEwMjQsXG4gIC4uLnJlc3Rcbn06IFByb3BzKSA9PiB7XG4gIGNvbnN0IHNyY1NldCA9IHJlc3Quc3JjU2V0ID8/IGdldFNyY1NldChzcmMsIGNyb3AsIGZvY2FsUG9pbnQpO1xuICBjb25zdCBxdWVyeVN0cmluZyA9IG1ha2VTcmNRdWVyeVN0cmluZyhmYWxsYmFja1dpZHRoLCBjcm9wLCBmb2NhbFBvaW50KTtcblxuICBpZiAoY29udGVudFR5cGUgJiYgY29udGVudFR5cGUgPT09ICdpbWFnZS9naWYnKSB7XG4gICAgcmV0dXJuIChcbiAgICAgIDxTdHlsZWRJbWFnZVdyYXBwZXI+XG4gICAgICAgIDxpbWcgYWx0PXthbHR9IHNyYz17YCR7c3JjfWB9IHsuLi5yZXN0fSAvPlxuICAgICAgPC9TdHlsZWRJbWFnZVdyYXBwZXI+XG4gICAgKTtcbiAgfVxuXG4gIGlmIChsYXp5TG9hZCkge1xuICAgIHJldHVybiAoXG4gICAgICA8U3R5bGVkSW1hZ2VXcmFwcGVyPlxuICAgICAgICA8TGF6eUxvYWRJbWFnZVxuICAgICAgICAgIGFsdD17YWx0fVxuICAgICAgICAgIHNyYz17YCR7c3JjfT8ke3F1ZXJ5U3RyaW5nfWB9XG4gICAgICAgICAgc3JjU2V0PXtzcmNTZXR9XG4gICAgICAgICAgc2l6ZXM9e3NpemVzfVxuICAgICAgICAgIGxhenlMb2FkU3JjPXtsYXp5TG9hZFNyY31cbiAgICAgICAgLz5cbiAgICAgIDwvU3R5bGVkSW1hZ2VXcmFwcGVyPlxuICAgICk7XG4gIH1cblxuICByZXR1cm4gKFxuICAgIDxTdHlsZWRJbWFnZVdyYXBwZXI+XG4gICAgICA8cGljdHVyZT5cbiAgICAgICAgPHNvdXJjZSB0eXBlPXtjb250ZW50VHlwZX0gc3JjU2V0PXtzcmNTZXR9IHNpemVzPXtzaXplc30gLz5cbiAgICAgICAgPGltZyBhbHQ9e2FsdH0gc3JjPXtgJHtzcmN9PyR7cXVlcnlTdHJpbmd9YH0gey4uLnJlc3R9IC8+XG4gICAgICA8L3BpY3R1cmU+XG4gICAgICB7ZXhwYW5kQnV0dG9ufVxuICAgIDwvU3R5bGVkSW1hZ2VXcmFwcGVyPlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgSW1hZ2U7XG4iXX0= */",
42
+ name: "zxsb69",
43
+ styles: "position:relative;width:100%;height:100%",
44
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkltYWdlLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF1Q3FDIiwiZmlsZSI6IkltYWdlLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE3LXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IFJlYWN0LCB7IFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCBMYXp5TG9hZEltYWdlIGZyb20gJy4vTGF6eUxvYWRJbWFnZSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgSW1hZ2VDcm9wIHtcbiAgc3RhcnRYOiBudW1iZXI7XG4gIHN0YXJ0WTogbnVtYmVyO1xuICBlbmRYOiBudW1iZXI7XG4gIGVuZFk6IG51bWJlcjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBJbWFnZUZvY2FsUG9pbnQge1xuICB4OiBudW1iZXI7XG4gIHk6IG51bWJlcjtcbn1cblxuZXhwb3J0IGNvbnN0IG1ha2VTcmNRdWVyeVN0cmluZyA9ICh3aWR0aDogbnVtYmVyIHwgdW5kZWZpbmVkLCBjcm9wPzogSW1hZ2VDcm9wLCBmb2NhbFBvaW50PzogSW1hZ2VGb2NhbFBvaW50KSA9PiB7XG4gIGNvbnN0IHdpZHRoUGFyYW1zID0gd2lkdGggJiYgYHdpZHRoPSR7d2lkdGh9YDtcbiAgY29uc3QgY3JvcFBhcmFtcyA9XG4gICAgY3JvcCAmJiBgY3JvcFN0YXJ0WD0ke2Nyb3Auc3RhcnRYfSZjcm9wRW5kWD0ke2Nyb3AuZW5kWH0mY3JvcFN0YXJ0WT0ke2Nyb3Auc3RhcnRZfSZjcm9wRW5kWT0ke2Nyb3AuZW5kWX1gO1xuICBjb25zdCBmb2NhbFBvaW50UGFyYW1zID0gZm9jYWxQb2ludCAmJiBgZm9jYWxYPSR7Zm9jYWxQb2ludC54fSZmb2NhbFk9JHtmb2NhbFBvaW50Lnl9YDtcbiAgY29uc3QgcGFyYW1zID0gW3dpZHRoUGFyYW1zLCBjcm9wUGFyYW1zLCBmb2NhbFBvaW50UGFyYW1zXS5maWx0ZXIoKHApID0+IHApLmpvaW4oJyYnKTtcblxuICByZXR1cm4gcGFyYW1zO1xufTtcblxuY29uc3QgZ2V0U3JjU2V0ID0gKHNyYzogc3RyaW5nLCBjcm9wOiBJbWFnZUNyb3AgfCB1bmRlZmluZWQsIGZvY2FsUG9pbnQ6IEltYWdlRm9jYWxQb2ludCB8IHVuZGVmaW5lZCkgPT4ge1xuICBjb25zdCB3aWR0aHMgPSBbMjcyMCwgMjA4MCwgMTc2MCwgMTQ0MCwgMTEyMCwgMTAwMCwgOTYwLCA4MDAsIDY0MCwgNDgwLCAzMjAsIDI0MCwgMTgwXTtcbiAgcmV0dXJuIHdpZHRocy5tYXAoKHdpZHRoKSA9PiBgJHtzcmN9PyR7bWFrZVNyY1F1ZXJ5U3RyaW5nKHdpZHRoLCBjcm9wLCBmb2NhbFBvaW50KX0gJHt3aWR0aH13YCkuam9pbignLCAnKTtcbn07XG5cbmNvbnN0IFN0eWxlZEltYWdlV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgd2lkdGg6IDEwMCU7XG4gIGhlaWdodDogMTAwJTtcbmA7XG5pbnRlcmZhY2UgUHJvcHMge1xuICBhbHQ6IHN0cmluZztcbiAgc3JjOiBzdHJpbmc7XG4gIHNpemVzPzogc3RyaW5nO1xuICBmYWxsYmFja1dpZHRoPzogbnVtYmVyO1xuICBjb250ZW50VHlwZT86IHN0cmluZztcbiAgc3JjU2V0Pzogc3RyaW5nO1xuICBsYXp5TG9hZD86IGJvb2xlYW47XG4gIGxhenlMb2FkU3JjPzogc3RyaW5nO1xuICBleHBhbmRCdXR0b24/OiBSZWFjdE5vZGU7XG4gIGNyb3A/OiBJbWFnZUNyb3A7XG4gIGZvY2FsUG9pbnQ/OiBJbWFnZUZvY2FsUG9pbnQ7XG59XG5cbmNvbnN0IEltYWdlID0gKHtcbiAgYWx0LFxuICBzcmMsXG4gIGxhenlMb2FkLFxuICBsYXp5TG9hZFNyYyxcbiAgY3JvcCxcbiAgZm9jYWxQb2ludCxcbiAgY29udGVudFR5cGUsXG4gIHNpemVzID0gJyhtaW4td2lkdGg6IDEwMjRweCkgMTAyNHB4LCAxMDB2dycsXG4gIGV4cGFuZEJ1dHRvbixcbiAgZmFsbGJhY2tXaWR0aCA9IDEwMjQsXG4gIC4uLnJlc3Rcbn06IFByb3BzKSA9PiB7XG4gIGNvbnN0IHNyY1NldCA9IHJlc3Quc3JjU2V0ID8/IGdldFNyY1NldChzcmMsIGNyb3AsIGZvY2FsUG9pbnQpO1xuICBjb25zdCBxdWVyeVN0cmluZyA9IG1ha2VTcmNRdWVyeVN0cmluZyhmYWxsYmFja1dpZHRoLCBjcm9wLCBmb2NhbFBvaW50KTtcblxuICBpZiAoY29udGVudFR5cGUgJiYgY29udGVudFR5cGUgPT09ICdpbWFnZS9naWYnKSB7XG4gICAgcmV0dXJuIChcbiAgICAgIDxTdHlsZWRJbWFnZVdyYXBwZXI+XG4gICAgICAgIDxpbWcgYWx0PXthbHR9IHNyYz17YCR7c3JjfWB9IHsuLi5yZXN0fSAvPlxuICAgICAgPC9TdHlsZWRJbWFnZVdyYXBwZXI+XG4gICAgKTtcbiAgfVxuXG4gIGlmIChsYXp5TG9hZCkge1xuICAgIHJldHVybiAoXG4gICAgICA8U3R5bGVkSW1hZ2VXcmFwcGVyPlxuICAgICAgICA8TGF6eUxvYWRJbWFnZVxuICAgICAgICAgIGFsdD17YWx0fVxuICAgICAgICAgIHNyYz17YCR7c3JjfT8ke3F1ZXJ5U3RyaW5nfWB9XG4gICAgICAgICAgc3JjU2V0PXtzcmNTZXR9XG4gICAgICAgICAgc2l6ZXM9e3NpemVzfVxuICAgICAgICAgIGxhenlMb2FkU3JjPXtsYXp5TG9hZFNyY31cbiAgICAgICAgLz5cbiAgICAgIDwvU3R5bGVkSW1hZ2VXcmFwcGVyPlxuICAgICk7XG4gIH1cblxuICByZXR1cm4gKFxuICAgIDxTdHlsZWRJbWFnZVdyYXBwZXI+XG4gICAgICA8cGljdHVyZT5cbiAgICAgICAgPHNvdXJjZSB0eXBlPXtjb250ZW50VHlwZX0gc3JjU2V0PXtzcmNTZXR9IHNpemVzPXtzaXplc30gLz5cbiAgICAgICAgPGltZyBhbHQ9e2FsdH0gc3JjPXtgJHtzcmN9PyR7cXVlcnlTdHJpbmd9YH0gey4uLnJlc3R9IC8+XG4gICAgICA8L3BpY3R1cmU+XG4gICAgICB7ZXhwYW5kQnV0dG9ufVxuICAgIDwvU3R5bGVkSW1hZ2VXcmFwcGVyPlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgSW1hZ2U7XG4iXX0= */",
45
45
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
46
46
  });
47
47
  var Image = function Image(_ref) {
@@ -20,12 +20,12 @@ var StyledLink = /*#__PURE__*/(0, _base["default"])("a", {
20
20
  target: "eo3pjlm0",
21
21
  label: "StyledLink"
22
22
  })(process.env.NODE_ENV === "production" ? {
23
- name: "1lq5d17",
24
- styles: "box-shadow:inset 0 0"
23
+ name: "68s54g",
24
+ styles: "box-shadow:inset 0 0;width:100%;height:100%"
25
25
  } : {
26
- name: "1lq5d17",
27
- styles: "box-shadow:inset 0 0",
28
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkltYWdlTGluay50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBYTJCIiwiZmlsZSI6IkltYWdlTGluay50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxOS1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCwgeyBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBtYWtlU3JjUXVlcnlTdHJpbmcgfSBmcm9tICcuL0ltYWdlJztcbmltcG9ydCB7IEltYWdlQ3JvcCwgSW1hZ2VGb2NhbFBvaW50IH0gZnJvbSAnLic7XG5cbmNvbnN0IFN0eWxlZExpbmsgPSBzdHlsZWQuYWBcbiAgYm94LXNoYWRvdzogaW5zZXQgMCAwO1xuYDtcblxuaW50ZXJmYWNlIFByb3BzIHtcbiAgc3JjOiBzdHJpbmc7XG4gIGNoaWxkcmVuOiBSZWFjdE5vZGU7XG4gIHNpemVzPzogc3RyaW5nO1xuICBjcm9wPzogSW1hZ2VDcm9wO1xuICBmb2NhbFBvaW50PzogSW1hZ2VGb2NhbFBvaW50O1xufVxuXG5leHBvcnQgZnVuY3Rpb24gSW1hZ2VMaW5rKHsgc3JjLCBjcm9wLCBjaGlsZHJlbiwgLi4ucmVzdCB9OiBQcm9wcykge1xuICByZXR1cm4gKFxuICAgIDxTdHlsZWRMaW5rXG4gICAgICB0YXJnZXQ9XCJfYmxhbmtcIlxuICAgICAgaHJlZj17YCR7c3JjfT8ke21ha2VTcmNRdWVyeVN0cmluZyh1bmRlZmluZWQsIGNyb3ApfWB9XG4gICAgICByZWw9XCJub29wZW5lciBub3JlZmVycmVyXCJcbiAgICAgIHsuLi5yZXN0fT5cbiAgICAgIHtjaGlsZHJlbn1cbiAgICA8L1N0eWxlZExpbms+XG4gICk7XG59XG4iXX0= */",
26
+ name: "68s54g",
27
+ styles: "box-shadow:inset 0 0;width:100%;height:100%",
28
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkltYWdlTGluay50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBYTJCIiwiZmlsZSI6IkltYWdlTGluay50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxOS1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCwgeyBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBtYWtlU3JjUXVlcnlTdHJpbmcgfSBmcm9tICcuL0ltYWdlJztcbmltcG9ydCB7IEltYWdlQ3JvcCwgSW1hZ2VGb2NhbFBvaW50IH0gZnJvbSAnLic7XG5cbmNvbnN0IFN0eWxlZExpbmsgPSBzdHlsZWQuYWBcbiAgYm94LXNoYWRvdzogaW5zZXQgMCAwO1xuICB3aWR0aDogMTAwJTtcbiAgaGVpZ2h0OiAxMDAlO1xuYDtcblxuaW50ZXJmYWNlIFByb3BzIHtcbiAgc3JjOiBzdHJpbmc7XG4gIGNoaWxkcmVuOiBSZWFjdE5vZGU7XG4gIHNpemVzPzogc3RyaW5nO1xuICBjcm9wPzogSW1hZ2VDcm9wO1xuICBmb2NhbFBvaW50PzogSW1hZ2VGb2NhbFBvaW50O1xufVxuXG5leHBvcnQgZnVuY3Rpb24gSW1hZ2VMaW5rKHsgc3JjLCBjcm9wLCBjaGlsZHJlbiwgLi4ucmVzdCB9OiBQcm9wcykge1xuICByZXR1cm4gKFxuICAgIDxTdHlsZWRMaW5rXG4gICAgICB0YXJnZXQ9XCJfYmxhbmtcIlxuICAgICAgaHJlZj17YCR7c3JjfT8ke21ha2VTcmNRdWVyeVN0cmluZyh1bmRlZmluZWQsIGNyb3ApfWB9XG4gICAgICByZWw9XCJub29wZW5lciBub3JlZmVycmVyXCJcbiAgICAgIHsuLi5yZXN0fT5cbiAgICAgIHtjaGlsZHJlbn1cbiAgICA8L1N0eWxlZExpbms+XG4gICk7XG59XG4iXX0= */",
29
29
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
30
30
  });
31
31
  function ImageLink(_ref) {
@@ -15,15 +15,15 @@ function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringif
15
15
  var Wrapper = /*#__PURE__*/(0, _base["default"])("div", {
16
16
  target: "e1kvpkml3",
17
17
  label: "Wrapper"
18
- })("padding:", _core.spacing.small, " ", _core.spacing.normal, ";position:relative;min-height:0;flex:1;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkl0ZW1Ub3BpY0hlYWRlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBaUIwQiIsImZpbGUiOiJJdGVtVG9waWNIZWFkZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjEtcHJlc2VudCwgTkRMQS5cbiAqXG4gKiBUaGlzIHNvdXJjZSBjb2RlIGlzIGxpY2Vuc2VkIHVuZGVyIHRoZSBHUEx2MyBsaWNlbnNlIGZvdW5kIGluIHRoZVxuICogTElDRU5TRSBmaWxlIGluIHRoZSByb290IGRpcmVjdG9yeSBvZiB0aGlzIHNvdXJjZSB0cmVlLlxuICpcbiAqL1xuXG5pbXBvcnQgUmVhY3QsIHsgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgdXNlVHJhbnNsYXRpb24gfSBmcm9tICdyZWFjdC1pMThuZXh0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNvbG9ycywgZm9udHMsIHNwYWNpbmcgfSBmcm9tICdAbmRsYS9jb3JlJztcblxuaW1wb3J0IHsgU2VhcmNoSXRlbVR5cGUgfSBmcm9tICcuLi9TZWFyY2hJdGVtJztcbmltcG9ydCBDb250ZW50VHlwZUJhZGdlIGZyb20gJy4uLy4uL0NvbnRlbnRUeXBlQmFkZ2UnO1xuaW1wb3J0IHsgQ29udGVudFR5cGUgfSBmcm9tICcuLi9TZWFyY2hUeXBlUmVzdWx0JztcblxuY29uc3QgV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIHBhZGRpbmc6ICR7c3BhY2luZy5zbWFsbH0gJHtzcGFjaW5nLm5vcm1hbH07XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgbWluLWhlaWdodDogMDtcbiAgZmxleDogMTtcbmA7XG5cbmNvbnN0IExhYmVsID0gc3R5bGVkLmRpdmBcbiAgJHtmb250cy5zaXplcygnMTJweCcsICcxNnB4Jyl9O1xuICBmb250LXdlaWdodDogJHtmb250cy53ZWlnaHQuc2VtaWJvbGR9O1xuICBoZWlnaHQ6IDI2cHg7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIG1hcmdpbi10b3A6ICR7c3BhY2luZy5zbWFsbH07XG5cbiAgLmMtY29udGVudC10eXBlLWJhZGdlIHtcbiAgICB3aWR0aDogMjZweDtcbiAgICBoZWlnaHQ6IDI2cHg7XG4gICAgbWFyZ2luLXJpZ2h0OiAke3NwYWNpbmcueHNtYWxsfTtcbiAgfVxuXG4gIHN2ZyB7XG4gICAgd2lkdGg6IDIycHg7XG4gICAgaGVpZ2h0OiAyMnB4O1xuICAgIGNvbG9yOiAke2NvbG9ycy50ZXh0LnByaW1hcnl9ICFpbXBvcnRhbnQ7XG4gIH1cbmA7XG5cbmNvbnN0IFRvcGljSGVhZGVyVmlzdWFsRWxlbWVudFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICBmbG9hdDogcmlnaHQ7XG4gIG1hcmdpbi1sZWZ0OiAke3NwYWNpbmcuc21hbGx9O1xuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gIHdpZHRoOiAxMTJweDtcbiAgaGVpZ2h0OiAxMTJweDtcbiAgZGlzcGxheTogZmxleDtcbiAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIG92ZXJmbG93OiBoaWRkZW47XG4gIGJvcmRlci1yYWRpdXM6IDUwJTtcbmA7XG5cbmNvbnN0IFRvcGljSGVhZGVySW1hZ2UgPSBzdHlsZWQuaW1nYFxuICB3aWR0aDogMTAwJTtcbiAgaGVpZ2h0OiAxMDAlO1xuICBvYmplY3QtZml0OiBjb3ZlcjtcbiAgbWF4LXdpZHRoOiB1bnNldDtcbmA7XG5cbnR5cGUgUHJvcHMgPSB7XG4gIGNoaWxkcmVuOiBSZWFjdE5vZGU7XG4gIGltYWdlPzogU2VhcmNoSXRlbVR5cGVbJ2l0ZW0nXVsnaW1nJ10gfCBudWxsO1xuICB0eXBlPzogQ29udGVudFR5cGU7XG59O1xuY29uc3QgSXRlbVRvcGljSGVhZGVyID0gKHsgY2hpbGRyZW4sIGltYWdlLCB0eXBlIH06IFByb3BzKSA9PiB7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcbiAgcmV0dXJuIChcbiAgICA8V3JhcHBlcj5cbiAgICAgIHtpbWFnZSAmJiAoXG4gICAgICAgIDxUb3BpY0hlYWRlclZpc3VhbEVsZW1lbnRXcmFwcGVyPlxuICAgICAgICAgIDxUb3BpY0hlYWRlckltYWdlIGNsYXNzTmFtZT1cInRvcGljLWhlYWRlci1pbWFnZVwiIHNyYz17aW1hZ2UudXJsfSBhbHQ9e2ltYWdlLmFsdH0gLz5cbiAgICAgICAgPC9Ub3BpY0hlYWRlclZpc3VhbEVsZW1lbnRXcmFwcGVyPlxuICAgICAgKX1cbiAgICAgIDxMYWJlbCBjbGFzc05hbWU9XCJ0b3BpYy1sYWJlbFwiPlxuICAgICAgICB7dHlwZSAmJiAoXG4gICAgICAgICAgPD5cbiAgICAgICAgICAgIDxDb250ZW50VHlwZUJhZGdlIHR5cGU9e3R5cGV9IGJvcmRlcj17ZmFsc2V9IC8+XG4gICAgICAgICAgICB7dChgY29udGVudFR5cGVzLiR7dHlwZX1gKX1cbiAgICAgICAgICA8Lz5cbiAgICAgICAgKX1cbiAgICAgIDwvTGFiZWw+XG4gICAgICB7Y2hpbGRyZW59XG4gICAgPC9XcmFwcGVyPlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgSXRlbVRvcGljSGVhZGVyO1xuIl19 */"));
18
+ })("padding:", _core.spacing.small, " ", _core.spacing.normal, ";position:relative;min-height:0;flex:1;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkl0ZW1Ub3BpY0hlYWRlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBaUIwQiIsImZpbGUiOiJJdGVtVG9waWNIZWFkZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjEtcHJlc2VudCwgTkRMQS5cbiAqXG4gKiBUaGlzIHNvdXJjZSBjb2RlIGlzIGxpY2Vuc2VkIHVuZGVyIHRoZSBHUEx2MyBsaWNlbnNlIGZvdW5kIGluIHRoZVxuICogTElDRU5TRSBmaWxlIGluIHRoZSByb290IGRpcmVjdG9yeSBvZiB0aGlzIHNvdXJjZSB0cmVlLlxuICpcbiAqL1xuXG5pbXBvcnQgUmVhY3QsIHsgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgdXNlVHJhbnNsYXRpb24gfSBmcm9tICdyZWFjdC1pMThuZXh0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNvbG9ycywgZm9udHMsIHNwYWNpbmcgfSBmcm9tICdAbmRsYS9jb3JlJztcblxuaW1wb3J0IHsgU2VhcmNoSXRlbVR5cGUgfSBmcm9tICcuLi9TZWFyY2hJdGVtJztcbmltcG9ydCBDb250ZW50VHlwZUJhZGdlIGZyb20gJy4uLy4uL0NvbnRlbnRUeXBlQmFkZ2UnO1xuaW1wb3J0IHsgQ29udGVudFR5cGUgfSBmcm9tICcuLi9TZWFyY2hUeXBlUmVzdWx0JztcblxuY29uc3QgV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIHBhZGRpbmc6ICR7c3BhY2luZy5zbWFsbH0gJHtzcGFjaW5nLm5vcm1hbH07XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgbWluLWhlaWdodDogMDtcbiAgZmxleDogMTtcbmA7XG5cbmNvbnN0IExhYmVsID0gc3R5bGVkLmRpdmBcbiAgJHtmb250cy5zaXplcygnMTJweCcsICcxNnB4Jyl9O1xuICBmb250LXdlaWdodDogJHtmb250cy53ZWlnaHQuc2VtaWJvbGR9O1xuICBoZWlnaHQ6IDI2cHg7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIG1hcmdpbi10b3A6ICR7c3BhY2luZy5zbWFsbH07XG5cbiAgLmMtY29udGVudC10eXBlLWJhZGdlIHtcbiAgICB3aWR0aDogMjZweDtcbiAgICBoZWlnaHQ6IDI2cHg7XG4gICAgbWFyZ2luLXJpZ2h0OiAke3NwYWNpbmcueHNtYWxsfTtcbiAgfVxuXG4gIHN2ZyB7XG4gICAgd2lkdGg6IDIycHg7XG4gICAgaGVpZ2h0OiAyMnB4O1xuICAgIGNvbG9yOiAke2NvbG9ycy50ZXh0LnByaW1hcnl9ICFpbXBvcnRhbnQ7XG4gIH1cbmA7XG5cbmNvbnN0IFRvcGljSGVhZGVyVmlzdWFsRWxlbWVudFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICBmbG9hdDogcmlnaHQ7XG4gIG1hcmdpbi1sZWZ0OiAke3NwYWNpbmcuc21hbGx9O1xuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gIHdpZHRoOiAxMTJweDtcbiAgaGVpZ2h0OiAxMTJweDtcbiAgZGlzcGxheTogZmxleDtcbiAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIG92ZXJmbG93OiBoaWRkZW47XG4gIGJvcmRlci1yYWRpdXM6IDUwJTtcbiAgLXdlYmtpdC1tYXNrLWltYWdlOiAtd2Via2l0LXJhZGlhbC1ncmFkaWVudCh3aGl0ZSwgYmxhY2spO1xuYDtcblxuY29uc3QgVG9waWNIZWFkZXJJbWFnZSA9IHN0eWxlZC5pbWdgXG4gIHdpZHRoOiAxMDAlO1xuICBoZWlnaHQ6IDEwMCU7XG4gIG9iamVjdC1maXQ6IGNvdmVyO1xuICBtYXgtd2lkdGg6IHVuc2V0O1xuYDtcblxudHlwZSBQcm9wcyA9IHtcbiAgY2hpbGRyZW46IFJlYWN0Tm9kZTtcbiAgaW1hZ2U/OiBTZWFyY2hJdGVtVHlwZVsnaXRlbSddWydpbWcnXSB8IG51bGw7XG4gIHR5cGU/OiBDb250ZW50VHlwZTtcbn07XG5jb25zdCBJdGVtVG9waWNIZWFkZXIgPSAoeyBjaGlsZHJlbiwgaW1hZ2UsIHR5cGUgfTogUHJvcHMpID0+IHtcbiAgY29uc3QgeyB0IH0gPSB1c2VUcmFuc2xhdGlvbigpO1xuICByZXR1cm4gKFxuICAgIDxXcmFwcGVyPlxuICAgICAge2ltYWdlICYmIChcbiAgICAgICAgPFRvcGljSGVhZGVyVmlzdWFsRWxlbWVudFdyYXBwZXI+XG4gICAgICAgICAgPFRvcGljSGVhZGVySW1hZ2UgY2xhc3NOYW1lPVwidG9waWMtaGVhZGVyLWltYWdlXCIgc3JjPXtpbWFnZS51cmx9IGFsdD17aW1hZ2UuYWx0fSAvPlxuICAgICAgICA8L1RvcGljSGVhZGVyVmlzdWFsRWxlbWVudFdyYXBwZXI+XG4gICAgICApfVxuICAgICAgPExhYmVsIGNsYXNzTmFtZT1cInRvcGljLWxhYmVsXCI+XG4gICAgICAgIHt0eXBlICYmIChcbiAgICAgICAgICA8PlxuICAgICAgICAgICAgPENvbnRlbnRUeXBlQmFkZ2UgdHlwZT17dHlwZX0gYm9yZGVyPXtmYWxzZX0gLz5cbiAgICAgICAgICAgIHt0KGBjb250ZW50VHlwZXMuJHt0eXBlfWApfVxuICAgICAgICAgIDwvPlxuICAgICAgICApfVxuICAgICAgPC9MYWJlbD5cbiAgICAgIHtjaGlsZHJlbn1cbiAgICA8L1dyYXBwZXI+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBJdGVtVG9waWNIZWFkZXI7XG4iXX0= */"));
19
19
  var Label = /*#__PURE__*/(0, _base["default"])("div", {
20
20
  target: "e1kvpkml2",
21
21
  label: "Label"
22
- })(_core.fonts.sizes('12px', '16px'), ";font-weight:", _core.fonts.weight.semibold, ";height:26px;display:flex;align-items:center;margin-top:", _core.spacing.small, ";.c-content-type-badge{width:26px;height:26px;margin-right:", _core.spacing.xsmall, ";}svg{width:22px;height:22px;color:", _core.colors.text.primary, "!important;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkl0ZW1Ub3BpY0hlYWRlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBd0J3QiIsImZpbGUiOiJJdGVtVG9waWNIZWFkZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjEtcHJlc2VudCwgTkRMQS5cbiAqXG4gKiBUaGlzIHNvdXJjZSBjb2RlIGlzIGxpY2Vuc2VkIHVuZGVyIHRoZSBHUEx2MyBsaWNlbnNlIGZvdW5kIGluIHRoZVxuICogTElDRU5TRSBmaWxlIGluIHRoZSByb290IGRpcmVjdG9yeSBvZiB0aGlzIHNvdXJjZSB0cmVlLlxuICpcbiAqL1xuXG5pbXBvcnQgUmVhY3QsIHsgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgdXNlVHJhbnNsYXRpb24gfSBmcm9tICdyZWFjdC1pMThuZXh0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNvbG9ycywgZm9udHMsIHNwYWNpbmcgfSBmcm9tICdAbmRsYS9jb3JlJztcblxuaW1wb3J0IHsgU2VhcmNoSXRlbVR5cGUgfSBmcm9tICcuLi9TZWFyY2hJdGVtJztcbmltcG9ydCBDb250ZW50VHlwZUJhZGdlIGZyb20gJy4uLy4uL0NvbnRlbnRUeXBlQmFkZ2UnO1xuaW1wb3J0IHsgQ29udGVudFR5cGUgfSBmcm9tICcuLi9TZWFyY2hUeXBlUmVzdWx0JztcblxuY29uc3QgV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIHBhZGRpbmc6ICR7c3BhY2luZy5zbWFsbH0gJHtzcGFjaW5nLm5vcm1hbH07XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgbWluLWhlaWdodDogMDtcbiAgZmxleDogMTtcbmA7XG5cbmNvbnN0IExhYmVsID0gc3R5bGVkLmRpdmBcbiAgJHtmb250cy5zaXplcygnMTJweCcsICcxNnB4Jyl9O1xuICBmb250LXdlaWdodDogJHtmb250cy53ZWlnaHQuc2VtaWJvbGR9O1xuICBoZWlnaHQ6IDI2cHg7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIG1hcmdpbi10b3A6ICR7c3BhY2luZy5zbWFsbH07XG5cbiAgLmMtY29udGVudC10eXBlLWJhZGdlIHtcbiAgICB3aWR0aDogMjZweDtcbiAgICBoZWlnaHQ6IDI2cHg7XG4gICAgbWFyZ2luLXJpZ2h0OiAke3NwYWNpbmcueHNtYWxsfTtcbiAgfVxuXG4gIHN2ZyB7XG4gICAgd2lkdGg6IDIycHg7XG4gICAgaGVpZ2h0OiAyMnB4O1xuICAgIGNvbG9yOiAke2NvbG9ycy50ZXh0LnByaW1hcnl9ICFpbXBvcnRhbnQ7XG4gIH1cbmA7XG5cbmNvbnN0IFRvcGljSGVhZGVyVmlzdWFsRWxlbWVudFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICBmbG9hdDogcmlnaHQ7XG4gIG1hcmdpbi1sZWZ0OiAke3NwYWNpbmcuc21hbGx9O1xuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gIHdpZHRoOiAxMTJweDtcbiAgaGVpZ2h0OiAxMTJweDtcbiAgZGlzcGxheTogZmxleDtcbiAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIG92ZXJmbG93OiBoaWRkZW47XG4gIGJvcmRlci1yYWRpdXM6IDUwJTtcbmA7XG5cbmNvbnN0IFRvcGljSGVhZGVySW1hZ2UgPSBzdHlsZWQuaW1nYFxuICB3aWR0aDogMTAwJTtcbiAgaGVpZ2h0OiAxMDAlO1xuICBvYmplY3QtZml0OiBjb3ZlcjtcbiAgbWF4LXdpZHRoOiB1bnNldDtcbmA7XG5cbnR5cGUgUHJvcHMgPSB7XG4gIGNoaWxkcmVuOiBSZWFjdE5vZGU7XG4gIGltYWdlPzogU2VhcmNoSXRlbVR5cGVbJ2l0ZW0nXVsnaW1nJ10gfCBudWxsO1xuICB0eXBlPzogQ29udGVudFR5cGU7XG59O1xuY29uc3QgSXRlbVRvcGljSGVhZGVyID0gKHsgY2hpbGRyZW4sIGltYWdlLCB0eXBlIH06IFByb3BzKSA9PiB7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcbiAgcmV0dXJuIChcbiAgICA8V3JhcHBlcj5cbiAgICAgIHtpbWFnZSAmJiAoXG4gICAgICAgIDxUb3BpY0hlYWRlclZpc3VhbEVsZW1lbnRXcmFwcGVyPlxuICAgICAgICAgIDxUb3BpY0hlYWRlckltYWdlIGNsYXNzTmFtZT1cInRvcGljLWhlYWRlci1pbWFnZVwiIHNyYz17aW1hZ2UudXJsfSBhbHQ9e2ltYWdlLmFsdH0gLz5cbiAgICAgICAgPC9Ub3BpY0hlYWRlclZpc3VhbEVsZW1lbnRXcmFwcGVyPlxuICAgICAgKX1cbiAgICAgIDxMYWJlbCBjbGFzc05hbWU9XCJ0b3BpYy1sYWJlbFwiPlxuICAgICAgICB7dHlwZSAmJiAoXG4gICAgICAgICAgPD5cbiAgICAgICAgICAgIDxDb250ZW50VHlwZUJhZGdlIHR5cGU9e3R5cGV9IGJvcmRlcj17ZmFsc2V9IC8+XG4gICAgICAgICAgICB7dChgY29udGVudFR5cGVzLiR7dHlwZX1gKX1cbiAgICAgICAgICA8Lz5cbiAgICAgICAgKX1cbiAgICAgIDwvTGFiZWw+XG4gICAgICB7Y2hpbGRyZW59XG4gICAgPC9XcmFwcGVyPlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgSXRlbVRvcGljSGVhZGVyO1xuIl19 */"));
22
+ })(_core.fonts.sizes('12px', '16px'), ";font-weight:", _core.fonts.weight.semibold, ";height:26px;display:flex;align-items:center;margin-top:", _core.spacing.small, ";.c-content-type-badge{width:26px;height:26px;margin-right:", _core.spacing.xsmall, ";}svg{width:22px;height:22px;color:", _core.colors.text.primary, "!important;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkl0ZW1Ub3BpY0hlYWRlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBd0J3QiIsImZpbGUiOiJJdGVtVG9waWNIZWFkZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjEtcHJlc2VudCwgTkRMQS5cbiAqXG4gKiBUaGlzIHNvdXJjZSBjb2RlIGlzIGxpY2Vuc2VkIHVuZGVyIHRoZSBHUEx2MyBsaWNlbnNlIGZvdW5kIGluIHRoZVxuICogTElDRU5TRSBmaWxlIGluIHRoZSByb290IGRpcmVjdG9yeSBvZiB0aGlzIHNvdXJjZSB0cmVlLlxuICpcbiAqL1xuXG5pbXBvcnQgUmVhY3QsIHsgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgdXNlVHJhbnNsYXRpb24gfSBmcm9tICdyZWFjdC1pMThuZXh0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNvbG9ycywgZm9udHMsIHNwYWNpbmcgfSBmcm9tICdAbmRsYS9jb3JlJztcblxuaW1wb3J0IHsgU2VhcmNoSXRlbVR5cGUgfSBmcm9tICcuLi9TZWFyY2hJdGVtJztcbmltcG9ydCBDb250ZW50VHlwZUJhZGdlIGZyb20gJy4uLy4uL0NvbnRlbnRUeXBlQmFkZ2UnO1xuaW1wb3J0IHsgQ29udGVudFR5cGUgfSBmcm9tICcuLi9TZWFyY2hUeXBlUmVzdWx0JztcblxuY29uc3QgV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIHBhZGRpbmc6ICR7c3BhY2luZy5zbWFsbH0gJHtzcGFjaW5nLm5vcm1hbH07XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgbWluLWhlaWdodDogMDtcbiAgZmxleDogMTtcbmA7XG5cbmNvbnN0IExhYmVsID0gc3R5bGVkLmRpdmBcbiAgJHtmb250cy5zaXplcygnMTJweCcsICcxNnB4Jyl9O1xuICBmb250LXdlaWdodDogJHtmb250cy53ZWlnaHQuc2VtaWJvbGR9O1xuICBoZWlnaHQ6IDI2cHg7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIG1hcmdpbi10b3A6ICR7c3BhY2luZy5zbWFsbH07XG5cbiAgLmMtY29udGVudC10eXBlLWJhZGdlIHtcbiAgICB3aWR0aDogMjZweDtcbiAgICBoZWlnaHQ6IDI2cHg7XG4gICAgbWFyZ2luLXJpZ2h0OiAke3NwYWNpbmcueHNtYWxsfTtcbiAgfVxuXG4gIHN2ZyB7XG4gICAgd2lkdGg6IDIycHg7XG4gICAgaGVpZ2h0OiAyMnB4O1xuICAgIGNvbG9yOiAke2NvbG9ycy50ZXh0LnByaW1hcnl9ICFpbXBvcnRhbnQ7XG4gIH1cbmA7XG5cbmNvbnN0IFRvcGljSGVhZGVyVmlzdWFsRWxlbWVudFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICBmbG9hdDogcmlnaHQ7XG4gIG1hcmdpbi1sZWZ0OiAke3NwYWNpbmcuc21hbGx9O1xuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gIHdpZHRoOiAxMTJweDtcbiAgaGVpZ2h0OiAxMTJweDtcbiAgZGlzcGxheTogZmxleDtcbiAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIG92ZXJmbG93OiBoaWRkZW47XG4gIGJvcmRlci1yYWRpdXM6IDUwJTtcbiAgLXdlYmtpdC1tYXNrLWltYWdlOiAtd2Via2l0LXJhZGlhbC1ncmFkaWVudCh3aGl0ZSwgYmxhY2spO1xuYDtcblxuY29uc3QgVG9waWNIZWFkZXJJbWFnZSA9IHN0eWxlZC5pbWdgXG4gIHdpZHRoOiAxMDAlO1xuICBoZWlnaHQ6IDEwMCU7XG4gIG9iamVjdC1maXQ6IGNvdmVyO1xuICBtYXgtd2lkdGg6IHVuc2V0O1xuYDtcblxudHlwZSBQcm9wcyA9IHtcbiAgY2hpbGRyZW46IFJlYWN0Tm9kZTtcbiAgaW1hZ2U/OiBTZWFyY2hJdGVtVHlwZVsnaXRlbSddWydpbWcnXSB8IG51bGw7XG4gIHR5cGU/OiBDb250ZW50VHlwZTtcbn07XG5jb25zdCBJdGVtVG9waWNIZWFkZXIgPSAoeyBjaGlsZHJlbiwgaW1hZ2UsIHR5cGUgfTogUHJvcHMpID0+IHtcbiAgY29uc3QgeyB0IH0gPSB1c2VUcmFuc2xhdGlvbigpO1xuICByZXR1cm4gKFxuICAgIDxXcmFwcGVyPlxuICAgICAge2ltYWdlICYmIChcbiAgICAgICAgPFRvcGljSGVhZGVyVmlzdWFsRWxlbWVudFdyYXBwZXI+XG4gICAgICAgICAgPFRvcGljSGVhZGVySW1hZ2UgY2xhc3NOYW1lPVwidG9waWMtaGVhZGVyLWltYWdlXCIgc3JjPXtpbWFnZS51cmx9IGFsdD17aW1hZ2UuYWx0fSAvPlxuICAgICAgICA8L1RvcGljSGVhZGVyVmlzdWFsRWxlbWVudFdyYXBwZXI+XG4gICAgICApfVxuICAgICAgPExhYmVsIGNsYXNzTmFtZT1cInRvcGljLWxhYmVsXCI+XG4gICAgICAgIHt0eXBlICYmIChcbiAgICAgICAgICA8PlxuICAgICAgICAgICAgPENvbnRlbnRUeXBlQmFkZ2UgdHlwZT17dHlwZX0gYm9yZGVyPXtmYWxzZX0gLz5cbiAgICAgICAgICAgIHt0KGBjb250ZW50VHlwZXMuJHt0eXBlfWApfVxuICAgICAgICAgIDwvPlxuICAgICAgICApfVxuICAgICAgPC9MYWJlbD5cbiAgICAgIHtjaGlsZHJlbn1cbiAgICA8L1dyYXBwZXI+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBJdGVtVG9waWNIZWFkZXI7XG4iXX0= */"));
23
23
  var TopicHeaderVisualElementWrapper = /*#__PURE__*/(0, _base["default"])("div", {
24
24
  target: "e1kvpkml1",
25
25
  label: "TopicHeaderVisualElementWrapper"
26
- })("float:right;margin-left:", _core.spacing.small, ";position:relative;width:112px;height:112px;display:flex;justify-content:center;align-items:center;overflow:hidden;border-radius:50%;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkl0ZW1Ub3BpY0hlYWRlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNkNrRCIsImZpbGUiOiJJdGVtVG9waWNIZWFkZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjEtcHJlc2VudCwgTkRMQS5cbiAqXG4gKiBUaGlzIHNvdXJjZSBjb2RlIGlzIGxpY2Vuc2VkIHVuZGVyIHRoZSBHUEx2MyBsaWNlbnNlIGZvdW5kIGluIHRoZVxuICogTElDRU5TRSBmaWxlIGluIHRoZSByb290IGRpcmVjdG9yeSBvZiB0aGlzIHNvdXJjZSB0cmVlLlxuICpcbiAqL1xuXG5pbXBvcnQgUmVhY3QsIHsgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgdXNlVHJhbnNsYXRpb24gfSBmcm9tICdyZWFjdC1pMThuZXh0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNvbG9ycywgZm9udHMsIHNwYWNpbmcgfSBmcm9tICdAbmRsYS9jb3JlJztcblxuaW1wb3J0IHsgU2VhcmNoSXRlbVR5cGUgfSBmcm9tICcuLi9TZWFyY2hJdGVtJztcbmltcG9ydCBDb250ZW50VHlwZUJhZGdlIGZyb20gJy4uLy4uL0NvbnRlbnRUeXBlQmFkZ2UnO1xuaW1wb3J0IHsgQ29udGVudFR5cGUgfSBmcm9tICcuLi9TZWFyY2hUeXBlUmVzdWx0JztcblxuY29uc3QgV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIHBhZGRpbmc6ICR7c3BhY2luZy5zbWFsbH0gJHtzcGFjaW5nLm5vcm1hbH07XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgbWluLWhlaWdodDogMDtcbiAgZmxleDogMTtcbmA7XG5cbmNvbnN0IExhYmVsID0gc3R5bGVkLmRpdmBcbiAgJHtmb250cy5zaXplcygnMTJweCcsICcxNnB4Jyl9O1xuICBmb250LXdlaWdodDogJHtmb250cy53ZWlnaHQuc2VtaWJvbGR9O1xuICBoZWlnaHQ6IDI2cHg7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIG1hcmdpbi10b3A6ICR7c3BhY2luZy5zbWFsbH07XG5cbiAgLmMtY29udGVudC10eXBlLWJhZGdlIHtcbiAgICB3aWR0aDogMjZweDtcbiAgICBoZWlnaHQ6IDI2cHg7XG4gICAgbWFyZ2luLXJpZ2h0OiAke3NwYWNpbmcueHNtYWxsfTtcbiAgfVxuXG4gIHN2ZyB7XG4gICAgd2lkdGg6IDIycHg7XG4gICAgaGVpZ2h0OiAyMnB4O1xuICAgIGNvbG9yOiAke2NvbG9ycy50ZXh0LnByaW1hcnl9ICFpbXBvcnRhbnQ7XG4gIH1cbmA7XG5cbmNvbnN0IFRvcGljSGVhZGVyVmlzdWFsRWxlbWVudFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICBmbG9hdDogcmlnaHQ7XG4gIG1hcmdpbi1sZWZ0OiAke3NwYWNpbmcuc21hbGx9O1xuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gIHdpZHRoOiAxMTJweDtcbiAgaGVpZ2h0OiAxMTJweDtcbiAgZGlzcGxheTogZmxleDtcbiAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIG92ZXJmbG93OiBoaWRkZW47XG4gIGJvcmRlci1yYWRpdXM6IDUwJTtcbmA7XG5cbmNvbnN0IFRvcGljSGVhZGVySW1hZ2UgPSBzdHlsZWQuaW1nYFxuICB3aWR0aDogMTAwJTtcbiAgaGVpZ2h0OiAxMDAlO1xuICBvYmplY3QtZml0OiBjb3ZlcjtcbiAgbWF4LXdpZHRoOiB1bnNldDtcbmA7XG5cbnR5cGUgUHJvcHMgPSB7XG4gIGNoaWxkcmVuOiBSZWFjdE5vZGU7XG4gIGltYWdlPzogU2VhcmNoSXRlbVR5cGVbJ2l0ZW0nXVsnaW1nJ10gfCBudWxsO1xuICB0eXBlPzogQ29udGVudFR5cGU7XG59O1xuY29uc3QgSXRlbVRvcGljSGVhZGVyID0gKHsgY2hpbGRyZW4sIGltYWdlLCB0eXBlIH06IFByb3BzKSA9PiB7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcbiAgcmV0dXJuIChcbiAgICA8V3JhcHBlcj5cbiAgICAgIHtpbWFnZSAmJiAoXG4gICAgICAgIDxUb3BpY0hlYWRlclZpc3VhbEVsZW1lbnRXcmFwcGVyPlxuICAgICAgICAgIDxUb3BpY0hlYWRlckltYWdlIGNsYXNzTmFtZT1cInRvcGljLWhlYWRlci1pbWFnZVwiIHNyYz17aW1hZ2UudXJsfSBhbHQ9e2ltYWdlLmFsdH0gLz5cbiAgICAgICAgPC9Ub3BpY0hlYWRlclZpc3VhbEVsZW1lbnRXcmFwcGVyPlxuICAgICAgKX1cbiAgICAgIDxMYWJlbCBjbGFzc05hbWU9XCJ0b3BpYy1sYWJlbFwiPlxuICAgICAgICB7dHlwZSAmJiAoXG4gICAgICAgICAgPD5cbiAgICAgICAgICAgIDxDb250ZW50VHlwZUJhZGdlIHR5cGU9e3R5cGV9IGJvcmRlcj17ZmFsc2V9IC8+XG4gICAgICAgICAgICB7dChgY29udGVudFR5cGVzLiR7dHlwZX1gKX1cbiAgICAgICAgICA8Lz5cbiAgICAgICAgKX1cbiAgICAgIDwvTGFiZWw+XG4gICAgICB7Y2hpbGRyZW59XG4gICAgPC9XcmFwcGVyPlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgSXRlbVRvcGljSGVhZGVyO1xuIl19 */"));
26
+ })("float:right;margin-left:", _core.spacing.small, ";position:relative;width:112px;height:112px;display:flex;justify-content:center;align-items:center;overflow:hidden;border-radius:50%;-webkit-mask-image:-webkit-radial-gradient(white, black);" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkl0ZW1Ub3BpY0hlYWRlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNkNrRCIsImZpbGUiOiJJdGVtVG9waWNIZWFkZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjEtcHJlc2VudCwgTkRMQS5cbiAqXG4gKiBUaGlzIHNvdXJjZSBjb2RlIGlzIGxpY2Vuc2VkIHVuZGVyIHRoZSBHUEx2MyBsaWNlbnNlIGZvdW5kIGluIHRoZVxuICogTElDRU5TRSBmaWxlIGluIHRoZSByb290IGRpcmVjdG9yeSBvZiB0aGlzIHNvdXJjZSB0cmVlLlxuICpcbiAqL1xuXG5pbXBvcnQgUmVhY3QsIHsgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgdXNlVHJhbnNsYXRpb24gfSBmcm9tICdyZWFjdC1pMThuZXh0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNvbG9ycywgZm9udHMsIHNwYWNpbmcgfSBmcm9tICdAbmRsYS9jb3JlJztcblxuaW1wb3J0IHsgU2VhcmNoSXRlbVR5cGUgfSBmcm9tICcuLi9TZWFyY2hJdGVtJztcbmltcG9ydCBDb250ZW50VHlwZUJhZGdlIGZyb20gJy4uLy4uL0NvbnRlbnRUeXBlQmFkZ2UnO1xuaW1wb3J0IHsgQ29udGVudFR5cGUgfSBmcm9tICcuLi9TZWFyY2hUeXBlUmVzdWx0JztcblxuY29uc3QgV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIHBhZGRpbmc6ICR7c3BhY2luZy5zbWFsbH0gJHtzcGFjaW5nLm5vcm1hbH07XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgbWluLWhlaWdodDogMDtcbiAgZmxleDogMTtcbmA7XG5cbmNvbnN0IExhYmVsID0gc3R5bGVkLmRpdmBcbiAgJHtmb250cy5zaXplcygnMTJweCcsICcxNnB4Jyl9O1xuICBmb250LXdlaWdodDogJHtmb250cy53ZWlnaHQuc2VtaWJvbGR9O1xuICBoZWlnaHQ6IDI2cHg7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIG1hcmdpbi10b3A6ICR7c3BhY2luZy5zbWFsbH07XG5cbiAgLmMtY29udGVudC10eXBlLWJhZGdlIHtcbiAgICB3aWR0aDogMjZweDtcbiAgICBoZWlnaHQ6IDI2cHg7XG4gICAgbWFyZ2luLXJpZ2h0OiAke3NwYWNpbmcueHNtYWxsfTtcbiAgfVxuXG4gIHN2ZyB7XG4gICAgd2lkdGg6IDIycHg7XG4gICAgaGVpZ2h0OiAyMnB4O1xuICAgIGNvbG9yOiAke2NvbG9ycy50ZXh0LnByaW1hcnl9ICFpbXBvcnRhbnQ7XG4gIH1cbmA7XG5cbmNvbnN0IFRvcGljSGVhZGVyVmlzdWFsRWxlbWVudFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICBmbG9hdDogcmlnaHQ7XG4gIG1hcmdpbi1sZWZ0OiAke3NwYWNpbmcuc21hbGx9O1xuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gIHdpZHRoOiAxMTJweDtcbiAgaGVpZ2h0OiAxMTJweDtcbiAgZGlzcGxheTogZmxleDtcbiAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIG92ZXJmbG93OiBoaWRkZW47XG4gIGJvcmRlci1yYWRpdXM6IDUwJTtcbiAgLXdlYmtpdC1tYXNrLWltYWdlOiAtd2Via2l0LXJhZGlhbC1ncmFkaWVudCh3aGl0ZSwgYmxhY2spO1xuYDtcblxuY29uc3QgVG9waWNIZWFkZXJJbWFnZSA9IHN0eWxlZC5pbWdgXG4gIHdpZHRoOiAxMDAlO1xuICBoZWlnaHQ6IDEwMCU7XG4gIG9iamVjdC1maXQ6IGNvdmVyO1xuICBtYXgtd2lkdGg6IHVuc2V0O1xuYDtcblxudHlwZSBQcm9wcyA9IHtcbiAgY2hpbGRyZW46IFJlYWN0Tm9kZTtcbiAgaW1hZ2U/OiBTZWFyY2hJdGVtVHlwZVsnaXRlbSddWydpbWcnXSB8IG51bGw7XG4gIHR5cGU/OiBDb250ZW50VHlwZTtcbn07XG5jb25zdCBJdGVtVG9waWNIZWFkZXIgPSAoeyBjaGlsZHJlbiwgaW1hZ2UsIHR5cGUgfTogUHJvcHMpID0+IHtcbiAgY29uc3QgeyB0IH0gPSB1c2VUcmFuc2xhdGlvbigpO1xuICByZXR1cm4gKFxuICAgIDxXcmFwcGVyPlxuICAgICAge2ltYWdlICYmIChcbiAgICAgICAgPFRvcGljSGVhZGVyVmlzdWFsRWxlbWVudFdyYXBwZXI+XG4gICAgICAgICAgPFRvcGljSGVhZGVySW1hZ2UgY2xhc3NOYW1lPVwidG9waWMtaGVhZGVyLWltYWdlXCIgc3JjPXtpbWFnZS51cmx9IGFsdD17aW1hZ2UuYWx0fSAvPlxuICAgICAgICA8L1RvcGljSGVhZGVyVmlzdWFsRWxlbWVudFdyYXBwZXI+XG4gICAgICApfVxuICAgICAgPExhYmVsIGNsYXNzTmFtZT1cInRvcGljLWxhYmVsXCI+XG4gICAgICAgIHt0eXBlICYmIChcbiAgICAgICAgICA8PlxuICAgICAgICAgICAgPENvbnRlbnRUeXBlQmFkZ2UgdHlwZT17dHlwZX0gYm9yZGVyPXtmYWxzZX0gLz5cbiAgICAgICAgICAgIHt0KGBjb250ZW50VHlwZXMuJHt0eXBlfWApfVxuICAgICAgICAgIDwvPlxuICAgICAgICApfVxuICAgICAgPC9MYWJlbD5cbiAgICAgIHtjaGlsZHJlbn1cbiAgICA8L1dyYXBwZXI+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBJdGVtVG9waWNIZWFkZXI7XG4iXX0= */"));
27
27
  var TopicHeaderImage = /*#__PURE__*/(0, _base["default"])("img", {
28
28
  target: "e1kvpkml0",
29
29
  label: "TopicHeaderImage"
@@ -33,7 +33,7 @@ var TopicHeaderImage = /*#__PURE__*/(0, _base["default"])("img", {
33
33
  } : {
34
34
  name: "ua5abx",
35
35
  styles: "width:100%;height:100%;object-fit:cover;max-width:unset",
36
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkl0ZW1Ub3BpY0hlYWRlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMERtQyIsImZpbGUiOiJJdGVtVG9waWNIZWFkZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjEtcHJlc2VudCwgTkRMQS5cbiAqXG4gKiBUaGlzIHNvdXJjZSBjb2RlIGlzIGxpY2Vuc2VkIHVuZGVyIHRoZSBHUEx2MyBsaWNlbnNlIGZvdW5kIGluIHRoZVxuICogTElDRU5TRSBmaWxlIGluIHRoZSByb290IGRpcmVjdG9yeSBvZiB0aGlzIHNvdXJjZSB0cmVlLlxuICpcbiAqL1xuXG5pbXBvcnQgUmVhY3QsIHsgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgdXNlVHJhbnNsYXRpb24gfSBmcm9tICdyZWFjdC1pMThuZXh0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNvbG9ycywgZm9udHMsIHNwYWNpbmcgfSBmcm9tICdAbmRsYS9jb3JlJztcblxuaW1wb3J0IHsgU2VhcmNoSXRlbVR5cGUgfSBmcm9tICcuLi9TZWFyY2hJdGVtJztcbmltcG9ydCBDb250ZW50VHlwZUJhZGdlIGZyb20gJy4uLy4uL0NvbnRlbnRUeXBlQmFkZ2UnO1xuaW1wb3J0IHsgQ29udGVudFR5cGUgfSBmcm9tICcuLi9TZWFyY2hUeXBlUmVzdWx0JztcblxuY29uc3QgV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIHBhZGRpbmc6ICR7c3BhY2luZy5zbWFsbH0gJHtzcGFjaW5nLm5vcm1hbH07XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgbWluLWhlaWdodDogMDtcbiAgZmxleDogMTtcbmA7XG5cbmNvbnN0IExhYmVsID0gc3R5bGVkLmRpdmBcbiAgJHtmb250cy5zaXplcygnMTJweCcsICcxNnB4Jyl9O1xuICBmb250LXdlaWdodDogJHtmb250cy53ZWlnaHQuc2VtaWJvbGR9O1xuICBoZWlnaHQ6IDI2cHg7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIG1hcmdpbi10b3A6ICR7c3BhY2luZy5zbWFsbH07XG5cbiAgLmMtY29udGVudC10eXBlLWJhZGdlIHtcbiAgICB3aWR0aDogMjZweDtcbiAgICBoZWlnaHQ6IDI2cHg7XG4gICAgbWFyZ2luLXJpZ2h0OiAke3NwYWNpbmcueHNtYWxsfTtcbiAgfVxuXG4gIHN2ZyB7XG4gICAgd2lkdGg6IDIycHg7XG4gICAgaGVpZ2h0OiAyMnB4O1xuICAgIGNvbG9yOiAke2NvbG9ycy50ZXh0LnByaW1hcnl9ICFpbXBvcnRhbnQ7XG4gIH1cbmA7XG5cbmNvbnN0IFRvcGljSGVhZGVyVmlzdWFsRWxlbWVudFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICBmbG9hdDogcmlnaHQ7XG4gIG1hcmdpbi1sZWZ0OiAke3NwYWNpbmcuc21hbGx9O1xuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gIHdpZHRoOiAxMTJweDtcbiAgaGVpZ2h0OiAxMTJweDtcbiAgZGlzcGxheTogZmxleDtcbiAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIG92ZXJmbG93OiBoaWRkZW47XG4gIGJvcmRlci1yYWRpdXM6IDUwJTtcbmA7XG5cbmNvbnN0IFRvcGljSGVhZGVySW1hZ2UgPSBzdHlsZWQuaW1nYFxuICB3aWR0aDogMTAwJTtcbiAgaGVpZ2h0OiAxMDAlO1xuICBvYmplY3QtZml0OiBjb3ZlcjtcbiAgbWF4LXdpZHRoOiB1bnNldDtcbmA7XG5cbnR5cGUgUHJvcHMgPSB7XG4gIGNoaWxkcmVuOiBSZWFjdE5vZGU7XG4gIGltYWdlPzogU2VhcmNoSXRlbVR5cGVbJ2l0ZW0nXVsnaW1nJ10gfCBudWxsO1xuICB0eXBlPzogQ29udGVudFR5cGU7XG59O1xuY29uc3QgSXRlbVRvcGljSGVhZGVyID0gKHsgY2hpbGRyZW4sIGltYWdlLCB0eXBlIH06IFByb3BzKSA9PiB7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcbiAgcmV0dXJuIChcbiAgICA8V3JhcHBlcj5cbiAgICAgIHtpbWFnZSAmJiAoXG4gICAgICAgIDxUb3BpY0hlYWRlclZpc3VhbEVsZW1lbnRXcmFwcGVyPlxuICAgICAgICAgIDxUb3BpY0hlYWRlckltYWdlIGNsYXNzTmFtZT1cInRvcGljLWhlYWRlci1pbWFnZVwiIHNyYz17aW1hZ2UudXJsfSBhbHQ9e2ltYWdlLmFsdH0gLz5cbiAgICAgICAgPC9Ub3BpY0hlYWRlclZpc3VhbEVsZW1lbnRXcmFwcGVyPlxuICAgICAgKX1cbiAgICAgIDxMYWJlbCBjbGFzc05hbWU9XCJ0b3BpYy1sYWJlbFwiPlxuICAgICAgICB7dHlwZSAmJiAoXG4gICAgICAgICAgPD5cbiAgICAgICAgICAgIDxDb250ZW50VHlwZUJhZGdlIHR5cGU9e3R5cGV9IGJvcmRlcj17ZmFsc2V9IC8+XG4gICAgICAgICAgICB7dChgY29udGVudFR5cGVzLiR7dHlwZX1gKX1cbiAgICAgICAgICA8Lz5cbiAgICAgICAgKX1cbiAgICAgIDwvTGFiZWw+XG4gICAgICB7Y2hpbGRyZW59XG4gICAgPC9XcmFwcGVyPlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgSXRlbVRvcGljSGVhZGVyO1xuIl19 */",
36
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkl0ZW1Ub3BpY0hlYWRlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMkRtQyIsImZpbGUiOiJJdGVtVG9waWNIZWFkZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjEtcHJlc2VudCwgTkRMQS5cbiAqXG4gKiBUaGlzIHNvdXJjZSBjb2RlIGlzIGxpY2Vuc2VkIHVuZGVyIHRoZSBHUEx2MyBsaWNlbnNlIGZvdW5kIGluIHRoZVxuICogTElDRU5TRSBmaWxlIGluIHRoZSByb290IGRpcmVjdG9yeSBvZiB0aGlzIHNvdXJjZSB0cmVlLlxuICpcbiAqL1xuXG5pbXBvcnQgUmVhY3QsIHsgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgdXNlVHJhbnNsYXRpb24gfSBmcm9tICdyZWFjdC1pMThuZXh0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNvbG9ycywgZm9udHMsIHNwYWNpbmcgfSBmcm9tICdAbmRsYS9jb3JlJztcblxuaW1wb3J0IHsgU2VhcmNoSXRlbVR5cGUgfSBmcm9tICcuLi9TZWFyY2hJdGVtJztcbmltcG9ydCBDb250ZW50VHlwZUJhZGdlIGZyb20gJy4uLy4uL0NvbnRlbnRUeXBlQmFkZ2UnO1xuaW1wb3J0IHsgQ29udGVudFR5cGUgfSBmcm9tICcuLi9TZWFyY2hUeXBlUmVzdWx0JztcblxuY29uc3QgV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIHBhZGRpbmc6ICR7c3BhY2luZy5zbWFsbH0gJHtzcGFjaW5nLm5vcm1hbH07XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgbWluLWhlaWdodDogMDtcbiAgZmxleDogMTtcbmA7XG5cbmNvbnN0IExhYmVsID0gc3R5bGVkLmRpdmBcbiAgJHtmb250cy5zaXplcygnMTJweCcsICcxNnB4Jyl9O1xuICBmb250LXdlaWdodDogJHtmb250cy53ZWlnaHQuc2VtaWJvbGR9O1xuICBoZWlnaHQ6IDI2cHg7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIG1hcmdpbi10b3A6ICR7c3BhY2luZy5zbWFsbH07XG5cbiAgLmMtY29udGVudC10eXBlLWJhZGdlIHtcbiAgICB3aWR0aDogMjZweDtcbiAgICBoZWlnaHQ6IDI2cHg7XG4gICAgbWFyZ2luLXJpZ2h0OiAke3NwYWNpbmcueHNtYWxsfTtcbiAgfVxuXG4gIHN2ZyB7XG4gICAgd2lkdGg6IDIycHg7XG4gICAgaGVpZ2h0OiAyMnB4O1xuICAgIGNvbG9yOiAke2NvbG9ycy50ZXh0LnByaW1hcnl9ICFpbXBvcnRhbnQ7XG4gIH1cbmA7XG5cbmNvbnN0IFRvcGljSGVhZGVyVmlzdWFsRWxlbWVudFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICBmbG9hdDogcmlnaHQ7XG4gIG1hcmdpbi1sZWZ0OiAke3NwYWNpbmcuc21hbGx9O1xuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gIHdpZHRoOiAxMTJweDtcbiAgaGVpZ2h0OiAxMTJweDtcbiAgZGlzcGxheTogZmxleDtcbiAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIG92ZXJmbG93OiBoaWRkZW47XG4gIGJvcmRlci1yYWRpdXM6IDUwJTtcbiAgLXdlYmtpdC1tYXNrLWltYWdlOiAtd2Via2l0LXJhZGlhbC1ncmFkaWVudCh3aGl0ZSwgYmxhY2spO1xuYDtcblxuY29uc3QgVG9waWNIZWFkZXJJbWFnZSA9IHN0eWxlZC5pbWdgXG4gIHdpZHRoOiAxMDAlO1xuICBoZWlnaHQ6IDEwMCU7XG4gIG9iamVjdC1maXQ6IGNvdmVyO1xuICBtYXgtd2lkdGg6IHVuc2V0O1xuYDtcblxudHlwZSBQcm9wcyA9IHtcbiAgY2hpbGRyZW46IFJlYWN0Tm9kZTtcbiAgaW1hZ2U/OiBTZWFyY2hJdGVtVHlwZVsnaXRlbSddWydpbWcnXSB8IG51bGw7XG4gIHR5cGU/OiBDb250ZW50VHlwZTtcbn07XG5jb25zdCBJdGVtVG9waWNIZWFkZXIgPSAoeyBjaGlsZHJlbiwgaW1hZ2UsIHR5cGUgfTogUHJvcHMpID0+IHtcbiAgY29uc3QgeyB0IH0gPSB1c2VUcmFuc2xhdGlvbigpO1xuICByZXR1cm4gKFxuICAgIDxXcmFwcGVyPlxuICAgICAge2ltYWdlICYmIChcbiAgICAgICAgPFRvcGljSGVhZGVyVmlzdWFsRWxlbWVudFdyYXBwZXI+XG4gICAgICAgICAgPFRvcGljSGVhZGVySW1hZ2UgY2xhc3NOYW1lPVwidG9waWMtaGVhZGVyLWltYWdlXCIgc3JjPXtpbWFnZS51cmx9IGFsdD17aW1hZ2UuYWx0fSAvPlxuICAgICAgICA8L1RvcGljSGVhZGVyVmlzdWFsRWxlbWVudFdyYXBwZXI+XG4gICAgICApfVxuICAgICAgPExhYmVsIGNsYXNzTmFtZT1cInRvcGljLWxhYmVsXCI+XG4gICAgICAgIHt0eXBlICYmIChcbiAgICAgICAgICA8PlxuICAgICAgICAgICAgPENvbnRlbnRUeXBlQmFkZ2UgdHlwZT17dHlwZX0gYm9yZGVyPXtmYWxzZX0gLz5cbiAgICAgICAgICAgIHt0KGBjb250ZW50VHlwZXMuJHt0eXBlfWApfVxuICAgICAgICAgIDwvPlxuICAgICAgICApfVxuICAgICAgPC9MYWJlbD5cbiAgICAgIHtjaGlsZHJlbn1cbiAgICA8L1dyYXBwZXI+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBJdGVtVG9waWNIZWFkZXI7XG4iXX0= */",
37
37
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
38
38
  });
39
39
  var ItemTopicHeader = function ItemTopicHeader(_ref) {
package/lib/index.d.ts CHANGED
@@ -46,6 +46,7 @@ export { default as MastheadAuthModal } from './Masthead/MastheadAuthModal';
46
46
  export { UserInfo } from './User';
47
47
  export { default as AuthModal } from './User';
48
48
  export type { FeideGoGroup, FeideGroup, FeideOrg, FeideUserApiType, FeideMembershipType, FeideUser } from './User';
49
+ export { default as resourceTypeColor } from './utils/resourceTypeColor';
49
50
  export { default as CreatedBy } from './CreatedBy';
50
51
  export { default as Breadcrumblist } from './Breadcrumblist';
51
52
  export { MessageBox, MessageBoxTag, MessageBanner } from './Messages';
package/lib/index.js CHANGED
@@ -96,6 +96,7 @@ var _exportNames = {
96
96
  MastheadAuthModal: true,
97
97
  UserInfo: true,
98
98
  AuthModal: true,
99
+ resourceTypeColor: true,
99
100
  CreatedBy: true,
100
101
  Breadcrumblist: true,
101
102
  MessageBox: true,
@@ -1359,6 +1360,12 @@ Object.defineProperty(exports, "messagesSE", {
1359
1360
  return _messagesSe["default"];
1360
1361
  }
1361
1362
  });
1363
+ Object.defineProperty(exports, "resourceTypeColor", {
1364
+ enumerable: true,
1365
+ get: function get() {
1366
+ return _resourceTypeColor["default"];
1367
+ }
1368
+ });
1362
1369
  Object.defineProperty(exports, "useMastheadHeight", {
1363
1370
  enumerable: true,
1364
1371
  get: function get() {
@@ -1417,6 +1424,7 @@ var _SearchFieldForm = require("./Search/SearchFieldForm");
1417
1424
  var _MastheadSearchModal = _interopRequireDefault(require("./Masthead/MastheadSearchModal"));
1418
1425
  var _MastheadAuthModal = _interopRequireDefault(require("./Masthead/MastheadAuthModal"));
1419
1426
  var _User = _interopRequireWildcard(require("./User"));
1427
+ var _resourceTypeColor = _interopRequireDefault(require("./utils/resourceTypeColor"));
1420
1428
  var _CreatedBy = _interopRequireDefault(require("./CreatedBy"));
1421
1429
  var _Breadcrumblist = _interopRequireDefault(require("./Breadcrumblist"));
1422
1430
  var _Messages = require("./Messages");