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