@ndla/ui 30.3.1 → 30.4.1

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.
@@ -22,6 +22,7 @@ import { useTranslation } from 'react-i18next';
22
22
  import Tabs from '@ndla/tabs';
23
23
  import SafeLink from '@ndla/safelink';
24
24
  import { colors, fonts, mq, breakpoints } from '@ndla/core';
25
+ import ContentLoader from '../ContentLoader';
25
26
  import { MessageBox } from '../Messages';
26
27
  import { ToggleItem } from '../Filter';
27
28
 
@@ -30,7 +31,7 @@ var StyledWrapper = /*#__PURE__*/_styled("nav", {
30
31
  label: "StyledWrapper"
31
32
  })("margin:32px 0 0;.c-tabs--subjects{margin:0;}.c-tabs__list--subjects{margin:0;}.c-tabs__tab--subjects{", mq.range({
32
33
  until: 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":"AASgC","file":"FrontpageAllSubjects.tsx","sourcesContent":["import React, { Fragment } from 'react';\nimport styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport Tabs from '@ndla/tabs';\nimport SafeLink from '@ndla/safelink';\nimport { colors, fonts, mq, breakpoints } from '@ndla/core';\nimport { MessageBox } from '../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  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"]} */"));
34
+ }), "{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"]} */"));
34
35
 
35
36
  var StyledList = /*#__PURE__*/_styled("ul", {
36
37
  target: "e1kk5ejg5",
@@ -39,7 +40,7 @@ var StyledList = /*#__PURE__*/_styled("ul", {
39
40
  from: breakpoints.tablet
40
41
  }), "{column-count:2;column-gap:20px;}", mq.range({
41
42
  from: breakpoints.tabletWide
42
- }), "{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":"AAiC4B","file":"FrontpageAllSubjects.tsx","sourcesContent":["import React, { Fragment } from 'react';\nimport styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport Tabs from '@ndla/tabs';\nimport SafeLink from '@ndla/safelink';\nimport { colors, fonts, mq, breakpoints } from '@ndla/core';\nimport { MessageBox } from '../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  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"]} */"));
43
+ }), "{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"]} */"));
43
44
 
44
45
  var StyledListItem = /*#__PURE__*/_styled("li", {
45
46
  target: "e1kk5ejg4",
@@ -50,7 +51,7 @@ var StyledListItem = /*#__PURE__*/_styled("li", {
50
51
  } : {
51
52
  name: "19qqojn",
52
53
  styles: "margin-bottom:0;break-inside:avoid",
53
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FrontpageAllSubjects.tsx"],"names":[],"mappings":"AA8CgC","file":"FrontpageAllSubjects.tsx","sourcesContent":["import React, { Fragment } from 'react';\nimport styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport Tabs from '@ndla/tabs';\nimport SafeLink from '@ndla/safelink';\nimport { colors, fonts, mq, breakpoints } from '@ndla/core';\nimport { MessageBox } from '../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  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"]} */",
54
+ 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"]} */",
54
55
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
55
56
  });
56
57
 
@@ -59,7 +60,7 @@ var StyledLetterItem = /*#__PURE__*/_styled("span", {
59
60
  label: "StyledLetterItem"
60
61
  })("display:block;", fonts.sizes(30, 1), ";font-weight:", fonts.weight.bold, ";color:", colors.brand.primary, ";margin-bottom:8px;", function (props) {
61
62
  return props.subjectViewType === 'checkbox' && "margin-left:37px;";
62
- }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FrontpageAllSubjects.tsx"],"names":[],"mappings":"AAmDkE","file":"FrontpageAllSubjects.tsx","sourcesContent":["import React, { Fragment } from 'react';\nimport styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport Tabs from '@ndla/tabs';\nimport SafeLink from '@ndla/safelink';\nimport { colors, fonts, mq, breakpoints } from '@ndla/core';\nimport { MessageBox } from '../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  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"]} */"));
63
+ }, ";" + (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"]} */"));
63
64
 
64
65
  var StyledSpacingElement = /*#__PURE__*/_styled("span", {
65
66
  target: "e1kk5ejg2",
@@ -70,7 +71,7 @@ var StyledSpacingElement = /*#__PURE__*/_styled("span", {
70
71
  } : {
71
72
  name: "wzb9li",
72
73
  styles: "display:block;width:100%;height:10px",
73
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FrontpageAllSubjects.tsx"],"names":[],"mappings":"AA4DwC","file":"FrontpageAllSubjects.tsx","sourcesContent":["import React, { Fragment } from 'react';\nimport styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport Tabs from '@ndla/tabs';\nimport SafeLink from '@ndla/safelink';\nimport { colors, fonts, mq, breakpoints } from '@ndla/core';\nimport { MessageBox } from '../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  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"]} */",
74
+ 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"]} */",
74
75
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
75
76
  });
76
77
 
@@ -83,7 +84,7 @@ var StyledLetterSpacing = /*#__PURE__*/_styled("span", {
83
84
  } : {
84
85
  name: "197vhxd",
85
86
  styles: "display:block;height:16px",
86
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FrontpageAllSubjects.tsx"],"names":[],"mappings":"AAkEuC","file":"FrontpageAllSubjects.tsx","sourcesContent":["import React, { Fragment } from 'react';\nimport styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport Tabs from '@ndla/tabs';\nimport SafeLink from '@ndla/safelink';\nimport { colors, fonts, mq, breakpoints } from '@ndla/core';\nimport { MessageBox } from '../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  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"]} */",
87
+ 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"]} */",
87
88
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
88
89
  });
89
90
 
@@ -96,7 +97,7 @@ var MessageBoxWrapper = /*#__PURE__*/_styled("div", {
96
97
  } : {
97
98
  name: "8qz8ia",
98
99
  styles: "padding-top:20px",
99
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FrontpageAllSubjects.tsx"],"names":[],"mappings":"AAuEoC","file":"FrontpageAllSubjects.tsx","sourcesContent":["import React, { Fragment } from 'react';\nimport styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport Tabs from '@ndla/tabs';\nimport SafeLink from '@ndla/safelink';\nimport { colors, fonts, mq, breakpoints } from '@ndla/core';\nimport { MessageBox } from '../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  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"]} */",
100
+ 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"]} */",
100
101
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
101
102
  });
102
103
 
@@ -187,6 +188,67 @@ var FrontpageAllSubjects = function FrontpageAllSubjects(_ref) {
187
188
  var _useTranslation = useTranslation(),
188
189
  t = _useTranslation.t;
189
190
 
191
+ if (categories.flatMap(function (c) {
192
+ return c.subjects;
193
+ }).length === 0) {
194
+ return _jsx(StyledWrapper, {
195
+ children: _jsxs(ContentLoader, {
196
+ width: 880,
197
+ height: 270,
198
+ children: [_jsx("rect", {
199
+ x: "0",
200
+ y: "10",
201
+ rx: "3",
202
+ ry: "3",
203
+ width: "90",
204
+ height: "35"
205
+ }, "rect-1-1"), _jsx("rect", {
206
+ x: "110",
207
+ y: "10",
208
+ rx: "3",
209
+ ry: "3",
210
+ width: "90",
211
+ height: "35"
212
+ }, "rect-1-2"), _jsx("rect", {
213
+ x: "220",
214
+ y: "10",
215
+ rx: "3",
216
+ ry: "3",
217
+ width: "90",
218
+ height: "35"
219
+ }, "rect-1-3"), _jsx("rect", {
220
+ x: "330",
221
+ y: "10",
222
+ rx: "3",
223
+ ry: "3",
224
+ width: "90",
225
+ height: "35"
226
+ }, "rect-1-4"), _jsx("rect", {
227
+ x: "0",
228
+ y: "70",
229
+ rx: "3",
230
+ ry: "3",
231
+ width: "280",
232
+ height: "200"
233
+ }, "rect-2-1"), _jsx("rect", {
234
+ x: "300",
235
+ y: "70",
236
+ rx: "3",
237
+ ry: "3",
238
+ width: "280",
239
+ height: "200"
240
+ }, "rect-2-2"), _jsx("rect", {
241
+ x: "600",
242
+ y: "70",
243
+ rx: "3",
244
+ ry: "3",
245
+ width: "280",
246
+ height: "200"
247
+ }, "rect-2-3")]
248
+ })
249
+ });
250
+ }
251
+
190
252
  categories.forEach(function (category) {
191
253
  allSubjects.push.apply(allSubjects, _toConsumableArray(category.subjects));
192
254
  category.visible && data.push({
@@ -44,7 +44,7 @@ var zoomInSelect = keyframes(_templateObject());
44
44
  var DropdownContainer = /*#__PURE__*/_styled("div", {
45
45
  target: "e10i3sm22",
46
46
  label: "DropdownContainer"
47
- })("position:relative;margin:0 0 ", spacing.normal, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNhdGVnb3J5U2VsZWN0LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFpQ29DIiwiZmlsZSI6IkNhdGVnb3J5U2VsZWN0LnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE5LXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IFJlYWN0LCB7IHVzZUVmZmVjdCwgdXNlUmVmLCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCBGb2N1c1RyYXBSZWFjdCBmcm9tICdmb2N1cy10cmFwLXJlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGtleWZyYW1lcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IGJyZWFrcG9pbnRzLCBjb2xvcnMsIGZvbnRzLCBtcSwgc3BhY2luZyB9IGZyb20gJ0BuZGxhL2NvcmUnO1xuaW1wb3J0IHsgQ2hldnJvbkRvd24gfSBmcm9tICdAbmRsYS9pY29ucy9jb21tb24nO1xuaW1wb3J0IHsgdXNlVHJhbnNsYXRpb24gfSBmcm9tICdyZWFjdC1pMThuZXh0JztcbmltcG9ydCB7IE1vdmllUmVzb3VyY2VUeXBlIH0gZnJvbSAnLi90eXBlcyc7XG5cbmNvbnN0IHpvb21JblNlbGVjdCA9IGtleWZyYW1lc2BcbiAgMCUge1xuICAgIGRpc3BsYXk6IG5vbmU7XG4gICAgb3BhY2l0eTogMDtcbiAgfVxuICAxJSB7XG4gICAgZGlzcGxheTogZmxleDtcbiAgICB0cmFuc2Zvcm06IHNjYWxlM2QoMC45NSwgMC45NSwgMC45NSk7XG4gICAgb3BhY2l0eTogMDtcbiAgfVxuICAxMDAlIHtcbiAgICBvcGFjaXR5OiAxO1xuICAgIHRyYW5zZm9ybTogc2NhbGUzZCgxLCAxLCAxKTtcbiAgfVxuYDtcblxuY29uc3QgRHJvcGRvd25Db250YWluZXIgPSBzdHlsZWQuZGl2YFxuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gIG1hcmdpbjogMCAwICR7c3BhY2luZy5ub3JtYWx9O1xuYDtcblxuY29uc3QgRHJvcGRvd25CdXR0b24gPSBzdHlsZWQuYnV0dG9uYFxuICBib3JkZXItcmFkaXVzOiA0cHg7XG4gICR7Zm9udHMuc2l6ZXMoJzIycHgnLCAnMjZweCcpfTtcbiAgYm9yZGVyOiAwO1xuICB0ZXh0LXRyYW5zZm9ybTogdXBwZXJjYXNlO1xuICBiYWNrZ3JvdW5kOiAke2NvbG9ycy5uZGxhRmlsbS5maWxtQ29sb3JCcmlnaHR9O1xuICBjb2xvcjogJHtjb2xvcnMud2hpdGV9O1xuICBwYWRkaW5nOiAke3NwYWNpbmcuc21hbGx9ICR7c3BhY2luZy5uc21hbGx9O1xuICBmb250LXdlaWdodDogJHtmb250cy53ZWlnaHQuc2VtaWJvbGR9O1xuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICB0ZXh0LWFsaWduOiBsZWZ0O1xuICBqdXN0aWZ5LWNvbnRlbnQ6IHNwYWNlLWJldHdlZW47XG4gIHdpZHRoOiAxMDAlO1xuICBsZXR0ZXItc3BhY2luZzogMC4wNWVtO1xuICAke21xLnJhbmdlKHsgZnJvbTogYnJlYWtwb2ludHMudGFibGV0IH0pfSB7XG4gICAgcGFkZGluZzogJHtzcGFjaW5nLnNtYWxsfSAke3NwYWNpbmcubm9ybWFsfTtcbiAgfVxuICBkaXY6Zmlyc3QtY2hpbGQge1xuICAgICR7bXEucmFuZ2UoeyB1bnRpbDogYnJlYWtwb2ludHMudGFibGV0IH0pfSB7XG4gICAgICBkaXNwbGF5OiBmbGV4O1xuICAgICAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgICAgIHNtYWxsIHtcbiAgICAgICAgcGFkZGluZzogMDtcbiAgICAgIH1cbiAgICB9XG4gIH1cbiAgc21hbGwge1xuICAgIHRleHQtdHJhbnNmb3JtOiBub25lO1xuICAgIHBhZGRpbmctbGVmdDogJHtzcGFjaW5nLnNtYWxsfTtcbiAgICBmb250LXdlaWdodDogbm9ybWFsO1xuICB9XG5gO1xuXG5pbnRlcmZhY2UgRHJvcGRvd25XcmFwcGVyUHJvcHMge1xuICBvZmZzZXREcm9wZG93bjogbnVtYmVyO1xufVxuXG5jb25zdCBEcm9wZG93bldyYXBwZXIgPSBzdHlsZWQuZGl2PERyb3Bkb3duV3JhcHBlclByb3BzPmBcbiAgdG9wOiAtJHsocHJvcHMpID0+IHByb3BzLm9mZnNldERyb3Bkb3duICogNTIgKyAxM31weDtcbiAgJHtEcm9wZG93bkJ1dHRvbn0ge1xuICAgIGJvcmRlci1yYWRpdXM6IDA7XG4gICAgdGV4dC10cmFuc2Zvcm06IG5vbmU7XG4gICAgbGV0dGVyLXNwYWNpbmc6IDA7XG4gIH1cbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgcGFkZGluZzogJHNwYWNpbmctLXNtYWxsIDA7XG4gIGJhY2tncm91bmQ6ICR7Y29sb3JzLmJyYW5kLmxpZ2h0ZXJ9O1xuICBib3JkZXItcmFkaXVzOiA0cHg7XG4gIGxlZnQ6IDA7XG4gIHJpZ2h0OiAwO1xuICBhbmltYXRpb246ICR7em9vbUluU2VsZWN0fSAyMDBtcyBlYXNlO1xuICBib3gtc2hhZG93OiAwIDAgMzBweCByZ2JhKCR7Y29sb3JzLmJsYWNrfSwgMC42KTtcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICB6LWluZGV4OiA5OTk5O1xuICBidXR0b24sXG4gIGEge1xuICAgIGNvbG9yOiAke2NvbG9ycy50ZXh0LnByaW1hcnl9O1xuICAgIGJvcmRlcjogMDtcbiAgICBvdXRsaW5lOiAwO1xuICAgIHRleHQtYWxpZ246IGxlZnQ7XG4gICAgYmFja2dyb3VuZDogdHJhbnNwYXJlbnQ7XG4gICAgcGFkZGluZzogJHtzcGFjaW5nLnNtYWxsfTtcbiAgICBwYWRkaW5nLWxlZnQ6ICR7c3BhY2luZy5ub3JtYWx9O1xuICAgIGZvbnQtd2VpZ2h0OiAke2ZvbnRzLndlaWdodC5zZW1pYm9sZH07XG4gICAgdGV4dC1kZWNvcmF0aW9uOiBub25lO1xuICAgIGJveC1zaGFkb3c6IG5vbmU7XG4gICAgdHJhbnNpdGlvbjogYmFja2dyb3VuZCAyMDBtcyBlYXNlO1xuICAgICY6aG92ZXIsXG4gICAgJjpmb2N1cyB7XG4gICAgICBjb2xvcjogJHtjb2xvcnMuYnJhbmQucHJpbWFyeX07XG4gICAgICBiYWNrZ3JvdW5kOiByZ2JhKDAsIDAsIDAsIDAuMik7XG4gICAgfVxuICB9XG5gO1xuXG5pbnRlcmZhY2UgUHJvcHMge1xuICByZXNvdXJjZVR5cGVzOiBNb3ZpZVJlc291cmNlVHlwZVtdO1xuICByZXNvdXJjZVR5cGVTZWxlY3RlZD86IE1vdmllUmVzb3VyY2VUeXBlO1xuICBhcmlhQ29udHJvbElkPzogc3RyaW5nO1xuICBvbkNoYW5nZVJlc291cmNlVHlwZTogKHJlc291cmNlSWQ/OiBzdHJpbmcpID0+IHZvaWQ7XG59XG5cbmNvbnN0IENhdGVnb3J5U2VsZWN0ID0gKHsgcmVzb3VyY2VUeXBlcywgcmVzb3VyY2VUeXBlU2VsZWN0ZWQsIGFyaWFDb250cm9sSWQsIG9uQ2hhbmdlUmVzb3VyY2VUeXBlIH06IFByb3BzKSA9PiB7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcbiAgY29uc3QgcmVmcyA9IHVzZVJlZjxSZWNvcmQ8c3RyaW5nLCBIVE1MQnV0dG9uRWxlbWVudCB8IG51bGw+Pih7fSk7XG5cbiAgY29uc3QgW3Jlc291cmNlVHlwZXNJc09wZW4sIHNldFJlc291cmNlVHlwZXNJc09wZW5dID0gdXNlU3RhdGU8Ym9vbGVhbj4oZmFsc2UpO1xuXG4gIGNvbnN0IHVwZGF0ZVJlZiA9IChlbDogSFRNTEJ1dHRvbkVsZW1lbnQgfCBudWxsLCBuYW1lOiBzdHJpbmcpID0+IHtcbiAgICByZWZzLmN1cnJlbnRbbmFtZV0gPSBlbDtcbiAgfTtcblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGlmIChyZXNvdXJjZVR5cGVTZWxlY3RlZCAmJiByZWZzLmN1cnJlbnRbcmVzb3VyY2VUeXBlU2VsZWN0ZWQuaWRdKSB7XG4gICAgICByZWZzLmN1cnJlbnRbcmVzb3VyY2VUeXBlU2VsZWN0ZWQuaWRdPy5mb2N1cygpO1xuICAgIH1cbiAgfSwgW3Jlc291cmNlVHlwZXNJc09wZW4sIHJlc291cmNlVHlwZVNlbGVjdGVkXSk7XG5cbiAgY29uc3Qgb25TZWxlY3QgPSAodmFsPzogc3RyaW5nKSA9PiB7XG4gICAgb25DaGFuZ2VSZXNvdXJjZVR5cGUodmFsKTtcbiAgICBzZXRSZXNvdXJjZVR5cGVzSXNPcGVuKGZhbHNlKTtcbiAgfTtcblxuICBjb25zdCBvZmZzZXREcm9wRG93biA9IHJlc291cmNlVHlwZVNlbGVjdGVkXG4gICAgPyByZXNvdXJjZVR5cGVzLmZpbmRJbmRleCgocmVzb3VyY2UpID0+IHJlc291cmNlLmlkID09PSByZXNvdXJjZVR5cGVTZWxlY3RlZC5pZCkgKyAxXG4gICAgOiAwO1xuXG4gIHJldHVybiAoXG4gICAgPERyb3Bkb3duQ29udGFpbmVyIGNsYXNzTmFtZT1cInUtMTIvMTJcIj5cbiAgICAgIDxEcm9wZG93bkJ1dHRvblxuICAgICAgICBhcmlhLWV4cGFuZGVkPXshcmVzb3VyY2VUeXBlc0lzT3Blbn1cbiAgICAgICAgYXJpYS1jb250cm9scz1cInNlbGVjdENhdGVnb3J5XCJcbiAgICAgICAgdHlwZT1cImJ1dHRvblwiXG4gICAgICAgIHRhYkluZGV4PXtyZXNvdXJjZVR5cGVzSXNPcGVuID8gLTEgOiAwfVxuICAgICAgICBvbkNsaWNrPXsoKSA9PiBzZXRSZXNvdXJjZVR5cGVzSXNPcGVuKHRydWUpfT5cbiAgICAgICAgPGRpdj5cbiAgICAgICAgICA8c3Bhbj57dCgnbmRsYUZpbG0uc2VhcmNoLmNob29zZUNhdGVnb3J5Jyl9PC9zcGFuPlxuICAgICAgICAgIDxzbWFsbD57KHJlc291cmNlVHlwZVNlbGVjdGVkICYmIHJlc291cmNlVHlwZVNlbGVjdGVkLm5hbWUpIHx8IHQoJ25kbGFGaWxtLnNlYXJjaC5jYXRlZ29yeUZyb21OZGxhJyl9PC9zbWFsbD5cbiAgICAgICAgPC9kaXY+XG4gICAgICAgIDxkaXY+XG4gICAgICAgICAgPENoZXZyb25Eb3duIGNsYXNzTmFtZT1cImMtaWNvbi0tMjJcIiAvPlxuICAgICAgICA8L2Rpdj5cbiAgICAgIDwvRHJvcGRvd25CdXR0b24+XG4gICAgICB7cmVzb3VyY2VUeXBlc0lzT3BlbiAmJiAoXG4gICAgICAgIDxGb2N1c1RyYXBSZWFjdFxuICAgICAgICAgIGFjdGl2ZT17cmVzb3VyY2VUeXBlc0lzT3Blbn1cbiAgICAgICAgICBmb2N1c1RyYXBPcHRpb25zPXt7XG4gICAgICAgICAgICBvbkRlYWN0aXZhdGU6ICgpID0+IHNldFJlc291cmNlVHlwZXNJc09wZW4oZmFsc2UpLFxuICAgICAgICAgICAgY2xpY2tPdXRzaWRlRGVhY3RpdmF0ZXM6IHRydWUsXG4gICAgICAgICAgICBlc2NhcGVEZWFjdGl2YXRlczogdHJ1ZSxcbiAgICAgICAgICB9fT5cbiAgICAgICAgICA8RHJvcGRvd25XcmFwcGVyIGlkPVwic2VsZWN0Q2F0ZWdvcnlcIiBvZmZzZXREcm9wZG93bj17b2Zmc2V0RHJvcERvd259PlxuICAgICAgICAgICAgPERyb3Bkb3duQnV0dG9uIGFyaWEtY29udHJvbHM9e2FyaWFDb250cm9sSWR9IHR5cGU9XCJidXR0b25cIiBvbkNsaWNrPXsoKSA9PiBvblNlbGVjdCgpfT5cbiAgICAgICAgICAgICAgPHNwYW4+e3QoJ25kbGFGaWxtLnNlYXJjaC5jYXRlZ29yeUZyb21OZGxhJyl9PC9zcGFuPlxuICAgICAgICAgICAgPC9Ecm9wZG93bkJ1dHRvbj5cbiAgICAgICAgICAgIHtyZXNvdXJjZVR5cGVzLm1hcCgocmVzb3VyY2VUeXBlKSA9PiAoXG4gICAgICAgICAgICAgIDxEcm9wZG93bkJ1dHRvblxuICAgICAgICAgICAgICAgIGFyaWEtY29udHJvbHM9e2FyaWFDb250cm9sSWR9XG4gICAgICAgICAgICAgICAgdHlwZT1cImJ1dHRvblwiXG4gICAgICAgICAgICAgICAgcmVmPXsoZWwpID0+IHVwZGF0ZVJlZihlbCwgcmVzb3VyY2VUeXBlLmlkKX1cbiAgICAgICAgICAgICAgICBvbkNsaWNrPXsoKSA9PiBvblNlbGVjdChyZXNvdXJjZVR5cGUuaWQpfVxuICAgICAgICAgICAgICAgIGRhdGEtaWQ9e3Jlc291cmNlVHlwZS5pZH1cbiAgICAgICAgICAgICAgICBrZXk9e3Jlc291cmNlVHlwZS5pZH0+XG4gICAgICAgICAgICAgICAgPHNwYW4+e3Jlc291cmNlVHlwZS5uYW1lfTwvc3Bhbj5cbiAgICAgICAgICAgICAgPC9Ecm9wZG93bkJ1dHRvbj5cbiAgICAgICAgICAgICkpfVxuICAgICAgICAgIDwvRHJvcGRvd25XcmFwcGVyPlxuICAgICAgICA8L0ZvY3VzVHJhcFJlYWN0PlxuICAgICAgKX1cbiAgICA8L0Ryb3Bkb3duQ29udGFpbmVyPlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgQ2F0ZWdvcnlTZWxlY3Q7XG4iXX0= */"));
47
+ })("position:relative;margin:0 0 ", spacing.normal, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNhdGVnb3J5U2VsZWN0LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFpQ29DIiwiZmlsZSI6IkNhdGVnb3J5U2VsZWN0LnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE5LXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IFJlYWN0LCB7IHVzZUVmZmVjdCwgdXNlUmVmLCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCBGb2N1c1RyYXBSZWFjdCBmcm9tICdmb2N1cy10cmFwLXJlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGtleWZyYW1lcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IGJyZWFrcG9pbnRzLCBjb2xvcnMsIGZvbnRzLCBtcSwgc3BhY2luZyB9IGZyb20gJ0BuZGxhL2NvcmUnO1xuaW1wb3J0IHsgQ2hldnJvbkRvd24gfSBmcm9tICdAbmRsYS9pY29ucy9jb21tb24nO1xuaW1wb3J0IHsgdXNlVHJhbnNsYXRpb24gfSBmcm9tICdyZWFjdC1pMThuZXh0JztcbmltcG9ydCB7IE1vdmllUmVzb3VyY2VUeXBlIH0gZnJvbSAnLi90eXBlcyc7XG5cbmNvbnN0IHpvb21JblNlbGVjdCA9IGtleWZyYW1lc2BcbiAgMCUge1xuICAgIGRpc3BsYXk6IG5vbmU7XG4gICAgb3BhY2l0eTogMDtcbiAgfVxuICAxJSB7XG4gICAgZGlzcGxheTogZmxleDtcbiAgICB0cmFuc2Zvcm06IHNjYWxlM2QoMC45NSwgMC45NSwgMC45NSk7XG4gICAgb3BhY2l0eTogMDtcbiAgfVxuICAxMDAlIHtcbiAgICBvcGFjaXR5OiAxO1xuICAgIHRyYW5zZm9ybTogc2NhbGUzZCgxLCAxLCAxKTtcbiAgfVxuYDtcblxuY29uc3QgRHJvcGRvd25Db250YWluZXIgPSBzdHlsZWQuZGl2YFxuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gIG1hcmdpbjogMCAwICR7c3BhY2luZy5ub3JtYWx9O1xuYDtcblxuY29uc3QgRHJvcGRvd25CdXR0b24gPSBzdHlsZWQuYnV0dG9uYFxuICBib3JkZXItcmFkaXVzOiA0cHg7XG4gICR7Zm9udHMuc2l6ZXMoJzIycHgnLCAnMjZweCcpfTtcbiAgYm9yZGVyOiAwO1xuICB0ZXh0LXRyYW5zZm9ybTogdXBwZXJjYXNlO1xuICBiYWNrZ3JvdW5kOiAke2NvbG9ycy5uZGxhRmlsbS5maWxtQ29sb3JCcmlnaHR9O1xuICBjb2xvcjogJHtjb2xvcnMud2hpdGV9O1xuICBwYWRkaW5nOiAke3NwYWNpbmcuc21hbGx9ICR7c3BhY2luZy5uc21hbGx9O1xuICBmb250LXdlaWdodDogJHtmb250cy53ZWlnaHQuc2VtaWJvbGR9O1xuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICB0ZXh0LWFsaWduOiBsZWZ0O1xuICBqdXN0aWZ5LWNvbnRlbnQ6IHNwYWNlLWJldHdlZW47XG4gIHdpZHRoOiAxMDAlO1xuICBsZXR0ZXItc3BhY2luZzogMC4wNWVtO1xuICAke21xLnJhbmdlKHsgZnJvbTogYnJlYWtwb2ludHMudGFibGV0IH0pfSB7XG4gICAgcGFkZGluZzogJHtzcGFjaW5nLnNtYWxsfSAke3NwYWNpbmcubm9ybWFsfTtcbiAgfVxuICBkaXY6Zmlyc3QtY2hpbGQge1xuICAgICR7bXEucmFuZ2UoeyB1bnRpbDogYnJlYWtwb2ludHMudGFibGV0IH0pfSB7XG4gICAgICBkaXNwbGF5OiBmbGV4O1xuICAgICAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgICAgIHNtYWxsIHtcbiAgICAgICAgcGFkZGluZzogMDtcbiAgICAgIH1cbiAgICB9XG4gIH1cbiAgc21hbGwge1xuICAgIHRleHQtdHJhbnNmb3JtOiBub25lO1xuICAgIHBhZGRpbmctbGVmdDogJHtzcGFjaW5nLnNtYWxsfTtcbiAgICBmb250LXdlaWdodDogbm9ybWFsO1xuICB9XG5gO1xuXG5pbnRlcmZhY2UgRHJvcGRvd25XcmFwcGVyUHJvcHMge1xuICBvZmZzZXREcm9wZG93bjogbnVtYmVyO1xufVxuXG5jb25zdCBEcm9wZG93bldyYXBwZXIgPSBzdHlsZWQuZGl2PERyb3Bkb3duV3JhcHBlclByb3BzPmBcbiAgdG9wOiAtJHsocHJvcHMpID0+IHByb3BzLm9mZnNldERyb3Bkb3duICogNTIgKyAxM31weDtcbiAgJHtEcm9wZG93bkJ1dHRvbn0ge1xuICAgIGJvcmRlci1yYWRpdXM6IDA7XG4gICAgdGV4dC10cmFuc2Zvcm06IG5vbmU7XG4gICAgbGV0dGVyLXNwYWNpbmc6IDA7XG4gIH1cbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgcGFkZGluZzogJHNwYWNpbmctLXNtYWxsIDA7XG4gIGJhY2tncm91bmQ6ICR7Y29sb3JzLmJyYW5kLmxpZ2h0ZXJ9O1xuICBib3JkZXItcmFkaXVzOiA0cHg7XG4gIGxlZnQ6IDA7XG4gIHJpZ2h0OiAwO1xuICBhbmltYXRpb246ICR7em9vbUluU2VsZWN0fSAyMDBtcyBlYXNlO1xuICBib3gtc2hhZG93OiAwIDAgMzBweCByZ2JhKCR7Y29sb3JzLmJsYWNrfSwgMC42KTtcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICB6LWluZGV4OiA5OTk5O1xuICBidXR0b24sXG4gIGEge1xuICAgIGNvbG9yOiAke2NvbG9ycy50ZXh0LnByaW1hcnl9O1xuICAgIGJvcmRlcjogMDtcbiAgICBvdXRsaW5lOiAwO1xuICAgIHRleHQtYWxpZ246IGxlZnQ7XG4gICAgYmFja2dyb3VuZDogdHJhbnNwYXJlbnQ7XG4gICAgcGFkZGluZzogJHtzcGFjaW5nLnNtYWxsfTtcbiAgICBwYWRkaW5nLWxlZnQ6ICR7c3BhY2luZy5ub3JtYWx9O1xuICAgIGZvbnQtd2VpZ2h0OiAke2ZvbnRzLndlaWdodC5zZW1pYm9sZH07XG4gICAgdGV4dC1kZWNvcmF0aW9uOiBub25lO1xuICAgIGJveC1zaGFkb3c6IG5vbmU7XG4gICAgdHJhbnNpdGlvbjogYmFja2dyb3VuZCAyMDBtcyBlYXNlO1xuICAgICY6aG92ZXIsXG4gICAgJjpmb2N1cyB7XG4gICAgICBjb2xvcjogJHtjb2xvcnMuYnJhbmQucHJpbWFyeX07XG4gICAgICBiYWNrZ3JvdW5kOiByZ2JhKDAsIDAsIDAsIDAuMik7XG4gICAgfVxuICB9XG5gO1xuXG5pbnRlcmZhY2UgUHJvcHMge1xuICByZXNvdXJjZVR5cGVzOiBNb3ZpZVJlc291cmNlVHlwZVtdO1xuICByZXNvdXJjZVR5cGVTZWxlY3RlZD86IE1vdmllUmVzb3VyY2VUeXBlO1xuICBhcmlhQ29udHJvbElkPzogc3RyaW5nO1xuICBvbkNoYW5nZVJlc291cmNlVHlwZTogKHJlc291cmNlSWQ/OiBzdHJpbmcpID0+IHZvaWQ7XG59XG5cbmNvbnN0IENhdGVnb3J5U2VsZWN0ID0gKHsgcmVzb3VyY2VUeXBlcywgcmVzb3VyY2VUeXBlU2VsZWN0ZWQsIGFyaWFDb250cm9sSWQsIG9uQ2hhbmdlUmVzb3VyY2VUeXBlIH06IFByb3BzKSA9PiB7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcbiAgY29uc3QgcmVmcyA9IHVzZVJlZjxSZWNvcmQ8c3RyaW5nLCBIVE1MQnV0dG9uRWxlbWVudCB8IG51bGw+Pih7fSk7XG5cbiAgY29uc3QgW3Jlc291cmNlVHlwZXNJc09wZW4sIHNldFJlc291cmNlVHlwZXNJc09wZW5dID0gdXNlU3RhdGU8Ym9vbGVhbj4oZmFsc2UpO1xuXG4gIGNvbnN0IHVwZGF0ZVJlZiA9IChlbDogSFRNTEJ1dHRvbkVsZW1lbnQgfCBudWxsLCBuYW1lOiBzdHJpbmcpID0+IHtcbiAgICByZWZzLmN1cnJlbnRbbmFtZV0gPSBlbDtcbiAgfTtcblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGlmIChyZXNvdXJjZVR5cGVTZWxlY3RlZCAmJiByZWZzLmN1cnJlbnRbcmVzb3VyY2VUeXBlU2VsZWN0ZWQuaWRdKSB7XG4gICAgICByZWZzLmN1cnJlbnRbcmVzb3VyY2VUeXBlU2VsZWN0ZWQuaWRdPy5mb2N1cygpO1xuICAgIH1cbiAgfSwgW3Jlc291cmNlVHlwZXNJc09wZW4sIHJlc291cmNlVHlwZVNlbGVjdGVkXSk7XG5cbiAgY29uc3Qgb25TZWxlY3QgPSAodmFsPzogc3RyaW5nKSA9PiB7XG4gICAgb25DaGFuZ2VSZXNvdXJjZVR5cGUodmFsKTtcbiAgICBzZXRSZXNvdXJjZVR5cGVzSXNPcGVuKGZhbHNlKTtcbiAgfTtcblxuICBjb25zdCBvZmZzZXREcm9wRG93biA9IHJlc291cmNlVHlwZVNlbGVjdGVkXG4gICAgPyByZXNvdXJjZVR5cGVzLmZpbmRJbmRleCgocmVzb3VyY2UpID0+IHJlc291cmNlLmlkID09PSByZXNvdXJjZVR5cGVTZWxlY3RlZC5pZCkgKyAxXG4gICAgOiAwO1xuXG4gIHJldHVybiAoXG4gICAgPERyb3Bkb3duQ29udGFpbmVyIGNsYXNzTmFtZT1cInUtMTIvMTJcIj5cbiAgICAgIDxEcm9wZG93bkJ1dHRvblxuICAgICAgICBhcmlhLWV4cGFuZGVkPXshIXJlc291cmNlVHlwZXNJc09wZW59XG4gICAgICAgIGFyaWEtY29udHJvbHM9XCJzZWxlY3RDYXRlZ29yeVwiXG4gICAgICAgIHR5cGU9XCJidXR0b25cIlxuICAgICAgICB0YWJJbmRleD17cmVzb3VyY2VUeXBlc0lzT3BlbiA/IC0xIDogMH1cbiAgICAgICAgb25DbGljaz17KCkgPT4gc2V0UmVzb3VyY2VUeXBlc0lzT3Blbih0cnVlKX0+XG4gICAgICAgIDxkaXY+XG4gICAgICAgICAgPHNwYW4+e3QoJ25kbGFGaWxtLnNlYXJjaC5jaG9vc2VDYXRlZ29yeScpfTwvc3Bhbj5cbiAgICAgICAgICA8c21hbGw+eyhyZXNvdXJjZVR5cGVTZWxlY3RlZCAmJiByZXNvdXJjZVR5cGVTZWxlY3RlZC5uYW1lKSB8fCB0KCduZGxhRmlsbS5zZWFyY2guY2F0ZWdvcnlGcm9tTmRsYScpfTwvc21hbGw+XG4gICAgICAgIDwvZGl2PlxuICAgICAgICA8ZGl2PlxuICAgICAgICAgIDxDaGV2cm9uRG93biBjbGFzc05hbWU9XCJjLWljb24tLTIyXCIgLz5cbiAgICAgICAgPC9kaXY+XG4gICAgICA8L0Ryb3Bkb3duQnV0dG9uPlxuICAgICAge3Jlc291cmNlVHlwZXNJc09wZW4gJiYgKFxuICAgICAgICA8Rm9jdXNUcmFwUmVhY3RcbiAgICAgICAgICBhY3RpdmU9e3Jlc291cmNlVHlwZXNJc09wZW59XG4gICAgICAgICAgZm9jdXNUcmFwT3B0aW9ucz17e1xuICAgICAgICAgICAgb25EZWFjdGl2YXRlOiAoKSA9PiBzZXRSZXNvdXJjZVR5cGVzSXNPcGVuKGZhbHNlKSxcbiAgICAgICAgICAgIGNsaWNrT3V0c2lkZURlYWN0aXZhdGVzOiB0cnVlLFxuICAgICAgICAgICAgZXNjYXBlRGVhY3RpdmF0ZXM6IHRydWUsXG4gICAgICAgICAgfX0+XG4gICAgICAgICAgPERyb3Bkb3duV3JhcHBlciBpZD1cInNlbGVjdENhdGVnb3J5XCIgb2Zmc2V0RHJvcGRvd249e29mZnNldERyb3BEb3dufT5cbiAgICAgICAgICAgIDxEcm9wZG93bkJ1dHRvbiBhcmlhLWNvbnRyb2xzPXthcmlhQ29udHJvbElkfSB0eXBlPVwiYnV0dG9uXCIgb25DbGljaz17KCkgPT4gb25TZWxlY3QoKX0+XG4gICAgICAgICAgICAgIDxzcGFuPnt0KCduZGxhRmlsbS5zZWFyY2guY2F0ZWdvcnlGcm9tTmRsYScpfTwvc3Bhbj5cbiAgICAgICAgICAgIDwvRHJvcGRvd25CdXR0b24+XG4gICAgICAgICAgICB7cmVzb3VyY2VUeXBlcy5tYXAoKHJlc291cmNlVHlwZSkgPT4gKFxuICAgICAgICAgICAgICA8RHJvcGRvd25CdXR0b25cbiAgICAgICAgICAgICAgICBhcmlhLWNvbnRyb2xzPXthcmlhQ29udHJvbElkfVxuICAgICAgICAgICAgICAgIHR5cGU9XCJidXR0b25cIlxuICAgICAgICAgICAgICAgIHJlZj17KGVsKSA9PiB1cGRhdGVSZWYoZWwsIHJlc291cmNlVHlwZS5pZCl9XG4gICAgICAgICAgICAgICAgb25DbGljaz17KCkgPT4gb25TZWxlY3QocmVzb3VyY2VUeXBlLmlkKX1cbiAgICAgICAgICAgICAgICBkYXRhLWlkPXtyZXNvdXJjZVR5cGUuaWR9XG4gICAgICAgICAgICAgICAga2V5PXtyZXNvdXJjZVR5cGUuaWR9PlxuICAgICAgICAgICAgICAgIDxzcGFuPntyZXNvdXJjZVR5cGUubmFtZX08L3NwYW4+XG4gICAgICAgICAgICAgIDwvRHJvcGRvd25CdXR0b24+XG4gICAgICAgICAgICApKX1cbiAgICAgICAgICA8L0Ryb3Bkb3duV3JhcHBlcj5cbiAgICAgICAgPC9Gb2N1c1RyYXBSZWFjdD5cbiAgICAgICl9XG4gICAgPC9Ecm9wZG93bkNvbnRhaW5lcj5cbiAgKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IENhdGVnb3J5U2VsZWN0O1xuIl19 */"));
48
48
 
49
49
  var DropdownButton = /*#__PURE__*/_styled("button", {
50
50
  target: "e10i3sm21",
@@ -53,14 +53,14 @@ var DropdownButton = /*#__PURE__*/_styled("button", {
53
53
  from: breakpoints.tablet
54
54
  }), "{padding:", spacing.small, " ", spacing.normal, ";}div:first-child{", mq.range({
55
55
  until: breakpoints.tablet
56
- }), "{display:flex;flex-direction:column;small{padding:0;}}}small{text-transform:none;padding-left:", spacing.small, ";font-weight:normal;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNhdGVnb3J5U2VsZWN0LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFzQ29DIiwiZmlsZSI6IkNhdGVnb3J5U2VsZWN0LnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE5LXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IFJlYWN0LCB7IHVzZUVmZmVjdCwgdXNlUmVmLCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCBGb2N1c1RyYXBSZWFjdCBmcm9tICdmb2N1cy10cmFwLXJlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGtleWZyYW1lcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IGJyZWFrcG9pbnRzLCBjb2xvcnMsIGZvbnRzLCBtcSwgc3BhY2luZyB9IGZyb20gJ0BuZGxhL2NvcmUnO1xuaW1wb3J0IHsgQ2hldnJvbkRvd24gfSBmcm9tICdAbmRsYS9pY29ucy9jb21tb24nO1xuaW1wb3J0IHsgdXNlVHJhbnNsYXRpb24gfSBmcm9tICdyZWFjdC1pMThuZXh0JztcbmltcG9ydCB7IE1vdmllUmVzb3VyY2VUeXBlIH0gZnJvbSAnLi90eXBlcyc7XG5cbmNvbnN0IHpvb21JblNlbGVjdCA9IGtleWZyYW1lc2BcbiAgMCUge1xuICAgIGRpc3BsYXk6IG5vbmU7XG4gICAgb3BhY2l0eTogMDtcbiAgfVxuICAxJSB7XG4gICAgZGlzcGxheTogZmxleDtcbiAgICB0cmFuc2Zvcm06IHNjYWxlM2QoMC45NSwgMC45NSwgMC45NSk7XG4gICAgb3BhY2l0eTogMDtcbiAgfVxuICAxMDAlIHtcbiAgICBvcGFjaXR5OiAxO1xuICAgIHRyYW5zZm9ybTogc2NhbGUzZCgxLCAxLCAxKTtcbiAgfVxuYDtcblxuY29uc3QgRHJvcGRvd25Db250YWluZXIgPSBzdHlsZWQuZGl2YFxuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gIG1hcmdpbjogMCAwICR7c3BhY2luZy5ub3JtYWx9O1xuYDtcblxuY29uc3QgRHJvcGRvd25CdXR0b24gPSBzdHlsZWQuYnV0dG9uYFxuICBib3JkZXItcmFkaXVzOiA0cHg7XG4gICR7Zm9udHMuc2l6ZXMoJzIycHgnLCAnMjZweCcpfTtcbiAgYm9yZGVyOiAwO1xuICB0ZXh0LXRyYW5zZm9ybTogdXBwZXJjYXNlO1xuICBiYWNrZ3JvdW5kOiAke2NvbG9ycy5uZGxhRmlsbS5maWxtQ29sb3JCcmlnaHR9O1xuICBjb2xvcjogJHtjb2xvcnMud2hpdGV9O1xuICBwYWRkaW5nOiAke3NwYWNpbmcuc21hbGx9ICR7c3BhY2luZy5uc21hbGx9O1xuICBmb250LXdlaWdodDogJHtmb250cy53ZWlnaHQuc2VtaWJvbGR9O1xuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICB0ZXh0LWFsaWduOiBsZWZ0O1xuICBqdXN0aWZ5LWNvbnRlbnQ6IHNwYWNlLWJldHdlZW47XG4gIHdpZHRoOiAxMDAlO1xuICBsZXR0ZXItc3BhY2luZzogMC4wNWVtO1xuICAke21xLnJhbmdlKHsgZnJvbTogYnJlYWtwb2ludHMudGFibGV0IH0pfSB7XG4gICAgcGFkZGluZzogJHtzcGFjaW5nLnNtYWxsfSAke3NwYWNpbmcubm9ybWFsfTtcbiAgfVxuICBkaXY6Zmlyc3QtY2hpbGQge1xuICAgICR7bXEucmFuZ2UoeyB1bnRpbDogYnJlYWtwb2ludHMudGFibGV0IH0pfSB7XG4gICAgICBkaXNwbGF5OiBmbGV4O1xuICAgICAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgICAgIHNtYWxsIHtcbiAgICAgICAgcGFkZGluZzogMDtcbiAgICAgIH1cbiAgICB9XG4gIH1cbiAgc21hbGwge1xuICAgIHRleHQtdHJhbnNmb3JtOiBub25lO1xuICAgIHBhZGRpbmctbGVmdDogJHtzcGFjaW5nLnNtYWxsfTtcbiAgICBmb250LXdlaWdodDogbm9ybWFsO1xuICB9XG5gO1xuXG5pbnRlcmZhY2UgRHJvcGRvd25XcmFwcGVyUHJvcHMge1xuICBvZmZzZXREcm9wZG93bjogbnVtYmVyO1xufVxuXG5jb25zdCBEcm9wZG93bldyYXBwZXIgPSBzdHlsZWQuZGl2PERyb3Bkb3duV3JhcHBlclByb3BzPmBcbiAgdG9wOiAtJHsocHJvcHMpID0+IHByb3BzLm9mZnNldERyb3Bkb3duICogNTIgKyAxM31weDtcbiAgJHtEcm9wZG93bkJ1dHRvbn0ge1xuICAgIGJvcmRlci1yYWRpdXM6IDA7XG4gICAgdGV4dC10cmFuc2Zvcm06IG5vbmU7XG4gICAgbGV0dGVyLXNwYWNpbmc6IDA7XG4gIH1cbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgcGFkZGluZzogJHNwYWNpbmctLXNtYWxsIDA7XG4gIGJhY2tncm91bmQ6ICR7Y29sb3JzLmJyYW5kLmxpZ2h0ZXJ9O1xuICBib3JkZXItcmFkaXVzOiA0cHg7XG4gIGxlZnQ6IDA7XG4gIHJpZ2h0OiAwO1xuICBhbmltYXRpb246ICR7em9vbUluU2VsZWN0fSAyMDBtcyBlYXNlO1xuICBib3gtc2hhZG93OiAwIDAgMzBweCByZ2JhKCR7Y29sb3JzLmJsYWNrfSwgMC42KTtcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICB6LWluZGV4OiA5OTk5O1xuICBidXR0b24sXG4gIGEge1xuICAgIGNvbG9yOiAke2NvbG9ycy50ZXh0LnByaW1hcnl9O1xuICAgIGJvcmRlcjogMDtcbiAgICBvdXRsaW5lOiAwO1xuICAgIHRleHQtYWxpZ246IGxlZnQ7XG4gICAgYmFja2dyb3VuZDogdHJhbnNwYXJlbnQ7XG4gICAgcGFkZGluZzogJHtzcGFjaW5nLnNtYWxsfTtcbiAgICBwYWRkaW5nLWxlZnQ6ICR7c3BhY2luZy5ub3JtYWx9O1xuICAgIGZvbnQtd2VpZ2h0OiAke2ZvbnRzLndlaWdodC5zZW1pYm9sZH07XG4gICAgdGV4dC1kZWNvcmF0aW9uOiBub25lO1xuICAgIGJveC1zaGFkb3c6IG5vbmU7XG4gICAgdHJhbnNpdGlvbjogYmFja2dyb3VuZCAyMDBtcyBlYXNlO1xuICAgICY6aG92ZXIsXG4gICAgJjpmb2N1cyB7XG4gICAgICBjb2xvcjogJHtjb2xvcnMuYnJhbmQucHJpbWFyeX07XG4gICAgICBiYWNrZ3JvdW5kOiByZ2JhKDAsIDAsIDAsIDAuMik7XG4gICAgfVxuICB9XG5gO1xuXG5pbnRlcmZhY2UgUHJvcHMge1xuICByZXNvdXJjZVR5cGVzOiBNb3ZpZVJlc291cmNlVHlwZVtdO1xuICByZXNvdXJjZVR5cGVTZWxlY3RlZD86IE1vdmllUmVzb3VyY2VUeXBlO1xuICBhcmlhQ29udHJvbElkPzogc3RyaW5nO1xuICBvbkNoYW5nZVJlc291cmNlVHlwZTogKHJlc291cmNlSWQ/OiBzdHJpbmcpID0+IHZvaWQ7XG59XG5cbmNvbnN0IENhdGVnb3J5U2VsZWN0ID0gKHsgcmVzb3VyY2VUeXBlcywgcmVzb3VyY2VUeXBlU2VsZWN0ZWQsIGFyaWFDb250cm9sSWQsIG9uQ2hhbmdlUmVzb3VyY2VUeXBlIH06IFByb3BzKSA9PiB7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcbiAgY29uc3QgcmVmcyA9IHVzZVJlZjxSZWNvcmQ8c3RyaW5nLCBIVE1MQnV0dG9uRWxlbWVudCB8IG51bGw+Pih7fSk7XG5cbiAgY29uc3QgW3Jlc291cmNlVHlwZXNJc09wZW4sIHNldFJlc291cmNlVHlwZXNJc09wZW5dID0gdXNlU3RhdGU8Ym9vbGVhbj4oZmFsc2UpO1xuXG4gIGNvbnN0IHVwZGF0ZVJlZiA9IChlbDogSFRNTEJ1dHRvbkVsZW1lbnQgfCBudWxsLCBuYW1lOiBzdHJpbmcpID0+IHtcbiAgICByZWZzLmN1cnJlbnRbbmFtZV0gPSBlbDtcbiAgfTtcblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGlmIChyZXNvdXJjZVR5cGVTZWxlY3RlZCAmJiByZWZzLmN1cnJlbnRbcmVzb3VyY2VUeXBlU2VsZWN0ZWQuaWRdKSB7XG4gICAgICByZWZzLmN1cnJlbnRbcmVzb3VyY2VUeXBlU2VsZWN0ZWQuaWRdPy5mb2N1cygpO1xuICAgIH1cbiAgfSwgW3Jlc291cmNlVHlwZXNJc09wZW4sIHJlc291cmNlVHlwZVNlbGVjdGVkXSk7XG5cbiAgY29uc3Qgb25TZWxlY3QgPSAodmFsPzogc3RyaW5nKSA9PiB7XG4gICAgb25DaGFuZ2VSZXNvdXJjZVR5cGUodmFsKTtcbiAgICBzZXRSZXNvdXJjZVR5cGVzSXNPcGVuKGZhbHNlKTtcbiAgfTtcblxuICBjb25zdCBvZmZzZXREcm9wRG93biA9IHJlc291cmNlVHlwZVNlbGVjdGVkXG4gICAgPyByZXNvdXJjZVR5cGVzLmZpbmRJbmRleCgocmVzb3VyY2UpID0+IHJlc291cmNlLmlkID09PSByZXNvdXJjZVR5cGVTZWxlY3RlZC5pZCkgKyAxXG4gICAgOiAwO1xuXG4gIHJldHVybiAoXG4gICAgPERyb3Bkb3duQ29udGFpbmVyIGNsYXNzTmFtZT1cInUtMTIvMTJcIj5cbiAgICAgIDxEcm9wZG93bkJ1dHRvblxuICAgICAgICBhcmlhLWV4cGFuZGVkPXshcmVzb3VyY2VUeXBlc0lzT3Blbn1cbiAgICAgICAgYXJpYS1jb250cm9scz1cInNlbGVjdENhdGVnb3J5XCJcbiAgICAgICAgdHlwZT1cImJ1dHRvblwiXG4gICAgICAgIHRhYkluZGV4PXtyZXNvdXJjZVR5cGVzSXNPcGVuID8gLTEgOiAwfVxuICAgICAgICBvbkNsaWNrPXsoKSA9PiBzZXRSZXNvdXJjZVR5cGVzSXNPcGVuKHRydWUpfT5cbiAgICAgICAgPGRpdj5cbiAgICAgICAgICA8c3Bhbj57dCgnbmRsYUZpbG0uc2VhcmNoLmNob29zZUNhdGVnb3J5Jyl9PC9zcGFuPlxuICAgICAgICAgIDxzbWFsbD57KHJlc291cmNlVHlwZVNlbGVjdGVkICYmIHJlc291cmNlVHlwZVNlbGVjdGVkLm5hbWUpIHx8IHQoJ25kbGFGaWxtLnNlYXJjaC5jYXRlZ29yeUZyb21OZGxhJyl9PC9zbWFsbD5cbiAgICAgICAgPC9kaXY+XG4gICAgICAgIDxkaXY+XG4gICAgICAgICAgPENoZXZyb25Eb3duIGNsYXNzTmFtZT1cImMtaWNvbi0tMjJcIiAvPlxuICAgICAgICA8L2Rpdj5cbiAgICAgIDwvRHJvcGRvd25CdXR0b24+XG4gICAgICB7cmVzb3VyY2VUeXBlc0lzT3BlbiAmJiAoXG4gICAgICAgIDxGb2N1c1RyYXBSZWFjdFxuICAgICAgICAgIGFjdGl2ZT17cmVzb3VyY2VUeXBlc0lzT3Blbn1cbiAgICAgICAgICBmb2N1c1RyYXBPcHRpb25zPXt7XG4gICAgICAgICAgICBvbkRlYWN0aXZhdGU6ICgpID0+IHNldFJlc291cmNlVHlwZXNJc09wZW4oZmFsc2UpLFxuICAgICAgICAgICAgY2xpY2tPdXRzaWRlRGVhY3RpdmF0ZXM6IHRydWUsXG4gICAgICAgICAgICBlc2NhcGVEZWFjdGl2YXRlczogdHJ1ZSxcbiAgICAgICAgICB9fT5cbiAgICAgICAgICA8RHJvcGRvd25XcmFwcGVyIGlkPVwic2VsZWN0Q2F0ZWdvcnlcIiBvZmZzZXREcm9wZG93bj17b2Zmc2V0RHJvcERvd259PlxuICAgICAgICAgICAgPERyb3Bkb3duQnV0dG9uIGFyaWEtY29udHJvbHM9e2FyaWFDb250cm9sSWR9IHR5cGU9XCJidXR0b25cIiBvbkNsaWNrPXsoKSA9PiBvblNlbGVjdCgpfT5cbiAgICAgICAgICAgICAgPHNwYW4+e3QoJ25kbGFGaWxtLnNlYXJjaC5jYXRlZ29yeUZyb21OZGxhJyl9PC9zcGFuPlxuICAgICAgICAgICAgPC9Ecm9wZG93bkJ1dHRvbj5cbiAgICAgICAgICAgIHtyZXNvdXJjZVR5cGVzLm1hcCgocmVzb3VyY2VUeXBlKSA9PiAoXG4gICAgICAgICAgICAgIDxEcm9wZG93bkJ1dHRvblxuICAgICAgICAgICAgICAgIGFyaWEtY29udHJvbHM9e2FyaWFDb250cm9sSWR9XG4gICAgICAgICAgICAgICAgdHlwZT1cImJ1dHRvblwiXG4gICAgICAgICAgICAgICAgcmVmPXsoZWwpID0+IHVwZGF0ZVJlZihlbCwgcmVzb3VyY2VUeXBlLmlkKX1cbiAgICAgICAgICAgICAgICBvbkNsaWNrPXsoKSA9PiBvblNlbGVjdChyZXNvdXJjZVR5cGUuaWQpfVxuICAgICAgICAgICAgICAgIGRhdGEtaWQ9e3Jlc291cmNlVHlwZS5pZH1cbiAgICAgICAgICAgICAgICBrZXk9e3Jlc291cmNlVHlwZS5pZH0+XG4gICAgICAgICAgICAgICAgPHNwYW4+e3Jlc291cmNlVHlwZS5uYW1lfTwvc3Bhbj5cbiAgICAgICAgICAgICAgPC9Ecm9wZG93bkJ1dHRvbj5cbiAgICAgICAgICAgICkpfVxuICAgICAgICAgIDwvRHJvcGRvd25XcmFwcGVyPlxuICAgICAgICA8L0ZvY3VzVHJhcFJlYWN0PlxuICAgICAgKX1cbiAgICA8L0Ryb3Bkb3duQ29udGFpbmVyPlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgQ2F0ZWdvcnlTZWxlY3Q7XG4iXX0= */"));
56
+ }), "{display:flex;flex-direction:column;small{padding:0;}}}small{text-transform:none;padding-left:", spacing.small, ";font-weight:normal;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNhdGVnb3J5U2VsZWN0LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFzQ29DIiwiZmlsZSI6IkNhdGVnb3J5U2VsZWN0LnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE5LXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IFJlYWN0LCB7IHVzZUVmZmVjdCwgdXNlUmVmLCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCBGb2N1c1RyYXBSZWFjdCBmcm9tICdmb2N1cy10cmFwLXJlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGtleWZyYW1lcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IGJyZWFrcG9pbnRzLCBjb2xvcnMsIGZvbnRzLCBtcSwgc3BhY2luZyB9IGZyb20gJ0BuZGxhL2NvcmUnO1xuaW1wb3J0IHsgQ2hldnJvbkRvd24gfSBmcm9tICdAbmRsYS9pY29ucy9jb21tb24nO1xuaW1wb3J0IHsgdXNlVHJhbnNsYXRpb24gfSBmcm9tICdyZWFjdC1pMThuZXh0JztcbmltcG9ydCB7IE1vdmllUmVzb3VyY2VUeXBlIH0gZnJvbSAnLi90eXBlcyc7XG5cbmNvbnN0IHpvb21JblNlbGVjdCA9IGtleWZyYW1lc2BcbiAgMCUge1xuICAgIGRpc3BsYXk6IG5vbmU7XG4gICAgb3BhY2l0eTogMDtcbiAgfVxuICAxJSB7XG4gICAgZGlzcGxheTogZmxleDtcbiAgICB0cmFuc2Zvcm06IHNjYWxlM2QoMC45NSwgMC45NSwgMC45NSk7XG4gICAgb3BhY2l0eTogMDtcbiAgfVxuICAxMDAlIHtcbiAgICBvcGFjaXR5OiAxO1xuICAgIHRyYW5zZm9ybTogc2NhbGUzZCgxLCAxLCAxKTtcbiAgfVxuYDtcblxuY29uc3QgRHJvcGRvd25Db250YWluZXIgPSBzdHlsZWQuZGl2YFxuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gIG1hcmdpbjogMCAwICR7c3BhY2luZy5ub3JtYWx9O1xuYDtcblxuY29uc3QgRHJvcGRvd25CdXR0b24gPSBzdHlsZWQuYnV0dG9uYFxuICBib3JkZXItcmFkaXVzOiA0cHg7XG4gICR7Zm9udHMuc2l6ZXMoJzIycHgnLCAnMjZweCcpfTtcbiAgYm9yZGVyOiAwO1xuICB0ZXh0LXRyYW5zZm9ybTogdXBwZXJjYXNlO1xuICBiYWNrZ3JvdW5kOiAke2NvbG9ycy5uZGxhRmlsbS5maWxtQ29sb3JCcmlnaHR9O1xuICBjb2xvcjogJHtjb2xvcnMud2hpdGV9O1xuICBwYWRkaW5nOiAke3NwYWNpbmcuc21hbGx9ICR7c3BhY2luZy5uc21hbGx9O1xuICBmb250LXdlaWdodDogJHtmb250cy53ZWlnaHQuc2VtaWJvbGR9O1xuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICB0ZXh0LWFsaWduOiBsZWZ0O1xuICBqdXN0aWZ5LWNvbnRlbnQ6IHNwYWNlLWJldHdlZW47XG4gIHdpZHRoOiAxMDAlO1xuICBsZXR0ZXItc3BhY2luZzogMC4wNWVtO1xuICAke21xLnJhbmdlKHsgZnJvbTogYnJlYWtwb2ludHMudGFibGV0IH0pfSB7XG4gICAgcGFkZGluZzogJHtzcGFjaW5nLnNtYWxsfSAke3NwYWNpbmcubm9ybWFsfTtcbiAgfVxuICBkaXY6Zmlyc3QtY2hpbGQge1xuICAgICR7bXEucmFuZ2UoeyB1bnRpbDogYnJlYWtwb2ludHMudGFibGV0IH0pfSB7XG4gICAgICBkaXNwbGF5OiBmbGV4O1xuICAgICAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgICAgIHNtYWxsIHtcbiAgICAgICAgcGFkZGluZzogMDtcbiAgICAgIH1cbiAgICB9XG4gIH1cbiAgc21hbGwge1xuICAgIHRleHQtdHJhbnNmb3JtOiBub25lO1xuICAgIHBhZGRpbmctbGVmdDogJHtzcGFjaW5nLnNtYWxsfTtcbiAgICBmb250LXdlaWdodDogbm9ybWFsO1xuICB9XG5gO1xuXG5pbnRlcmZhY2UgRHJvcGRvd25XcmFwcGVyUHJvcHMge1xuICBvZmZzZXREcm9wZG93bjogbnVtYmVyO1xufVxuXG5jb25zdCBEcm9wZG93bldyYXBwZXIgPSBzdHlsZWQuZGl2PERyb3Bkb3duV3JhcHBlclByb3BzPmBcbiAgdG9wOiAtJHsocHJvcHMpID0+IHByb3BzLm9mZnNldERyb3Bkb3duICogNTIgKyAxM31weDtcbiAgJHtEcm9wZG93bkJ1dHRvbn0ge1xuICAgIGJvcmRlci1yYWRpdXM6IDA7XG4gICAgdGV4dC10cmFuc2Zvcm06IG5vbmU7XG4gICAgbGV0dGVyLXNwYWNpbmc6IDA7XG4gIH1cbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgcGFkZGluZzogJHNwYWNpbmctLXNtYWxsIDA7XG4gIGJhY2tncm91bmQ6ICR7Y29sb3JzLmJyYW5kLmxpZ2h0ZXJ9O1xuICBib3JkZXItcmFkaXVzOiA0cHg7XG4gIGxlZnQ6IDA7XG4gIHJpZ2h0OiAwO1xuICBhbmltYXRpb246ICR7em9vbUluU2VsZWN0fSAyMDBtcyBlYXNlO1xuICBib3gtc2hhZG93OiAwIDAgMzBweCByZ2JhKCR7Y29sb3JzLmJsYWNrfSwgMC42KTtcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICB6LWluZGV4OiA5OTk5O1xuICBidXR0b24sXG4gIGEge1xuICAgIGNvbG9yOiAke2NvbG9ycy50ZXh0LnByaW1hcnl9O1xuICAgIGJvcmRlcjogMDtcbiAgICBvdXRsaW5lOiAwO1xuICAgIHRleHQtYWxpZ246IGxlZnQ7XG4gICAgYmFja2dyb3VuZDogdHJhbnNwYXJlbnQ7XG4gICAgcGFkZGluZzogJHtzcGFjaW5nLnNtYWxsfTtcbiAgICBwYWRkaW5nLWxlZnQ6ICR7c3BhY2luZy5ub3JtYWx9O1xuICAgIGZvbnQtd2VpZ2h0OiAke2ZvbnRzLndlaWdodC5zZW1pYm9sZH07XG4gICAgdGV4dC1kZWNvcmF0aW9uOiBub25lO1xuICAgIGJveC1zaGFkb3c6IG5vbmU7XG4gICAgdHJhbnNpdGlvbjogYmFja2dyb3VuZCAyMDBtcyBlYXNlO1xuICAgICY6aG92ZXIsXG4gICAgJjpmb2N1cyB7XG4gICAgICBjb2xvcjogJHtjb2xvcnMuYnJhbmQucHJpbWFyeX07XG4gICAgICBiYWNrZ3JvdW5kOiByZ2JhKDAsIDAsIDAsIDAuMik7XG4gICAgfVxuICB9XG5gO1xuXG5pbnRlcmZhY2UgUHJvcHMge1xuICByZXNvdXJjZVR5cGVzOiBNb3ZpZVJlc291cmNlVHlwZVtdO1xuICByZXNvdXJjZVR5cGVTZWxlY3RlZD86IE1vdmllUmVzb3VyY2VUeXBlO1xuICBhcmlhQ29udHJvbElkPzogc3RyaW5nO1xuICBvbkNoYW5nZVJlc291cmNlVHlwZTogKHJlc291cmNlSWQ/OiBzdHJpbmcpID0+IHZvaWQ7XG59XG5cbmNvbnN0IENhdGVnb3J5U2VsZWN0ID0gKHsgcmVzb3VyY2VUeXBlcywgcmVzb3VyY2VUeXBlU2VsZWN0ZWQsIGFyaWFDb250cm9sSWQsIG9uQ2hhbmdlUmVzb3VyY2VUeXBlIH06IFByb3BzKSA9PiB7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcbiAgY29uc3QgcmVmcyA9IHVzZVJlZjxSZWNvcmQ8c3RyaW5nLCBIVE1MQnV0dG9uRWxlbWVudCB8IG51bGw+Pih7fSk7XG5cbiAgY29uc3QgW3Jlc291cmNlVHlwZXNJc09wZW4sIHNldFJlc291cmNlVHlwZXNJc09wZW5dID0gdXNlU3RhdGU8Ym9vbGVhbj4oZmFsc2UpO1xuXG4gIGNvbnN0IHVwZGF0ZVJlZiA9IChlbDogSFRNTEJ1dHRvbkVsZW1lbnQgfCBudWxsLCBuYW1lOiBzdHJpbmcpID0+IHtcbiAgICByZWZzLmN1cnJlbnRbbmFtZV0gPSBlbDtcbiAgfTtcblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGlmIChyZXNvdXJjZVR5cGVTZWxlY3RlZCAmJiByZWZzLmN1cnJlbnRbcmVzb3VyY2VUeXBlU2VsZWN0ZWQuaWRdKSB7XG4gICAgICByZWZzLmN1cnJlbnRbcmVzb3VyY2VUeXBlU2VsZWN0ZWQuaWRdPy5mb2N1cygpO1xuICAgIH1cbiAgfSwgW3Jlc291cmNlVHlwZXNJc09wZW4sIHJlc291cmNlVHlwZVNlbGVjdGVkXSk7XG5cbiAgY29uc3Qgb25TZWxlY3QgPSAodmFsPzogc3RyaW5nKSA9PiB7XG4gICAgb25DaGFuZ2VSZXNvdXJjZVR5cGUodmFsKTtcbiAgICBzZXRSZXNvdXJjZVR5cGVzSXNPcGVuKGZhbHNlKTtcbiAgfTtcblxuICBjb25zdCBvZmZzZXREcm9wRG93biA9IHJlc291cmNlVHlwZVNlbGVjdGVkXG4gICAgPyByZXNvdXJjZVR5cGVzLmZpbmRJbmRleCgocmVzb3VyY2UpID0+IHJlc291cmNlLmlkID09PSByZXNvdXJjZVR5cGVTZWxlY3RlZC5pZCkgKyAxXG4gICAgOiAwO1xuXG4gIHJldHVybiAoXG4gICAgPERyb3Bkb3duQ29udGFpbmVyIGNsYXNzTmFtZT1cInUtMTIvMTJcIj5cbiAgICAgIDxEcm9wZG93bkJ1dHRvblxuICAgICAgICBhcmlhLWV4cGFuZGVkPXshIXJlc291cmNlVHlwZXNJc09wZW59XG4gICAgICAgIGFyaWEtY29udHJvbHM9XCJzZWxlY3RDYXRlZ29yeVwiXG4gICAgICAgIHR5cGU9XCJidXR0b25cIlxuICAgICAgICB0YWJJbmRleD17cmVzb3VyY2VUeXBlc0lzT3BlbiA/IC0xIDogMH1cbiAgICAgICAgb25DbGljaz17KCkgPT4gc2V0UmVzb3VyY2VUeXBlc0lzT3Blbih0cnVlKX0+XG4gICAgICAgIDxkaXY+XG4gICAgICAgICAgPHNwYW4+e3QoJ25kbGFGaWxtLnNlYXJjaC5jaG9vc2VDYXRlZ29yeScpfTwvc3Bhbj5cbiAgICAgICAgICA8c21hbGw+eyhyZXNvdXJjZVR5cGVTZWxlY3RlZCAmJiByZXNvdXJjZVR5cGVTZWxlY3RlZC5uYW1lKSB8fCB0KCduZGxhRmlsbS5zZWFyY2guY2F0ZWdvcnlGcm9tTmRsYScpfTwvc21hbGw+XG4gICAgICAgIDwvZGl2PlxuICAgICAgICA8ZGl2PlxuICAgICAgICAgIDxDaGV2cm9uRG93biBjbGFzc05hbWU9XCJjLWljb24tLTIyXCIgLz5cbiAgICAgICAgPC9kaXY+XG4gICAgICA8L0Ryb3Bkb3duQnV0dG9uPlxuICAgICAge3Jlc291cmNlVHlwZXNJc09wZW4gJiYgKFxuICAgICAgICA8Rm9jdXNUcmFwUmVhY3RcbiAgICAgICAgICBhY3RpdmU9e3Jlc291cmNlVHlwZXNJc09wZW59XG4gICAgICAgICAgZm9jdXNUcmFwT3B0aW9ucz17e1xuICAgICAgICAgICAgb25EZWFjdGl2YXRlOiAoKSA9PiBzZXRSZXNvdXJjZVR5cGVzSXNPcGVuKGZhbHNlKSxcbiAgICAgICAgICAgIGNsaWNrT3V0c2lkZURlYWN0aXZhdGVzOiB0cnVlLFxuICAgICAgICAgICAgZXNjYXBlRGVhY3RpdmF0ZXM6IHRydWUsXG4gICAgICAgICAgfX0+XG4gICAgICAgICAgPERyb3Bkb3duV3JhcHBlciBpZD1cInNlbGVjdENhdGVnb3J5XCIgb2Zmc2V0RHJvcGRvd249e29mZnNldERyb3BEb3dufT5cbiAgICAgICAgICAgIDxEcm9wZG93bkJ1dHRvbiBhcmlhLWNvbnRyb2xzPXthcmlhQ29udHJvbElkfSB0eXBlPVwiYnV0dG9uXCIgb25DbGljaz17KCkgPT4gb25TZWxlY3QoKX0+XG4gICAgICAgICAgICAgIDxzcGFuPnt0KCduZGxhRmlsbS5zZWFyY2guY2F0ZWdvcnlGcm9tTmRsYScpfTwvc3Bhbj5cbiAgICAgICAgICAgIDwvRHJvcGRvd25CdXR0b24+XG4gICAgICAgICAgICB7cmVzb3VyY2VUeXBlcy5tYXAoKHJlc291cmNlVHlwZSkgPT4gKFxuICAgICAgICAgICAgICA8RHJvcGRvd25CdXR0b25cbiAgICAgICAgICAgICAgICBhcmlhLWNvbnRyb2xzPXthcmlhQ29udHJvbElkfVxuICAgICAgICAgICAgICAgIHR5cGU9XCJidXR0b25cIlxuICAgICAgICAgICAgICAgIHJlZj17KGVsKSA9PiB1cGRhdGVSZWYoZWwsIHJlc291cmNlVHlwZS5pZCl9XG4gICAgICAgICAgICAgICAgb25DbGljaz17KCkgPT4gb25TZWxlY3QocmVzb3VyY2VUeXBlLmlkKX1cbiAgICAgICAgICAgICAgICBkYXRhLWlkPXtyZXNvdXJjZVR5cGUuaWR9XG4gICAgICAgICAgICAgICAga2V5PXtyZXNvdXJjZVR5cGUuaWR9PlxuICAgICAgICAgICAgICAgIDxzcGFuPntyZXNvdXJjZVR5cGUubmFtZX08L3NwYW4+XG4gICAgICAgICAgICAgIDwvRHJvcGRvd25CdXR0b24+XG4gICAgICAgICAgICApKX1cbiAgICAgICAgICA8L0Ryb3Bkb3duV3JhcHBlcj5cbiAgICAgICAgPC9Gb2N1c1RyYXBSZWFjdD5cbiAgICAgICl9XG4gICAgPC9Ecm9wZG93bkNvbnRhaW5lcj5cbiAgKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IENhdGVnb3J5U2VsZWN0O1xuIl19 */"));
57
57
 
58
58
  var DropdownWrapper = /*#__PURE__*/_styled("div", {
59
59
  target: "e10i3sm20",
60
60
  label: "DropdownWrapper"
61
61
  })("top:-", function (props) {
62
62
  return props.offsetDropdown * 52 + 13;
63
- }, "px;", DropdownButton, "{border-radius:0;text-transform:none;letter-spacing:0;}display:flex;flex-direction:column;padding:$spacing--small 0;background:", colors.brand.lighter, ";border-radius:4px;left:0;right:0;animation:", zoomInSelect, " 200ms ease;box-shadow:0 0 30px rgba(", colors.black, ", 0.6);position:absolute;z-index:9999;button,a{color:", colors.text.primary, ";border:0;outline:0;text-align:left;background:transparent;padding:", spacing.small, ";padding-left:", spacing.normal, ";font-weight:", fonts.weight.semibold, ";text-decoration:none;box-shadow:none;transition:background 200ms ease;&:hover,&:focus{color:", colors.brand.primary, ";background:rgba(0, 0, 0, 0.2);}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNhdGVnb3J5U2VsZWN0LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE0RXdEIiwiZmlsZSI6IkNhdGVnb3J5U2VsZWN0LnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE5LXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IFJlYWN0LCB7IHVzZUVmZmVjdCwgdXNlUmVmLCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCBGb2N1c1RyYXBSZWFjdCBmcm9tICdmb2N1cy10cmFwLXJlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGtleWZyYW1lcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IGJyZWFrcG9pbnRzLCBjb2xvcnMsIGZvbnRzLCBtcSwgc3BhY2luZyB9IGZyb20gJ0BuZGxhL2NvcmUnO1xuaW1wb3J0IHsgQ2hldnJvbkRvd24gfSBmcm9tICdAbmRsYS9pY29ucy9jb21tb24nO1xuaW1wb3J0IHsgdXNlVHJhbnNsYXRpb24gfSBmcm9tICdyZWFjdC1pMThuZXh0JztcbmltcG9ydCB7IE1vdmllUmVzb3VyY2VUeXBlIH0gZnJvbSAnLi90eXBlcyc7XG5cbmNvbnN0IHpvb21JblNlbGVjdCA9IGtleWZyYW1lc2BcbiAgMCUge1xuICAgIGRpc3BsYXk6IG5vbmU7XG4gICAgb3BhY2l0eTogMDtcbiAgfVxuICAxJSB7XG4gICAgZGlzcGxheTogZmxleDtcbiAgICB0cmFuc2Zvcm06IHNjYWxlM2QoMC45NSwgMC45NSwgMC45NSk7XG4gICAgb3BhY2l0eTogMDtcbiAgfVxuICAxMDAlIHtcbiAgICBvcGFjaXR5OiAxO1xuICAgIHRyYW5zZm9ybTogc2NhbGUzZCgxLCAxLCAxKTtcbiAgfVxuYDtcblxuY29uc3QgRHJvcGRvd25Db250YWluZXIgPSBzdHlsZWQuZGl2YFxuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gIG1hcmdpbjogMCAwICR7c3BhY2luZy5ub3JtYWx9O1xuYDtcblxuY29uc3QgRHJvcGRvd25CdXR0b24gPSBzdHlsZWQuYnV0dG9uYFxuICBib3JkZXItcmFkaXVzOiA0cHg7XG4gICR7Zm9udHMuc2l6ZXMoJzIycHgnLCAnMjZweCcpfTtcbiAgYm9yZGVyOiAwO1xuICB0ZXh0LXRyYW5zZm9ybTogdXBwZXJjYXNlO1xuICBiYWNrZ3JvdW5kOiAke2NvbG9ycy5uZGxhRmlsbS5maWxtQ29sb3JCcmlnaHR9O1xuICBjb2xvcjogJHtjb2xvcnMud2hpdGV9O1xuICBwYWRkaW5nOiAke3NwYWNpbmcuc21hbGx9ICR7c3BhY2luZy5uc21hbGx9O1xuICBmb250LXdlaWdodDogJHtmb250cy53ZWlnaHQuc2VtaWJvbGR9O1xuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICB0ZXh0LWFsaWduOiBsZWZ0O1xuICBqdXN0aWZ5LWNvbnRlbnQ6IHNwYWNlLWJldHdlZW47XG4gIHdpZHRoOiAxMDAlO1xuICBsZXR0ZXItc3BhY2luZzogMC4wNWVtO1xuICAke21xLnJhbmdlKHsgZnJvbTogYnJlYWtwb2ludHMudGFibGV0IH0pfSB7XG4gICAgcGFkZGluZzogJHtzcGFjaW5nLnNtYWxsfSAke3NwYWNpbmcubm9ybWFsfTtcbiAgfVxuICBkaXY6Zmlyc3QtY2hpbGQge1xuICAgICR7bXEucmFuZ2UoeyB1bnRpbDogYnJlYWtwb2ludHMudGFibGV0IH0pfSB7XG4gICAgICBkaXNwbGF5OiBmbGV4O1xuICAgICAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgICAgIHNtYWxsIHtcbiAgICAgICAgcGFkZGluZzogMDtcbiAgICAgIH1cbiAgICB9XG4gIH1cbiAgc21hbGwge1xuICAgIHRleHQtdHJhbnNmb3JtOiBub25lO1xuICAgIHBhZGRpbmctbGVmdDogJHtzcGFjaW5nLnNtYWxsfTtcbiAgICBmb250LXdlaWdodDogbm9ybWFsO1xuICB9XG5gO1xuXG5pbnRlcmZhY2UgRHJvcGRvd25XcmFwcGVyUHJvcHMge1xuICBvZmZzZXREcm9wZG93bjogbnVtYmVyO1xufVxuXG5jb25zdCBEcm9wZG93bldyYXBwZXIgPSBzdHlsZWQuZGl2PERyb3Bkb3duV3JhcHBlclByb3BzPmBcbiAgdG9wOiAtJHsocHJvcHMpID0+IHByb3BzLm9mZnNldERyb3Bkb3duICogNTIgKyAxM31weDtcbiAgJHtEcm9wZG93bkJ1dHRvbn0ge1xuICAgIGJvcmRlci1yYWRpdXM6IDA7XG4gICAgdGV4dC10cmFuc2Zvcm06IG5vbmU7XG4gICAgbGV0dGVyLXNwYWNpbmc6IDA7XG4gIH1cbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgcGFkZGluZzogJHNwYWNpbmctLXNtYWxsIDA7XG4gIGJhY2tncm91bmQ6ICR7Y29sb3JzLmJyYW5kLmxpZ2h0ZXJ9O1xuICBib3JkZXItcmFkaXVzOiA0cHg7XG4gIGxlZnQ6IDA7XG4gIHJpZ2h0OiAwO1xuICBhbmltYXRpb246ICR7em9vbUluU2VsZWN0fSAyMDBtcyBlYXNlO1xuICBib3gtc2hhZG93OiAwIDAgMzBweCByZ2JhKCR7Y29sb3JzLmJsYWNrfSwgMC42KTtcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICB6LWluZGV4OiA5OTk5O1xuICBidXR0b24sXG4gIGEge1xuICAgIGNvbG9yOiAke2NvbG9ycy50ZXh0LnByaW1hcnl9O1xuICAgIGJvcmRlcjogMDtcbiAgICBvdXRsaW5lOiAwO1xuICAgIHRleHQtYWxpZ246IGxlZnQ7XG4gICAgYmFja2dyb3VuZDogdHJhbnNwYXJlbnQ7XG4gICAgcGFkZGluZzogJHtzcGFjaW5nLnNtYWxsfTtcbiAgICBwYWRkaW5nLWxlZnQ6ICR7c3BhY2luZy5ub3JtYWx9O1xuICAgIGZvbnQtd2VpZ2h0OiAke2ZvbnRzLndlaWdodC5zZW1pYm9sZH07XG4gICAgdGV4dC1kZWNvcmF0aW9uOiBub25lO1xuICAgIGJveC1zaGFkb3c6IG5vbmU7XG4gICAgdHJhbnNpdGlvbjogYmFja2dyb3VuZCAyMDBtcyBlYXNlO1xuICAgICY6aG92ZXIsXG4gICAgJjpmb2N1cyB7XG4gICAgICBjb2xvcjogJHtjb2xvcnMuYnJhbmQucHJpbWFyeX07XG4gICAgICBiYWNrZ3JvdW5kOiByZ2JhKDAsIDAsIDAsIDAuMik7XG4gICAgfVxuICB9XG5gO1xuXG5pbnRlcmZhY2UgUHJvcHMge1xuICByZXNvdXJjZVR5cGVzOiBNb3ZpZVJlc291cmNlVHlwZVtdO1xuICByZXNvdXJjZVR5cGVTZWxlY3RlZD86IE1vdmllUmVzb3VyY2VUeXBlO1xuICBhcmlhQ29udHJvbElkPzogc3RyaW5nO1xuICBvbkNoYW5nZVJlc291cmNlVHlwZTogKHJlc291cmNlSWQ/OiBzdHJpbmcpID0+IHZvaWQ7XG59XG5cbmNvbnN0IENhdGVnb3J5U2VsZWN0ID0gKHsgcmVzb3VyY2VUeXBlcywgcmVzb3VyY2VUeXBlU2VsZWN0ZWQsIGFyaWFDb250cm9sSWQsIG9uQ2hhbmdlUmVzb3VyY2VUeXBlIH06IFByb3BzKSA9PiB7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcbiAgY29uc3QgcmVmcyA9IHVzZVJlZjxSZWNvcmQ8c3RyaW5nLCBIVE1MQnV0dG9uRWxlbWVudCB8IG51bGw+Pih7fSk7XG5cbiAgY29uc3QgW3Jlc291cmNlVHlwZXNJc09wZW4sIHNldFJlc291cmNlVHlwZXNJc09wZW5dID0gdXNlU3RhdGU8Ym9vbGVhbj4oZmFsc2UpO1xuXG4gIGNvbnN0IHVwZGF0ZVJlZiA9IChlbDogSFRNTEJ1dHRvbkVsZW1lbnQgfCBudWxsLCBuYW1lOiBzdHJpbmcpID0+IHtcbiAgICByZWZzLmN1cnJlbnRbbmFtZV0gPSBlbDtcbiAgfTtcblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGlmIChyZXNvdXJjZVR5cGVTZWxlY3RlZCAmJiByZWZzLmN1cnJlbnRbcmVzb3VyY2VUeXBlU2VsZWN0ZWQuaWRdKSB7XG4gICAgICByZWZzLmN1cnJlbnRbcmVzb3VyY2VUeXBlU2VsZWN0ZWQuaWRdPy5mb2N1cygpO1xuICAgIH1cbiAgfSwgW3Jlc291cmNlVHlwZXNJc09wZW4sIHJlc291cmNlVHlwZVNlbGVjdGVkXSk7XG5cbiAgY29uc3Qgb25TZWxlY3QgPSAodmFsPzogc3RyaW5nKSA9PiB7XG4gICAgb25DaGFuZ2VSZXNvdXJjZVR5cGUodmFsKTtcbiAgICBzZXRSZXNvdXJjZVR5cGVzSXNPcGVuKGZhbHNlKTtcbiAgfTtcblxuICBjb25zdCBvZmZzZXREcm9wRG93biA9IHJlc291cmNlVHlwZVNlbGVjdGVkXG4gICAgPyByZXNvdXJjZVR5cGVzLmZpbmRJbmRleCgocmVzb3VyY2UpID0+IHJlc291cmNlLmlkID09PSByZXNvdXJjZVR5cGVTZWxlY3RlZC5pZCkgKyAxXG4gICAgOiAwO1xuXG4gIHJldHVybiAoXG4gICAgPERyb3Bkb3duQ29udGFpbmVyIGNsYXNzTmFtZT1cInUtMTIvMTJcIj5cbiAgICAgIDxEcm9wZG93bkJ1dHRvblxuICAgICAgICBhcmlhLWV4cGFuZGVkPXshcmVzb3VyY2VUeXBlc0lzT3Blbn1cbiAgICAgICAgYXJpYS1jb250cm9scz1cInNlbGVjdENhdGVnb3J5XCJcbiAgICAgICAgdHlwZT1cImJ1dHRvblwiXG4gICAgICAgIHRhYkluZGV4PXtyZXNvdXJjZVR5cGVzSXNPcGVuID8gLTEgOiAwfVxuICAgICAgICBvbkNsaWNrPXsoKSA9PiBzZXRSZXNvdXJjZVR5cGVzSXNPcGVuKHRydWUpfT5cbiAgICAgICAgPGRpdj5cbiAgICAgICAgICA8c3Bhbj57dCgnbmRsYUZpbG0uc2VhcmNoLmNob29zZUNhdGVnb3J5Jyl9PC9zcGFuPlxuICAgICAgICAgIDxzbWFsbD57KHJlc291cmNlVHlwZVNlbGVjdGVkICYmIHJlc291cmNlVHlwZVNlbGVjdGVkLm5hbWUpIHx8IHQoJ25kbGFGaWxtLnNlYXJjaC5jYXRlZ29yeUZyb21OZGxhJyl9PC9zbWFsbD5cbiAgICAgICAgPC9kaXY+XG4gICAgICAgIDxkaXY+XG4gICAgICAgICAgPENoZXZyb25Eb3duIGNsYXNzTmFtZT1cImMtaWNvbi0tMjJcIiAvPlxuICAgICAgICA8L2Rpdj5cbiAgICAgIDwvRHJvcGRvd25CdXR0b24+XG4gICAgICB7cmVzb3VyY2VUeXBlc0lzT3BlbiAmJiAoXG4gICAgICAgIDxGb2N1c1RyYXBSZWFjdFxuICAgICAgICAgIGFjdGl2ZT17cmVzb3VyY2VUeXBlc0lzT3Blbn1cbiAgICAgICAgICBmb2N1c1RyYXBPcHRpb25zPXt7XG4gICAgICAgICAgICBvbkRlYWN0aXZhdGU6ICgpID0+IHNldFJlc291cmNlVHlwZXNJc09wZW4oZmFsc2UpLFxuICAgICAgICAgICAgY2xpY2tPdXRzaWRlRGVhY3RpdmF0ZXM6IHRydWUsXG4gICAgICAgICAgICBlc2NhcGVEZWFjdGl2YXRlczogdHJ1ZSxcbiAgICAgICAgICB9fT5cbiAgICAgICAgICA8RHJvcGRvd25XcmFwcGVyIGlkPVwic2VsZWN0Q2F0ZWdvcnlcIiBvZmZzZXREcm9wZG93bj17b2Zmc2V0RHJvcERvd259PlxuICAgICAgICAgICAgPERyb3Bkb3duQnV0dG9uIGFyaWEtY29udHJvbHM9e2FyaWFDb250cm9sSWR9IHR5cGU9XCJidXR0b25cIiBvbkNsaWNrPXsoKSA9PiBvblNlbGVjdCgpfT5cbiAgICAgICAgICAgICAgPHNwYW4+e3QoJ25kbGFGaWxtLnNlYXJjaC5jYXRlZ29yeUZyb21OZGxhJyl9PC9zcGFuPlxuICAgICAgICAgICAgPC9Ecm9wZG93bkJ1dHRvbj5cbiAgICAgICAgICAgIHtyZXNvdXJjZVR5cGVzLm1hcCgocmVzb3VyY2VUeXBlKSA9PiAoXG4gICAgICAgICAgICAgIDxEcm9wZG93bkJ1dHRvblxuICAgICAgICAgICAgICAgIGFyaWEtY29udHJvbHM9e2FyaWFDb250cm9sSWR9XG4gICAgICAgICAgICAgICAgdHlwZT1cImJ1dHRvblwiXG4gICAgICAgICAgICAgICAgcmVmPXsoZWwpID0+IHVwZGF0ZVJlZihlbCwgcmVzb3VyY2VUeXBlLmlkKX1cbiAgICAgICAgICAgICAgICBvbkNsaWNrPXsoKSA9PiBvblNlbGVjdChyZXNvdXJjZVR5cGUuaWQpfVxuICAgICAgICAgICAgICAgIGRhdGEtaWQ9e3Jlc291cmNlVHlwZS5pZH1cbiAgICAgICAgICAgICAgICBrZXk9e3Jlc291cmNlVHlwZS5pZH0+XG4gICAgICAgICAgICAgICAgPHNwYW4+e3Jlc291cmNlVHlwZS5uYW1lfTwvc3Bhbj5cbiAgICAgICAgICAgICAgPC9Ecm9wZG93bkJ1dHRvbj5cbiAgICAgICAgICAgICkpfVxuICAgICAgICAgIDwvRHJvcGRvd25XcmFwcGVyPlxuICAgICAgICA8L0ZvY3VzVHJhcFJlYWN0PlxuICAgICAgKX1cbiAgICA8L0Ryb3Bkb3duQ29udGFpbmVyPlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgQ2F0ZWdvcnlTZWxlY3Q7XG4iXX0= */"));
63
+ }, "px;", DropdownButton, "{border-radius:0;text-transform:none;letter-spacing:0;}display:flex;flex-direction:column;padding:$spacing--small 0;background:", colors.brand.lighter, ";border-radius:4px;left:0;right:0;animation:", zoomInSelect, " 200ms ease;box-shadow:0 0 30px rgba(", colors.black, ", 0.6);position:absolute;z-index:9999;button,a{color:", colors.text.primary, ";border:0;outline:0;text-align:left;background:transparent;padding:", spacing.small, ";padding-left:", spacing.normal, ";font-weight:", fonts.weight.semibold, ";text-decoration:none;box-shadow:none;transition:background 200ms ease;&:hover,&:focus{color:", colors.brand.primary, ";background:rgba(0, 0, 0, 0.2);}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNhdGVnb3J5U2VsZWN0LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE0RXdEIiwiZmlsZSI6IkNhdGVnb3J5U2VsZWN0LnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE5LXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IFJlYWN0LCB7IHVzZUVmZmVjdCwgdXNlUmVmLCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCBGb2N1c1RyYXBSZWFjdCBmcm9tICdmb2N1cy10cmFwLXJlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGtleWZyYW1lcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IGJyZWFrcG9pbnRzLCBjb2xvcnMsIGZvbnRzLCBtcSwgc3BhY2luZyB9IGZyb20gJ0BuZGxhL2NvcmUnO1xuaW1wb3J0IHsgQ2hldnJvbkRvd24gfSBmcm9tICdAbmRsYS9pY29ucy9jb21tb24nO1xuaW1wb3J0IHsgdXNlVHJhbnNsYXRpb24gfSBmcm9tICdyZWFjdC1pMThuZXh0JztcbmltcG9ydCB7IE1vdmllUmVzb3VyY2VUeXBlIH0gZnJvbSAnLi90eXBlcyc7XG5cbmNvbnN0IHpvb21JblNlbGVjdCA9IGtleWZyYW1lc2BcbiAgMCUge1xuICAgIGRpc3BsYXk6IG5vbmU7XG4gICAgb3BhY2l0eTogMDtcbiAgfVxuICAxJSB7XG4gICAgZGlzcGxheTogZmxleDtcbiAgICB0cmFuc2Zvcm06IHNjYWxlM2QoMC45NSwgMC45NSwgMC45NSk7XG4gICAgb3BhY2l0eTogMDtcbiAgfVxuICAxMDAlIHtcbiAgICBvcGFjaXR5OiAxO1xuICAgIHRyYW5zZm9ybTogc2NhbGUzZCgxLCAxLCAxKTtcbiAgfVxuYDtcblxuY29uc3QgRHJvcGRvd25Db250YWluZXIgPSBzdHlsZWQuZGl2YFxuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gIG1hcmdpbjogMCAwICR7c3BhY2luZy5ub3JtYWx9O1xuYDtcblxuY29uc3QgRHJvcGRvd25CdXR0b24gPSBzdHlsZWQuYnV0dG9uYFxuICBib3JkZXItcmFkaXVzOiA0cHg7XG4gICR7Zm9udHMuc2l6ZXMoJzIycHgnLCAnMjZweCcpfTtcbiAgYm9yZGVyOiAwO1xuICB0ZXh0LXRyYW5zZm9ybTogdXBwZXJjYXNlO1xuICBiYWNrZ3JvdW5kOiAke2NvbG9ycy5uZGxhRmlsbS5maWxtQ29sb3JCcmlnaHR9O1xuICBjb2xvcjogJHtjb2xvcnMud2hpdGV9O1xuICBwYWRkaW5nOiAke3NwYWNpbmcuc21hbGx9ICR7c3BhY2luZy5uc21hbGx9O1xuICBmb250LXdlaWdodDogJHtmb250cy53ZWlnaHQuc2VtaWJvbGR9O1xuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICB0ZXh0LWFsaWduOiBsZWZ0O1xuICBqdXN0aWZ5LWNvbnRlbnQ6IHNwYWNlLWJldHdlZW47XG4gIHdpZHRoOiAxMDAlO1xuICBsZXR0ZXItc3BhY2luZzogMC4wNWVtO1xuICAke21xLnJhbmdlKHsgZnJvbTogYnJlYWtwb2ludHMudGFibGV0IH0pfSB7XG4gICAgcGFkZGluZzogJHtzcGFjaW5nLnNtYWxsfSAke3NwYWNpbmcubm9ybWFsfTtcbiAgfVxuICBkaXY6Zmlyc3QtY2hpbGQge1xuICAgICR7bXEucmFuZ2UoeyB1bnRpbDogYnJlYWtwb2ludHMudGFibGV0IH0pfSB7XG4gICAgICBkaXNwbGF5OiBmbGV4O1xuICAgICAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgICAgIHNtYWxsIHtcbiAgICAgICAgcGFkZGluZzogMDtcbiAgICAgIH1cbiAgICB9XG4gIH1cbiAgc21hbGwge1xuICAgIHRleHQtdHJhbnNmb3JtOiBub25lO1xuICAgIHBhZGRpbmctbGVmdDogJHtzcGFjaW5nLnNtYWxsfTtcbiAgICBmb250LXdlaWdodDogbm9ybWFsO1xuICB9XG5gO1xuXG5pbnRlcmZhY2UgRHJvcGRvd25XcmFwcGVyUHJvcHMge1xuICBvZmZzZXREcm9wZG93bjogbnVtYmVyO1xufVxuXG5jb25zdCBEcm9wZG93bldyYXBwZXIgPSBzdHlsZWQuZGl2PERyb3Bkb3duV3JhcHBlclByb3BzPmBcbiAgdG9wOiAtJHsocHJvcHMpID0+IHByb3BzLm9mZnNldERyb3Bkb3duICogNTIgKyAxM31weDtcbiAgJHtEcm9wZG93bkJ1dHRvbn0ge1xuICAgIGJvcmRlci1yYWRpdXM6IDA7XG4gICAgdGV4dC10cmFuc2Zvcm06IG5vbmU7XG4gICAgbGV0dGVyLXNwYWNpbmc6IDA7XG4gIH1cbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgcGFkZGluZzogJHNwYWNpbmctLXNtYWxsIDA7XG4gIGJhY2tncm91bmQ6ICR7Y29sb3JzLmJyYW5kLmxpZ2h0ZXJ9O1xuICBib3JkZXItcmFkaXVzOiA0cHg7XG4gIGxlZnQ6IDA7XG4gIHJpZ2h0OiAwO1xuICBhbmltYXRpb246ICR7em9vbUluU2VsZWN0fSAyMDBtcyBlYXNlO1xuICBib3gtc2hhZG93OiAwIDAgMzBweCByZ2JhKCR7Y29sb3JzLmJsYWNrfSwgMC42KTtcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICB6LWluZGV4OiA5OTk5O1xuICBidXR0b24sXG4gIGEge1xuICAgIGNvbG9yOiAke2NvbG9ycy50ZXh0LnByaW1hcnl9O1xuICAgIGJvcmRlcjogMDtcbiAgICBvdXRsaW5lOiAwO1xuICAgIHRleHQtYWxpZ246IGxlZnQ7XG4gICAgYmFja2dyb3VuZDogdHJhbnNwYXJlbnQ7XG4gICAgcGFkZGluZzogJHtzcGFjaW5nLnNtYWxsfTtcbiAgICBwYWRkaW5nLWxlZnQ6ICR7c3BhY2luZy5ub3JtYWx9O1xuICAgIGZvbnQtd2VpZ2h0OiAke2ZvbnRzLndlaWdodC5zZW1pYm9sZH07XG4gICAgdGV4dC1kZWNvcmF0aW9uOiBub25lO1xuICAgIGJveC1zaGFkb3c6IG5vbmU7XG4gICAgdHJhbnNpdGlvbjogYmFja2dyb3VuZCAyMDBtcyBlYXNlO1xuICAgICY6aG92ZXIsXG4gICAgJjpmb2N1cyB7XG4gICAgICBjb2xvcjogJHtjb2xvcnMuYnJhbmQucHJpbWFyeX07XG4gICAgICBiYWNrZ3JvdW5kOiByZ2JhKDAsIDAsIDAsIDAuMik7XG4gICAgfVxuICB9XG5gO1xuXG5pbnRlcmZhY2UgUHJvcHMge1xuICByZXNvdXJjZVR5cGVzOiBNb3ZpZVJlc291cmNlVHlwZVtdO1xuICByZXNvdXJjZVR5cGVTZWxlY3RlZD86IE1vdmllUmVzb3VyY2VUeXBlO1xuICBhcmlhQ29udHJvbElkPzogc3RyaW5nO1xuICBvbkNoYW5nZVJlc291cmNlVHlwZTogKHJlc291cmNlSWQ/OiBzdHJpbmcpID0+IHZvaWQ7XG59XG5cbmNvbnN0IENhdGVnb3J5U2VsZWN0ID0gKHsgcmVzb3VyY2VUeXBlcywgcmVzb3VyY2VUeXBlU2VsZWN0ZWQsIGFyaWFDb250cm9sSWQsIG9uQ2hhbmdlUmVzb3VyY2VUeXBlIH06IFByb3BzKSA9PiB7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcbiAgY29uc3QgcmVmcyA9IHVzZVJlZjxSZWNvcmQ8c3RyaW5nLCBIVE1MQnV0dG9uRWxlbWVudCB8IG51bGw+Pih7fSk7XG5cbiAgY29uc3QgW3Jlc291cmNlVHlwZXNJc09wZW4sIHNldFJlc291cmNlVHlwZXNJc09wZW5dID0gdXNlU3RhdGU8Ym9vbGVhbj4oZmFsc2UpO1xuXG4gIGNvbnN0IHVwZGF0ZVJlZiA9IChlbDogSFRNTEJ1dHRvbkVsZW1lbnQgfCBudWxsLCBuYW1lOiBzdHJpbmcpID0+IHtcbiAgICByZWZzLmN1cnJlbnRbbmFtZV0gPSBlbDtcbiAgfTtcblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGlmIChyZXNvdXJjZVR5cGVTZWxlY3RlZCAmJiByZWZzLmN1cnJlbnRbcmVzb3VyY2VUeXBlU2VsZWN0ZWQuaWRdKSB7XG4gICAgICByZWZzLmN1cnJlbnRbcmVzb3VyY2VUeXBlU2VsZWN0ZWQuaWRdPy5mb2N1cygpO1xuICAgIH1cbiAgfSwgW3Jlc291cmNlVHlwZXNJc09wZW4sIHJlc291cmNlVHlwZVNlbGVjdGVkXSk7XG5cbiAgY29uc3Qgb25TZWxlY3QgPSAodmFsPzogc3RyaW5nKSA9PiB7XG4gICAgb25DaGFuZ2VSZXNvdXJjZVR5cGUodmFsKTtcbiAgICBzZXRSZXNvdXJjZVR5cGVzSXNPcGVuKGZhbHNlKTtcbiAgfTtcblxuICBjb25zdCBvZmZzZXREcm9wRG93biA9IHJlc291cmNlVHlwZVNlbGVjdGVkXG4gICAgPyByZXNvdXJjZVR5cGVzLmZpbmRJbmRleCgocmVzb3VyY2UpID0+IHJlc291cmNlLmlkID09PSByZXNvdXJjZVR5cGVTZWxlY3RlZC5pZCkgKyAxXG4gICAgOiAwO1xuXG4gIHJldHVybiAoXG4gICAgPERyb3Bkb3duQ29udGFpbmVyIGNsYXNzTmFtZT1cInUtMTIvMTJcIj5cbiAgICAgIDxEcm9wZG93bkJ1dHRvblxuICAgICAgICBhcmlhLWV4cGFuZGVkPXshIXJlc291cmNlVHlwZXNJc09wZW59XG4gICAgICAgIGFyaWEtY29udHJvbHM9XCJzZWxlY3RDYXRlZ29yeVwiXG4gICAgICAgIHR5cGU9XCJidXR0b25cIlxuICAgICAgICB0YWJJbmRleD17cmVzb3VyY2VUeXBlc0lzT3BlbiA/IC0xIDogMH1cbiAgICAgICAgb25DbGljaz17KCkgPT4gc2V0UmVzb3VyY2VUeXBlc0lzT3Blbih0cnVlKX0+XG4gICAgICAgIDxkaXY+XG4gICAgICAgICAgPHNwYW4+e3QoJ25kbGFGaWxtLnNlYXJjaC5jaG9vc2VDYXRlZ29yeScpfTwvc3Bhbj5cbiAgICAgICAgICA8c21hbGw+eyhyZXNvdXJjZVR5cGVTZWxlY3RlZCAmJiByZXNvdXJjZVR5cGVTZWxlY3RlZC5uYW1lKSB8fCB0KCduZGxhRmlsbS5zZWFyY2guY2F0ZWdvcnlGcm9tTmRsYScpfTwvc21hbGw+XG4gICAgICAgIDwvZGl2PlxuICAgICAgICA8ZGl2PlxuICAgICAgICAgIDxDaGV2cm9uRG93biBjbGFzc05hbWU9XCJjLWljb24tLTIyXCIgLz5cbiAgICAgICAgPC9kaXY+XG4gICAgICA8L0Ryb3Bkb3duQnV0dG9uPlxuICAgICAge3Jlc291cmNlVHlwZXNJc09wZW4gJiYgKFxuICAgICAgICA8Rm9jdXNUcmFwUmVhY3RcbiAgICAgICAgICBhY3RpdmU9e3Jlc291cmNlVHlwZXNJc09wZW59XG4gICAgICAgICAgZm9jdXNUcmFwT3B0aW9ucz17e1xuICAgICAgICAgICAgb25EZWFjdGl2YXRlOiAoKSA9PiBzZXRSZXNvdXJjZVR5cGVzSXNPcGVuKGZhbHNlKSxcbiAgICAgICAgICAgIGNsaWNrT3V0c2lkZURlYWN0aXZhdGVzOiB0cnVlLFxuICAgICAgICAgICAgZXNjYXBlRGVhY3RpdmF0ZXM6IHRydWUsXG4gICAgICAgICAgfX0+XG4gICAgICAgICAgPERyb3Bkb3duV3JhcHBlciBpZD1cInNlbGVjdENhdGVnb3J5XCIgb2Zmc2V0RHJvcGRvd249e29mZnNldERyb3BEb3dufT5cbiAgICAgICAgICAgIDxEcm9wZG93bkJ1dHRvbiBhcmlhLWNvbnRyb2xzPXthcmlhQ29udHJvbElkfSB0eXBlPVwiYnV0dG9uXCIgb25DbGljaz17KCkgPT4gb25TZWxlY3QoKX0+XG4gICAgICAgICAgICAgIDxzcGFuPnt0KCduZGxhRmlsbS5zZWFyY2guY2F0ZWdvcnlGcm9tTmRsYScpfTwvc3Bhbj5cbiAgICAgICAgICAgIDwvRHJvcGRvd25CdXR0b24+XG4gICAgICAgICAgICB7cmVzb3VyY2VUeXBlcy5tYXAoKHJlc291cmNlVHlwZSkgPT4gKFxuICAgICAgICAgICAgICA8RHJvcGRvd25CdXR0b25cbiAgICAgICAgICAgICAgICBhcmlhLWNvbnRyb2xzPXthcmlhQ29udHJvbElkfVxuICAgICAgICAgICAgICAgIHR5cGU9XCJidXR0b25cIlxuICAgICAgICAgICAgICAgIHJlZj17KGVsKSA9PiB1cGRhdGVSZWYoZWwsIHJlc291cmNlVHlwZS5pZCl9XG4gICAgICAgICAgICAgICAgb25DbGljaz17KCkgPT4gb25TZWxlY3QocmVzb3VyY2VUeXBlLmlkKX1cbiAgICAgICAgICAgICAgICBkYXRhLWlkPXtyZXNvdXJjZVR5cGUuaWR9XG4gICAgICAgICAgICAgICAga2V5PXtyZXNvdXJjZVR5cGUuaWR9PlxuICAgICAgICAgICAgICAgIDxzcGFuPntyZXNvdXJjZVR5cGUubmFtZX08L3NwYW4+XG4gICAgICAgICAgICAgIDwvRHJvcGRvd25CdXR0b24+XG4gICAgICAgICAgICApKX1cbiAgICAgICAgICA8L0Ryb3Bkb3duV3JhcHBlcj5cbiAgICAgICAgPC9Gb2N1c1RyYXBSZWFjdD5cbiAgICAgICl9XG4gICAgPC9Ecm9wZG93bkNvbnRhaW5lcj5cbiAgKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IENhdGVnb3J5U2VsZWN0O1xuIl19 */"));
64
64
 
65
65
  var CategorySelect = function CategorySelect(_ref) {
66
66
  var resourceTypes = _ref.resourceTypes,
@@ -101,7 +101,7 @@ var CategorySelect = function CategorySelect(_ref) {
101
101
  return _jsxs(DropdownContainer, {
102
102
  className: "u-12/12",
103
103
  children: [_jsxs(DropdownButton, {
104
- "aria-expanded": !resourceTypesIsOpen,
104
+ "aria-expanded": !!resourceTypesIsOpen,
105
105
  "aria-controls": "selectCategory",
106
106
  type: "button",
107
107
  tabIndex: resourceTypesIsOpen ? -1 : 0,