@ndla/ui 22.0.2 → 22.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (98) hide show
  1. package/es/Article/ArticleByline.js +7 -4
  2. package/es/Article/ArticleNotions.js +10 -6
  3. package/es/CompetenceGoalTab/CompetenceGoalItem.js +12 -10
  4. package/es/CompetenceGoalTab/CompetenceGoalTab.js +11 -9
  5. package/es/CompetenceGoalTab/CompetenceItem.js +14 -12
  6. package/es/CompetenceGoalTab/SearchButton.js +7 -4
  7. package/es/CompetenceGoals/CompetenceGoalsDialog.js +8 -4
  8. package/es/Filter/FilterButtons.js +10 -9
  9. package/es/Footer/FooterPrivacy.js +3 -2
  10. package/es/Masthead/MastheadSearchModal.js +4 -3
  11. package/es/Resource/BlockResource.js +9 -5
  12. package/es/Resource/ListResource.js +8 -6
  13. package/es/Resource/resourceComponents.js +36 -25
  14. package/es/ResourcesWrapper/ResourcesTopicTitle.js +7 -4
  15. package/es/SearchTypeResult/PopupFilter.js +12 -8
  16. package/es/SearchTypeResult/components/ItemContexts.js +8 -7
  17. package/es/Topic/Topic.js +21 -20
  18. package/es/TreeStructure/FolderItem.js +34 -29
  19. package/es/TreeStructure/TreeStructure.js +5 -3
  20. package/es/TreeStructure/TreeStructureWrapper.js +2 -2
  21. package/es/User/AuthModal.js +9 -8
  22. package/es/locale/messages-en.js +12 -4
  23. package/es/locale/messages-nb.js +12 -4
  24. package/es/locale/messages-nn.js +12 -4
  25. package/es/locale/messages-se.js +12 -4
  26. package/es/locale/messages-sma.js +12 -4
  27. package/lib/Article/ArticleByline.js +7 -4
  28. package/lib/Article/ArticleNotions.js +10 -6
  29. package/lib/CompetenceGoalTab/CompetenceGoalItem.d.ts +1 -1
  30. package/lib/CompetenceGoalTab/CompetenceGoalItem.js +12 -10
  31. package/lib/CompetenceGoalTab/CompetenceGoalTab.d.ts +2 -1
  32. package/lib/CompetenceGoalTab/CompetenceGoalTab.js +11 -9
  33. package/lib/CompetenceGoalTab/CompetenceItem.d.ts +2 -1
  34. package/lib/CompetenceGoalTab/CompetenceItem.js +14 -12
  35. package/lib/CompetenceGoalTab/SearchButton.d.ts +2 -1
  36. package/lib/CompetenceGoalTab/SearchButton.js +7 -4
  37. package/lib/CompetenceGoals/CompetenceGoalsDialog.js +8 -4
  38. package/lib/Filter/FilterButtons.js +10 -9
  39. package/lib/Footer/FooterPrivacy.js +3 -2
  40. package/lib/Masthead/MastheadSearchModal.js +4 -3
  41. package/lib/Resource/BlockResource.d.ts +2 -1
  42. package/lib/Resource/BlockResource.js +9 -5
  43. package/lib/Resource/ListResource.d.ts +2 -1
  44. package/lib/Resource/ListResource.js +8 -6
  45. package/lib/Resource/resourceComponents.d.ts +4 -2
  46. package/lib/Resource/resourceComponents.js +38 -19
  47. package/lib/ResourcesWrapper/ResourcesTopicTitle.js +7 -4
  48. package/lib/SearchTypeResult/PopupFilter.js +12 -8
  49. package/lib/SearchTypeResult/components/ItemContexts.js +8 -7
  50. package/lib/Topic/Topic.js +21 -20
  51. package/lib/TreeStructure/FolderItem.d.ts +1 -1
  52. package/lib/TreeStructure/FolderItem.js +34 -29
  53. package/lib/TreeStructure/TreeStructure.d.ts +0 -1
  54. package/lib/TreeStructure/TreeStructure.js +5 -3
  55. package/lib/TreeStructure/TreeStructureWrapper.js +2 -2
  56. package/lib/TreeStructure/types.d.ts +1 -0
  57. package/lib/User/AuthModal.js +9 -8
  58. package/lib/locale/messages-en.d.ts +8 -0
  59. package/lib/locale/messages-en.js +12 -4
  60. package/lib/locale/messages-nb.d.ts +8 -0
  61. package/lib/locale/messages-nb.js +12 -4
  62. package/lib/locale/messages-nn.d.ts +8 -0
  63. package/lib/locale/messages-nn.js +12 -4
  64. package/lib/locale/messages-se.d.ts +8 -0
  65. package/lib/locale/messages-se.js +12 -4
  66. package/lib/locale/messages-sma.d.ts +8 -0
  67. package/lib/locale/messages-sma.js +12 -4
  68. package/lib/types.d.ts +1 -0
  69. package/package.json +8 -7
  70. package/src/Article/ArticleByline.tsx +4 -1
  71. package/src/Article/ArticleNotions.tsx +4 -1
  72. package/src/CompetenceGoalTab/CompetenceGoalItem.tsx +6 -2
  73. package/src/CompetenceGoalTab/CompetenceGoalTab.tsx +5 -4
  74. package/src/CompetenceGoalTab/CompetenceItem.tsx +9 -2
  75. package/src/CompetenceGoalTab/SearchButton.tsx +3 -2
  76. package/src/CompetenceGoals/CompetenceGoalsDialog.jsx +5 -2
  77. package/src/Filter/FilterButtons.tsx +1 -0
  78. package/src/Footer/FooterPrivacy.tsx +4 -1
  79. package/src/Masthead/MastheadSearchModal.tsx +1 -0
  80. package/src/Resource/BlockResource.tsx +4 -2
  81. package/src/Resource/ListResource.tsx +3 -1
  82. package/src/Resource/resourceComponents.tsx +25 -9
  83. package/src/ResourcesWrapper/ResourcesTopicTitle.tsx +5 -1
  84. package/src/SearchTypeResult/PopupFilter.tsx +3 -1
  85. package/src/SearchTypeResult/components/ItemContexts.tsx +1 -0
  86. package/src/Topic/Topic.tsx +1 -0
  87. package/src/TreeStructure/FolderItem.tsx +7 -2
  88. package/src/TreeStructure/TreeStructure.tsx +2 -1
  89. package/src/TreeStructure/TreeStructureWrapper.tsx +9 -12
  90. package/src/TreeStructure/types.ts +1 -0
  91. package/src/User/AuthModal.tsx +2 -1
  92. package/src/locale/messages-en.ts +8 -0
  93. package/src/locale/messages-nb.ts +8 -0
  94. package/src/locale/messages-nn.ts +8 -0
  95. package/src/locale/messages-se.ts +8 -0
  96. package/src/locale/messages-sma.ts +8 -0
  97. package/src/types.ts +1 -0
  98. package/src/.DS_Store +0 -0
@@ -35,7 +35,7 @@ import { jsx as ___EmotionJSX } from "@emotion/core";
35
35
  var StyledHeading = _styled("h3", {
36
36
  target: "e1yaxziw0",
37
37
  label: "StyledHeading"
38
- })(fonts.sizes('16px', '32px'), ";margin:0 0 ", spacing.small, ";color:", colors.text.light, ";font-weight:", fonts.weight.semibold, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilterButtons.tsx"],"names":[],"mappings":"AAkB+B","file":"FilterButtons.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\nimport React, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\n// @ts-ignore\nimport ToggleItem from './ToggleItem';\nimport FilterCarousel from './FilterCarousel';\n\nconst StyledHeading = styled.h3`\n  ${fonts.sizes('16px', '32px')};\n  margin: 0 0 ${spacing.small};\n  color: ${colors.text.light};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledButtonsWrapper = styled.div`\n  display: inline-flex;\n  flex-wrap: wrap;\n`;\n\nconst StyledButtonElementWrapper = styled.div`\n  margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n  break-inside: avoid;\n  flex-shrink: 0;\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    column-count: 2;\n    column-gap: 20px;\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    column-count: 3;\n    column-gap: 20px;\n  }\n`;\nconst StyledListItem = styled.li`\n  margin-bottom: 0;\n  break-inside: avoid;\n`;\n\nconst StyledButtonContent = styled.span``;\n\nconst StyledButtonContentSelected = styled.span`\n  margin-left: ${spacing.small};\n  display: inline-flex;\n  align-items: center;\n`;\n\nconst StyledRemoveWrapper = styled.div`\n  margin-top: ${spacing.xsmall};\n  margin-left: 10px;\n`;\n\nconst ButtonRemoveText = styled.span`\n  ${fonts.sizes('16px', '32px')};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nexport type ItemProps = {\n  label: string;\n  value: string;\n  selected?: boolean;\n};\nexport type FilterButtonsProps = {\n  heading?: string;\n  items: ItemProps[];\n  onFilterToggle: (value: string) => void;\n  onRemoveAllFilters: () => void;\n  labels: {\n    openFilter: string;\n  };\n};\n\nexport const FilterButtons = ({ heading, items, onFilterToggle, onRemoveAllFilters, labels }: FilterButtonsProps) => {\n  const { t } = useTranslation();\n  const [isNarrowScreen, setIsNarrowScreen] = useState(false);\n\n  useEffect(() => {\n    const isNarrowScreenMatch = window.matchMedia('(max-width: 767px)');\n    const handleChange = (e: MediaQueryListEvent | MediaQueryList) => {\n      setIsNarrowScreen(e.matches);\n    };\n    isNarrowScreenMatch.addEventListener('change', handleChange);\n    handleChange(isNarrowScreenMatch);\n    return () => {\n      isNarrowScreenMatch.removeEventListener('change', handleChange);\n    };\n  }, []);\n\n  const hasSelectedFilters = items.some((item) => {\n    return item.selected;\n  });\n\n  const activeItems = items.filter((item) => item.selected);\n\n  return (\n    <>\n      {isNarrowScreen && (\n        <StyledButtonsWrapper>\n          {activeItems.map((item: ItemProps) => (\n            <StyledButtonElementWrapper key={item.value}>\n              <Button\n                type=\"button\"\n                size=\"normal\"\n                borderShape=\"rounded\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}>\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </Button>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal\n            size=\"fullscreen\"\n            animation=\"subtle\"\n            backgroundColor=\"white\"\n            activateButton={\n              <StyledButtonElementWrapper>\n                <Button type=\"button\" size=\"normal\" light borderShape=\"rounded\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </Button>\n              </StyledButtonElementWrapper>\n            }>\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier={['left-align']}>\n                  <h1>{heading}</h1>\n                  <ModalCloseButton title={t('modal.closeModal')} onClick={onClose} />\n                </ModalHeader>\n                <ModalBody modifier=\"slide-in-left\">\n                  <StyledList>\n                    {items.map((item: ItemProps) => (\n                      <StyledListItem key={item.value}>\n                        <ToggleItem\n                          id={item.value}\n                          value={item.value}\n                          checked={item.selected}\n                          label={item.label}\n                          component=\"div\"\n                          onChange={() => onFilterToggle(item.value)}\n                        />\n                      </StyledListItem>\n                    ))}\n                  </StyledList>\n                </ModalBody>\n              </>\n            )}\n          </Modal>\n        </StyledButtonsWrapper>\n      )}\n      {!isNarrowScreen && (\n        <>\n          {heading && <StyledHeading>{heading}</StyledHeading>}\n          <FilterCarousel>\n            {items.map((item: ItemProps) => (\n              <StyledButtonElementWrapper key={item.value}>\n                <Button\n                  type=\"button\"\n                  size=\"normal\"\n                  greyLighter={!item.selected}\n                  borderShape=\"rounded\"\n                  onClick={() => onFilterToggle(item.value)}>\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </Button>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <Button onClick={onRemoveAllFilters} link>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </Button>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */"));
38
+ })(fonts.sizes('16px', '32px'), ";margin:0 0 ", spacing.small, ";color:", colors.text.light, ";font-weight:", fonts.weight.semibold, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilterButtons.tsx"],"names":[],"mappings":"AAkB+B","file":"FilterButtons.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\nimport React, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\n// @ts-ignore\nimport ToggleItem from './ToggleItem';\nimport FilterCarousel from './FilterCarousel';\n\nconst StyledHeading = styled.h3`\n  ${fonts.sizes('16px', '32px')};\n  margin: 0 0 ${spacing.small};\n  color: ${colors.text.light};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledButtonsWrapper = styled.div`\n  display: inline-flex;\n  flex-wrap: wrap;\n`;\n\nconst StyledButtonElementWrapper = styled.div`\n  margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n  break-inside: avoid;\n  flex-shrink: 0;\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    column-count: 2;\n    column-gap: 20px;\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    column-count: 3;\n    column-gap: 20px;\n  }\n`;\nconst StyledListItem = styled.li`\n  margin-bottom: 0;\n  break-inside: avoid;\n`;\n\nconst StyledButtonContent = styled.span``;\n\nconst StyledButtonContentSelected = styled.span`\n  margin-left: ${spacing.small};\n  display: inline-flex;\n  align-items: center;\n`;\n\nconst StyledRemoveWrapper = styled.div`\n  margin-top: ${spacing.xsmall};\n  margin-left: 10px;\n`;\n\nconst ButtonRemoveText = styled.span`\n  ${fonts.sizes('16px', '32px')};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nexport type ItemProps = {\n  label: string;\n  value: string;\n  selected?: boolean;\n};\nexport type FilterButtonsProps = {\n  heading?: string;\n  items: ItemProps[];\n  onFilterToggle: (value: string) => void;\n  onRemoveAllFilters: () => void;\n  labels: {\n    openFilter: string;\n  };\n};\n\nexport const FilterButtons = ({ heading, items, onFilterToggle, onRemoveAllFilters, labels }: FilterButtonsProps) => {\n  const { t } = useTranslation();\n  const [isNarrowScreen, setIsNarrowScreen] = useState(false);\n\n  useEffect(() => {\n    const isNarrowScreenMatch = window.matchMedia('(max-width: 767px)');\n    const handleChange = (e: MediaQueryListEvent | MediaQueryList) => {\n      setIsNarrowScreen(e.matches);\n    };\n    isNarrowScreenMatch.addEventListener('change', handleChange);\n    handleChange(isNarrowScreenMatch);\n    return () => {\n      isNarrowScreenMatch.removeEventListener('change', handleChange);\n    };\n  }, []);\n\n  const hasSelectedFilters = items.some((item) => {\n    return item.selected;\n  });\n\n  const activeItems = items.filter((item) => item.selected);\n\n  return (\n    <>\n      {isNarrowScreen && (\n        <StyledButtonsWrapper>\n          {activeItems.map((item: ItemProps) => (\n            <StyledButtonElementWrapper key={item.value}>\n              <Button\n                type=\"button\"\n                size=\"normal\"\n                borderShape=\"rounded\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}>\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </Button>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal\n            label={t('searchPage.searchFilterMessages.resourceTypeFilter.button')}\n            size=\"fullscreen\"\n            animation=\"subtle\"\n            backgroundColor=\"white\"\n            activateButton={\n              <StyledButtonElementWrapper>\n                <Button type=\"button\" size=\"normal\" light borderShape=\"rounded\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </Button>\n              </StyledButtonElementWrapper>\n            }>\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier={['left-align']}>\n                  <h1>{heading}</h1>\n                  <ModalCloseButton title={t('modal.closeModal')} onClick={onClose} />\n                </ModalHeader>\n                <ModalBody modifier=\"slide-in-left\">\n                  <StyledList>\n                    {items.map((item: ItemProps) => (\n                      <StyledListItem key={item.value}>\n                        <ToggleItem\n                          id={item.value}\n                          value={item.value}\n                          checked={item.selected}\n                          label={item.label}\n                          component=\"div\"\n                          onChange={() => onFilterToggle(item.value)}\n                        />\n                      </StyledListItem>\n                    ))}\n                  </StyledList>\n                </ModalBody>\n              </>\n            )}\n          </Modal>\n        </StyledButtonsWrapper>\n      )}\n      {!isNarrowScreen && (\n        <>\n          {heading && <StyledHeading>{heading}</StyledHeading>}\n          <FilterCarousel>\n            {items.map((item: ItemProps) => (\n              <StyledButtonElementWrapper key={item.value}>\n                <Button\n                  type=\"button\"\n                  size=\"normal\"\n                  greyLighter={!item.selected}\n                  borderShape=\"rounded\"\n                  onClick={() => onFilterToggle(item.value)}>\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </Button>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <Button onClick={onRemoveAllFilters} link>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </Button>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */"));
39
39
 
40
40
  var StyledButtonsWrapper = _styled("div", {
41
41
  target: "e1yaxziw1",
@@ -46,14 +46,14 @@ var StyledButtonsWrapper = _styled("div", {
46
46
  } : {
47
47
  name: "ao5xof",
48
48
  styles: "display:inline-flex;flex-wrap:wrap;",
49
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilterButtons.tsx"],"names":[],"mappings":"AAyBuC","file":"FilterButtons.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\nimport React, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\n// @ts-ignore\nimport ToggleItem from './ToggleItem';\nimport FilterCarousel from './FilterCarousel';\n\nconst StyledHeading = styled.h3`\n  ${fonts.sizes('16px', '32px')};\n  margin: 0 0 ${spacing.small};\n  color: ${colors.text.light};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledButtonsWrapper = styled.div`\n  display: inline-flex;\n  flex-wrap: wrap;\n`;\n\nconst StyledButtonElementWrapper = styled.div`\n  margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n  break-inside: avoid;\n  flex-shrink: 0;\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    column-count: 2;\n    column-gap: 20px;\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    column-count: 3;\n    column-gap: 20px;\n  }\n`;\nconst StyledListItem = styled.li`\n  margin-bottom: 0;\n  break-inside: avoid;\n`;\n\nconst StyledButtonContent = styled.span``;\n\nconst StyledButtonContentSelected = styled.span`\n  margin-left: ${spacing.small};\n  display: inline-flex;\n  align-items: center;\n`;\n\nconst StyledRemoveWrapper = styled.div`\n  margin-top: ${spacing.xsmall};\n  margin-left: 10px;\n`;\n\nconst ButtonRemoveText = styled.span`\n  ${fonts.sizes('16px', '32px')};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nexport type ItemProps = {\n  label: string;\n  value: string;\n  selected?: boolean;\n};\nexport type FilterButtonsProps = {\n  heading?: string;\n  items: ItemProps[];\n  onFilterToggle: (value: string) => void;\n  onRemoveAllFilters: () => void;\n  labels: {\n    openFilter: string;\n  };\n};\n\nexport const FilterButtons = ({ heading, items, onFilterToggle, onRemoveAllFilters, labels }: FilterButtonsProps) => {\n  const { t } = useTranslation();\n  const [isNarrowScreen, setIsNarrowScreen] = useState(false);\n\n  useEffect(() => {\n    const isNarrowScreenMatch = window.matchMedia('(max-width: 767px)');\n    const handleChange = (e: MediaQueryListEvent | MediaQueryList) => {\n      setIsNarrowScreen(e.matches);\n    };\n    isNarrowScreenMatch.addEventListener('change', handleChange);\n    handleChange(isNarrowScreenMatch);\n    return () => {\n      isNarrowScreenMatch.removeEventListener('change', handleChange);\n    };\n  }, []);\n\n  const hasSelectedFilters = items.some((item) => {\n    return item.selected;\n  });\n\n  const activeItems = items.filter((item) => item.selected);\n\n  return (\n    <>\n      {isNarrowScreen && (\n        <StyledButtonsWrapper>\n          {activeItems.map((item: ItemProps) => (\n            <StyledButtonElementWrapper key={item.value}>\n              <Button\n                type=\"button\"\n                size=\"normal\"\n                borderShape=\"rounded\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}>\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </Button>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal\n            size=\"fullscreen\"\n            animation=\"subtle\"\n            backgroundColor=\"white\"\n            activateButton={\n              <StyledButtonElementWrapper>\n                <Button type=\"button\" size=\"normal\" light borderShape=\"rounded\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </Button>\n              </StyledButtonElementWrapper>\n            }>\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier={['left-align']}>\n                  <h1>{heading}</h1>\n                  <ModalCloseButton title={t('modal.closeModal')} onClick={onClose} />\n                </ModalHeader>\n                <ModalBody modifier=\"slide-in-left\">\n                  <StyledList>\n                    {items.map((item: ItemProps) => (\n                      <StyledListItem key={item.value}>\n                        <ToggleItem\n                          id={item.value}\n                          value={item.value}\n                          checked={item.selected}\n                          label={item.label}\n                          component=\"div\"\n                          onChange={() => onFilterToggle(item.value)}\n                        />\n                      </StyledListItem>\n                    ))}\n                  </StyledList>\n                </ModalBody>\n              </>\n            )}\n          </Modal>\n        </StyledButtonsWrapper>\n      )}\n      {!isNarrowScreen && (\n        <>\n          {heading && <StyledHeading>{heading}</StyledHeading>}\n          <FilterCarousel>\n            {items.map((item: ItemProps) => (\n              <StyledButtonElementWrapper key={item.value}>\n                <Button\n                  type=\"button\"\n                  size=\"normal\"\n                  greyLighter={!item.selected}\n                  borderShape=\"rounded\"\n                  onClick={() => onFilterToggle(item.value)}>\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </Button>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <Button onClick={onRemoveAllFilters} link>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </Button>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */",
49
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilterButtons.tsx"],"names":[],"mappings":"AAyBuC","file":"FilterButtons.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\nimport React, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\n// @ts-ignore\nimport ToggleItem from './ToggleItem';\nimport FilterCarousel from './FilterCarousel';\n\nconst StyledHeading = styled.h3`\n  ${fonts.sizes('16px', '32px')};\n  margin: 0 0 ${spacing.small};\n  color: ${colors.text.light};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledButtonsWrapper = styled.div`\n  display: inline-flex;\n  flex-wrap: wrap;\n`;\n\nconst StyledButtonElementWrapper = styled.div`\n  margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n  break-inside: avoid;\n  flex-shrink: 0;\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    column-count: 2;\n    column-gap: 20px;\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    column-count: 3;\n    column-gap: 20px;\n  }\n`;\nconst StyledListItem = styled.li`\n  margin-bottom: 0;\n  break-inside: avoid;\n`;\n\nconst StyledButtonContent = styled.span``;\n\nconst StyledButtonContentSelected = styled.span`\n  margin-left: ${spacing.small};\n  display: inline-flex;\n  align-items: center;\n`;\n\nconst StyledRemoveWrapper = styled.div`\n  margin-top: ${spacing.xsmall};\n  margin-left: 10px;\n`;\n\nconst ButtonRemoveText = styled.span`\n  ${fonts.sizes('16px', '32px')};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nexport type ItemProps = {\n  label: string;\n  value: string;\n  selected?: boolean;\n};\nexport type FilterButtonsProps = {\n  heading?: string;\n  items: ItemProps[];\n  onFilterToggle: (value: string) => void;\n  onRemoveAllFilters: () => void;\n  labels: {\n    openFilter: string;\n  };\n};\n\nexport const FilterButtons = ({ heading, items, onFilterToggle, onRemoveAllFilters, labels }: FilterButtonsProps) => {\n  const { t } = useTranslation();\n  const [isNarrowScreen, setIsNarrowScreen] = useState(false);\n\n  useEffect(() => {\n    const isNarrowScreenMatch = window.matchMedia('(max-width: 767px)');\n    const handleChange = (e: MediaQueryListEvent | MediaQueryList) => {\n      setIsNarrowScreen(e.matches);\n    };\n    isNarrowScreenMatch.addEventListener('change', handleChange);\n    handleChange(isNarrowScreenMatch);\n    return () => {\n      isNarrowScreenMatch.removeEventListener('change', handleChange);\n    };\n  }, []);\n\n  const hasSelectedFilters = items.some((item) => {\n    return item.selected;\n  });\n\n  const activeItems = items.filter((item) => item.selected);\n\n  return (\n    <>\n      {isNarrowScreen && (\n        <StyledButtonsWrapper>\n          {activeItems.map((item: ItemProps) => (\n            <StyledButtonElementWrapper key={item.value}>\n              <Button\n                type=\"button\"\n                size=\"normal\"\n                borderShape=\"rounded\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}>\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </Button>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal\n            label={t('searchPage.searchFilterMessages.resourceTypeFilter.button')}\n            size=\"fullscreen\"\n            animation=\"subtle\"\n            backgroundColor=\"white\"\n            activateButton={\n              <StyledButtonElementWrapper>\n                <Button type=\"button\" size=\"normal\" light borderShape=\"rounded\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </Button>\n              </StyledButtonElementWrapper>\n            }>\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier={['left-align']}>\n                  <h1>{heading}</h1>\n                  <ModalCloseButton title={t('modal.closeModal')} onClick={onClose} />\n                </ModalHeader>\n                <ModalBody modifier=\"slide-in-left\">\n                  <StyledList>\n                    {items.map((item: ItemProps) => (\n                      <StyledListItem key={item.value}>\n                        <ToggleItem\n                          id={item.value}\n                          value={item.value}\n                          checked={item.selected}\n                          label={item.label}\n                          component=\"div\"\n                          onChange={() => onFilterToggle(item.value)}\n                        />\n                      </StyledListItem>\n                    ))}\n                  </StyledList>\n                </ModalBody>\n              </>\n            )}\n          </Modal>\n        </StyledButtonsWrapper>\n      )}\n      {!isNarrowScreen && (\n        <>\n          {heading && <StyledHeading>{heading}</StyledHeading>}\n          <FilterCarousel>\n            {items.map((item: ItemProps) => (\n              <StyledButtonElementWrapper key={item.value}>\n                <Button\n                  type=\"button\"\n                  size=\"normal\"\n                  greyLighter={!item.selected}\n                  borderShape=\"rounded\"\n                  onClick={() => onFilterToggle(item.value)}>\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </Button>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <Button onClick={onRemoveAllFilters} link>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </Button>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */",
50
50
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
51
51
  });
52
52
 
53
53
  var StyledButtonElementWrapper = _styled("div", {
54
54
  target: "e1yaxziw2",
55
55
  label: "StyledButtonElementWrapper"
56
- })("margin:0 ", spacing.xsmall, " ", spacing.xsmall, " 0;break-inside:avoid;flex-shrink:0;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilterButtons.tsx"],"names":[],"mappings":"AA8B6C","file":"FilterButtons.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\nimport React, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\n// @ts-ignore\nimport ToggleItem from './ToggleItem';\nimport FilterCarousel from './FilterCarousel';\n\nconst StyledHeading = styled.h3`\n  ${fonts.sizes('16px', '32px')};\n  margin: 0 0 ${spacing.small};\n  color: ${colors.text.light};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledButtonsWrapper = styled.div`\n  display: inline-flex;\n  flex-wrap: wrap;\n`;\n\nconst StyledButtonElementWrapper = styled.div`\n  margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n  break-inside: avoid;\n  flex-shrink: 0;\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    column-count: 2;\n    column-gap: 20px;\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    column-count: 3;\n    column-gap: 20px;\n  }\n`;\nconst StyledListItem = styled.li`\n  margin-bottom: 0;\n  break-inside: avoid;\n`;\n\nconst StyledButtonContent = styled.span``;\n\nconst StyledButtonContentSelected = styled.span`\n  margin-left: ${spacing.small};\n  display: inline-flex;\n  align-items: center;\n`;\n\nconst StyledRemoveWrapper = styled.div`\n  margin-top: ${spacing.xsmall};\n  margin-left: 10px;\n`;\n\nconst ButtonRemoveText = styled.span`\n  ${fonts.sizes('16px', '32px')};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nexport type ItemProps = {\n  label: string;\n  value: string;\n  selected?: boolean;\n};\nexport type FilterButtonsProps = {\n  heading?: string;\n  items: ItemProps[];\n  onFilterToggle: (value: string) => void;\n  onRemoveAllFilters: () => void;\n  labels: {\n    openFilter: string;\n  };\n};\n\nexport const FilterButtons = ({ heading, items, onFilterToggle, onRemoveAllFilters, labels }: FilterButtonsProps) => {\n  const { t } = useTranslation();\n  const [isNarrowScreen, setIsNarrowScreen] = useState(false);\n\n  useEffect(() => {\n    const isNarrowScreenMatch = window.matchMedia('(max-width: 767px)');\n    const handleChange = (e: MediaQueryListEvent | MediaQueryList) => {\n      setIsNarrowScreen(e.matches);\n    };\n    isNarrowScreenMatch.addEventListener('change', handleChange);\n    handleChange(isNarrowScreenMatch);\n    return () => {\n      isNarrowScreenMatch.removeEventListener('change', handleChange);\n    };\n  }, []);\n\n  const hasSelectedFilters = items.some((item) => {\n    return item.selected;\n  });\n\n  const activeItems = items.filter((item) => item.selected);\n\n  return (\n    <>\n      {isNarrowScreen && (\n        <StyledButtonsWrapper>\n          {activeItems.map((item: ItemProps) => (\n            <StyledButtonElementWrapper key={item.value}>\n              <Button\n                type=\"button\"\n                size=\"normal\"\n                borderShape=\"rounded\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}>\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </Button>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal\n            size=\"fullscreen\"\n            animation=\"subtle\"\n            backgroundColor=\"white\"\n            activateButton={\n              <StyledButtonElementWrapper>\n                <Button type=\"button\" size=\"normal\" light borderShape=\"rounded\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </Button>\n              </StyledButtonElementWrapper>\n            }>\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier={['left-align']}>\n                  <h1>{heading}</h1>\n                  <ModalCloseButton title={t('modal.closeModal')} onClick={onClose} />\n                </ModalHeader>\n                <ModalBody modifier=\"slide-in-left\">\n                  <StyledList>\n                    {items.map((item: ItemProps) => (\n                      <StyledListItem key={item.value}>\n                        <ToggleItem\n                          id={item.value}\n                          value={item.value}\n                          checked={item.selected}\n                          label={item.label}\n                          component=\"div\"\n                          onChange={() => onFilterToggle(item.value)}\n                        />\n                      </StyledListItem>\n                    ))}\n                  </StyledList>\n                </ModalBody>\n              </>\n            )}\n          </Modal>\n        </StyledButtonsWrapper>\n      )}\n      {!isNarrowScreen && (\n        <>\n          {heading && <StyledHeading>{heading}</StyledHeading>}\n          <FilterCarousel>\n            {items.map((item: ItemProps) => (\n              <StyledButtonElementWrapper key={item.value}>\n                <Button\n                  type=\"button\"\n                  size=\"normal\"\n                  greyLighter={!item.selected}\n                  borderShape=\"rounded\"\n                  onClick={() => onFilterToggle(item.value)}>\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </Button>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <Button onClick={onRemoveAllFilters} link>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </Button>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */"));
56
+ })("margin:0 ", spacing.xsmall, " ", spacing.xsmall, " 0;break-inside:avoid;flex-shrink:0;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilterButtons.tsx"],"names":[],"mappings":"AA8B6C","file":"FilterButtons.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\nimport React, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\n// @ts-ignore\nimport ToggleItem from './ToggleItem';\nimport FilterCarousel from './FilterCarousel';\n\nconst StyledHeading = styled.h3`\n  ${fonts.sizes('16px', '32px')};\n  margin: 0 0 ${spacing.small};\n  color: ${colors.text.light};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledButtonsWrapper = styled.div`\n  display: inline-flex;\n  flex-wrap: wrap;\n`;\n\nconst StyledButtonElementWrapper = styled.div`\n  margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n  break-inside: avoid;\n  flex-shrink: 0;\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    column-count: 2;\n    column-gap: 20px;\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    column-count: 3;\n    column-gap: 20px;\n  }\n`;\nconst StyledListItem = styled.li`\n  margin-bottom: 0;\n  break-inside: avoid;\n`;\n\nconst StyledButtonContent = styled.span``;\n\nconst StyledButtonContentSelected = styled.span`\n  margin-left: ${spacing.small};\n  display: inline-flex;\n  align-items: center;\n`;\n\nconst StyledRemoveWrapper = styled.div`\n  margin-top: ${spacing.xsmall};\n  margin-left: 10px;\n`;\n\nconst ButtonRemoveText = styled.span`\n  ${fonts.sizes('16px', '32px')};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nexport type ItemProps = {\n  label: string;\n  value: string;\n  selected?: boolean;\n};\nexport type FilterButtonsProps = {\n  heading?: string;\n  items: ItemProps[];\n  onFilterToggle: (value: string) => void;\n  onRemoveAllFilters: () => void;\n  labels: {\n    openFilter: string;\n  };\n};\n\nexport const FilterButtons = ({ heading, items, onFilterToggle, onRemoveAllFilters, labels }: FilterButtonsProps) => {\n  const { t } = useTranslation();\n  const [isNarrowScreen, setIsNarrowScreen] = useState(false);\n\n  useEffect(() => {\n    const isNarrowScreenMatch = window.matchMedia('(max-width: 767px)');\n    const handleChange = (e: MediaQueryListEvent | MediaQueryList) => {\n      setIsNarrowScreen(e.matches);\n    };\n    isNarrowScreenMatch.addEventListener('change', handleChange);\n    handleChange(isNarrowScreenMatch);\n    return () => {\n      isNarrowScreenMatch.removeEventListener('change', handleChange);\n    };\n  }, []);\n\n  const hasSelectedFilters = items.some((item) => {\n    return item.selected;\n  });\n\n  const activeItems = items.filter((item) => item.selected);\n\n  return (\n    <>\n      {isNarrowScreen && (\n        <StyledButtonsWrapper>\n          {activeItems.map((item: ItemProps) => (\n            <StyledButtonElementWrapper key={item.value}>\n              <Button\n                type=\"button\"\n                size=\"normal\"\n                borderShape=\"rounded\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}>\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </Button>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal\n            label={t('searchPage.searchFilterMessages.resourceTypeFilter.button')}\n            size=\"fullscreen\"\n            animation=\"subtle\"\n            backgroundColor=\"white\"\n            activateButton={\n              <StyledButtonElementWrapper>\n                <Button type=\"button\" size=\"normal\" light borderShape=\"rounded\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </Button>\n              </StyledButtonElementWrapper>\n            }>\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier={['left-align']}>\n                  <h1>{heading}</h1>\n                  <ModalCloseButton title={t('modal.closeModal')} onClick={onClose} />\n                </ModalHeader>\n                <ModalBody modifier=\"slide-in-left\">\n                  <StyledList>\n                    {items.map((item: ItemProps) => (\n                      <StyledListItem key={item.value}>\n                        <ToggleItem\n                          id={item.value}\n                          value={item.value}\n                          checked={item.selected}\n                          label={item.label}\n                          component=\"div\"\n                          onChange={() => onFilterToggle(item.value)}\n                        />\n                      </StyledListItem>\n                    ))}\n                  </StyledList>\n                </ModalBody>\n              </>\n            )}\n          </Modal>\n        </StyledButtonsWrapper>\n      )}\n      {!isNarrowScreen && (\n        <>\n          {heading && <StyledHeading>{heading}</StyledHeading>}\n          <FilterCarousel>\n            {items.map((item: ItemProps) => (\n              <StyledButtonElementWrapper key={item.value}>\n                <Button\n                  type=\"button\"\n                  size=\"normal\"\n                  greyLighter={!item.selected}\n                  borderShape=\"rounded\"\n                  onClick={() => onFilterToggle(item.value)}>\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </Button>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <Button onClick={onRemoveAllFilters} link>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </Button>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */"));
57
57
 
58
58
  var StyledList = _styled("ul", {
59
59
  target: "e1yaxziw3",
@@ -62,7 +62,7 @@ var StyledList = _styled("ul", {
62
62
  from: breakpoints.tablet
63
63
  }), "{column-count:2;column-gap:20px;}", mq.range({
64
64
  from: breakpoints.tabletWide
65
- }), "{column-count:3;column-gap:20px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilterButtons.tsx"],"names":[],"mappings":"AAoC4B","file":"FilterButtons.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\nimport React, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\n// @ts-ignore\nimport ToggleItem from './ToggleItem';\nimport FilterCarousel from './FilterCarousel';\n\nconst StyledHeading = styled.h3`\n  ${fonts.sizes('16px', '32px')};\n  margin: 0 0 ${spacing.small};\n  color: ${colors.text.light};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledButtonsWrapper = styled.div`\n  display: inline-flex;\n  flex-wrap: wrap;\n`;\n\nconst StyledButtonElementWrapper = styled.div`\n  margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n  break-inside: avoid;\n  flex-shrink: 0;\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    column-count: 2;\n    column-gap: 20px;\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    column-count: 3;\n    column-gap: 20px;\n  }\n`;\nconst StyledListItem = styled.li`\n  margin-bottom: 0;\n  break-inside: avoid;\n`;\n\nconst StyledButtonContent = styled.span``;\n\nconst StyledButtonContentSelected = styled.span`\n  margin-left: ${spacing.small};\n  display: inline-flex;\n  align-items: center;\n`;\n\nconst StyledRemoveWrapper = styled.div`\n  margin-top: ${spacing.xsmall};\n  margin-left: 10px;\n`;\n\nconst ButtonRemoveText = styled.span`\n  ${fonts.sizes('16px', '32px')};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nexport type ItemProps = {\n  label: string;\n  value: string;\n  selected?: boolean;\n};\nexport type FilterButtonsProps = {\n  heading?: string;\n  items: ItemProps[];\n  onFilterToggle: (value: string) => void;\n  onRemoveAllFilters: () => void;\n  labels: {\n    openFilter: string;\n  };\n};\n\nexport const FilterButtons = ({ heading, items, onFilterToggle, onRemoveAllFilters, labels }: FilterButtonsProps) => {\n  const { t } = useTranslation();\n  const [isNarrowScreen, setIsNarrowScreen] = useState(false);\n\n  useEffect(() => {\n    const isNarrowScreenMatch = window.matchMedia('(max-width: 767px)');\n    const handleChange = (e: MediaQueryListEvent | MediaQueryList) => {\n      setIsNarrowScreen(e.matches);\n    };\n    isNarrowScreenMatch.addEventListener('change', handleChange);\n    handleChange(isNarrowScreenMatch);\n    return () => {\n      isNarrowScreenMatch.removeEventListener('change', handleChange);\n    };\n  }, []);\n\n  const hasSelectedFilters = items.some((item) => {\n    return item.selected;\n  });\n\n  const activeItems = items.filter((item) => item.selected);\n\n  return (\n    <>\n      {isNarrowScreen && (\n        <StyledButtonsWrapper>\n          {activeItems.map((item: ItemProps) => (\n            <StyledButtonElementWrapper key={item.value}>\n              <Button\n                type=\"button\"\n                size=\"normal\"\n                borderShape=\"rounded\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}>\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </Button>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal\n            size=\"fullscreen\"\n            animation=\"subtle\"\n            backgroundColor=\"white\"\n            activateButton={\n              <StyledButtonElementWrapper>\n                <Button type=\"button\" size=\"normal\" light borderShape=\"rounded\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </Button>\n              </StyledButtonElementWrapper>\n            }>\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier={['left-align']}>\n                  <h1>{heading}</h1>\n                  <ModalCloseButton title={t('modal.closeModal')} onClick={onClose} />\n                </ModalHeader>\n                <ModalBody modifier=\"slide-in-left\">\n                  <StyledList>\n                    {items.map((item: ItemProps) => (\n                      <StyledListItem key={item.value}>\n                        <ToggleItem\n                          id={item.value}\n                          value={item.value}\n                          checked={item.selected}\n                          label={item.label}\n                          component=\"div\"\n                          onChange={() => onFilterToggle(item.value)}\n                        />\n                      </StyledListItem>\n                    ))}\n                  </StyledList>\n                </ModalBody>\n              </>\n            )}\n          </Modal>\n        </StyledButtonsWrapper>\n      )}\n      {!isNarrowScreen && (\n        <>\n          {heading && <StyledHeading>{heading}</StyledHeading>}\n          <FilterCarousel>\n            {items.map((item: ItemProps) => (\n              <StyledButtonElementWrapper key={item.value}>\n                <Button\n                  type=\"button\"\n                  size=\"normal\"\n                  greyLighter={!item.selected}\n                  borderShape=\"rounded\"\n                  onClick={() => onFilterToggle(item.value)}>\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </Button>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <Button onClick={onRemoveAllFilters} link>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </Button>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */"));
65
+ }), "{column-count:3;column-gap:20px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilterButtons.tsx"],"names":[],"mappings":"AAoC4B","file":"FilterButtons.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\nimport React, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\n// @ts-ignore\nimport ToggleItem from './ToggleItem';\nimport FilterCarousel from './FilterCarousel';\n\nconst StyledHeading = styled.h3`\n  ${fonts.sizes('16px', '32px')};\n  margin: 0 0 ${spacing.small};\n  color: ${colors.text.light};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledButtonsWrapper = styled.div`\n  display: inline-flex;\n  flex-wrap: wrap;\n`;\n\nconst StyledButtonElementWrapper = styled.div`\n  margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n  break-inside: avoid;\n  flex-shrink: 0;\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    column-count: 2;\n    column-gap: 20px;\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    column-count: 3;\n    column-gap: 20px;\n  }\n`;\nconst StyledListItem = styled.li`\n  margin-bottom: 0;\n  break-inside: avoid;\n`;\n\nconst StyledButtonContent = styled.span``;\n\nconst StyledButtonContentSelected = styled.span`\n  margin-left: ${spacing.small};\n  display: inline-flex;\n  align-items: center;\n`;\n\nconst StyledRemoveWrapper = styled.div`\n  margin-top: ${spacing.xsmall};\n  margin-left: 10px;\n`;\n\nconst ButtonRemoveText = styled.span`\n  ${fonts.sizes('16px', '32px')};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nexport type ItemProps = {\n  label: string;\n  value: string;\n  selected?: boolean;\n};\nexport type FilterButtonsProps = {\n  heading?: string;\n  items: ItemProps[];\n  onFilterToggle: (value: string) => void;\n  onRemoveAllFilters: () => void;\n  labels: {\n    openFilter: string;\n  };\n};\n\nexport const FilterButtons = ({ heading, items, onFilterToggle, onRemoveAllFilters, labels }: FilterButtonsProps) => {\n  const { t } = useTranslation();\n  const [isNarrowScreen, setIsNarrowScreen] = useState(false);\n\n  useEffect(() => {\n    const isNarrowScreenMatch = window.matchMedia('(max-width: 767px)');\n    const handleChange = (e: MediaQueryListEvent | MediaQueryList) => {\n      setIsNarrowScreen(e.matches);\n    };\n    isNarrowScreenMatch.addEventListener('change', handleChange);\n    handleChange(isNarrowScreenMatch);\n    return () => {\n      isNarrowScreenMatch.removeEventListener('change', handleChange);\n    };\n  }, []);\n\n  const hasSelectedFilters = items.some((item) => {\n    return item.selected;\n  });\n\n  const activeItems = items.filter((item) => item.selected);\n\n  return (\n    <>\n      {isNarrowScreen && (\n        <StyledButtonsWrapper>\n          {activeItems.map((item: ItemProps) => (\n            <StyledButtonElementWrapper key={item.value}>\n              <Button\n                type=\"button\"\n                size=\"normal\"\n                borderShape=\"rounded\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}>\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </Button>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal\n            label={t('searchPage.searchFilterMessages.resourceTypeFilter.button')}\n            size=\"fullscreen\"\n            animation=\"subtle\"\n            backgroundColor=\"white\"\n            activateButton={\n              <StyledButtonElementWrapper>\n                <Button type=\"button\" size=\"normal\" light borderShape=\"rounded\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </Button>\n              </StyledButtonElementWrapper>\n            }>\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier={['left-align']}>\n                  <h1>{heading}</h1>\n                  <ModalCloseButton title={t('modal.closeModal')} onClick={onClose} />\n                </ModalHeader>\n                <ModalBody modifier=\"slide-in-left\">\n                  <StyledList>\n                    {items.map((item: ItemProps) => (\n                      <StyledListItem key={item.value}>\n                        <ToggleItem\n                          id={item.value}\n                          value={item.value}\n                          checked={item.selected}\n                          label={item.label}\n                          component=\"div\"\n                          onChange={() => onFilterToggle(item.value)}\n                        />\n                      </StyledListItem>\n                    ))}\n                  </StyledList>\n                </ModalBody>\n              </>\n            )}\n          </Modal>\n        </StyledButtonsWrapper>\n      )}\n      {!isNarrowScreen && (\n        <>\n          {heading && <StyledHeading>{heading}</StyledHeading>}\n          <FilterCarousel>\n            {items.map((item: ItemProps) => (\n              <StyledButtonElementWrapper key={item.value}>\n                <Button\n                  type=\"button\"\n                  size=\"normal\"\n                  greyLighter={!item.selected}\n                  borderShape=\"rounded\"\n                  onClick={() => onFilterToggle(item.value)}>\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </Button>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <Button onClick={onRemoveAllFilters} link>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </Button>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */"));
66
66
 
67
67
  var StyledListItem = _styled("li", {
68
68
  target: "e1yaxziw4",
@@ -73,29 +73,29 @@ var StyledListItem = _styled("li", {
73
73
  } : {
74
74
  name: "1gj47mt",
75
75
  styles: "margin-bottom:0;break-inside:avoid;",
76
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilterButtons.tsx"],"names":[],"mappings":"AAiDgC","file":"FilterButtons.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\nimport React, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\n// @ts-ignore\nimport ToggleItem from './ToggleItem';\nimport FilterCarousel from './FilterCarousel';\n\nconst StyledHeading = styled.h3`\n  ${fonts.sizes('16px', '32px')};\n  margin: 0 0 ${spacing.small};\n  color: ${colors.text.light};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledButtonsWrapper = styled.div`\n  display: inline-flex;\n  flex-wrap: wrap;\n`;\n\nconst StyledButtonElementWrapper = styled.div`\n  margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n  break-inside: avoid;\n  flex-shrink: 0;\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    column-count: 2;\n    column-gap: 20px;\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    column-count: 3;\n    column-gap: 20px;\n  }\n`;\nconst StyledListItem = styled.li`\n  margin-bottom: 0;\n  break-inside: avoid;\n`;\n\nconst StyledButtonContent = styled.span``;\n\nconst StyledButtonContentSelected = styled.span`\n  margin-left: ${spacing.small};\n  display: inline-flex;\n  align-items: center;\n`;\n\nconst StyledRemoveWrapper = styled.div`\n  margin-top: ${spacing.xsmall};\n  margin-left: 10px;\n`;\n\nconst ButtonRemoveText = styled.span`\n  ${fonts.sizes('16px', '32px')};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nexport type ItemProps = {\n  label: string;\n  value: string;\n  selected?: boolean;\n};\nexport type FilterButtonsProps = {\n  heading?: string;\n  items: ItemProps[];\n  onFilterToggle: (value: string) => void;\n  onRemoveAllFilters: () => void;\n  labels: {\n    openFilter: string;\n  };\n};\n\nexport const FilterButtons = ({ heading, items, onFilterToggle, onRemoveAllFilters, labels }: FilterButtonsProps) => {\n  const { t } = useTranslation();\n  const [isNarrowScreen, setIsNarrowScreen] = useState(false);\n\n  useEffect(() => {\n    const isNarrowScreenMatch = window.matchMedia('(max-width: 767px)');\n    const handleChange = (e: MediaQueryListEvent | MediaQueryList) => {\n      setIsNarrowScreen(e.matches);\n    };\n    isNarrowScreenMatch.addEventListener('change', handleChange);\n    handleChange(isNarrowScreenMatch);\n    return () => {\n      isNarrowScreenMatch.removeEventListener('change', handleChange);\n    };\n  }, []);\n\n  const hasSelectedFilters = items.some((item) => {\n    return item.selected;\n  });\n\n  const activeItems = items.filter((item) => item.selected);\n\n  return (\n    <>\n      {isNarrowScreen && (\n        <StyledButtonsWrapper>\n          {activeItems.map((item: ItemProps) => (\n            <StyledButtonElementWrapper key={item.value}>\n              <Button\n                type=\"button\"\n                size=\"normal\"\n                borderShape=\"rounded\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}>\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </Button>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal\n            size=\"fullscreen\"\n            animation=\"subtle\"\n            backgroundColor=\"white\"\n            activateButton={\n              <StyledButtonElementWrapper>\n                <Button type=\"button\" size=\"normal\" light borderShape=\"rounded\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </Button>\n              </StyledButtonElementWrapper>\n            }>\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier={['left-align']}>\n                  <h1>{heading}</h1>\n                  <ModalCloseButton title={t('modal.closeModal')} onClick={onClose} />\n                </ModalHeader>\n                <ModalBody modifier=\"slide-in-left\">\n                  <StyledList>\n                    {items.map((item: ItemProps) => (\n                      <StyledListItem key={item.value}>\n                        <ToggleItem\n                          id={item.value}\n                          value={item.value}\n                          checked={item.selected}\n                          label={item.label}\n                          component=\"div\"\n                          onChange={() => onFilterToggle(item.value)}\n                        />\n                      </StyledListItem>\n                    ))}\n                  </StyledList>\n                </ModalBody>\n              </>\n            )}\n          </Modal>\n        </StyledButtonsWrapper>\n      )}\n      {!isNarrowScreen && (\n        <>\n          {heading && <StyledHeading>{heading}</StyledHeading>}\n          <FilterCarousel>\n            {items.map((item: ItemProps) => (\n              <StyledButtonElementWrapper key={item.value}>\n                <Button\n                  type=\"button\"\n                  size=\"normal\"\n                  greyLighter={!item.selected}\n                  borderShape=\"rounded\"\n                  onClick={() => onFilterToggle(item.value)}>\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </Button>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <Button onClick={onRemoveAllFilters} link>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </Button>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */",
76
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilterButtons.tsx"],"names":[],"mappings":"AAiDgC","file":"FilterButtons.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\nimport React, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\n// @ts-ignore\nimport ToggleItem from './ToggleItem';\nimport FilterCarousel from './FilterCarousel';\n\nconst StyledHeading = styled.h3`\n  ${fonts.sizes('16px', '32px')};\n  margin: 0 0 ${spacing.small};\n  color: ${colors.text.light};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledButtonsWrapper = styled.div`\n  display: inline-flex;\n  flex-wrap: wrap;\n`;\n\nconst StyledButtonElementWrapper = styled.div`\n  margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n  break-inside: avoid;\n  flex-shrink: 0;\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    column-count: 2;\n    column-gap: 20px;\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    column-count: 3;\n    column-gap: 20px;\n  }\n`;\nconst StyledListItem = styled.li`\n  margin-bottom: 0;\n  break-inside: avoid;\n`;\n\nconst StyledButtonContent = styled.span``;\n\nconst StyledButtonContentSelected = styled.span`\n  margin-left: ${spacing.small};\n  display: inline-flex;\n  align-items: center;\n`;\n\nconst StyledRemoveWrapper = styled.div`\n  margin-top: ${spacing.xsmall};\n  margin-left: 10px;\n`;\n\nconst ButtonRemoveText = styled.span`\n  ${fonts.sizes('16px', '32px')};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nexport type ItemProps = {\n  label: string;\n  value: string;\n  selected?: boolean;\n};\nexport type FilterButtonsProps = {\n  heading?: string;\n  items: ItemProps[];\n  onFilterToggle: (value: string) => void;\n  onRemoveAllFilters: () => void;\n  labels: {\n    openFilter: string;\n  };\n};\n\nexport const FilterButtons = ({ heading, items, onFilterToggle, onRemoveAllFilters, labels }: FilterButtonsProps) => {\n  const { t } = useTranslation();\n  const [isNarrowScreen, setIsNarrowScreen] = useState(false);\n\n  useEffect(() => {\n    const isNarrowScreenMatch = window.matchMedia('(max-width: 767px)');\n    const handleChange = (e: MediaQueryListEvent | MediaQueryList) => {\n      setIsNarrowScreen(e.matches);\n    };\n    isNarrowScreenMatch.addEventListener('change', handleChange);\n    handleChange(isNarrowScreenMatch);\n    return () => {\n      isNarrowScreenMatch.removeEventListener('change', handleChange);\n    };\n  }, []);\n\n  const hasSelectedFilters = items.some((item) => {\n    return item.selected;\n  });\n\n  const activeItems = items.filter((item) => item.selected);\n\n  return (\n    <>\n      {isNarrowScreen && (\n        <StyledButtonsWrapper>\n          {activeItems.map((item: ItemProps) => (\n            <StyledButtonElementWrapper key={item.value}>\n              <Button\n                type=\"button\"\n                size=\"normal\"\n                borderShape=\"rounded\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}>\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </Button>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal\n            label={t('searchPage.searchFilterMessages.resourceTypeFilter.button')}\n            size=\"fullscreen\"\n            animation=\"subtle\"\n            backgroundColor=\"white\"\n            activateButton={\n              <StyledButtonElementWrapper>\n                <Button type=\"button\" size=\"normal\" light borderShape=\"rounded\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </Button>\n              </StyledButtonElementWrapper>\n            }>\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier={['left-align']}>\n                  <h1>{heading}</h1>\n                  <ModalCloseButton title={t('modal.closeModal')} onClick={onClose} />\n                </ModalHeader>\n                <ModalBody modifier=\"slide-in-left\">\n                  <StyledList>\n                    {items.map((item: ItemProps) => (\n                      <StyledListItem key={item.value}>\n                        <ToggleItem\n                          id={item.value}\n                          value={item.value}\n                          checked={item.selected}\n                          label={item.label}\n                          component=\"div\"\n                          onChange={() => onFilterToggle(item.value)}\n                        />\n                      </StyledListItem>\n                    ))}\n                  </StyledList>\n                </ModalBody>\n              </>\n            )}\n          </Modal>\n        </StyledButtonsWrapper>\n      )}\n      {!isNarrowScreen && (\n        <>\n          {heading && <StyledHeading>{heading}</StyledHeading>}\n          <FilterCarousel>\n            {items.map((item: ItemProps) => (\n              <StyledButtonElementWrapper key={item.value}>\n                <Button\n                  type=\"button\"\n                  size=\"normal\"\n                  greyLighter={!item.selected}\n                  borderShape=\"rounded\"\n                  onClick={() => onFilterToggle(item.value)}>\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </Button>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <Button onClick={onRemoveAllFilters} link>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </Button>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */",
77
77
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
78
78
  });
79
79
 
80
80
  var StyledButtonContent = _styled("span", {
81
81
  target: "e1yaxziw5",
82
82
  label: "StyledButtonContent"
83
- })(process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilterButtons.tsx"],"names":[],"mappings":"AAsDuC","file":"FilterButtons.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\nimport React, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\n// @ts-ignore\nimport ToggleItem from './ToggleItem';\nimport FilterCarousel from './FilterCarousel';\n\nconst StyledHeading = styled.h3`\n  ${fonts.sizes('16px', '32px')};\n  margin: 0 0 ${spacing.small};\n  color: ${colors.text.light};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledButtonsWrapper = styled.div`\n  display: inline-flex;\n  flex-wrap: wrap;\n`;\n\nconst StyledButtonElementWrapper = styled.div`\n  margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n  break-inside: avoid;\n  flex-shrink: 0;\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    column-count: 2;\n    column-gap: 20px;\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    column-count: 3;\n    column-gap: 20px;\n  }\n`;\nconst StyledListItem = styled.li`\n  margin-bottom: 0;\n  break-inside: avoid;\n`;\n\nconst StyledButtonContent = styled.span``;\n\nconst StyledButtonContentSelected = styled.span`\n  margin-left: ${spacing.small};\n  display: inline-flex;\n  align-items: center;\n`;\n\nconst StyledRemoveWrapper = styled.div`\n  margin-top: ${spacing.xsmall};\n  margin-left: 10px;\n`;\n\nconst ButtonRemoveText = styled.span`\n  ${fonts.sizes('16px', '32px')};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nexport type ItemProps = {\n  label: string;\n  value: string;\n  selected?: boolean;\n};\nexport type FilterButtonsProps = {\n  heading?: string;\n  items: ItemProps[];\n  onFilterToggle: (value: string) => void;\n  onRemoveAllFilters: () => void;\n  labels: {\n    openFilter: string;\n  };\n};\n\nexport const FilterButtons = ({ heading, items, onFilterToggle, onRemoveAllFilters, labels }: FilterButtonsProps) => {\n  const { t } = useTranslation();\n  const [isNarrowScreen, setIsNarrowScreen] = useState(false);\n\n  useEffect(() => {\n    const isNarrowScreenMatch = window.matchMedia('(max-width: 767px)');\n    const handleChange = (e: MediaQueryListEvent | MediaQueryList) => {\n      setIsNarrowScreen(e.matches);\n    };\n    isNarrowScreenMatch.addEventListener('change', handleChange);\n    handleChange(isNarrowScreenMatch);\n    return () => {\n      isNarrowScreenMatch.removeEventListener('change', handleChange);\n    };\n  }, []);\n\n  const hasSelectedFilters = items.some((item) => {\n    return item.selected;\n  });\n\n  const activeItems = items.filter((item) => item.selected);\n\n  return (\n    <>\n      {isNarrowScreen && (\n        <StyledButtonsWrapper>\n          {activeItems.map((item: ItemProps) => (\n            <StyledButtonElementWrapper key={item.value}>\n              <Button\n                type=\"button\"\n                size=\"normal\"\n                borderShape=\"rounded\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}>\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </Button>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal\n            size=\"fullscreen\"\n            animation=\"subtle\"\n            backgroundColor=\"white\"\n            activateButton={\n              <StyledButtonElementWrapper>\n                <Button type=\"button\" size=\"normal\" light borderShape=\"rounded\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </Button>\n              </StyledButtonElementWrapper>\n            }>\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier={['left-align']}>\n                  <h1>{heading}</h1>\n                  <ModalCloseButton title={t('modal.closeModal')} onClick={onClose} />\n                </ModalHeader>\n                <ModalBody modifier=\"slide-in-left\">\n                  <StyledList>\n                    {items.map((item: ItemProps) => (\n                      <StyledListItem key={item.value}>\n                        <ToggleItem\n                          id={item.value}\n                          value={item.value}\n                          checked={item.selected}\n                          label={item.label}\n                          component=\"div\"\n                          onChange={() => onFilterToggle(item.value)}\n                        />\n                      </StyledListItem>\n                    ))}\n                  </StyledList>\n                </ModalBody>\n              </>\n            )}\n          </Modal>\n        </StyledButtonsWrapper>\n      )}\n      {!isNarrowScreen && (\n        <>\n          {heading && <StyledHeading>{heading}</StyledHeading>}\n          <FilterCarousel>\n            {items.map((item: ItemProps) => (\n              <StyledButtonElementWrapper key={item.value}>\n                <Button\n                  type=\"button\"\n                  size=\"normal\"\n                  greyLighter={!item.selected}\n                  borderShape=\"rounded\"\n                  onClick={() => onFilterToggle(item.value)}>\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </Button>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <Button onClick={onRemoveAllFilters} link>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </Button>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */");
83
+ })(process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilterButtons.tsx"],"names":[],"mappings":"AAsDuC","file":"FilterButtons.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\nimport React, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\n// @ts-ignore\nimport ToggleItem from './ToggleItem';\nimport FilterCarousel from './FilterCarousel';\n\nconst StyledHeading = styled.h3`\n  ${fonts.sizes('16px', '32px')};\n  margin: 0 0 ${spacing.small};\n  color: ${colors.text.light};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledButtonsWrapper = styled.div`\n  display: inline-flex;\n  flex-wrap: wrap;\n`;\n\nconst StyledButtonElementWrapper = styled.div`\n  margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n  break-inside: avoid;\n  flex-shrink: 0;\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    column-count: 2;\n    column-gap: 20px;\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    column-count: 3;\n    column-gap: 20px;\n  }\n`;\nconst StyledListItem = styled.li`\n  margin-bottom: 0;\n  break-inside: avoid;\n`;\n\nconst StyledButtonContent = styled.span``;\n\nconst StyledButtonContentSelected = styled.span`\n  margin-left: ${spacing.small};\n  display: inline-flex;\n  align-items: center;\n`;\n\nconst StyledRemoveWrapper = styled.div`\n  margin-top: ${spacing.xsmall};\n  margin-left: 10px;\n`;\n\nconst ButtonRemoveText = styled.span`\n  ${fonts.sizes('16px', '32px')};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nexport type ItemProps = {\n  label: string;\n  value: string;\n  selected?: boolean;\n};\nexport type FilterButtonsProps = {\n  heading?: string;\n  items: ItemProps[];\n  onFilterToggle: (value: string) => void;\n  onRemoveAllFilters: () => void;\n  labels: {\n    openFilter: string;\n  };\n};\n\nexport const FilterButtons = ({ heading, items, onFilterToggle, onRemoveAllFilters, labels }: FilterButtonsProps) => {\n  const { t } = useTranslation();\n  const [isNarrowScreen, setIsNarrowScreen] = useState(false);\n\n  useEffect(() => {\n    const isNarrowScreenMatch = window.matchMedia('(max-width: 767px)');\n    const handleChange = (e: MediaQueryListEvent | MediaQueryList) => {\n      setIsNarrowScreen(e.matches);\n    };\n    isNarrowScreenMatch.addEventListener('change', handleChange);\n    handleChange(isNarrowScreenMatch);\n    return () => {\n      isNarrowScreenMatch.removeEventListener('change', handleChange);\n    };\n  }, []);\n\n  const hasSelectedFilters = items.some((item) => {\n    return item.selected;\n  });\n\n  const activeItems = items.filter((item) => item.selected);\n\n  return (\n    <>\n      {isNarrowScreen && (\n        <StyledButtonsWrapper>\n          {activeItems.map((item: ItemProps) => (\n            <StyledButtonElementWrapper key={item.value}>\n              <Button\n                type=\"button\"\n                size=\"normal\"\n                borderShape=\"rounded\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}>\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </Button>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal\n            label={t('searchPage.searchFilterMessages.resourceTypeFilter.button')}\n            size=\"fullscreen\"\n            animation=\"subtle\"\n            backgroundColor=\"white\"\n            activateButton={\n              <StyledButtonElementWrapper>\n                <Button type=\"button\" size=\"normal\" light borderShape=\"rounded\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </Button>\n              </StyledButtonElementWrapper>\n            }>\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier={['left-align']}>\n                  <h1>{heading}</h1>\n                  <ModalCloseButton title={t('modal.closeModal')} onClick={onClose} />\n                </ModalHeader>\n                <ModalBody modifier=\"slide-in-left\">\n                  <StyledList>\n                    {items.map((item: ItemProps) => (\n                      <StyledListItem key={item.value}>\n                        <ToggleItem\n                          id={item.value}\n                          value={item.value}\n                          checked={item.selected}\n                          label={item.label}\n                          component=\"div\"\n                          onChange={() => onFilterToggle(item.value)}\n                        />\n                      </StyledListItem>\n                    ))}\n                  </StyledList>\n                </ModalBody>\n              </>\n            )}\n          </Modal>\n        </StyledButtonsWrapper>\n      )}\n      {!isNarrowScreen && (\n        <>\n          {heading && <StyledHeading>{heading}</StyledHeading>}\n          <FilterCarousel>\n            {items.map((item: ItemProps) => (\n              <StyledButtonElementWrapper key={item.value}>\n                <Button\n                  type=\"button\"\n                  size=\"normal\"\n                  greyLighter={!item.selected}\n                  borderShape=\"rounded\"\n                  onClick={() => onFilterToggle(item.value)}>\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </Button>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <Button onClick={onRemoveAllFilters} link>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </Button>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */");
84
84
 
85
85
  var StyledButtonContentSelected = _styled("span", {
86
86
  target: "e1yaxziw6",
87
87
  label: "StyledButtonContentSelected"
88
- })("margin-left:", spacing.small, ";display:inline-flex;align-items:center;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilterButtons.tsx"],"names":[],"mappings":"AAwD+C","file":"FilterButtons.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\nimport React, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\n// @ts-ignore\nimport ToggleItem from './ToggleItem';\nimport FilterCarousel from './FilterCarousel';\n\nconst StyledHeading = styled.h3`\n  ${fonts.sizes('16px', '32px')};\n  margin: 0 0 ${spacing.small};\n  color: ${colors.text.light};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledButtonsWrapper = styled.div`\n  display: inline-flex;\n  flex-wrap: wrap;\n`;\n\nconst StyledButtonElementWrapper = styled.div`\n  margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n  break-inside: avoid;\n  flex-shrink: 0;\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    column-count: 2;\n    column-gap: 20px;\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    column-count: 3;\n    column-gap: 20px;\n  }\n`;\nconst StyledListItem = styled.li`\n  margin-bottom: 0;\n  break-inside: avoid;\n`;\n\nconst StyledButtonContent = styled.span``;\n\nconst StyledButtonContentSelected = styled.span`\n  margin-left: ${spacing.small};\n  display: inline-flex;\n  align-items: center;\n`;\n\nconst StyledRemoveWrapper = styled.div`\n  margin-top: ${spacing.xsmall};\n  margin-left: 10px;\n`;\n\nconst ButtonRemoveText = styled.span`\n  ${fonts.sizes('16px', '32px')};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nexport type ItemProps = {\n  label: string;\n  value: string;\n  selected?: boolean;\n};\nexport type FilterButtonsProps = {\n  heading?: string;\n  items: ItemProps[];\n  onFilterToggle: (value: string) => void;\n  onRemoveAllFilters: () => void;\n  labels: {\n    openFilter: string;\n  };\n};\n\nexport const FilterButtons = ({ heading, items, onFilterToggle, onRemoveAllFilters, labels }: FilterButtonsProps) => {\n  const { t } = useTranslation();\n  const [isNarrowScreen, setIsNarrowScreen] = useState(false);\n\n  useEffect(() => {\n    const isNarrowScreenMatch = window.matchMedia('(max-width: 767px)');\n    const handleChange = (e: MediaQueryListEvent | MediaQueryList) => {\n      setIsNarrowScreen(e.matches);\n    };\n    isNarrowScreenMatch.addEventListener('change', handleChange);\n    handleChange(isNarrowScreenMatch);\n    return () => {\n      isNarrowScreenMatch.removeEventListener('change', handleChange);\n    };\n  }, []);\n\n  const hasSelectedFilters = items.some((item) => {\n    return item.selected;\n  });\n\n  const activeItems = items.filter((item) => item.selected);\n\n  return (\n    <>\n      {isNarrowScreen && (\n        <StyledButtonsWrapper>\n          {activeItems.map((item: ItemProps) => (\n            <StyledButtonElementWrapper key={item.value}>\n              <Button\n                type=\"button\"\n                size=\"normal\"\n                borderShape=\"rounded\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}>\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </Button>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal\n            size=\"fullscreen\"\n            animation=\"subtle\"\n            backgroundColor=\"white\"\n            activateButton={\n              <StyledButtonElementWrapper>\n                <Button type=\"button\" size=\"normal\" light borderShape=\"rounded\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </Button>\n              </StyledButtonElementWrapper>\n            }>\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier={['left-align']}>\n                  <h1>{heading}</h1>\n                  <ModalCloseButton title={t('modal.closeModal')} onClick={onClose} />\n                </ModalHeader>\n                <ModalBody modifier=\"slide-in-left\">\n                  <StyledList>\n                    {items.map((item: ItemProps) => (\n                      <StyledListItem key={item.value}>\n                        <ToggleItem\n                          id={item.value}\n                          value={item.value}\n                          checked={item.selected}\n                          label={item.label}\n                          component=\"div\"\n                          onChange={() => onFilterToggle(item.value)}\n                        />\n                      </StyledListItem>\n                    ))}\n                  </StyledList>\n                </ModalBody>\n              </>\n            )}\n          </Modal>\n        </StyledButtonsWrapper>\n      )}\n      {!isNarrowScreen && (\n        <>\n          {heading && <StyledHeading>{heading}</StyledHeading>}\n          <FilterCarousel>\n            {items.map((item: ItemProps) => (\n              <StyledButtonElementWrapper key={item.value}>\n                <Button\n                  type=\"button\"\n                  size=\"normal\"\n                  greyLighter={!item.selected}\n                  borderShape=\"rounded\"\n                  onClick={() => onFilterToggle(item.value)}>\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </Button>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <Button onClick={onRemoveAllFilters} link>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </Button>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */"));
88
+ })("margin-left:", spacing.small, ";display:inline-flex;align-items:center;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilterButtons.tsx"],"names":[],"mappings":"AAwD+C","file":"FilterButtons.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\nimport React, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\n// @ts-ignore\nimport ToggleItem from './ToggleItem';\nimport FilterCarousel from './FilterCarousel';\n\nconst StyledHeading = styled.h3`\n  ${fonts.sizes('16px', '32px')};\n  margin: 0 0 ${spacing.small};\n  color: ${colors.text.light};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledButtonsWrapper = styled.div`\n  display: inline-flex;\n  flex-wrap: wrap;\n`;\n\nconst StyledButtonElementWrapper = styled.div`\n  margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n  break-inside: avoid;\n  flex-shrink: 0;\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    column-count: 2;\n    column-gap: 20px;\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    column-count: 3;\n    column-gap: 20px;\n  }\n`;\nconst StyledListItem = styled.li`\n  margin-bottom: 0;\n  break-inside: avoid;\n`;\n\nconst StyledButtonContent = styled.span``;\n\nconst StyledButtonContentSelected = styled.span`\n  margin-left: ${spacing.small};\n  display: inline-flex;\n  align-items: center;\n`;\n\nconst StyledRemoveWrapper = styled.div`\n  margin-top: ${spacing.xsmall};\n  margin-left: 10px;\n`;\n\nconst ButtonRemoveText = styled.span`\n  ${fonts.sizes('16px', '32px')};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nexport type ItemProps = {\n  label: string;\n  value: string;\n  selected?: boolean;\n};\nexport type FilterButtonsProps = {\n  heading?: string;\n  items: ItemProps[];\n  onFilterToggle: (value: string) => void;\n  onRemoveAllFilters: () => void;\n  labels: {\n    openFilter: string;\n  };\n};\n\nexport const FilterButtons = ({ heading, items, onFilterToggle, onRemoveAllFilters, labels }: FilterButtonsProps) => {\n  const { t } = useTranslation();\n  const [isNarrowScreen, setIsNarrowScreen] = useState(false);\n\n  useEffect(() => {\n    const isNarrowScreenMatch = window.matchMedia('(max-width: 767px)');\n    const handleChange = (e: MediaQueryListEvent | MediaQueryList) => {\n      setIsNarrowScreen(e.matches);\n    };\n    isNarrowScreenMatch.addEventListener('change', handleChange);\n    handleChange(isNarrowScreenMatch);\n    return () => {\n      isNarrowScreenMatch.removeEventListener('change', handleChange);\n    };\n  }, []);\n\n  const hasSelectedFilters = items.some((item) => {\n    return item.selected;\n  });\n\n  const activeItems = items.filter((item) => item.selected);\n\n  return (\n    <>\n      {isNarrowScreen && (\n        <StyledButtonsWrapper>\n          {activeItems.map((item: ItemProps) => (\n            <StyledButtonElementWrapper key={item.value}>\n              <Button\n                type=\"button\"\n                size=\"normal\"\n                borderShape=\"rounded\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}>\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </Button>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal\n            label={t('searchPage.searchFilterMessages.resourceTypeFilter.button')}\n            size=\"fullscreen\"\n            animation=\"subtle\"\n            backgroundColor=\"white\"\n            activateButton={\n              <StyledButtonElementWrapper>\n                <Button type=\"button\" size=\"normal\" light borderShape=\"rounded\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </Button>\n              </StyledButtonElementWrapper>\n            }>\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier={['left-align']}>\n                  <h1>{heading}</h1>\n                  <ModalCloseButton title={t('modal.closeModal')} onClick={onClose} />\n                </ModalHeader>\n                <ModalBody modifier=\"slide-in-left\">\n                  <StyledList>\n                    {items.map((item: ItemProps) => (\n                      <StyledListItem key={item.value}>\n                        <ToggleItem\n                          id={item.value}\n                          value={item.value}\n                          checked={item.selected}\n                          label={item.label}\n                          component=\"div\"\n                          onChange={() => onFilterToggle(item.value)}\n                        />\n                      </StyledListItem>\n                    ))}\n                  </StyledList>\n                </ModalBody>\n              </>\n            )}\n          </Modal>\n        </StyledButtonsWrapper>\n      )}\n      {!isNarrowScreen && (\n        <>\n          {heading && <StyledHeading>{heading}</StyledHeading>}\n          <FilterCarousel>\n            {items.map((item: ItemProps) => (\n              <StyledButtonElementWrapper key={item.value}>\n                <Button\n                  type=\"button\"\n                  size=\"normal\"\n                  greyLighter={!item.selected}\n                  borderShape=\"rounded\"\n                  onClick={() => onFilterToggle(item.value)}>\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </Button>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <Button onClick={onRemoveAllFilters} link>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </Button>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */"));
89
89
 
90
90
  var StyledRemoveWrapper = _styled("div", {
91
91
  target: "e1yaxziw7",
92
92
  label: "StyledRemoveWrapper"
93
- })("margin-top:", spacing.xsmall, ";margin-left:10px;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilterButtons.tsx"],"names":[],"mappings":"AA8DsC","file":"FilterButtons.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\nimport React, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\n// @ts-ignore\nimport ToggleItem from './ToggleItem';\nimport FilterCarousel from './FilterCarousel';\n\nconst StyledHeading = styled.h3`\n  ${fonts.sizes('16px', '32px')};\n  margin: 0 0 ${spacing.small};\n  color: ${colors.text.light};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledButtonsWrapper = styled.div`\n  display: inline-flex;\n  flex-wrap: wrap;\n`;\n\nconst StyledButtonElementWrapper = styled.div`\n  margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n  break-inside: avoid;\n  flex-shrink: 0;\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    column-count: 2;\n    column-gap: 20px;\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    column-count: 3;\n    column-gap: 20px;\n  }\n`;\nconst StyledListItem = styled.li`\n  margin-bottom: 0;\n  break-inside: avoid;\n`;\n\nconst StyledButtonContent = styled.span``;\n\nconst StyledButtonContentSelected = styled.span`\n  margin-left: ${spacing.small};\n  display: inline-flex;\n  align-items: center;\n`;\n\nconst StyledRemoveWrapper = styled.div`\n  margin-top: ${spacing.xsmall};\n  margin-left: 10px;\n`;\n\nconst ButtonRemoveText = styled.span`\n  ${fonts.sizes('16px', '32px')};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nexport type ItemProps = {\n  label: string;\n  value: string;\n  selected?: boolean;\n};\nexport type FilterButtonsProps = {\n  heading?: string;\n  items: ItemProps[];\n  onFilterToggle: (value: string) => void;\n  onRemoveAllFilters: () => void;\n  labels: {\n    openFilter: string;\n  };\n};\n\nexport const FilterButtons = ({ heading, items, onFilterToggle, onRemoveAllFilters, labels }: FilterButtonsProps) => {\n  const { t } = useTranslation();\n  const [isNarrowScreen, setIsNarrowScreen] = useState(false);\n\n  useEffect(() => {\n    const isNarrowScreenMatch = window.matchMedia('(max-width: 767px)');\n    const handleChange = (e: MediaQueryListEvent | MediaQueryList) => {\n      setIsNarrowScreen(e.matches);\n    };\n    isNarrowScreenMatch.addEventListener('change', handleChange);\n    handleChange(isNarrowScreenMatch);\n    return () => {\n      isNarrowScreenMatch.removeEventListener('change', handleChange);\n    };\n  }, []);\n\n  const hasSelectedFilters = items.some((item) => {\n    return item.selected;\n  });\n\n  const activeItems = items.filter((item) => item.selected);\n\n  return (\n    <>\n      {isNarrowScreen && (\n        <StyledButtonsWrapper>\n          {activeItems.map((item: ItemProps) => (\n            <StyledButtonElementWrapper key={item.value}>\n              <Button\n                type=\"button\"\n                size=\"normal\"\n                borderShape=\"rounded\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}>\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </Button>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal\n            size=\"fullscreen\"\n            animation=\"subtle\"\n            backgroundColor=\"white\"\n            activateButton={\n              <StyledButtonElementWrapper>\n                <Button type=\"button\" size=\"normal\" light borderShape=\"rounded\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </Button>\n              </StyledButtonElementWrapper>\n            }>\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier={['left-align']}>\n                  <h1>{heading}</h1>\n                  <ModalCloseButton title={t('modal.closeModal')} onClick={onClose} />\n                </ModalHeader>\n                <ModalBody modifier=\"slide-in-left\">\n                  <StyledList>\n                    {items.map((item: ItemProps) => (\n                      <StyledListItem key={item.value}>\n                        <ToggleItem\n                          id={item.value}\n                          value={item.value}\n                          checked={item.selected}\n                          label={item.label}\n                          component=\"div\"\n                          onChange={() => onFilterToggle(item.value)}\n                        />\n                      </StyledListItem>\n                    ))}\n                  </StyledList>\n                </ModalBody>\n              </>\n            )}\n          </Modal>\n        </StyledButtonsWrapper>\n      )}\n      {!isNarrowScreen && (\n        <>\n          {heading && <StyledHeading>{heading}</StyledHeading>}\n          <FilterCarousel>\n            {items.map((item: ItemProps) => (\n              <StyledButtonElementWrapper key={item.value}>\n                <Button\n                  type=\"button\"\n                  size=\"normal\"\n                  greyLighter={!item.selected}\n                  borderShape=\"rounded\"\n                  onClick={() => onFilterToggle(item.value)}>\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </Button>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <Button onClick={onRemoveAllFilters} link>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </Button>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */"));
93
+ })("margin-top:", spacing.xsmall, ";margin-left:10px;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilterButtons.tsx"],"names":[],"mappings":"AA8DsC","file":"FilterButtons.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\nimport React, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\n// @ts-ignore\nimport ToggleItem from './ToggleItem';\nimport FilterCarousel from './FilterCarousel';\n\nconst StyledHeading = styled.h3`\n  ${fonts.sizes('16px', '32px')};\n  margin: 0 0 ${spacing.small};\n  color: ${colors.text.light};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledButtonsWrapper = styled.div`\n  display: inline-flex;\n  flex-wrap: wrap;\n`;\n\nconst StyledButtonElementWrapper = styled.div`\n  margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n  break-inside: avoid;\n  flex-shrink: 0;\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    column-count: 2;\n    column-gap: 20px;\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    column-count: 3;\n    column-gap: 20px;\n  }\n`;\nconst StyledListItem = styled.li`\n  margin-bottom: 0;\n  break-inside: avoid;\n`;\n\nconst StyledButtonContent = styled.span``;\n\nconst StyledButtonContentSelected = styled.span`\n  margin-left: ${spacing.small};\n  display: inline-flex;\n  align-items: center;\n`;\n\nconst StyledRemoveWrapper = styled.div`\n  margin-top: ${spacing.xsmall};\n  margin-left: 10px;\n`;\n\nconst ButtonRemoveText = styled.span`\n  ${fonts.sizes('16px', '32px')};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nexport type ItemProps = {\n  label: string;\n  value: string;\n  selected?: boolean;\n};\nexport type FilterButtonsProps = {\n  heading?: string;\n  items: ItemProps[];\n  onFilterToggle: (value: string) => void;\n  onRemoveAllFilters: () => void;\n  labels: {\n    openFilter: string;\n  };\n};\n\nexport const FilterButtons = ({ heading, items, onFilterToggle, onRemoveAllFilters, labels }: FilterButtonsProps) => {\n  const { t } = useTranslation();\n  const [isNarrowScreen, setIsNarrowScreen] = useState(false);\n\n  useEffect(() => {\n    const isNarrowScreenMatch = window.matchMedia('(max-width: 767px)');\n    const handleChange = (e: MediaQueryListEvent | MediaQueryList) => {\n      setIsNarrowScreen(e.matches);\n    };\n    isNarrowScreenMatch.addEventListener('change', handleChange);\n    handleChange(isNarrowScreenMatch);\n    return () => {\n      isNarrowScreenMatch.removeEventListener('change', handleChange);\n    };\n  }, []);\n\n  const hasSelectedFilters = items.some((item) => {\n    return item.selected;\n  });\n\n  const activeItems = items.filter((item) => item.selected);\n\n  return (\n    <>\n      {isNarrowScreen && (\n        <StyledButtonsWrapper>\n          {activeItems.map((item: ItemProps) => (\n            <StyledButtonElementWrapper key={item.value}>\n              <Button\n                type=\"button\"\n                size=\"normal\"\n                borderShape=\"rounded\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}>\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </Button>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal\n            label={t('searchPage.searchFilterMessages.resourceTypeFilter.button')}\n            size=\"fullscreen\"\n            animation=\"subtle\"\n            backgroundColor=\"white\"\n            activateButton={\n              <StyledButtonElementWrapper>\n                <Button type=\"button\" size=\"normal\" light borderShape=\"rounded\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </Button>\n              </StyledButtonElementWrapper>\n            }>\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier={['left-align']}>\n                  <h1>{heading}</h1>\n                  <ModalCloseButton title={t('modal.closeModal')} onClick={onClose} />\n                </ModalHeader>\n                <ModalBody modifier=\"slide-in-left\">\n                  <StyledList>\n                    {items.map((item: ItemProps) => (\n                      <StyledListItem key={item.value}>\n                        <ToggleItem\n                          id={item.value}\n                          value={item.value}\n                          checked={item.selected}\n                          label={item.label}\n                          component=\"div\"\n                          onChange={() => onFilterToggle(item.value)}\n                        />\n                      </StyledListItem>\n                    ))}\n                  </StyledList>\n                </ModalBody>\n              </>\n            )}\n          </Modal>\n        </StyledButtonsWrapper>\n      )}\n      {!isNarrowScreen && (\n        <>\n          {heading && <StyledHeading>{heading}</StyledHeading>}\n          <FilterCarousel>\n            {items.map((item: ItemProps) => (\n              <StyledButtonElementWrapper key={item.value}>\n                <Button\n                  type=\"button\"\n                  size=\"normal\"\n                  greyLighter={!item.selected}\n                  borderShape=\"rounded\"\n                  onClick={() => onFilterToggle(item.value)}>\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </Button>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <Button onClick={onRemoveAllFilters} link>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </Button>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */"));
94
94
 
95
95
  var ButtonRemoveText = _styled("span", {
96
96
  target: "e1yaxziw8",
97
97
  label: "ButtonRemoveText"
98
- })(fonts.sizes('16px', '32px'), ";font-weight:", fonts.weight.semibold, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilterButtons.tsx"],"names":[],"mappings":"AAmEoC","file":"FilterButtons.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\nimport React, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\n// @ts-ignore\nimport ToggleItem from './ToggleItem';\nimport FilterCarousel from './FilterCarousel';\n\nconst StyledHeading = styled.h3`\n  ${fonts.sizes('16px', '32px')};\n  margin: 0 0 ${spacing.small};\n  color: ${colors.text.light};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledButtonsWrapper = styled.div`\n  display: inline-flex;\n  flex-wrap: wrap;\n`;\n\nconst StyledButtonElementWrapper = styled.div`\n  margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n  break-inside: avoid;\n  flex-shrink: 0;\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    column-count: 2;\n    column-gap: 20px;\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    column-count: 3;\n    column-gap: 20px;\n  }\n`;\nconst StyledListItem = styled.li`\n  margin-bottom: 0;\n  break-inside: avoid;\n`;\n\nconst StyledButtonContent = styled.span``;\n\nconst StyledButtonContentSelected = styled.span`\n  margin-left: ${spacing.small};\n  display: inline-flex;\n  align-items: center;\n`;\n\nconst StyledRemoveWrapper = styled.div`\n  margin-top: ${spacing.xsmall};\n  margin-left: 10px;\n`;\n\nconst ButtonRemoveText = styled.span`\n  ${fonts.sizes('16px', '32px')};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nexport type ItemProps = {\n  label: string;\n  value: string;\n  selected?: boolean;\n};\nexport type FilterButtonsProps = {\n  heading?: string;\n  items: ItemProps[];\n  onFilterToggle: (value: string) => void;\n  onRemoveAllFilters: () => void;\n  labels: {\n    openFilter: string;\n  };\n};\n\nexport const FilterButtons = ({ heading, items, onFilterToggle, onRemoveAllFilters, labels }: FilterButtonsProps) => {\n  const { t } = useTranslation();\n  const [isNarrowScreen, setIsNarrowScreen] = useState(false);\n\n  useEffect(() => {\n    const isNarrowScreenMatch = window.matchMedia('(max-width: 767px)');\n    const handleChange = (e: MediaQueryListEvent | MediaQueryList) => {\n      setIsNarrowScreen(e.matches);\n    };\n    isNarrowScreenMatch.addEventListener('change', handleChange);\n    handleChange(isNarrowScreenMatch);\n    return () => {\n      isNarrowScreenMatch.removeEventListener('change', handleChange);\n    };\n  }, []);\n\n  const hasSelectedFilters = items.some((item) => {\n    return item.selected;\n  });\n\n  const activeItems = items.filter((item) => item.selected);\n\n  return (\n    <>\n      {isNarrowScreen && (\n        <StyledButtonsWrapper>\n          {activeItems.map((item: ItemProps) => (\n            <StyledButtonElementWrapper key={item.value}>\n              <Button\n                type=\"button\"\n                size=\"normal\"\n                borderShape=\"rounded\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}>\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </Button>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal\n            size=\"fullscreen\"\n            animation=\"subtle\"\n            backgroundColor=\"white\"\n            activateButton={\n              <StyledButtonElementWrapper>\n                <Button type=\"button\" size=\"normal\" light borderShape=\"rounded\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </Button>\n              </StyledButtonElementWrapper>\n            }>\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier={['left-align']}>\n                  <h1>{heading}</h1>\n                  <ModalCloseButton title={t('modal.closeModal')} onClick={onClose} />\n                </ModalHeader>\n                <ModalBody modifier=\"slide-in-left\">\n                  <StyledList>\n                    {items.map((item: ItemProps) => (\n                      <StyledListItem key={item.value}>\n                        <ToggleItem\n                          id={item.value}\n                          value={item.value}\n                          checked={item.selected}\n                          label={item.label}\n                          component=\"div\"\n                          onChange={() => onFilterToggle(item.value)}\n                        />\n                      </StyledListItem>\n                    ))}\n                  </StyledList>\n                </ModalBody>\n              </>\n            )}\n          </Modal>\n        </StyledButtonsWrapper>\n      )}\n      {!isNarrowScreen && (\n        <>\n          {heading && <StyledHeading>{heading}</StyledHeading>}\n          <FilterCarousel>\n            {items.map((item: ItemProps) => (\n              <StyledButtonElementWrapper key={item.value}>\n                <Button\n                  type=\"button\"\n                  size=\"normal\"\n                  greyLighter={!item.selected}\n                  borderShape=\"rounded\"\n                  onClick={() => onFilterToggle(item.value)}>\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </Button>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <Button onClick={onRemoveAllFilters} link>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </Button>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */"));
98
+ })(fonts.sizes('16px', '32px'), ";font-weight:", fonts.weight.semibold, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilterButtons.tsx"],"names":[],"mappings":"AAmEoC","file":"FilterButtons.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\nimport React, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\n// @ts-ignore\nimport ToggleItem from './ToggleItem';\nimport FilterCarousel from './FilterCarousel';\n\nconst StyledHeading = styled.h3`\n  ${fonts.sizes('16px', '32px')};\n  margin: 0 0 ${spacing.small};\n  color: ${colors.text.light};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledButtonsWrapper = styled.div`\n  display: inline-flex;\n  flex-wrap: wrap;\n`;\n\nconst StyledButtonElementWrapper = styled.div`\n  margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n  break-inside: avoid;\n  flex-shrink: 0;\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    column-count: 2;\n    column-gap: 20px;\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    column-count: 3;\n    column-gap: 20px;\n  }\n`;\nconst StyledListItem = styled.li`\n  margin-bottom: 0;\n  break-inside: avoid;\n`;\n\nconst StyledButtonContent = styled.span``;\n\nconst StyledButtonContentSelected = styled.span`\n  margin-left: ${spacing.small};\n  display: inline-flex;\n  align-items: center;\n`;\n\nconst StyledRemoveWrapper = styled.div`\n  margin-top: ${spacing.xsmall};\n  margin-left: 10px;\n`;\n\nconst ButtonRemoveText = styled.span`\n  ${fonts.sizes('16px', '32px')};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nexport type ItemProps = {\n  label: string;\n  value: string;\n  selected?: boolean;\n};\nexport type FilterButtonsProps = {\n  heading?: string;\n  items: ItemProps[];\n  onFilterToggle: (value: string) => void;\n  onRemoveAllFilters: () => void;\n  labels: {\n    openFilter: string;\n  };\n};\n\nexport const FilterButtons = ({ heading, items, onFilterToggle, onRemoveAllFilters, labels }: FilterButtonsProps) => {\n  const { t } = useTranslation();\n  const [isNarrowScreen, setIsNarrowScreen] = useState(false);\n\n  useEffect(() => {\n    const isNarrowScreenMatch = window.matchMedia('(max-width: 767px)');\n    const handleChange = (e: MediaQueryListEvent | MediaQueryList) => {\n      setIsNarrowScreen(e.matches);\n    };\n    isNarrowScreenMatch.addEventListener('change', handleChange);\n    handleChange(isNarrowScreenMatch);\n    return () => {\n      isNarrowScreenMatch.removeEventListener('change', handleChange);\n    };\n  }, []);\n\n  const hasSelectedFilters = items.some((item) => {\n    return item.selected;\n  });\n\n  const activeItems = items.filter((item) => item.selected);\n\n  return (\n    <>\n      {isNarrowScreen && (\n        <StyledButtonsWrapper>\n          {activeItems.map((item: ItemProps) => (\n            <StyledButtonElementWrapper key={item.value}>\n              <Button\n                type=\"button\"\n                size=\"normal\"\n                borderShape=\"rounded\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}>\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </Button>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal\n            label={t('searchPage.searchFilterMessages.resourceTypeFilter.button')}\n            size=\"fullscreen\"\n            animation=\"subtle\"\n            backgroundColor=\"white\"\n            activateButton={\n              <StyledButtonElementWrapper>\n                <Button type=\"button\" size=\"normal\" light borderShape=\"rounded\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </Button>\n              </StyledButtonElementWrapper>\n            }>\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier={['left-align']}>\n                  <h1>{heading}</h1>\n                  <ModalCloseButton title={t('modal.closeModal')} onClick={onClose} />\n                </ModalHeader>\n                <ModalBody modifier=\"slide-in-left\">\n                  <StyledList>\n                    {items.map((item: ItemProps) => (\n                      <StyledListItem key={item.value}>\n                        <ToggleItem\n                          id={item.value}\n                          value={item.value}\n                          checked={item.selected}\n                          label={item.label}\n                          component=\"div\"\n                          onChange={() => onFilterToggle(item.value)}\n                        />\n                      </StyledListItem>\n                    ))}\n                  </StyledList>\n                </ModalBody>\n              </>\n            )}\n          </Modal>\n        </StyledButtonsWrapper>\n      )}\n      {!isNarrowScreen && (\n        <>\n          {heading && <StyledHeading>{heading}</StyledHeading>}\n          <FilterCarousel>\n            {items.map((item: ItemProps) => (\n              <StyledButtonElementWrapper key={item.value}>\n                <Button\n                  type=\"button\"\n                  size=\"normal\"\n                  greyLighter={!item.selected}\n                  borderShape=\"rounded\"\n                  onClick={() => onFilterToggle(item.value)}>\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </Button>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <Button onClick={onRemoveAllFilters} link>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </Button>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */"));
99
99
 
100
100
  export var FilterButtons = function FilterButtons(_ref) {
101
101
  var heading = _ref.heading,
@@ -143,6 +143,7 @@ export var FilterButtons = function FilterButtons(_ref) {
143
143
  }
144
144
  }, ___EmotionJSX(StyledButtonContent, null, item.label), ___EmotionJSX(StyledButtonContentSelected, null, ___EmotionJSX(CrossIcon, null))));
145
145
  }), ___EmotionJSX(Modal, {
146
+ label: t('searchPage.searchFilterMessages.resourceTypeFilter.button'),
146
147
  size: "fullscreen",
147
148
  animation: "subtle",
148
149
  backgroundColor: "white",
@@ -31,7 +31,7 @@ var privacyTexts = function privacyTexts(lang) {
31
31
  var StyledPrivacyButton = _styled("button", {
32
32
  target: "e1yo4d830",
33
33
  label: "StyledPrivacyButton"
34
- })("background:none;color:#fff;border:0;padding:0;box-shadow:", misc.textLinkBoxShadow, ";cursor:pointer;margin-bottom:", spacing.large, ";&:hover,&:focus{box-shadow:none;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZvb3RlclByaXZhY3kudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWtDeUMiLCJmaWxlIjoiRm9vdGVyUHJpdmFjeS50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxNi1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgTW9kYWwsIHsgTW9kYWxIZWFkZXIsIE1vZGFsQm9keSwgTW9kYWxDbG9zZUJ1dHRvbiB9IGZyb20gJ0BuZGxhL21vZGFsJztcbmltcG9ydCB7IHNwYWNpbmcsIGZvbnRzLCBtaXNjLCBtcSwgYnJlYWtwb2ludHMgfSBmcm9tICdAbmRsYS9jb3JlJztcbmltcG9ydCB7IE9uZUNvbHVtbiB9IGZyb20gJy4uL0xheW91dCc7XG5pbXBvcnQgeyBMb2NhbGUgfSBmcm9tICcuLi90eXBlcyc7XG5cbmltcG9ydCBQcml2YWN5TmIgZnJvbSAnLi9wcml2YWN5X25iJztcbmltcG9ydCBQcml2YWN5Tm4gZnJvbSAnLi9wcml2YWN5X25uJztcbmltcG9ydCBQcml2YWN5RW4gZnJvbSAnLi9wcml2YWN5X2VuJztcblxudHlwZSBGb290ZXJQcml2YWN5UHJvcHMgPSB7XG4gIGxhYmVsOiBzdHJpbmc7XG4gIGxhbmc6IExvY2FsZTtcbn07XG5cbmNvbnN0IHByaXZhY3lUZXh0cyA9IChsYW5nOiBzdHJpbmcpID0+IHtcbiAgaWYgKGxhbmcgPT09ICdubicpIHtcbiAgICByZXR1cm4gPFByaXZhY3lObiAvPjtcbiAgfVxuICBpZiAobGFuZyA9PT0gJ2VuJykge1xuICAgIHJldHVybiA8UHJpdmFjeUVuIC8+O1xuICB9XG4gIHJldHVybiA8UHJpdmFjeU5iIC8+O1xufTtcblxuY29uc3QgU3R5bGVkUHJpdmFjeUJ1dHRvbiA9IHN0eWxlZC5idXR0b25gXG4gIGJhY2tncm91bmQ6IG5vbmU7XG4gIGNvbG9yOiAjZmZmO1xuICBib3JkZXI6IDA7XG4gIHBhZGRpbmc6IDA7XG4gIGJveC1zaGFkb3c6ICR7bWlzYy50ZXh0TGlua0JveFNoYWRvd307XG4gIGN1cnNvcjogcG9pbnRlcjtcbiAgbWFyZ2luLWJvdHRvbTogJHtzcGFjaW5nLmxhcmdlfTtcbiAgJjpob3ZlcixcbiAgJjpmb2N1cyB7XG4gICAgYm94LXNoYWRvdzogbm9uZTtcbiAgfVxuYDtcbmNvbnN0IFN0eWxlZEZvb3RlclRleHQgPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICA+IHNwYW4ge1xuICAgIHBhZGRpbmc6ICR7c3BhY2luZy54c21hbGx9IDA7XG4gICAgdGV4dC1hbGlnbjogY2VudGVyO1xuICB9XG4gICR7bXEucmFuZ2UoeyB1bnRpbDogYnJlYWtwb2ludHMudGFibGV0V2lkZSB9KX0ge1xuICAgICR7Zm9udHMuc2l6ZXMoMTYsIDEuNSl9O1xuICAgID4gc3BhbiB7XG4gICAgICBwYWRkaW5nOiAwO1xuICAgIH1cbiAgfVxuICAke21xLnJhbmdlKHsgdW50aWw6IGJyZWFrcG9pbnRzLm1vYmlsZVdpZGUgfSl9IHtcbiAgICAke2ZvbnRzLnNpemVzKDE0LCAxLjMpfTtcbiAgICA+IHNwYW4ge1xuICAgICAgcGFkZGluZy1ib3R0b206ICR7c3BhY2luZy54c21hbGx9O1xuICAgIH1cbiAgfVxuYDtcblxuY29uc3QgRm9vdGVyUHJpdmFjeSA9ICh7IGxhbmcsIGxhYmVsIH06IEZvb3RlclByaXZhY3lQcm9wcykgPT4gKFxuICA8U3R5bGVkRm9vdGVyVGV4dD5cbiAgICA8TW9kYWwgYWN0aXZhdGVCdXR0b249ezxTdHlsZWRQcml2YWN5QnV0dG9uIHR5cGU9XCJidXR0b25cIj57bGFiZWx9PC9TdHlsZWRQcml2YWN5QnV0dG9uPn0gc2l6ZT1cImZ1bGxzY3JlZW5cIj5cbiAgICAgIHsob25DbG9zZTogKCkgPT4gdm9pZCkgPT4gKFxuICAgICAgICA8T25lQ29sdW1uIGNzc01vZGlmaWVyPVwibWVkaXVtXCI+XG4gICAgICAgICAgPE1vZGFsSGVhZGVyPlxuICAgICAgICAgICAgPE1vZGFsQ2xvc2VCdXR0b24gb25DbGljaz17b25DbG9zZX0gdGl0bGU9XCJMdWtrXCIgLz5cbiAgICAgICAgICA8L01vZGFsSGVhZGVyPlxuICAgICAgICAgIDxNb2RhbEJvZHk+e3ByaXZhY3lUZXh0cyhsYW5nKX08L01vZGFsQm9keT5cbiAgICAgICAgPC9PbmVDb2x1bW4+XG4gICAgICApfVxuICAgIDwvTW9kYWw+XG4gIDwvU3R5bGVkRm9vdGVyVGV4dD5cbik7XG5cbmV4cG9ydCBkZWZhdWx0IEZvb3RlclByaXZhY3k7XG4iXX0= */"));
34
+ })("background:none;color:#fff;border:0;padding:0;box-shadow:", misc.textLinkBoxShadow, ";cursor:pointer;margin-bottom:", spacing.large, ";&:hover,&:focus{box-shadow:none;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZvb3RlclByaXZhY3kudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWtDeUMiLCJmaWxlIjoiRm9vdGVyUHJpdmFjeS50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxNi1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgTW9kYWwsIHsgTW9kYWxIZWFkZXIsIE1vZGFsQm9keSwgTW9kYWxDbG9zZUJ1dHRvbiB9IGZyb20gJ0BuZGxhL21vZGFsJztcbmltcG9ydCB7IHNwYWNpbmcsIGZvbnRzLCBtaXNjLCBtcSwgYnJlYWtwb2ludHMgfSBmcm9tICdAbmRsYS9jb3JlJztcbmltcG9ydCB7IE9uZUNvbHVtbiB9IGZyb20gJy4uL0xheW91dCc7XG5pbXBvcnQgeyBMb2NhbGUgfSBmcm9tICcuLi90eXBlcyc7XG5cbmltcG9ydCBQcml2YWN5TmIgZnJvbSAnLi9wcml2YWN5X25iJztcbmltcG9ydCBQcml2YWN5Tm4gZnJvbSAnLi9wcml2YWN5X25uJztcbmltcG9ydCBQcml2YWN5RW4gZnJvbSAnLi9wcml2YWN5X2VuJztcblxudHlwZSBGb290ZXJQcml2YWN5UHJvcHMgPSB7XG4gIGxhYmVsOiBzdHJpbmc7XG4gIGxhbmc6IExvY2FsZTtcbn07XG5cbmNvbnN0IHByaXZhY3lUZXh0cyA9IChsYW5nOiBzdHJpbmcpID0+IHtcbiAgaWYgKGxhbmcgPT09ICdubicpIHtcbiAgICByZXR1cm4gPFByaXZhY3lObiAvPjtcbiAgfVxuICBpZiAobGFuZyA9PT0gJ2VuJykge1xuICAgIHJldHVybiA8UHJpdmFjeUVuIC8+O1xuICB9XG4gIHJldHVybiA8UHJpdmFjeU5iIC8+O1xufTtcblxuY29uc3QgU3R5bGVkUHJpdmFjeUJ1dHRvbiA9IHN0eWxlZC5idXR0b25gXG4gIGJhY2tncm91bmQ6IG5vbmU7XG4gIGNvbG9yOiAjZmZmO1xuICBib3JkZXI6IDA7XG4gIHBhZGRpbmc6IDA7XG4gIGJveC1zaGFkb3c6ICR7bWlzYy50ZXh0TGlua0JveFNoYWRvd307XG4gIGN1cnNvcjogcG9pbnRlcjtcbiAgbWFyZ2luLWJvdHRvbTogJHtzcGFjaW5nLmxhcmdlfTtcbiAgJjpob3ZlcixcbiAgJjpmb2N1cyB7XG4gICAgYm94LXNoYWRvdzogbm9uZTtcbiAgfVxuYDtcbmNvbnN0IFN0eWxlZEZvb3RlclRleHQgPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICA+IHNwYW4ge1xuICAgIHBhZGRpbmc6ICR7c3BhY2luZy54c21hbGx9IDA7XG4gICAgdGV4dC1hbGlnbjogY2VudGVyO1xuICB9XG4gICR7bXEucmFuZ2UoeyB1bnRpbDogYnJlYWtwb2ludHMudGFibGV0V2lkZSB9KX0ge1xuICAgICR7Zm9udHMuc2l6ZXMoMTYsIDEuNSl9O1xuICAgID4gc3BhbiB7XG4gICAgICBwYWRkaW5nOiAwO1xuICAgIH1cbiAgfVxuICAke21xLnJhbmdlKHsgdW50aWw6IGJyZWFrcG9pbnRzLm1vYmlsZVdpZGUgfSl9IHtcbiAgICAke2ZvbnRzLnNpemVzKDE0LCAxLjMpfTtcbiAgICA+IHNwYW4ge1xuICAgICAgcGFkZGluZy1ib3R0b206ICR7c3BhY2luZy54c21hbGx9O1xuICAgIH1cbiAgfVxuYDtcblxuY29uc3QgRm9vdGVyUHJpdmFjeSA9ICh7IGxhbmcsIGxhYmVsIH06IEZvb3RlclByaXZhY3lQcm9wcykgPT4gKFxuICA8U3R5bGVkRm9vdGVyVGV4dD5cbiAgICA8TW9kYWxcbiAgICAgIGxhYmVsPXtsYWJlbH1cbiAgICAgIGFjdGl2YXRlQnV0dG9uPXs8U3R5bGVkUHJpdmFjeUJ1dHRvbiB0eXBlPVwiYnV0dG9uXCI+e2xhYmVsfTwvU3R5bGVkUHJpdmFjeUJ1dHRvbj59XG4gICAgICBzaXplPVwiZnVsbHNjcmVlblwiPlxuICAgICAgeyhvbkNsb3NlOiAoKSA9PiB2b2lkKSA9PiAoXG4gICAgICAgIDxPbmVDb2x1bW4gY3NzTW9kaWZpZXI9XCJtZWRpdW1cIj5cbiAgICAgICAgICA8TW9kYWxIZWFkZXI+XG4gICAgICAgICAgICA8TW9kYWxDbG9zZUJ1dHRvbiBvbkNsaWNrPXtvbkNsb3NlfSB0aXRsZT1cIkx1a2tcIiAvPlxuICAgICAgICAgIDwvTW9kYWxIZWFkZXI+XG4gICAgICAgICAgPE1vZGFsQm9keT57cHJpdmFjeVRleHRzKGxhbmcpfTwvTW9kYWxCb2R5PlxuICAgICAgICA8L09uZUNvbHVtbj5cbiAgICAgICl9XG4gICAgPC9Nb2RhbD5cbiAgPC9TdHlsZWRGb290ZXJUZXh0PlxuKTtcblxuZXhwb3J0IGRlZmF1bHQgRm9vdGVyUHJpdmFjeTtcbiJdfQ== */"));
35
35
 
36
36
  var StyledFooterText = _styled("div", {
37
37
  target: "e1yo4d831",
@@ -40,12 +40,13 @@ var StyledFooterText = _styled("div", {
40
40
  until: breakpoints.tabletWide
41
41
  }), "{", fonts.sizes(16, 1.5), ";> span{padding:0;}}", mq.range({
42
42
  until: breakpoints.mobileWide
43
- }), "{", fonts.sizes(14, 1.3), ";> span{padding-bottom:", spacing.xsmall, ";}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZvb3RlclByaXZhY3kudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQStDbUMiLCJmaWxlIjoiRm9vdGVyUHJpdmFjeS50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxNi1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgTW9kYWwsIHsgTW9kYWxIZWFkZXIsIE1vZGFsQm9keSwgTW9kYWxDbG9zZUJ1dHRvbiB9IGZyb20gJ0BuZGxhL21vZGFsJztcbmltcG9ydCB7IHNwYWNpbmcsIGZvbnRzLCBtaXNjLCBtcSwgYnJlYWtwb2ludHMgfSBmcm9tICdAbmRsYS9jb3JlJztcbmltcG9ydCB7IE9uZUNvbHVtbiB9IGZyb20gJy4uL0xheW91dCc7XG5pbXBvcnQgeyBMb2NhbGUgfSBmcm9tICcuLi90eXBlcyc7XG5cbmltcG9ydCBQcml2YWN5TmIgZnJvbSAnLi9wcml2YWN5X25iJztcbmltcG9ydCBQcml2YWN5Tm4gZnJvbSAnLi9wcml2YWN5X25uJztcbmltcG9ydCBQcml2YWN5RW4gZnJvbSAnLi9wcml2YWN5X2VuJztcblxudHlwZSBGb290ZXJQcml2YWN5UHJvcHMgPSB7XG4gIGxhYmVsOiBzdHJpbmc7XG4gIGxhbmc6IExvY2FsZTtcbn07XG5cbmNvbnN0IHByaXZhY3lUZXh0cyA9IChsYW5nOiBzdHJpbmcpID0+IHtcbiAgaWYgKGxhbmcgPT09ICdubicpIHtcbiAgICByZXR1cm4gPFByaXZhY3lObiAvPjtcbiAgfVxuICBpZiAobGFuZyA9PT0gJ2VuJykge1xuICAgIHJldHVybiA8UHJpdmFjeUVuIC8+O1xuICB9XG4gIHJldHVybiA8UHJpdmFjeU5iIC8+O1xufTtcblxuY29uc3QgU3R5bGVkUHJpdmFjeUJ1dHRvbiA9IHN0eWxlZC5idXR0b25gXG4gIGJhY2tncm91bmQ6IG5vbmU7XG4gIGNvbG9yOiAjZmZmO1xuICBib3JkZXI6IDA7XG4gIHBhZGRpbmc6IDA7XG4gIGJveC1zaGFkb3c6ICR7bWlzYy50ZXh0TGlua0JveFNoYWRvd307XG4gIGN1cnNvcjogcG9pbnRlcjtcbiAgbWFyZ2luLWJvdHRvbTogJHtzcGFjaW5nLmxhcmdlfTtcbiAgJjpob3ZlcixcbiAgJjpmb2N1cyB7XG4gICAgYm94LXNoYWRvdzogbm9uZTtcbiAgfVxuYDtcbmNvbnN0IFN0eWxlZEZvb3RlclRleHQgPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICA+IHNwYW4ge1xuICAgIHBhZGRpbmc6ICR7c3BhY2luZy54c21hbGx9IDA7XG4gICAgdGV4dC1hbGlnbjogY2VudGVyO1xuICB9XG4gICR7bXEucmFuZ2UoeyB1bnRpbDogYnJlYWtwb2ludHMudGFibGV0V2lkZSB9KX0ge1xuICAgICR7Zm9udHMuc2l6ZXMoMTYsIDEuNSl9O1xuICAgID4gc3BhbiB7XG4gICAgICBwYWRkaW5nOiAwO1xuICAgIH1cbiAgfVxuICAke21xLnJhbmdlKHsgdW50aWw6IGJyZWFrcG9pbnRzLm1vYmlsZVdpZGUgfSl9IHtcbiAgICAke2ZvbnRzLnNpemVzKDE0LCAxLjMpfTtcbiAgICA+IHNwYW4ge1xuICAgICAgcGFkZGluZy1ib3R0b206ICR7c3BhY2luZy54c21hbGx9O1xuICAgIH1cbiAgfVxuYDtcblxuY29uc3QgRm9vdGVyUHJpdmFjeSA9ICh7IGxhbmcsIGxhYmVsIH06IEZvb3RlclByaXZhY3lQcm9wcykgPT4gKFxuICA8U3R5bGVkRm9vdGVyVGV4dD5cbiAgICA8TW9kYWwgYWN0aXZhdGVCdXR0b249ezxTdHlsZWRQcml2YWN5QnV0dG9uIHR5cGU9XCJidXR0b25cIj57bGFiZWx9PC9TdHlsZWRQcml2YWN5QnV0dG9uPn0gc2l6ZT1cImZ1bGxzY3JlZW5cIj5cbiAgICAgIHsob25DbG9zZTogKCkgPT4gdm9pZCkgPT4gKFxuICAgICAgICA8T25lQ29sdW1uIGNzc01vZGlmaWVyPVwibWVkaXVtXCI+XG4gICAgICAgICAgPE1vZGFsSGVhZGVyPlxuICAgICAgICAgICAgPE1vZGFsQ2xvc2VCdXR0b24gb25DbGljaz17b25DbG9zZX0gdGl0bGU9XCJMdWtrXCIgLz5cbiAgICAgICAgICA8L01vZGFsSGVhZGVyPlxuICAgICAgICAgIDxNb2RhbEJvZHk+e3ByaXZhY3lUZXh0cyhsYW5nKX08L01vZGFsQm9keT5cbiAgICAgICAgPC9PbmVDb2x1bW4+XG4gICAgICApfVxuICAgIDwvTW9kYWw+XG4gIDwvU3R5bGVkRm9vdGVyVGV4dD5cbik7XG5cbmV4cG9ydCBkZWZhdWx0IEZvb3RlclByaXZhY3k7XG4iXX0= */"));
43
+ }), "{", fonts.sizes(14, 1.3), ";> span{padding-bottom:", spacing.xsmall, ";}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZvb3RlclByaXZhY3kudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQStDbUMiLCJmaWxlIjoiRm9vdGVyUHJpdmFjeS50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxNi1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgTW9kYWwsIHsgTW9kYWxIZWFkZXIsIE1vZGFsQm9keSwgTW9kYWxDbG9zZUJ1dHRvbiB9IGZyb20gJ0BuZGxhL21vZGFsJztcbmltcG9ydCB7IHNwYWNpbmcsIGZvbnRzLCBtaXNjLCBtcSwgYnJlYWtwb2ludHMgfSBmcm9tICdAbmRsYS9jb3JlJztcbmltcG9ydCB7IE9uZUNvbHVtbiB9IGZyb20gJy4uL0xheW91dCc7XG5pbXBvcnQgeyBMb2NhbGUgfSBmcm9tICcuLi90eXBlcyc7XG5cbmltcG9ydCBQcml2YWN5TmIgZnJvbSAnLi9wcml2YWN5X25iJztcbmltcG9ydCBQcml2YWN5Tm4gZnJvbSAnLi9wcml2YWN5X25uJztcbmltcG9ydCBQcml2YWN5RW4gZnJvbSAnLi9wcml2YWN5X2VuJztcblxudHlwZSBGb290ZXJQcml2YWN5UHJvcHMgPSB7XG4gIGxhYmVsOiBzdHJpbmc7XG4gIGxhbmc6IExvY2FsZTtcbn07XG5cbmNvbnN0IHByaXZhY3lUZXh0cyA9IChsYW5nOiBzdHJpbmcpID0+IHtcbiAgaWYgKGxhbmcgPT09ICdubicpIHtcbiAgICByZXR1cm4gPFByaXZhY3lObiAvPjtcbiAgfVxuICBpZiAobGFuZyA9PT0gJ2VuJykge1xuICAgIHJldHVybiA8UHJpdmFjeUVuIC8+O1xuICB9XG4gIHJldHVybiA8UHJpdmFjeU5iIC8+O1xufTtcblxuY29uc3QgU3R5bGVkUHJpdmFjeUJ1dHRvbiA9IHN0eWxlZC5idXR0b25gXG4gIGJhY2tncm91bmQ6IG5vbmU7XG4gIGNvbG9yOiAjZmZmO1xuICBib3JkZXI6IDA7XG4gIHBhZGRpbmc6IDA7XG4gIGJveC1zaGFkb3c6ICR7bWlzYy50ZXh0TGlua0JveFNoYWRvd307XG4gIGN1cnNvcjogcG9pbnRlcjtcbiAgbWFyZ2luLWJvdHRvbTogJHtzcGFjaW5nLmxhcmdlfTtcbiAgJjpob3ZlcixcbiAgJjpmb2N1cyB7XG4gICAgYm94LXNoYWRvdzogbm9uZTtcbiAgfVxuYDtcbmNvbnN0IFN0eWxlZEZvb3RlclRleHQgPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICA+IHNwYW4ge1xuICAgIHBhZGRpbmc6ICR7c3BhY2luZy54c21hbGx9IDA7XG4gICAgdGV4dC1hbGlnbjogY2VudGVyO1xuICB9XG4gICR7bXEucmFuZ2UoeyB1bnRpbDogYnJlYWtwb2ludHMudGFibGV0V2lkZSB9KX0ge1xuICAgICR7Zm9udHMuc2l6ZXMoMTYsIDEuNSl9O1xuICAgID4gc3BhbiB7XG4gICAgICBwYWRkaW5nOiAwO1xuICAgIH1cbiAgfVxuICAke21xLnJhbmdlKHsgdW50aWw6IGJyZWFrcG9pbnRzLm1vYmlsZVdpZGUgfSl9IHtcbiAgICAke2ZvbnRzLnNpemVzKDE0LCAxLjMpfTtcbiAgICA+IHNwYW4ge1xuICAgICAgcGFkZGluZy1ib3R0b206ICR7c3BhY2luZy54c21hbGx9O1xuICAgIH1cbiAgfVxuYDtcblxuY29uc3QgRm9vdGVyUHJpdmFjeSA9ICh7IGxhbmcsIGxhYmVsIH06IEZvb3RlclByaXZhY3lQcm9wcykgPT4gKFxuICA8U3R5bGVkRm9vdGVyVGV4dD5cbiAgICA8TW9kYWxcbiAgICAgIGxhYmVsPXtsYWJlbH1cbiAgICAgIGFjdGl2YXRlQnV0dG9uPXs8U3R5bGVkUHJpdmFjeUJ1dHRvbiB0eXBlPVwiYnV0dG9uXCI+e2xhYmVsfTwvU3R5bGVkUHJpdmFjeUJ1dHRvbj59XG4gICAgICBzaXplPVwiZnVsbHNjcmVlblwiPlxuICAgICAgeyhvbkNsb3NlOiAoKSA9PiB2b2lkKSA9PiAoXG4gICAgICAgIDxPbmVDb2x1bW4gY3NzTW9kaWZpZXI9XCJtZWRpdW1cIj5cbiAgICAgICAgICA8TW9kYWxIZWFkZXI+XG4gICAgICAgICAgICA8TW9kYWxDbG9zZUJ1dHRvbiBvbkNsaWNrPXtvbkNsb3NlfSB0aXRsZT1cIkx1a2tcIiAvPlxuICAgICAgICAgIDwvTW9kYWxIZWFkZXI+XG4gICAgICAgICAgPE1vZGFsQm9keT57cHJpdmFjeVRleHRzKGxhbmcpfTwvTW9kYWxCb2R5PlxuICAgICAgICA8L09uZUNvbHVtbj5cbiAgICAgICl9XG4gICAgPC9Nb2RhbD5cbiAgPC9TdHlsZWRGb290ZXJUZXh0PlxuKTtcblxuZXhwb3J0IGRlZmF1bHQgRm9vdGVyUHJpdmFjeTtcbiJdfQ== */"));
44
44
 
45
45
  var FooterPrivacy = function FooterPrivacy(_ref) {
46
46
  var lang = _ref.lang,
47
47
  label = _ref.label;
48
48
  return ___EmotionJSX(StyledFooterText, null, ___EmotionJSX(Modal, {
49
+ label: label,
49
50
  activateButton: ___EmotionJSX(StyledPrivacyButton, {
50
51
  type: "button"
51
52
  }, label),