@ndla/ui 50.7.2 → 50.8.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/Breadcrumb/BreadcrumbItem.js +7 -7
  2. package/es/CampaignBlock/CampaignBlock.js +7 -7
  3. package/es/CompetenceGoalTab/CompetenceItem.js +9 -9
  4. package/es/CompetenceGoalTab/styles.js +5 -5
  5. package/es/Embed/conceptComponents.js +9 -9
  6. package/es/FileList/FileList.js +7 -7
  7. package/es/Filter/FilterButtons.js +14 -14
  8. package/es/Frontpage/FrontpageAllSubjects.js +12 -12
  9. package/es/LearningPaths/LearningPathInformation.js +14 -5
  10. package/es/LearningPaths/LearningPathMenuContent.js +7 -7
  11. package/es/LinkBlock/LinkBlockSection.js +1 -1
  12. package/es/List/OrderedList.js +4 -1
  13. package/es/List/UnOrderedList.js +1 -1
  14. package/es/NDLAFilm/FilmMovieSearch.js +4 -4
  15. package/es/Navigation/NavigationBox.js +24 -30
  16. package/es/Programme/ProgrammeSubjects.js +1 -1
  17. package/es/Resource/resourceComponents.js +11 -11
  18. package/es/ResourceGroup/ResourceList.js +1 -1
  19. package/es/Search/ActiveFilters.js +6 -6
  20. package/es/Search/ContentTypeResultStyles.js +12 -12
  21. package/es/Search/SearchResult.js +12 -12
  22. package/es/SearchTypeResult/ActiveFilters.js +8 -8
  23. package/es/SearchTypeResult/PopupFilter.js +10 -10
  24. package/es/SearchTypeResult/SearchHeader.js +12 -12
  25. package/es/SearchTypeResult/SearchItem.js +12 -24
  26. package/es/SearchTypeResult/SearchItems.js +3 -3
  27. package/es/SearchTypeResult/components/ItemContexts.js +9 -9
  28. package/es/SnackBar/SnackbarProvider.js +6 -6
  29. package/es/Table/Table.js +6 -6
  30. package/es/TreeStructure/FolderItems.js +6 -6
  31. package/es/all.css +1 -1
  32. package/lib/Breadcrumb/BreadcrumbItem.js +7 -7
  33. package/lib/CampaignBlock/CampaignBlock.d.ts +3 -3
  34. package/lib/CampaignBlock/CampaignBlock.js +7 -7
  35. package/lib/CompetenceGoalTab/CompetenceItem.js +9 -9
  36. package/lib/CompetenceGoalTab/styles.js +5 -5
  37. package/lib/Embed/conceptComponents.js +9 -9
  38. package/lib/FileList/FileList.js +7 -7
  39. package/lib/Filter/FilterButtons.js +14 -14
  40. package/lib/Frontpage/FrontpageAllSubjects.js +12 -12
  41. package/lib/LearningPaths/LearningPathInformation.js +14 -7
  42. package/lib/LearningPaths/LearningPathMenuContent.js +7 -7
  43. package/lib/LinkBlock/LinkBlockSection.js +1 -1
  44. package/lib/List/OrderedList.d.ts +2 -0
  45. package/lib/List/OrderedList.js +5 -2
  46. package/lib/List/UnOrderedList.js +1 -1
  47. package/lib/NDLAFilm/FilmMovieSearch.js +4 -4
  48. package/lib/Navigation/NavigationBox.js +24 -30
  49. package/lib/Programme/ProgrammeSubjects.js +1 -1
  50. package/lib/Resource/resourceComponents.js +11 -11
  51. package/lib/ResourceGroup/ResourceList.js +1 -1
  52. package/lib/Search/ActiveFilters.js +6 -6
  53. package/lib/Search/ContentTypeResultStyles.js +12 -12
  54. package/lib/Search/SearchResult.js +12 -12
  55. package/lib/SearchTypeResult/ActiveFilters.js +8 -8
  56. package/lib/SearchTypeResult/PopupFilter.js +10 -10
  57. package/lib/SearchTypeResult/SearchHeader.js +12 -12
  58. package/lib/SearchTypeResult/SearchItem.js +12 -24
  59. package/lib/SearchTypeResult/SearchItems.js +3 -3
  60. package/lib/SearchTypeResult/components/ItemContexts.js +9 -9
  61. package/lib/SnackBar/SnackbarProvider.js +6 -6
  62. package/lib/Table/Table.js +6 -6
  63. package/lib/TreeStructure/FolderItems.js +6 -6
  64. package/lib/all.css +1 -1
  65. package/package.json +18 -18
  66. package/src/Breadcrumb/BreadcrumbItem.tsx +1 -2
  67. package/src/CampaignBlock/CampaignBlock.tsx +4 -4
  68. package/src/CompetenceGoalTab/CompetenceItem.tsx +0 -1
  69. package/src/CompetenceGoalTab/styles.ts +1 -0
  70. package/src/Embed/conceptComponents.tsx +0 -1
  71. package/src/FileList/FileList.tsx +0 -1
  72. package/src/Filter/FilterButtons.tsx +1 -2
  73. package/src/Frontpage/FrontpageAllSubjects.tsx +3 -3
  74. package/src/LearningPaths/LearningPathInformation.tsx +4 -5
  75. package/src/LearningPaths/LearningPathMenuContent.tsx +1 -2
  76. package/src/LinkBlock/LinkBlockSection.tsx +0 -2
  77. package/src/List/OrderedList.stories.tsx +27 -4
  78. package/src/List/OrderedList.tsx +71 -41
  79. package/src/List/UnOrderedList.tsx +4 -8
  80. package/src/List/UnorderedList.stories.tsx +23 -0
  81. package/src/NDLAFilm/FilmMovieSearch.tsx +2 -0
  82. package/src/Navigation/NavigationBox.tsx +6 -14
  83. package/src/Programme/ProgrammeSubjects.tsx +2 -0
  84. package/src/Resource/resourceComponents.tsx +1 -2
  85. package/src/ResourceGroup/ResourceList.tsx +0 -1
  86. package/src/Search/ActiveFilters.tsx +2 -2
  87. package/src/Search/ContentTypeResultStyles.tsx +0 -1
  88. package/src/Search/SearchResult.tsx +2 -3
  89. package/src/Search/component.search-result.scss +0 -1
  90. package/src/SearchTypeResult/ActiveFilters.tsx +3 -4
  91. package/src/SearchTypeResult/PopupFilter.tsx +1 -1
  92. package/src/SearchTypeResult/SearchHeader.tsx +1 -2
  93. package/src/SearchTypeResult/SearchItem.tsx +0 -4
  94. package/src/SearchTypeResult/SearchItems.tsx +1 -0
  95. package/src/SearchTypeResult/components/ItemContexts.tsx +0 -1
  96. package/src/SnackBar/SnackbarProvider.tsx +0 -1
  97. package/src/Table/Table.tsx +1 -1
  98. package/src/TreeStructure/FolderItems.tsx +0 -2
@@ -21,7 +21,7 @@ import { Fragment as _Fragment } from "@emotion/react/jsx-runtime";
21
21
  const StyledHeading = /*#__PURE__*/_styled("h3", {
22
22
  target: "e1yaxziw8",
23
23
  label: "StyledHeading"
24
- })(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":"AAiB+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 { useEffect, useState } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport { ModalHeader, ModalBody, ModalCloseButton, Modal, ModalTrigger, ModalContent } from '@ndla/modal';\nimport FilterCarousel from './FilterCarousel';\nimport ToggleItem from './ToggleItem';\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              <ButtonV2\n                size=\"normal\"\n                shape=\"pill\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}\n              >\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </ButtonV2>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal aria-label={t('searchPage.searchFilterMessages.resourceTypeFilter.button')}>\n            <StyledButtonElementWrapper>\n              <ModalTrigger>\n                <ButtonV2 colorTheme=\"light\" size=\"normal\" shape=\"pill\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </ButtonV2>\n              </ModalTrigger>\n            </StyledButtonElementWrapper>\n            <ModalContent size=\"full\" animation=\"subtle\">\n              <ModalHeader>\n                <h1>{heading}</h1>\n                <ModalCloseButton />\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            </ModalContent>\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                <ButtonV2\n                  size=\"normal\"\n                  colorTheme={!item.selected ? 'greyLighter' : undefined}\n                  shape=\"pill\"\n                  onClick={() => onFilterToggle(item.value)}\n                >\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </ButtonV2>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <ButtonV2 variant=\"link\" onClick={onRemoveAllFilters}>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </ButtonV2>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */"));
24
+ })(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":"AAiB+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 { useEffect, useState } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport { ModalHeader, ModalBody, ModalCloseButton, Modal, ModalTrigger, ModalContent } from '@ndla/modal';\nimport FilterCarousel from './FilterCarousel';\nimport ToggleItem from './ToggleItem';\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  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  padding-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              <ButtonV2\n                size=\"normal\"\n                shape=\"pill\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}\n              >\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </ButtonV2>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal aria-label={t('searchPage.searchFilterMessages.resourceTypeFilter.button')}>\n            <StyledButtonElementWrapper>\n              <ModalTrigger>\n                <ButtonV2 colorTheme=\"light\" size=\"normal\" shape=\"pill\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </ButtonV2>\n              </ModalTrigger>\n            </StyledButtonElementWrapper>\n            <ModalContent size=\"full\" animation=\"subtle\">\n              <ModalHeader>\n                <h1>{heading}</h1>\n                <ModalCloseButton />\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            </ModalContent>\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                <ButtonV2\n                  size=\"normal\"\n                  colorTheme={!item.selected ? 'greyLighter' : undefined}\n                  shape=\"pill\"\n                  onClick={() => onFilterToggle(item.value)}\n                >\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </ButtonV2>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <ButtonV2 variant=\"link\" onClick={onRemoveAllFilters}>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </ButtonV2>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */"));
25
25
  const StyledButtonsWrapper = /*#__PURE__*/_styled("div", {
26
26
  target: "e1yaxziw7",
27
27
  label: "StyledButtonsWrapper"
@@ -31,49 +31,49 @@ const StyledButtonsWrapper = /*#__PURE__*/_styled("div", {
31
31
  } : {
32
32
  name: "1uo5tpo",
33
33
  styles: "display:inline-flex;flex-wrap:wrap",
34
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilterButtons.tsx"],"names":[],"mappings":"AAwBuC","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 { useEffect, useState } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport { ModalHeader, ModalBody, ModalCloseButton, Modal, ModalTrigger, ModalContent } from '@ndla/modal';\nimport FilterCarousel from './FilterCarousel';\nimport ToggleItem from './ToggleItem';\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              <ButtonV2\n                size=\"normal\"\n                shape=\"pill\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}\n              >\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </ButtonV2>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal aria-label={t('searchPage.searchFilterMessages.resourceTypeFilter.button')}>\n            <StyledButtonElementWrapper>\n              <ModalTrigger>\n                <ButtonV2 colorTheme=\"light\" size=\"normal\" shape=\"pill\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </ButtonV2>\n              </ModalTrigger>\n            </StyledButtonElementWrapper>\n            <ModalContent size=\"full\" animation=\"subtle\">\n              <ModalHeader>\n                <h1>{heading}</h1>\n                <ModalCloseButton />\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            </ModalContent>\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                <ButtonV2\n                  size=\"normal\"\n                  colorTheme={!item.selected ? 'greyLighter' : undefined}\n                  shape=\"pill\"\n                  onClick={() => onFilterToggle(item.value)}\n                >\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </ButtonV2>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <ButtonV2 variant=\"link\" onClick={onRemoveAllFilters}>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </ButtonV2>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */",
34
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilterButtons.tsx"],"names":[],"mappings":"AAwBuC","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 { useEffect, useState } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport { ModalHeader, ModalBody, ModalCloseButton, Modal, ModalTrigger, ModalContent } from '@ndla/modal';\nimport FilterCarousel from './FilterCarousel';\nimport ToggleItem from './ToggleItem';\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  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  padding-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              <ButtonV2\n                size=\"normal\"\n                shape=\"pill\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}\n              >\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </ButtonV2>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal aria-label={t('searchPage.searchFilterMessages.resourceTypeFilter.button')}>\n            <StyledButtonElementWrapper>\n              <ModalTrigger>\n                <ButtonV2 colorTheme=\"light\" size=\"normal\" shape=\"pill\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </ButtonV2>\n              </ModalTrigger>\n            </StyledButtonElementWrapper>\n            <ModalContent size=\"full\" animation=\"subtle\">\n              <ModalHeader>\n                <h1>{heading}</h1>\n                <ModalCloseButton />\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            </ModalContent>\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                <ButtonV2\n                  size=\"normal\"\n                  colorTheme={!item.selected ? 'greyLighter' : undefined}\n                  shape=\"pill\"\n                  onClick={() => onFilterToggle(item.value)}\n                >\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </ButtonV2>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <ButtonV2 variant=\"link\" onClick={onRemoveAllFilters}>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </ButtonV2>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */",
35
35
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
36
36
  });
37
37
  const StyledButtonElementWrapper = /*#__PURE__*/_styled("div", {
38
38
  target: "e1yaxziw6",
39
39
  label: "StyledButtonElementWrapper"
40
- })("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":"AA6B6C","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 { useEffect, useState } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport { ModalHeader, ModalBody, ModalCloseButton, Modal, ModalTrigger, ModalContent } from '@ndla/modal';\nimport FilterCarousel from './FilterCarousel';\nimport ToggleItem from './ToggleItem';\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              <ButtonV2\n                size=\"normal\"\n                shape=\"pill\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}\n              >\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </ButtonV2>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal aria-label={t('searchPage.searchFilterMessages.resourceTypeFilter.button')}>\n            <StyledButtonElementWrapper>\n              <ModalTrigger>\n                <ButtonV2 colorTheme=\"light\" size=\"normal\" shape=\"pill\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </ButtonV2>\n              </ModalTrigger>\n            </StyledButtonElementWrapper>\n            <ModalContent size=\"full\" animation=\"subtle\">\n              <ModalHeader>\n                <h1>{heading}</h1>\n                <ModalCloseButton />\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            </ModalContent>\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                <ButtonV2\n                  size=\"normal\"\n                  colorTheme={!item.selected ? 'greyLighter' : undefined}\n                  shape=\"pill\"\n                  onClick={() => onFilterToggle(item.value)}\n                >\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </ButtonV2>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <ButtonV2 variant=\"link\" onClick={onRemoveAllFilters}>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </ButtonV2>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */"));
40
+ })("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":"AA6B6C","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 { useEffect, useState } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport { ModalHeader, ModalBody, ModalCloseButton, Modal, ModalTrigger, ModalContent } from '@ndla/modal';\nimport FilterCarousel from './FilterCarousel';\nimport ToggleItem from './ToggleItem';\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  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  padding-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              <ButtonV2\n                size=\"normal\"\n                shape=\"pill\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}\n              >\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </ButtonV2>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal aria-label={t('searchPage.searchFilterMessages.resourceTypeFilter.button')}>\n            <StyledButtonElementWrapper>\n              <ModalTrigger>\n                <ButtonV2 colorTheme=\"light\" size=\"normal\" shape=\"pill\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </ButtonV2>\n              </ModalTrigger>\n            </StyledButtonElementWrapper>\n            <ModalContent size=\"full\" animation=\"subtle\">\n              <ModalHeader>\n                <h1>{heading}</h1>\n                <ModalCloseButton />\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            </ModalContent>\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                <ButtonV2\n                  size=\"normal\"\n                  colorTheme={!item.selected ? 'greyLighter' : undefined}\n                  shape=\"pill\"\n                  onClick={() => onFilterToggle(item.value)}\n                >\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </ButtonV2>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <ButtonV2 variant=\"link\" onClick={onRemoveAllFilters}>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </ButtonV2>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */"));
41
41
  const StyledList = /*#__PURE__*/_styled("ul", {
42
42
  target: "e1yaxziw5",
43
43
  label: "StyledList"
44
- })("list-style:none;margin:0;padding:0;", mq.range({
44
+ })("list-style:none;padding:0;", mq.range({
45
45
  from: breakpoints.tablet
46
46
  }), "{column-count:2;column-gap:20px;}", mq.range({
47
47
  from: breakpoints.tabletWide
48
- }), "{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":"AAmC4B","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 { useEffect, useState } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport { ModalHeader, ModalBody, ModalCloseButton, Modal, ModalTrigger, ModalContent } from '@ndla/modal';\nimport FilterCarousel from './FilterCarousel';\nimport ToggleItem from './ToggleItem';\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              <ButtonV2\n                size=\"normal\"\n                shape=\"pill\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}\n              >\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </ButtonV2>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal aria-label={t('searchPage.searchFilterMessages.resourceTypeFilter.button')}>\n            <StyledButtonElementWrapper>\n              <ModalTrigger>\n                <ButtonV2 colorTheme=\"light\" size=\"normal\" shape=\"pill\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </ButtonV2>\n              </ModalTrigger>\n            </StyledButtonElementWrapper>\n            <ModalContent size=\"full\" animation=\"subtle\">\n              <ModalHeader>\n                <h1>{heading}</h1>\n                <ModalCloseButton />\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            </ModalContent>\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                <ButtonV2\n                  size=\"normal\"\n                  colorTheme={!item.selected ? 'greyLighter' : undefined}\n                  shape=\"pill\"\n                  onClick={() => onFilterToggle(item.value)}\n                >\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </ButtonV2>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <ButtonV2 variant=\"link\" onClick={onRemoveAllFilters}>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </ButtonV2>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */"));
48
+ }), "{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":"AAmC4B","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 { useEffect, useState } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport { ModalHeader, ModalBody, ModalCloseButton, Modal, ModalTrigger, ModalContent } from '@ndla/modal';\nimport FilterCarousel from './FilterCarousel';\nimport ToggleItem from './ToggleItem';\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  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  padding-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              <ButtonV2\n                size=\"normal\"\n                shape=\"pill\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}\n              >\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </ButtonV2>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal aria-label={t('searchPage.searchFilterMessages.resourceTypeFilter.button')}>\n            <StyledButtonElementWrapper>\n              <ModalTrigger>\n                <ButtonV2 colorTheme=\"light\" size=\"normal\" shape=\"pill\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </ButtonV2>\n              </ModalTrigger>\n            </StyledButtonElementWrapper>\n            <ModalContent size=\"full\" animation=\"subtle\">\n              <ModalHeader>\n                <h1>{heading}</h1>\n                <ModalCloseButton />\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            </ModalContent>\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                <ButtonV2\n                  size=\"normal\"\n                  colorTheme={!item.selected ? 'greyLighter' : undefined}\n                  shape=\"pill\"\n                  onClick={() => onFilterToggle(item.value)}\n                >\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </ButtonV2>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <ButtonV2 variant=\"link\" onClick={onRemoveAllFilters}>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </ButtonV2>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */"));
49
49
  const StyledListItem = /*#__PURE__*/_styled("li", {
50
50
  target: "e1yaxziw4",
51
51
  label: "StyledListItem"
52
52
  })(process.env.NODE_ENV === "production" ? {
53
- name: "19qqojn",
54
- styles: "margin-bottom:0;break-inside:avoid"
53
+ name: "1umvmcl",
54
+ styles: "padding-bottom:0;break-inside:avoid"
55
55
  } : {
56
- name: "19qqojn",
57
- styles: "margin-bottom:0;break-inside:avoid",
58
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilterButtons.tsx"],"names":[],"mappings":"AAgDgC","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 { useEffect, useState } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport { ModalHeader, ModalBody, ModalCloseButton, Modal, ModalTrigger, ModalContent } from '@ndla/modal';\nimport FilterCarousel from './FilterCarousel';\nimport ToggleItem from './ToggleItem';\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              <ButtonV2\n                size=\"normal\"\n                shape=\"pill\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}\n              >\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </ButtonV2>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal aria-label={t('searchPage.searchFilterMessages.resourceTypeFilter.button')}>\n            <StyledButtonElementWrapper>\n              <ModalTrigger>\n                <ButtonV2 colorTheme=\"light\" size=\"normal\" shape=\"pill\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </ButtonV2>\n              </ModalTrigger>\n            </StyledButtonElementWrapper>\n            <ModalContent size=\"full\" animation=\"subtle\">\n              <ModalHeader>\n                <h1>{heading}</h1>\n                <ModalCloseButton />\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            </ModalContent>\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                <ButtonV2\n                  size=\"normal\"\n                  colorTheme={!item.selected ? 'greyLighter' : undefined}\n                  shape=\"pill\"\n                  onClick={() => onFilterToggle(item.value)}\n                >\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </ButtonV2>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <ButtonV2 variant=\"link\" onClick={onRemoveAllFilters}>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </ButtonV2>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */",
56
+ name: "1umvmcl",
57
+ styles: "padding-bottom:0;break-inside:avoid",
58
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilterButtons.tsx"],"names":[],"mappings":"AA+CgC","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 { useEffect, useState } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport { ModalHeader, ModalBody, ModalCloseButton, Modal, ModalTrigger, ModalContent } from '@ndla/modal';\nimport FilterCarousel from './FilterCarousel';\nimport ToggleItem from './ToggleItem';\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  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  padding-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              <ButtonV2\n                size=\"normal\"\n                shape=\"pill\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}\n              >\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </ButtonV2>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal aria-label={t('searchPage.searchFilterMessages.resourceTypeFilter.button')}>\n            <StyledButtonElementWrapper>\n              <ModalTrigger>\n                <ButtonV2 colorTheme=\"light\" size=\"normal\" shape=\"pill\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </ButtonV2>\n              </ModalTrigger>\n            </StyledButtonElementWrapper>\n            <ModalContent size=\"full\" animation=\"subtle\">\n              <ModalHeader>\n                <h1>{heading}</h1>\n                <ModalCloseButton />\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            </ModalContent>\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                <ButtonV2\n                  size=\"normal\"\n                  colorTheme={!item.selected ? 'greyLighter' : undefined}\n                  shape=\"pill\"\n                  onClick={() => onFilterToggle(item.value)}\n                >\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </ButtonV2>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <ButtonV2 variant=\"link\" onClick={onRemoveAllFilters}>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </ButtonV2>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */",
59
59
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
60
60
  });
61
61
  const StyledButtonContent = /*#__PURE__*/_styled("span", {
62
62
  target: "e1yaxziw3",
63
63
  label: "StyledButtonContent"
64
- })(process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilterButtons.tsx"],"names":[],"mappings":"AAqDuC","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 { useEffect, useState } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport { ModalHeader, ModalBody, ModalCloseButton, Modal, ModalTrigger, ModalContent } from '@ndla/modal';\nimport FilterCarousel from './FilterCarousel';\nimport ToggleItem from './ToggleItem';\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              <ButtonV2\n                size=\"normal\"\n                shape=\"pill\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}\n              >\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </ButtonV2>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal aria-label={t('searchPage.searchFilterMessages.resourceTypeFilter.button')}>\n            <StyledButtonElementWrapper>\n              <ModalTrigger>\n                <ButtonV2 colorTheme=\"light\" size=\"normal\" shape=\"pill\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </ButtonV2>\n              </ModalTrigger>\n            </StyledButtonElementWrapper>\n            <ModalContent size=\"full\" animation=\"subtle\">\n              <ModalHeader>\n                <h1>{heading}</h1>\n                <ModalCloseButton />\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            </ModalContent>\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                <ButtonV2\n                  size=\"normal\"\n                  colorTheme={!item.selected ? 'greyLighter' : undefined}\n                  shape=\"pill\"\n                  onClick={() => onFilterToggle(item.value)}\n                >\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </ButtonV2>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <ButtonV2 variant=\"link\" onClick={onRemoveAllFilters}>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </ButtonV2>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */");
64
+ })(process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilterButtons.tsx"],"names":[],"mappings":"AAoDuC","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 { useEffect, useState } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport { ModalHeader, ModalBody, ModalCloseButton, Modal, ModalTrigger, ModalContent } from '@ndla/modal';\nimport FilterCarousel from './FilterCarousel';\nimport ToggleItem from './ToggleItem';\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  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  padding-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              <ButtonV2\n                size=\"normal\"\n                shape=\"pill\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}\n              >\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </ButtonV2>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal aria-label={t('searchPage.searchFilterMessages.resourceTypeFilter.button')}>\n            <StyledButtonElementWrapper>\n              <ModalTrigger>\n                <ButtonV2 colorTheme=\"light\" size=\"normal\" shape=\"pill\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </ButtonV2>\n              </ModalTrigger>\n            </StyledButtonElementWrapper>\n            <ModalContent size=\"full\" animation=\"subtle\">\n              <ModalHeader>\n                <h1>{heading}</h1>\n                <ModalCloseButton />\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            </ModalContent>\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                <ButtonV2\n                  size=\"normal\"\n                  colorTheme={!item.selected ? 'greyLighter' : undefined}\n                  shape=\"pill\"\n                  onClick={() => onFilterToggle(item.value)}\n                >\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </ButtonV2>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <ButtonV2 variant=\"link\" onClick={onRemoveAllFilters}>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </ButtonV2>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */");
65
65
  const StyledButtonContentSelected = /*#__PURE__*/_styled("span", {
66
66
  target: "e1yaxziw2",
67
67
  label: "StyledButtonContentSelected"
68
- })("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":"AAuD+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 { useEffect, useState } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport { ModalHeader, ModalBody, ModalCloseButton, Modal, ModalTrigger, ModalContent } from '@ndla/modal';\nimport FilterCarousel from './FilterCarousel';\nimport ToggleItem from './ToggleItem';\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              <ButtonV2\n                size=\"normal\"\n                shape=\"pill\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}\n              >\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </ButtonV2>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal aria-label={t('searchPage.searchFilterMessages.resourceTypeFilter.button')}>\n            <StyledButtonElementWrapper>\n              <ModalTrigger>\n                <ButtonV2 colorTheme=\"light\" size=\"normal\" shape=\"pill\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </ButtonV2>\n              </ModalTrigger>\n            </StyledButtonElementWrapper>\n            <ModalContent size=\"full\" animation=\"subtle\">\n              <ModalHeader>\n                <h1>{heading}</h1>\n                <ModalCloseButton />\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            </ModalContent>\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                <ButtonV2\n                  size=\"normal\"\n                  colorTheme={!item.selected ? 'greyLighter' : undefined}\n                  shape=\"pill\"\n                  onClick={() => onFilterToggle(item.value)}\n                >\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </ButtonV2>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <ButtonV2 variant=\"link\" onClick={onRemoveAllFilters}>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </ButtonV2>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */"));
68
+ })("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":"AAsD+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 { useEffect, useState } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport { ModalHeader, ModalBody, ModalCloseButton, Modal, ModalTrigger, ModalContent } from '@ndla/modal';\nimport FilterCarousel from './FilterCarousel';\nimport ToggleItem from './ToggleItem';\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  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  padding-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              <ButtonV2\n                size=\"normal\"\n                shape=\"pill\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}\n              >\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </ButtonV2>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal aria-label={t('searchPage.searchFilterMessages.resourceTypeFilter.button')}>\n            <StyledButtonElementWrapper>\n              <ModalTrigger>\n                <ButtonV2 colorTheme=\"light\" size=\"normal\" shape=\"pill\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </ButtonV2>\n              </ModalTrigger>\n            </StyledButtonElementWrapper>\n            <ModalContent size=\"full\" animation=\"subtle\">\n              <ModalHeader>\n                <h1>{heading}</h1>\n                <ModalCloseButton />\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            </ModalContent>\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                <ButtonV2\n                  size=\"normal\"\n                  colorTheme={!item.selected ? 'greyLighter' : undefined}\n                  shape=\"pill\"\n                  onClick={() => onFilterToggle(item.value)}\n                >\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </ButtonV2>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <ButtonV2 variant=\"link\" onClick={onRemoveAllFilters}>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </ButtonV2>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */"));
69
69
  const StyledRemoveWrapper = /*#__PURE__*/_styled("div", {
70
70
  target: "e1yaxziw1",
71
71
  label: "StyledRemoveWrapper"
72
- })("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":"AA6DsC","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 { useEffect, useState } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport { ModalHeader, ModalBody, ModalCloseButton, Modal, ModalTrigger, ModalContent } from '@ndla/modal';\nimport FilterCarousel from './FilterCarousel';\nimport ToggleItem from './ToggleItem';\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              <ButtonV2\n                size=\"normal\"\n                shape=\"pill\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}\n              >\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </ButtonV2>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal aria-label={t('searchPage.searchFilterMessages.resourceTypeFilter.button')}>\n            <StyledButtonElementWrapper>\n              <ModalTrigger>\n                <ButtonV2 colorTheme=\"light\" size=\"normal\" shape=\"pill\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </ButtonV2>\n              </ModalTrigger>\n            </StyledButtonElementWrapper>\n            <ModalContent size=\"full\" animation=\"subtle\">\n              <ModalHeader>\n                <h1>{heading}</h1>\n                <ModalCloseButton />\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            </ModalContent>\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                <ButtonV2\n                  size=\"normal\"\n                  colorTheme={!item.selected ? 'greyLighter' : undefined}\n                  shape=\"pill\"\n                  onClick={() => onFilterToggle(item.value)}\n                >\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </ButtonV2>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <ButtonV2 variant=\"link\" onClick={onRemoveAllFilters}>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </ButtonV2>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */"));
72
+ })("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":"AA4DsC","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 { useEffect, useState } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport { ModalHeader, ModalBody, ModalCloseButton, Modal, ModalTrigger, ModalContent } from '@ndla/modal';\nimport FilterCarousel from './FilterCarousel';\nimport ToggleItem from './ToggleItem';\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  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  padding-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              <ButtonV2\n                size=\"normal\"\n                shape=\"pill\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}\n              >\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </ButtonV2>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal aria-label={t('searchPage.searchFilterMessages.resourceTypeFilter.button')}>\n            <StyledButtonElementWrapper>\n              <ModalTrigger>\n                <ButtonV2 colorTheme=\"light\" size=\"normal\" shape=\"pill\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </ButtonV2>\n              </ModalTrigger>\n            </StyledButtonElementWrapper>\n            <ModalContent size=\"full\" animation=\"subtle\">\n              <ModalHeader>\n                <h1>{heading}</h1>\n                <ModalCloseButton />\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            </ModalContent>\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                <ButtonV2\n                  size=\"normal\"\n                  colorTheme={!item.selected ? 'greyLighter' : undefined}\n                  shape=\"pill\"\n                  onClick={() => onFilterToggle(item.value)}\n                >\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </ButtonV2>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <ButtonV2 variant=\"link\" onClick={onRemoveAllFilters}>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </ButtonV2>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */"));
73
73
  const ButtonRemoveText = /*#__PURE__*/_styled("span", {
74
74
  target: "e1yaxziw0",
75
75
  label: "ButtonRemoveText"
76
- })(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":"AAkEoC","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 { useEffect, useState } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport { ModalHeader, ModalBody, ModalCloseButton, Modal, ModalTrigger, ModalContent } from '@ndla/modal';\nimport FilterCarousel from './FilterCarousel';\nimport ToggleItem from './ToggleItem';\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              <ButtonV2\n                size=\"normal\"\n                shape=\"pill\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}\n              >\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </ButtonV2>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal aria-label={t('searchPage.searchFilterMessages.resourceTypeFilter.button')}>\n            <StyledButtonElementWrapper>\n              <ModalTrigger>\n                <ButtonV2 colorTheme=\"light\" size=\"normal\" shape=\"pill\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </ButtonV2>\n              </ModalTrigger>\n            </StyledButtonElementWrapper>\n            <ModalContent size=\"full\" animation=\"subtle\">\n              <ModalHeader>\n                <h1>{heading}</h1>\n                <ModalCloseButton />\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            </ModalContent>\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                <ButtonV2\n                  size=\"normal\"\n                  colorTheme={!item.selected ? 'greyLighter' : undefined}\n                  shape=\"pill\"\n                  onClick={() => onFilterToggle(item.value)}\n                >\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </ButtonV2>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <ButtonV2 variant=\"link\" onClick={onRemoveAllFilters}>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </ButtonV2>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */"));
76
+ })(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":"AAiEoC","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 { useEffect, useState } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport { ModalHeader, ModalBody, ModalCloseButton, Modal, ModalTrigger, ModalContent } from '@ndla/modal';\nimport FilterCarousel from './FilterCarousel';\nimport ToggleItem from './ToggleItem';\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  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  padding-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              <ButtonV2\n                size=\"normal\"\n                shape=\"pill\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}\n              >\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </ButtonV2>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal aria-label={t('searchPage.searchFilterMessages.resourceTypeFilter.button')}>\n            <StyledButtonElementWrapper>\n              <ModalTrigger>\n                <ButtonV2 colorTheme=\"light\" size=\"normal\" shape=\"pill\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </ButtonV2>\n              </ModalTrigger>\n            </StyledButtonElementWrapper>\n            <ModalContent size=\"full\" animation=\"subtle\">\n              <ModalHeader>\n                <h1>{heading}</h1>\n                <ModalCloseButton />\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            </ModalContent>\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                <ButtonV2\n                  size=\"normal\"\n                  colorTheme={!item.selected ? 'greyLighter' : undefined}\n                  shape=\"pill\"\n                  onClick={() => onFilterToggle(item.value)}\n                >\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </ButtonV2>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <ButtonV2 variant=\"link\" onClick={onRemoveAllFilters}>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </ButtonV2>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */"));
77
77
  export const FilterButtons = _ref => {
78
78
  let {
79
79
  heading,