@ndla/ui 3.2.5 → 3.3.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/README.md +1 -1
- package/es/Article/ArticleByline.js +4 -4
- package/es/Article/ArticleNotions.js +5 -5
- package/es/CopyParagraphButton/CopyParagraphButton.js +23 -7
- package/es/CopyParagraphButton/initCopyParagraphButtons.js +2 -2
- package/es/Figure/FigureBylineExpandButton.js +1 -2
- package/es/Filter/FilterButtons.js +9 -9
- package/es/Footer/FooterPrivacy.js +2 -2
- package/es/Table/Table.js +0 -9
- package/es/User/AuthModal.js +8 -8
- package/es/index-javascript.js +0 -1
- package/es/index.js +1 -0
- package/es/locale/messages-en.js +2 -2
- package/es/locale/messages-nb.js +2 -2
- package/es/locale/messages-nn.js +2 -2
- package/lib/Article/ArticleByline.js +4 -4
- package/lib/Article/ArticleNotions.js +5 -5
- package/lib/CopyParagraphButton/CopyParagraphButton.d.ts +2 -1
- package/lib/CopyParagraphButton/CopyParagraphButton.js +23 -7
- package/lib/CopyParagraphButton/initCopyParagraphButtons.js +2 -2
- package/lib/Figure/Figure.d.ts +4 -3
- package/lib/Figure/FigureBylineExpandButton.d.ts +1 -2
- package/lib/Figure/FigureBylineExpandButton.js +1 -2
- package/lib/Figure/index.d.ts +1 -0
- package/lib/Filter/FilterButtons.js +9 -9
- package/lib/Footer/FooterPrivacy.js +2 -2
- package/lib/Masthead/MastheadSearchModal.d.ts +1 -1
- package/lib/MessageBox/MessageBox.d.ts +1 -1
- package/lib/Table/Table.d.ts +14 -0
- package/lib/Table/Table.js +0 -10
- package/lib/Table/index.d.ts +9 -0
- package/lib/User/AuthModal.d.ts +2 -2
- package/lib/User/AuthModal.js +8 -8
- package/lib/index-javascript.js +3 -11
- package/lib/index.d.ts +1 -0
- package/lib/index.js +9 -0
- package/lib/locale/messages-en.js +2 -2
- package/lib/locale/messages-nb.js +2 -2
- package/lib/locale/messages-nn.js +2 -2
- package/package.json +4 -4
- package/src/Article/ArticleByline.tsx +1 -1
- package/src/Article/ArticleNotions.tsx +1 -1
- package/src/CopyParagraphButton/CopyParagraphButton.tsx +23 -4
- package/src/CopyParagraphButton/initCopyParagraphButtons.tsx +1 -2
- package/src/Figure/Figure.tsx +13 -3
- package/src/Figure/FigureBylineExpandButton.tsx +1 -2
- package/src/Figure/index.ts +2 -0
- package/src/Filter/FilterButtons.tsx +1 -1
- package/src/Footer/FooterPrivacy.tsx +1 -1
- package/src/Table/{Table.jsx → Table.tsx} +14 -12
- package/src/Table/{index.js → index.ts} +0 -0
- package/src/User/AuthModal.tsx +3 -3
- package/src/index-javascript.js +0 -1
- package/src/index.ts +2 -0
- package/src/locale/messages-en.ts +2 -2
- package/src/locale/messages-nb.ts +2 -2
- package/src/locale/messages-nn.ts +2 -2
|
@@ -37,7 +37,7 @@ import { jsx as ___EmotionJSX } from "@emotion/core";
|
|
|
37
37
|
var StyledHeading = _styled("h3", {
|
|
38
38
|
target: "e1yaxziw0",
|
|
39
39
|
label: "StyledHeading"
|
|
40
|
-
})(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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZpbHRlckJ1dHRvbnMudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXNCK0IiLCJmaWxlIjoiRmlsdGVyQnV0dG9ucy50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMS1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCwgeyB1c2VFZmZlY3QsIHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuLy8gQHRzLWlnbm9yZVxuaW1wb3J0IEJ1dHRvbiBmcm9tICdAbmRsYS9idXR0b24nO1xuaW1wb3J0IHsgYnJlYWtwb2ludHMsIGNvbG9ycywgZm9udHMsIG1xLCBzcGFjaW5nIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgeyB1c2VUcmFuc2xhdGlvbiB9IGZyb20gJ3JlYWN0LWkxOG5leHQnO1xuLy8gQHRzLWlnbm9yZVxuaW1wb3J0IHsgQ3Jvc3MgYXMgQ3Jvc3NJY29uLCBQbHVzIGFzIFBsdXNJY29uIH0gZnJvbSAnQG5kbGEvaWNvbnMvYWN0aW9uJztcbi8vIEB0cy1pZ25vcmVcbmltcG9ydCBNb2RhbCwgeyBNb2RhbEhlYWRlciwgTW9kYWxCb2R5LCBNb2RhbENsb3NlQnV0dG9uIH0gZnJvbSAnQG5kbGEvbW9kYWwnO1xuXG4vLyBAdHMtaWdub3JlXG5pbXBvcnQgVG9nZ2xlSXRlbSBmcm9tICcuL1RvZ2dsZUl0ZW0nO1xuXG5jb25zdCBTdHlsZWRIZWFkaW5nID0gc3R5bGVkLmgzYFxuICAke2ZvbnRzLnNpemVzKCcxNnB4JywgJzMycHgnKX07XG4gIG1hcmdpbjogMCAwICR7c3BhY2luZy5zbWFsbH07XG4gIGNvbG9yOiAke2NvbG9ycy50ZXh0LmxpZ2h0fTtcbiAgZm9udC13ZWlnaHQ6ICR7Zm9udHMud2VpZ2h0LnNlbWlib2xkfTtcbmA7XG5cbmNvbnN0IFN0eWxlZEJ1dHRvbnNXcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC13cmFwOiB3cmFwO1xuYDtcblxuY29uc3QgU3R5bGVkQnV0dG9uRWxlbWVudFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICBtYXJnaW46IDAgJHtzcGFjaW5nLnhzbWFsbH0gJHtzcGFjaW5nLnhzbWFsbH0gMDtcbiAgYnJlYWstaW5zaWRlOiBhdm9pZDtcbmA7XG5cbmNvbnN0IFN0eWxlZExpc3QgPSBzdHlsZWQudWxgXG4gIGxpc3Qtc3R5bGU6IG5vbmU7XG4gIG1hcmdpbjogMDtcbiAgcGFkZGluZzogMDtcbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLnRhYmxldCB9KX0ge1xuICAgIGNvbHVtbi1jb3VudDogMjtcbiAgICBjb2x1bW4tZ2FwOiAyMHB4O1xuICB9XG4gICR7bXEucmFuZ2UoeyBmcm9tOiBicmVha3BvaW50cy50YWJsZXRXaWRlIH0pfSB7XG4gICAgY29sdW1uLWNvdW50OiAzO1xuICAgIGNvbHVtbi1nYXA6IDIwcHg7XG4gIH1cbmA7XG5jb25zdCBTdHlsZWRMaXN0SXRlbSA9IHN0eWxlZC5saWBcbiAgbWFyZ2luLWJvdHRvbTogMDtcbiAgYnJlYWstaW5zaWRlOiBhdm9pZDtcbmA7XG5cbmNvbnN0IFN0eWxlZEJ1dHRvbkNvbnRlbnQgPSBzdHlsZWQuc3BhbmBgO1xuXG5jb25zdCBTdHlsZWRCdXR0b25Db250ZW50U2VsZWN0ZWQgPSBzdHlsZWQuc3BhbmBcbiAgbWFyZ2luLWxlZnQ6ICR7c3BhY2luZy5zbWFsbH07XG4gIGRpc3BsYXk6IGlubGluZS1mbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuYDtcblxuY29uc3QgU3R5bGVkUmVtb3ZlV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIG1hcmdpbi10b3A6ICR7c3BhY2luZy54c21hbGx9O1xuYDtcblxuY29uc3QgQnV0dG9uUmVtb3ZlVGV4dCA9IHN0eWxlZC5zcGFuYFxuICAke2ZvbnRzLnNpemVzKCcxNnB4JywgJzMycHgnKX07XG4gIGZvbnQtd2VpZ2h0OiAke2ZvbnRzLndlaWdodC5zZW1pYm9sZH07XG5gO1xuXG5leHBvcnQgdHlwZSBJdGVtUHJvcHMgPSB7XG4gIGxhYmVsOiBzdHJpbmc7XG4gIHZhbHVlOiBzdHJpbmc7XG4gIHNlbGVjdGVkPzogYm9vbGVhbjtcbn07XG50eXBlIFByb3BzID0ge1xuICBoZWFkaW5nOiBzdHJpbmc7XG4gIGl0ZW1zOiBJdGVtUHJvcHNbXTtcbiAgb25GaWx0ZXJUb2dnbGU6ICh2YWx1ZTogc3RyaW5nKSA9PiB2b2lkO1xuICBvblJlbW92ZUFsbEZpbHRlcnM6ICgpID0+IHZvaWQ7XG4gIGxhYmVsczoge1xuICAgIG9wZW5GaWx0ZXI6IHN0cmluZztcbiAgfTtcbn07XG5cbmV4cG9ydCBjb25zdCBGaWx0ZXJCdXR0b25zID0gKHsgaGVhZGluZywgaXRlbXMsIG9uRmlsdGVyVG9nZ2xlLCBvblJlbW92ZUFsbEZpbHRlcnMsIGxhYmVscyB9OiBQcm9wcykgPT4ge1xuICBjb25zdCB7IHQgfSA9IHVzZVRyYW5zbGF0aW9uKCk7XG4gIGNvbnN0IFtpc05hcnJvd1NjcmVlbiwgc2V0SXNOYXJyb3dTY3JlZW5dID0gdXNlU3RhdGUoZmFsc2UpO1xuXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgY29uc3QgaXNOYXJyb3dTY3JlZW5NYXRjaCA9IHdpbmRvdy5tYXRjaE1lZGlhKCcobWF4LXdpZHRoOiA3NjdweCknKTtcbiAgICBjb25zdCBoYW5kbGVDaGFuZ2UgPSAoZTogTWVkaWFRdWVyeUxpc3RFdmVudCB8IE1lZGlhUXVlcnlMaXN0KSA9PiB7XG4gICAgICBzZXRJc05hcnJvd1NjcmVlbihlLm1hdGNoZXMpO1xuICAgIH07XG4gICAgaXNOYXJyb3dTY3JlZW5NYXRjaC5hZGRFdmVudExpc3RlbmVyKCdjaGFuZ2UnLCBoYW5kbGVDaGFuZ2UpO1xuICAgIGhhbmRsZUNoYW5nZShpc05hcnJvd1NjcmVlbk1hdGNoKTtcbiAgICByZXR1cm4gKCkgPT4ge1xuICAgICAgaXNOYXJyb3dTY3JlZW5NYXRjaC5yZW1vdmVFdmVudExpc3RlbmVyKCdjaGFuZ2UnLCBoYW5kbGVDaGFuZ2UpO1xuICAgIH07XG4gIH0sIFtdKTtcblxuICBjb25zdCBoYXNTZWxlY3RlZEZpbHRlcnMgPSBpdGVtcy5zb21lKChpdGVtKSA9PiB7XG4gICAgcmV0dXJuIGl0ZW0uc2VsZWN0ZWQ7XG4gIH0pO1xuXG4gIGNvbnN0IGFjdGl2ZUl0ZW1zID0gaXRlbXMuZmlsdGVyKChpdGVtKSA9PiBpdGVtLnNlbGVjdGVkKTtcblxuICByZXR1cm4gKFxuICAgIDw+XG4gICAgICB7aXNOYXJyb3dTY3JlZW4gJiYgKFxuICAgICAgICA8U3R5bGVkQnV0dG9uc1dyYXBwZXI+XG4gICAgICAgICAge2FjdGl2ZUl0ZW1zLm1hcCgoaXRlbTogSXRlbVByb3BzKSA9PiAoXG4gICAgICAgICAgICA8U3R5bGVkQnV0dG9uRWxlbWVudFdyYXBwZXIga2V5PXtpdGVtLnZhbHVlfT5cbiAgICAgICAgICAgICAgPEJ1dHRvblxuICAgICAgICAgICAgICAgIHR5cGU9XCJidXR0b25cIlxuICAgICAgICAgICAgICAgIHNpemU9XCJub3JtYWxcIlxuICAgICAgICAgICAgICAgIGJvcmRlclNoYXBlPVwicm91bmRlZFwiXG4gICAgICAgICAgICAgICAgb25DbGljaz17KCkgPT4ge1xuICAgICAgICAgICAgICAgICAgb25GaWx0ZXJUb2dnbGUoaXRlbS52YWx1ZSk7XG4gICAgICAgICAgICAgICAgfX0+XG4gICAgICAgICAgICAgICAgPFN0eWxlZEJ1dHRvbkNvbnRlbnQ+e2l0ZW0ubGFiZWx9PC9TdHlsZWRCdXR0b25Db250ZW50PlxuICAgICAgICAgICAgICAgIDxTdHlsZWRCdXR0b25Db250ZW50U2VsZWN0ZWQ+XG4gICAgICAgICAgICAgICAgICA8Q3Jvc3NJY29uIC8+XG4gICAgICAgICAgICAgICAgPC9TdHlsZWRCdXR0b25Db250ZW50U2VsZWN0ZWQ+XG4gICAgICAgICAgICAgIDwvQnV0dG9uPlxuICAgICAgICAgICAgPC9TdHlsZWRCdXR0b25FbGVtZW50V3JhcHBlcj5cbiAgICAgICAgICApKX1cbiAgICAgICAgICA8TW9kYWxcbiAgICAgICAgICAgIHNpemU9XCJmdWxsc2NyZWVuXCJcbiAgICAgICAgICAgIGFuaW1hdGlvbj1cInN1YnRsZVwiXG4gICAgICAgICAgICBiYWNrZ3JvdW5kQ29sb3I9XCJ3aGl0ZVwiXG4gICAgICAgICAgICBhY3RpdmF0ZUJ1dHRvbj17XG4gICAgICAgICAgICAgIDxTdHlsZWRCdXR0b25FbGVtZW50V3JhcHBlcj5cbiAgICAgICAgICAgICAgICA8QnV0dG9uIHR5cGU9XCJidXR0b25cIiBzaXplPVwibm9ybWFsXCIgbGlnaHQgYm9yZGVyU2hhcGU9XCJyb3VuZGVkXCI+XG4gICAgICAgICAgICAgICAgICA8U3R5bGVkQnV0dG9uQ29udGVudD57bGFiZWxzLm9wZW5GaWx0ZXJ9PC9TdHlsZWRCdXR0b25Db250ZW50PlxuICAgICAgICAgICAgICAgICAgPFN0eWxlZEJ1dHRvbkNvbnRlbnRTZWxlY3RlZD5cbiAgICAgICAgICAgICAgICAgICAgPFBsdXNJY29uIC8+XG4gICAgICAgICAgICAgICAgICA8L1N0eWxlZEJ1dHRvbkNvbnRlbnRTZWxlY3RlZD5cbiAgICAgICAgICAgICAgICA8L0J1dHRvbj5cbiAgICAgICAgICAgICAgPC9TdHlsZWRCdXR0b25FbGVtZW50V3JhcHBlcj5cbiAgICAgICAgICAgIH0+
|
|
40
|
+
})(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":"AAsB+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 */\n\nimport React, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\n// @ts-ignore\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\n// @ts-ignore\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\n// @ts-ignore\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\n\n// @ts-ignore\nimport ToggleItem from './ToggleItem';\n\nconst StyledHeading = styled.h3`\n  ${fonts.sizes('16px', '32px')};\n  margin: 0 0 ${spacing.small};\n  color: ${colors.text.light};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledButtonsWrapper = styled.div`\n  display: flex;\n  flex-wrap: wrap;\n`;\n\nconst StyledButtonElementWrapper = styled.div`\n  margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n  break-inside: avoid;\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`;\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};\ntype Props = {\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 }: Props) => {\n  const { t } = useTranslation();\n  const [isNarrowScreen, setIsNarrowScreen] = useState(false);\n\n  useEffect(() => {\n    const isNarrowScreenMatch = window.matchMedia('(max-width: 767px)');\n    const handleChange = (e: MediaQueryListEvent | MediaQueryList) => {\n      setIsNarrowScreen(e.matches);\n    };\n    isNarrowScreenMatch.addEventListener('change', handleChange);\n    handleChange(isNarrowScreenMatch);\n    return () => {\n      isNarrowScreenMatch.removeEventListener('change', handleChange);\n    };\n  }, []);\n\n  const hasSelectedFilters = items.some((item) => {\n    return item.selected;\n  });\n\n  const activeItems = items.filter((item) => item.selected);\n\n  return (\n    <>\n      {isNarrowScreen && (\n        <StyledButtonsWrapper>\n          {activeItems.map((item: ItemProps) => (\n            <StyledButtonElementWrapper key={item.value}>\n              <Button\n                type=\"button\"\n                size=\"normal\"\n                borderShape=\"rounded\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}>\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </Button>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal\n            size=\"fullscreen\"\n            animation=\"subtle\"\n            backgroundColor=\"white\"\n            activateButton={\n              <StyledButtonElementWrapper>\n                <Button type=\"button\" size=\"normal\" light borderShape=\"rounded\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </Button>\n              </StyledButtonElementWrapper>\n            }>\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier={['left-align']}>\n                  <h1>{heading}</h1>\n                  <ModalCloseButton title={t('modal.closeModal')} onClick={onClose} />\n                </ModalHeader>\n                <ModalBody modifier=\"slide-in-left\">\n                  <StyledList>\n                    {items.map((item: ItemProps) => (\n                      <StyledListItem key={item.value}>\n                        <ToggleItem\n                          id={item.value}\n                          value={item.value}\n                          checked={item.selected}\n                          label={item.label}\n                          component=\"div\"\n                          onChange={() => {\n                            onFilterToggle(item.value);\n                          }}\n                        />\n                      </StyledListItem>\n                    ))}\n                  </StyledList>\n                </ModalBody>\n              </>\n            )}\n          </Modal>\n        </StyledButtonsWrapper>\n      )}\n      {!isNarrowScreen && (\n        <>\n          <StyledHeading>{heading}</StyledHeading>\n          <StyledButtonsWrapper>\n            {items.map((item: ItemProps) => (\n              <StyledButtonElementWrapper key={item.value}>\n                <Button\n                  type=\"button\"\n                  size=\"normal\"\n                  greyLightest={!item.selected}\n                  borderShape=\"rounded\"\n                  onClick={() => {\n                    onFilterToggle(item.value);\n                  }}>\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </Button>\n              </StyledButtonElementWrapper>\n            ))}\n          </StyledButtonsWrapper>\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"]} */"));
|
|
41
41
|
|
|
42
42
|
var StyledButtonsWrapper = _styled("div", {
|
|
43
43
|
target: "e1yaxziw1",
|
|
@@ -48,14 +48,14 @@ var StyledButtonsWrapper = _styled("div", {
|
|
|
48
48
|
} : {
|
|
49
49
|
name: "2imjyh",
|
|
50
50
|
styles: "display:flex;flex-wrap:wrap;",
|
|
51
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZpbHRlckJ1dHRvbnMudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTZCdUMiLCJmaWxlIjoiRmlsdGVyQnV0dG9ucy50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMS1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCwgeyB1c2VFZmZlY3QsIHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuLy8gQHRzLWlnbm9yZVxuaW1wb3J0IEJ1dHRvbiBmcm9tICdAbmRsYS9idXR0b24nO1xuaW1wb3J0IHsgYnJlYWtwb2ludHMsIGNvbG9ycywgZm9udHMsIG1xLCBzcGFjaW5nIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgeyB1c2VUcmFuc2xhdGlvbiB9IGZyb20gJ3JlYWN0LWkxOG5leHQnO1xuLy8gQHRzLWlnbm9yZVxuaW1wb3J0IHsgQ3Jvc3MgYXMgQ3Jvc3NJY29uLCBQbHVzIGFzIFBsdXNJY29uIH0gZnJvbSAnQG5kbGEvaWNvbnMvYWN0aW9uJztcbi8vIEB0cy1pZ25vcmVcbmltcG9ydCBNb2RhbCwgeyBNb2RhbEhlYWRlciwgTW9kYWxCb2R5LCBNb2RhbENsb3NlQnV0dG9uIH0gZnJvbSAnQG5kbGEvbW9kYWwnO1xuXG4vLyBAdHMtaWdub3JlXG5pbXBvcnQgVG9nZ2xlSXRlbSBmcm9tICcuL1RvZ2dsZUl0ZW0nO1xuXG5jb25zdCBTdHlsZWRIZWFkaW5nID0gc3R5bGVkLmgzYFxuICAke2ZvbnRzLnNpemVzKCcxNnB4JywgJzMycHgnKX07XG4gIG1hcmdpbjogMCAwICR7c3BhY2luZy5zbWFsbH07XG4gIGNvbG9yOiAke2NvbG9ycy50ZXh0LmxpZ2h0fTtcbiAgZm9udC13ZWlnaHQ6ICR7Zm9udHMud2VpZ2h0LnNlbWlib2xkfTtcbmA7XG5cbmNvbnN0IFN0eWxlZEJ1dHRvbnNXcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC13cmFwOiB3cmFwO1xuYDtcblxuY29uc3QgU3R5bGVkQnV0dG9uRWxlbWVudFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICBtYXJnaW46IDAgJHtzcGFjaW5nLnhzbWFsbH0gJHtzcGFjaW5nLnhzbWFsbH0gMDtcbiAgYnJlYWstaW5zaWRlOiBhdm9pZDtcbmA7XG5cbmNvbnN0IFN0eWxlZExpc3QgPSBzdHlsZWQudWxgXG4gIGxpc3Qtc3R5bGU6IG5vbmU7XG4gIG1hcmdpbjogMDtcbiAgcGFkZGluZzogMDtcbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLnRhYmxldCB9KX0ge1xuICAgIGNvbHVtbi1jb3VudDogMjtcbiAgICBjb2x1bW4tZ2FwOiAyMHB4O1xuICB9XG4gICR7bXEucmFuZ2UoeyBmcm9tOiBicmVha3BvaW50cy50YWJsZXRXaWRlIH0pfSB7XG4gICAgY29sdW1uLWNvdW50OiAzO1xuICAgIGNvbHVtbi1nYXA6IDIwcHg7XG4gIH1cbmA7XG5jb25zdCBTdHlsZWRMaXN0SXRlbSA9IHN0eWxlZC5saWBcbiAgbWFyZ2luLWJvdHRvbTogMDtcbiAgYnJlYWstaW5zaWRlOiBhdm9pZDtcbmA7XG5cbmNvbnN0IFN0eWxlZEJ1dHRvbkNvbnRlbnQgPSBzdHlsZWQuc3BhbmBgO1xuXG5jb25zdCBTdHlsZWRCdXR0b25Db250ZW50U2VsZWN0ZWQgPSBzdHlsZWQuc3BhbmBcbiAgbWFyZ2luLWxlZnQ6ICR7c3BhY2luZy5zbWFsbH07XG4gIGRpc3BsYXk6IGlubGluZS1mbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuYDtcblxuY29uc3QgU3R5bGVkUmVtb3ZlV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIG1hcmdpbi10b3A6ICR7c3BhY2luZy54c21hbGx9O1xuYDtcblxuY29uc3QgQnV0dG9uUmVtb3ZlVGV4dCA9IHN0eWxlZC5zcGFuYFxuICAke2ZvbnRzLnNpemVzKCcxNnB4JywgJzMycHgnKX07XG4gIGZvbnQtd2VpZ2h0OiAke2ZvbnRzLndlaWdodC5zZW1pYm9sZH07XG5gO1xuXG5leHBvcnQgdHlwZSBJdGVtUHJvcHMgPSB7XG4gIGxhYmVsOiBzdHJpbmc7XG4gIHZhbHVlOiBzdHJpbmc7XG4gIHNlbGVjdGVkPzogYm9vbGVhbjtcbn07XG50eXBlIFByb3BzID0ge1xuICBoZWFkaW5nOiBzdHJpbmc7XG4gIGl0ZW1zOiBJdGVtUHJvcHNbXTtcbiAgb25GaWx0ZXJUb2dnbGU6ICh2YWx1ZTogc3RyaW5nKSA9PiB2b2lkO1xuICBvblJlbW92ZUFsbEZpbHRlcnM6ICgpID0+IHZvaWQ7XG4gIGxhYmVsczoge1xuICAgIG9wZW5GaWx0ZXI6IHN0cmluZztcbiAgfTtcbn07XG5cbmV4cG9ydCBjb25zdCBGaWx0ZXJCdXR0b25zID0gKHsgaGVhZGluZywgaXRlbXMsIG9uRmlsdGVyVG9nZ2xlLCBvblJlbW92ZUFsbEZpbHRlcnMsIGxhYmVscyB9OiBQcm9wcykgPT4ge1xuICBjb25zdCB7IHQgfSA9IHVzZVRyYW5zbGF0aW9uKCk7XG4gIGNvbnN0IFtpc05hcnJvd1NjcmVlbiwgc2V0SXNOYXJyb3dTY3JlZW5dID0gdXNlU3RhdGUoZmFsc2UpO1xuXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgY29uc3QgaXNOYXJyb3dTY3JlZW5NYXRjaCA9IHdpbmRvdy5tYXRjaE1lZGlhKCcobWF4LXdpZHRoOiA3NjdweCknKTtcbiAgICBjb25zdCBoYW5kbGVDaGFuZ2UgPSAoZTogTWVkaWFRdWVyeUxpc3RFdmVudCB8IE1lZGlhUXVlcnlMaXN0KSA9PiB7XG4gICAgICBzZXRJc05hcnJvd1NjcmVlbihlLm1hdGNoZXMpO1xuICAgIH07XG4gICAgaXNOYXJyb3dTY3JlZW5NYXRjaC5hZGRFdmVudExpc3RlbmVyKCdjaGFuZ2UnLCBoYW5kbGVDaGFuZ2UpO1xuICAgIGhhbmRsZUNoYW5nZShpc05hcnJvd1NjcmVlbk1hdGNoKTtcbiAgICByZXR1cm4gKCkgPT4ge1xuICAgICAgaXNOYXJyb3dTY3JlZW5NYXRjaC5yZW1vdmVFdmVudExpc3RlbmVyKCdjaGFuZ2UnLCBoYW5kbGVDaGFuZ2UpO1xuICAgIH07XG4gIH0sIFtdKTtcblxuICBjb25zdCBoYXNTZWxlY3RlZEZpbHRlcnMgPSBpdGVtcy5zb21lKChpdGVtKSA9PiB7XG4gICAgcmV0dXJuIGl0ZW0uc2VsZWN0ZWQ7XG4gIH0pO1xuXG4gIGNvbnN0IGFjdGl2ZUl0ZW1zID0gaXRlbXMuZmlsdGVyKChpdGVtKSA9PiBpdGVtLnNlbGVjdGVkKTtcblxuICByZXR1cm4gKFxuICAgIDw+XG4gICAgICB7aXNOYXJyb3dTY3JlZW4gJiYgKFxuICAgICAgICA8U3R5bGVkQnV0dG9uc1dyYXBwZXI+XG4gICAgICAgICAge2FjdGl2ZUl0ZW1zLm1hcCgoaXRlbTogSXRlbVByb3BzKSA9PiAoXG4gICAgICAgICAgICA8U3R5bGVkQnV0dG9uRWxlbWVudFdyYXBwZXIga2V5PXtpdGVtLnZhbHVlfT5cbiAgICAgICAgICAgICAgPEJ1dHRvblxuICAgICAgICAgICAgICAgIHR5cGU9XCJidXR0b25cIlxuICAgICAgICAgICAgICAgIHNpemU9XCJub3JtYWxcIlxuICAgICAgICAgICAgICAgIGJvcmRlclNoYXBlPVwicm91bmRlZFwiXG4gICAgICAgICAgICAgICAgb25DbGljaz17KCkgPT4ge1xuICAgICAgICAgICAgICAgICAgb25GaWx0ZXJUb2dnbGUoaXRlbS52YWx1ZSk7XG4gICAgICAgICAgICAgICAgfX0+XG4gICAgICAgICAgICAgICAgPFN0eWxlZEJ1dHRvbkNvbnRlbnQ+e2l0ZW0ubGFiZWx9PC9TdHlsZWRCdXR0b25Db250ZW50PlxuICAgICAgICAgICAgICAgIDxTdHlsZWRCdXR0b25Db250ZW50U2VsZWN0ZWQ+XG4gICAgICAgICAgICAgICAgICA8Q3Jvc3NJY29uIC8+XG4gICAgICAgICAgICAgICAgPC9TdHlsZWRCdXR0b25Db250ZW50U2VsZWN0ZWQ+XG4gICAgICAgICAgICAgIDwvQnV0dG9uPlxuICAgICAgICAgICAgPC9TdHlsZWRCdXR0b25FbGVtZW50V3JhcHBlcj5cbiAgICAgICAgICApKX1cbiAgICAgICAgICA8TW9kYWxcbiAgICAgICAgICAgIHNpemU9XCJmdWxsc2NyZWVuXCJcbiAgICAgICAgICAgIGFuaW1hdGlvbj1cInN1YnRsZVwiXG4gICAgICAgICAgICBiYWNrZ3JvdW5kQ29sb3I9XCJ3aGl0ZVwiXG4gICAgICAgICAgICBhY3RpdmF0ZUJ1dHRvbj17XG4gICAgICAgICAgICAgIDxTdHlsZWRCdXR0b25FbGVtZW50V3JhcHBlcj5cbiAgICAgICAgICAgICAgICA8QnV0dG9uIHR5cGU9XCJidXR0b25cIiBzaXplPVwibm9ybWFsXCIgbGlnaHQgYm9yZGVyU2hhcGU9XCJyb3VuZGVkXCI+XG4gICAgICAgICAgICAgICAgICA8U3R5bGVkQnV0dG9uQ29udGVudD57bGFiZWxzLm9wZW5GaWx0ZXJ9PC9TdHlsZWRCdXR0b25Db250ZW50PlxuICAgICAgICAgICAgICAgICAgPFN0eWxlZEJ1dHRvbkNvbnRlbnRTZWxlY3RlZD5cbiAgICAgICAgICAgICAgICAgICAgPFBsdXNJY29uIC8+XG4gICAgICAgICAgICAgICAgICA8L1N0eWxlZEJ1dHRvbkNvbnRlbnRTZWxlY3RlZD5cbiAgICAgICAgICAgICAgICA8L0J1dHRvbj5cbiAgICAgICAgICAgICAgPC9TdHlsZWRCdXR0b25FbGVtZW50V3JhcHBlcj5cbiAgICAgICAgICAgIH0+
|
|
51
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilterButtons.tsx"],"names":[],"mappings":"AA6BuC","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 */\n\nimport React, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\n// @ts-ignore\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\n// @ts-ignore\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\n// @ts-ignore\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\n\n// @ts-ignore\nimport ToggleItem from './ToggleItem';\n\nconst StyledHeading = styled.h3`\n  ${fonts.sizes('16px', '32px')};\n  margin: 0 0 ${spacing.small};\n  color: ${colors.text.light};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledButtonsWrapper = styled.div`\n  display: flex;\n  flex-wrap: wrap;\n`;\n\nconst StyledButtonElementWrapper = styled.div`\n  margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n  break-inside: avoid;\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`;\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};\ntype Props = {\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 }: Props) => {\n  const { t } = useTranslation();\n  const [isNarrowScreen, setIsNarrowScreen] = useState(false);\n\n  useEffect(() => {\n    const isNarrowScreenMatch = window.matchMedia('(max-width: 767px)');\n    const handleChange = (e: MediaQueryListEvent | MediaQueryList) => {\n      setIsNarrowScreen(e.matches);\n    };\n    isNarrowScreenMatch.addEventListener('change', handleChange);\n    handleChange(isNarrowScreenMatch);\n    return () => {\n      isNarrowScreenMatch.removeEventListener('change', handleChange);\n    };\n  }, []);\n\n  const hasSelectedFilters = items.some((item) => {\n    return item.selected;\n  });\n\n  const activeItems = items.filter((item) => item.selected);\n\n  return (\n    <>\n      {isNarrowScreen && (\n        <StyledButtonsWrapper>\n          {activeItems.map((item: ItemProps) => (\n            <StyledButtonElementWrapper key={item.value}>\n              <Button\n                type=\"button\"\n                size=\"normal\"\n                borderShape=\"rounded\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}>\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </Button>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal\n            size=\"fullscreen\"\n            animation=\"subtle\"\n            backgroundColor=\"white\"\n            activateButton={\n              <StyledButtonElementWrapper>\n                <Button type=\"button\" size=\"normal\" light borderShape=\"rounded\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </Button>\n              </StyledButtonElementWrapper>\n            }>\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier={['left-align']}>\n                  <h1>{heading}</h1>\n                  <ModalCloseButton title={t('modal.closeModal')} onClick={onClose} />\n                </ModalHeader>\n                <ModalBody modifier=\"slide-in-left\">\n                  <StyledList>\n                    {items.map((item: ItemProps) => (\n                      <StyledListItem key={item.value}>\n                        <ToggleItem\n                          id={item.value}\n                          value={item.value}\n                          checked={item.selected}\n                          label={item.label}\n                          component=\"div\"\n                          onChange={() => {\n                            onFilterToggle(item.value);\n                          }}\n                        />\n                      </StyledListItem>\n                    ))}\n                  </StyledList>\n                </ModalBody>\n              </>\n            )}\n          </Modal>\n        </StyledButtonsWrapper>\n      )}\n      {!isNarrowScreen && (\n        <>\n          <StyledHeading>{heading}</StyledHeading>\n          <StyledButtonsWrapper>\n            {items.map((item: ItemProps) => (\n              <StyledButtonElementWrapper key={item.value}>\n                <Button\n                  type=\"button\"\n                  size=\"normal\"\n                  greyLightest={!item.selected}\n                  borderShape=\"rounded\"\n                  onClick={() => {\n                    onFilterToggle(item.value);\n                  }}>\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </Button>\n              </StyledButtonElementWrapper>\n            ))}\n          </StyledButtonsWrapper>\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"]} */",
|
|
52
52
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
53
53
|
});
|
|
54
54
|
|
|
55
55
|
var StyledButtonElementWrapper = _styled("div", {
|
|
56
56
|
target: "e1yaxziw2",
|
|
57
57
|
label: "StyledButtonElementWrapper"
|
|
58
|
-
})("margin:0 ", spacing.xsmall, " ", spacing.xsmall, " 0;break-inside:avoid;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZpbHRlckJ1dHRvbnMudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWtDNkMiLCJmaWxlIjoiRmlsdGVyQnV0dG9ucy50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMS1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCwgeyB1c2VFZmZlY3QsIHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuLy8gQHRzLWlnbm9yZVxuaW1wb3J0IEJ1dHRvbiBmcm9tICdAbmRsYS9idXR0b24nO1xuaW1wb3J0IHsgYnJlYWtwb2ludHMsIGNvbG9ycywgZm9udHMsIG1xLCBzcGFjaW5nIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgeyB1c2VUcmFuc2xhdGlvbiB9IGZyb20gJ3JlYWN0LWkxOG5leHQnO1xuLy8gQHRzLWlnbm9yZVxuaW1wb3J0IHsgQ3Jvc3MgYXMgQ3Jvc3NJY29uLCBQbHVzIGFzIFBsdXNJY29uIH0gZnJvbSAnQG5kbGEvaWNvbnMvYWN0aW9uJztcbi8vIEB0cy1pZ25vcmVcbmltcG9ydCBNb2RhbCwgeyBNb2RhbEhlYWRlciwgTW9kYWxCb2R5LCBNb2RhbENsb3NlQnV0dG9uIH0gZnJvbSAnQG5kbGEvbW9kYWwnO1xuXG4vLyBAdHMtaWdub3JlXG5pbXBvcnQgVG9nZ2xlSXRlbSBmcm9tICcuL1RvZ2dsZUl0ZW0nO1xuXG5jb25zdCBTdHlsZWRIZWFkaW5nID0gc3R5bGVkLmgzYFxuICAke2ZvbnRzLnNpemVzKCcxNnB4JywgJzMycHgnKX07XG4gIG1hcmdpbjogMCAwICR7c3BhY2luZy5zbWFsbH07XG4gIGNvbG9yOiAke2NvbG9ycy50ZXh0LmxpZ2h0fTtcbiAgZm9udC13ZWlnaHQ6ICR7Zm9udHMud2VpZ2h0LnNlbWlib2xkfTtcbmA7XG5cbmNvbnN0IFN0eWxlZEJ1dHRvbnNXcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC13cmFwOiB3cmFwO1xuYDtcblxuY29uc3QgU3R5bGVkQnV0dG9uRWxlbWVudFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICBtYXJnaW46IDAgJHtzcGFjaW5nLnhzbWFsbH0gJHtzcGFjaW5nLnhzbWFsbH0gMDtcbiAgYnJlYWstaW5zaWRlOiBhdm9pZDtcbmA7XG5cbmNvbnN0IFN0eWxlZExpc3QgPSBzdHlsZWQudWxgXG4gIGxpc3Qtc3R5bGU6IG5vbmU7XG4gIG1hcmdpbjogMDtcbiAgcGFkZGluZzogMDtcbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLnRhYmxldCB9KX0ge1xuICAgIGNvbHVtbi1jb3VudDogMjtcbiAgICBjb2x1bW4tZ2FwOiAyMHB4O1xuICB9XG4gICR7bXEucmFuZ2UoeyBmcm9tOiBicmVha3BvaW50cy50YWJsZXRXaWRlIH0pfSB7XG4gICAgY29sdW1uLWNvdW50OiAzO1xuICAgIGNvbHVtbi1nYXA6IDIwcHg7XG4gIH1cbmA7XG5jb25zdCBTdHlsZWRMaXN0SXRlbSA9IHN0eWxlZC5saWBcbiAgbWFyZ2luLWJvdHRvbTogMDtcbiAgYnJlYWstaW5zaWRlOiBhdm9pZDtcbmA7XG5cbmNvbnN0IFN0eWxlZEJ1dHRvbkNvbnRlbnQgPSBzdHlsZWQuc3BhbmBgO1xuXG5jb25zdCBTdHlsZWRCdXR0b25Db250ZW50U2VsZWN0ZWQgPSBzdHlsZWQuc3BhbmBcbiAgbWFyZ2luLWxlZnQ6ICR7c3BhY2luZy5zbWFsbH07XG4gIGRpc3BsYXk6IGlubGluZS1mbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuYDtcblxuY29uc3QgU3R5bGVkUmVtb3ZlV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIG1hcmdpbi10b3A6ICR7c3BhY2luZy54c21hbGx9O1xuYDtcblxuY29uc3QgQnV0dG9uUmVtb3ZlVGV4dCA9IHN0eWxlZC5zcGFuYFxuICAke2ZvbnRzLnNpemVzKCcxNnB4JywgJzMycHgnKX07XG4gIGZvbnQtd2VpZ2h0OiAke2ZvbnRzLndlaWdodC5zZW1pYm9sZH07XG5gO1xuXG5leHBvcnQgdHlwZSBJdGVtUHJvcHMgPSB7XG4gIGxhYmVsOiBzdHJpbmc7XG4gIHZhbHVlOiBzdHJpbmc7XG4gIHNlbGVjdGVkPzogYm9vbGVhbjtcbn07XG50eXBlIFByb3BzID0ge1xuICBoZWFkaW5nOiBzdHJpbmc7XG4gIGl0ZW1zOiBJdGVtUHJvcHNbXTtcbiAgb25GaWx0ZXJUb2dnbGU6ICh2YWx1ZTogc3RyaW5nKSA9PiB2b2lkO1xuICBvblJlbW92ZUFsbEZpbHRlcnM6ICgpID0+IHZvaWQ7XG4gIGxhYmVsczoge1xuICAgIG9wZW5GaWx0ZXI6IHN0cmluZztcbiAgfTtcbn07XG5cbmV4cG9ydCBjb25zdCBGaWx0ZXJCdXR0b25zID0gKHsgaGVhZGluZywgaXRlbXMsIG9uRmlsdGVyVG9nZ2xlLCBvblJlbW92ZUFsbEZpbHRlcnMsIGxhYmVscyB9OiBQcm9wcykgPT4ge1xuICBjb25zdCB7IHQgfSA9IHVzZVRyYW5zbGF0aW9uKCk7XG4gIGNvbnN0IFtpc05hcnJvd1NjcmVlbiwgc2V0SXNOYXJyb3dTY3JlZW5dID0gdXNlU3RhdGUoZmFsc2UpO1xuXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgY29uc3QgaXNOYXJyb3dTY3JlZW5NYXRjaCA9IHdpbmRvdy5tYXRjaE1lZGlhKCcobWF4LXdpZHRoOiA3NjdweCknKTtcbiAgICBjb25zdCBoYW5kbGVDaGFuZ2UgPSAoZTogTWVkaWFRdWVyeUxpc3RFdmVudCB8IE1lZGlhUXVlcnlMaXN0KSA9PiB7XG4gICAgICBzZXRJc05hcnJvd1NjcmVlbihlLm1hdGNoZXMpO1xuICAgIH07XG4gICAgaXNOYXJyb3dTY3JlZW5NYXRjaC5hZGRFdmVudExpc3RlbmVyKCdjaGFuZ2UnLCBoYW5kbGVDaGFuZ2UpO1xuICAgIGhhbmRsZUNoYW5nZShpc05hcnJvd1NjcmVlbk1hdGNoKTtcbiAgICByZXR1cm4gKCkgPT4ge1xuICAgICAgaXNOYXJyb3dTY3JlZW5NYXRjaC5yZW1vdmVFdmVudExpc3RlbmVyKCdjaGFuZ2UnLCBoYW5kbGVDaGFuZ2UpO1xuICAgIH07XG4gIH0sIFtdKTtcblxuICBjb25zdCBoYXNTZWxlY3RlZEZpbHRlcnMgPSBpdGVtcy5zb21lKChpdGVtKSA9PiB7XG4gICAgcmV0dXJuIGl0ZW0uc2VsZWN0ZWQ7XG4gIH0pO1xuXG4gIGNvbnN0IGFjdGl2ZUl0ZW1zID0gaXRlbXMuZmlsdGVyKChpdGVtKSA9PiBpdGVtLnNlbGVjdGVkKTtcblxuICByZXR1cm4gKFxuICAgIDw+XG4gICAgICB7aXNOYXJyb3dTY3JlZW4gJiYgKFxuICAgICAgICA8U3R5bGVkQnV0dG9uc1dyYXBwZXI+XG4gICAgICAgICAge2FjdGl2ZUl0ZW1zLm1hcCgoaXRlbTogSXRlbVByb3BzKSA9PiAoXG4gICAgICAgICAgICA8U3R5bGVkQnV0dG9uRWxlbWVudFdyYXBwZXIga2V5PXtpdGVtLnZhbHVlfT5cbiAgICAgICAgICAgICAgPEJ1dHRvblxuICAgICAgICAgICAgICAgIHR5cGU9XCJidXR0b25cIlxuICAgICAgICAgICAgICAgIHNpemU9XCJub3JtYWxcIlxuICAgICAgICAgICAgICAgIGJvcmRlclNoYXBlPVwicm91bmRlZFwiXG4gICAgICAgICAgICAgICAgb25DbGljaz17KCkgPT4ge1xuICAgICAgICAgICAgICAgICAgb25GaWx0ZXJUb2dnbGUoaXRlbS52YWx1ZSk7XG4gICAgICAgICAgICAgICAgfX0+XG4gICAgICAgICAgICAgICAgPFN0eWxlZEJ1dHRvbkNvbnRlbnQ+e2l0ZW0ubGFiZWx9PC9TdHlsZWRCdXR0b25Db250ZW50PlxuICAgICAgICAgICAgICAgIDxTdHlsZWRCdXR0b25Db250ZW50U2VsZWN0ZWQ+XG4gICAgICAgICAgICAgICAgICA8Q3Jvc3NJY29uIC8+XG4gICAgICAgICAgICAgICAgPC9TdHlsZWRCdXR0b25Db250ZW50U2VsZWN0ZWQ+XG4gICAgICAgICAgICAgIDwvQnV0dG9uPlxuICAgICAgICAgICAgPC9TdHlsZWRCdXR0b25FbGVtZW50V3JhcHBlcj5cbiAgICAgICAgICApKX1cbiAgICAgICAgICA8TW9kYWxcbiAgICAgICAgICAgIHNpemU9XCJmdWxsc2NyZWVuXCJcbiAgICAgICAgICAgIGFuaW1hdGlvbj1cInN1YnRsZVwiXG4gICAgICAgICAgICBiYWNrZ3JvdW5kQ29sb3I9XCJ3aGl0ZVwiXG4gICAgICAgICAgICBhY3RpdmF0ZUJ1dHRvbj17XG4gICAgICAgICAgICAgIDxTdHlsZWRCdXR0b25FbGVtZW50V3JhcHBlcj5cbiAgICAgICAgICAgICAgICA8QnV0dG9uIHR5cGU9XCJidXR0b25cIiBzaXplPVwibm9ybWFsXCIgbGlnaHQgYm9yZGVyU2hhcGU9XCJyb3VuZGVkXCI+XG4gICAgICAgICAgICAgICAgICA8U3R5bGVkQnV0dG9uQ29udGVudD57bGFiZWxzLm9wZW5GaWx0ZXJ9PC9TdHlsZWRCdXR0b25Db250ZW50PlxuICAgICAgICAgICAgICAgICAgPFN0eWxlZEJ1dHRvbkNvbnRlbnRTZWxlY3RlZD5cbiAgICAgICAgICAgICAgICAgICAgPFBsdXNJY29uIC8+XG4gICAgICAgICAgICAgICAgICA8L1N0eWxlZEJ1dHRvbkNvbnRlbnRTZWxlY3RlZD5cbiAgICAgICAgICAgICAgICA8L0J1dHRvbj5cbiAgICAgICAgICAgICAgPC9TdHlsZWRCdXR0b25FbGVtZW50V3JhcHBlcj5cbiAgICAgICAgICAgIH0+
|
|
58
|
+
})("margin:0 ", spacing.xsmall, " ", spacing.xsmall, " 0;break-inside:avoid;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilterButtons.tsx"],"names":[],"mappings":"AAkC6C","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 */\n\nimport React, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\n// @ts-ignore\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\n// @ts-ignore\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\n// @ts-ignore\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\n\n// @ts-ignore\nimport ToggleItem from './ToggleItem';\n\nconst StyledHeading = styled.h3`\n  ${fonts.sizes('16px', '32px')};\n  margin: 0 0 ${spacing.small};\n  color: ${colors.text.light};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledButtonsWrapper = styled.div`\n  display: flex;\n  flex-wrap: wrap;\n`;\n\nconst StyledButtonElementWrapper = styled.div`\n  margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n  break-inside: avoid;\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`;\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};\ntype Props = {\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 }: Props) => {\n  const { t } = useTranslation();\n  const [isNarrowScreen, setIsNarrowScreen] = useState(false);\n\n  useEffect(() => {\n    const isNarrowScreenMatch = window.matchMedia('(max-width: 767px)');\n    const handleChange = (e: MediaQueryListEvent | MediaQueryList) => {\n      setIsNarrowScreen(e.matches);\n    };\n    isNarrowScreenMatch.addEventListener('change', handleChange);\n    handleChange(isNarrowScreenMatch);\n    return () => {\n      isNarrowScreenMatch.removeEventListener('change', handleChange);\n    };\n  }, []);\n\n  const hasSelectedFilters = items.some((item) => {\n    return item.selected;\n  });\n\n  const activeItems = items.filter((item) => item.selected);\n\n  return (\n    <>\n      {isNarrowScreen && (\n        <StyledButtonsWrapper>\n          {activeItems.map((item: ItemProps) => (\n            <StyledButtonElementWrapper key={item.value}>\n              <Button\n                type=\"button\"\n                size=\"normal\"\n                borderShape=\"rounded\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}>\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </Button>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal\n            size=\"fullscreen\"\n            animation=\"subtle\"\n            backgroundColor=\"white\"\n            activateButton={\n              <StyledButtonElementWrapper>\n                <Button type=\"button\" size=\"normal\" light borderShape=\"rounded\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </Button>\n              </StyledButtonElementWrapper>\n            }>\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier={['left-align']}>\n                  <h1>{heading}</h1>\n                  <ModalCloseButton title={t('modal.closeModal')} onClick={onClose} />\n                </ModalHeader>\n                <ModalBody modifier=\"slide-in-left\">\n                  <StyledList>\n                    {items.map((item: ItemProps) => (\n                      <StyledListItem key={item.value}>\n                        <ToggleItem\n                          id={item.value}\n                          value={item.value}\n                          checked={item.selected}\n                          label={item.label}\n                          component=\"div\"\n                          onChange={() => {\n                            onFilterToggle(item.value);\n                          }}\n                        />\n                      </StyledListItem>\n                    ))}\n                  </StyledList>\n                </ModalBody>\n              </>\n            )}\n          </Modal>\n        </StyledButtonsWrapper>\n      )}\n      {!isNarrowScreen && (\n        <>\n          <StyledHeading>{heading}</StyledHeading>\n          <StyledButtonsWrapper>\n            {items.map((item: ItemProps) => (\n              <StyledButtonElementWrapper key={item.value}>\n                <Button\n                  type=\"button\"\n                  size=\"normal\"\n                  greyLightest={!item.selected}\n                  borderShape=\"rounded\"\n                  onClick={() => {\n                    onFilterToggle(item.value);\n                  }}>\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </Button>\n              </StyledButtonElementWrapper>\n            ))}\n          </StyledButtonsWrapper>\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"]} */"));
|
|
59
59
|
|
|
60
60
|
var StyledList = _styled("ul", {
|
|
61
61
|
target: "e1yaxziw3",
|
|
@@ -64,7 +64,7 @@ var StyledList = _styled("ul", {
|
|
|
64
64
|
from: breakpoints.tablet
|
|
65
65
|
}), "{column-count:2;column-gap:20px;}", mq.range({
|
|
66
66
|
from: breakpoints.tabletWide
|
|
67
|
-
}), "{column-count:3;column-gap:20px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZpbHRlckJ1dHRvbnMudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXVDNEIiLCJmaWxlIjoiRmlsdGVyQnV0dG9ucy50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMS1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCwgeyB1c2VFZmZlY3QsIHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuLy8gQHRzLWlnbm9yZVxuaW1wb3J0IEJ1dHRvbiBmcm9tICdAbmRsYS9idXR0b24nO1xuaW1wb3J0IHsgYnJlYWtwb2ludHMsIGNvbG9ycywgZm9udHMsIG1xLCBzcGFjaW5nIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgeyB1c2VUcmFuc2xhdGlvbiB9IGZyb20gJ3JlYWN0LWkxOG5leHQnO1xuLy8gQHRzLWlnbm9yZVxuaW1wb3J0IHsgQ3Jvc3MgYXMgQ3Jvc3NJY29uLCBQbHVzIGFzIFBsdXNJY29uIH0gZnJvbSAnQG5kbGEvaWNvbnMvYWN0aW9uJztcbi8vIEB0cy1pZ25vcmVcbmltcG9ydCBNb2RhbCwgeyBNb2RhbEhlYWRlciwgTW9kYWxCb2R5LCBNb2RhbENsb3NlQnV0dG9uIH0gZnJvbSAnQG5kbGEvbW9kYWwnO1xuXG4vLyBAdHMtaWdub3JlXG5pbXBvcnQgVG9nZ2xlSXRlbSBmcm9tICcuL1RvZ2dsZUl0ZW0nO1xuXG5jb25zdCBTdHlsZWRIZWFkaW5nID0gc3R5bGVkLmgzYFxuICAke2ZvbnRzLnNpemVzKCcxNnB4JywgJzMycHgnKX07XG4gIG1hcmdpbjogMCAwICR7c3BhY2luZy5zbWFsbH07XG4gIGNvbG9yOiAke2NvbG9ycy50ZXh0LmxpZ2h0fTtcbiAgZm9udC13ZWlnaHQ6ICR7Zm9udHMud2VpZ2h0LnNlbWlib2xkfTtcbmA7XG5cbmNvbnN0IFN0eWxlZEJ1dHRvbnNXcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC13cmFwOiB3cmFwO1xuYDtcblxuY29uc3QgU3R5bGVkQnV0dG9uRWxlbWVudFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICBtYXJnaW46IDAgJHtzcGFjaW5nLnhzbWFsbH0gJHtzcGFjaW5nLnhzbWFsbH0gMDtcbiAgYnJlYWstaW5zaWRlOiBhdm9pZDtcbmA7XG5cbmNvbnN0IFN0eWxlZExpc3QgPSBzdHlsZWQudWxgXG4gIGxpc3Qtc3R5bGU6IG5vbmU7XG4gIG1hcmdpbjogMDtcbiAgcGFkZGluZzogMDtcbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLnRhYmxldCB9KX0ge1xuICAgIGNvbHVtbi1jb3VudDogMjtcbiAgICBjb2x1bW4tZ2FwOiAyMHB4O1xuICB9XG4gICR7bXEucmFuZ2UoeyBmcm9tOiBicmVha3BvaW50cy50YWJsZXRXaWRlIH0pfSB7XG4gICAgY29sdW1uLWNvdW50OiAzO1xuICAgIGNvbHVtbi1nYXA6IDIwcHg7XG4gIH1cbmA7XG5jb25zdCBTdHlsZWRMaXN0SXRlbSA9IHN0eWxlZC5saWBcbiAgbWFyZ2luLWJvdHRvbTogMDtcbiAgYnJlYWstaW5zaWRlOiBhdm9pZDtcbmA7XG5cbmNvbnN0IFN0eWxlZEJ1dHRvbkNvbnRlbnQgPSBzdHlsZWQuc3BhbmBgO1xuXG5jb25zdCBTdHlsZWRCdXR0b25Db250ZW50U2VsZWN0ZWQgPSBzdHlsZWQuc3BhbmBcbiAgbWFyZ2luLWxlZnQ6ICR7c3BhY2luZy5zbWFsbH07XG4gIGRpc3BsYXk6IGlubGluZS1mbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuYDtcblxuY29uc3QgU3R5bGVkUmVtb3ZlV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIG1hcmdpbi10b3A6ICR7c3BhY2luZy54c21hbGx9O1xuYDtcblxuY29uc3QgQnV0dG9uUmVtb3ZlVGV4dCA9IHN0eWxlZC5zcGFuYFxuICAke2ZvbnRzLnNpemVzKCcxNnB4JywgJzMycHgnKX07XG4gIGZvbnQtd2VpZ2h0OiAke2ZvbnRzLndlaWdodC5zZW1pYm9sZH07XG5gO1xuXG5leHBvcnQgdHlwZSBJdGVtUHJvcHMgPSB7XG4gIGxhYmVsOiBzdHJpbmc7XG4gIHZhbHVlOiBzdHJpbmc7XG4gIHNlbGVjdGVkPzogYm9vbGVhbjtcbn07XG50eXBlIFByb3BzID0ge1xuICBoZWFkaW5nOiBzdHJpbmc7XG4gIGl0ZW1zOiBJdGVtUHJvcHNbXTtcbiAgb25GaWx0ZXJUb2dnbGU6ICh2YWx1ZTogc3RyaW5nKSA9PiB2b2lkO1xuICBvblJlbW92ZUFsbEZpbHRlcnM6ICgpID0+IHZvaWQ7XG4gIGxhYmVsczoge1xuICAgIG9wZW5GaWx0ZXI6IHN0cmluZztcbiAgfTtcbn07XG5cbmV4cG9ydCBjb25zdCBGaWx0ZXJCdXR0b25zID0gKHsgaGVhZGluZywgaXRlbXMsIG9uRmlsdGVyVG9nZ2xlLCBvblJlbW92ZUFsbEZpbHRlcnMsIGxhYmVscyB9OiBQcm9wcykgPT4ge1xuICBjb25zdCB7IHQgfSA9IHVzZVRyYW5zbGF0aW9uKCk7XG4gIGNvbnN0IFtpc05hcnJvd1NjcmVlbiwgc2V0SXNOYXJyb3dTY3JlZW5dID0gdXNlU3RhdGUoZmFsc2UpO1xuXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgY29uc3QgaXNOYXJyb3dTY3JlZW5NYXRjaCA9IHdpbmRvdy5tYXRjaE1lZGlhKCcobWF4LXdpZHRoOiA3NjdweCknKTtcbiAgICBjb25zdCBoYW5kbGVDaGFuZ2UgPSAoZTogTWVkaWFRdWVyeUxpc3RFdmVudCB8IE1lZGlhUXVlcnlMaXN0KSA9PiB7XG4gICAgICBzZXRJc05hcnJvd1NjcmVlbihlLm1hdGNoZXMpO1xuICAgIH07XG4gICAgaXNOYXJyb3dTY3JlZW5NYXRjaC5hZGRFdmVudExpc3RlbmVyKCdjaGFuZ2UnLCBoYW5kbGVDaGFuZ2UpO1xuICAgIGhhbmRsZUNoYW5nZShpc05hcnJvd1NjcmVlbk1hdGNoKTtcbiAgICByZXR1cm4gKCkgPT4ge1xuICAgICAgaXNOYXJyb3dTY3JlZW5NYXRjaC5yZW1vdmVFdmVudExpc3RlbmVyKCdjaGFuZ2UnLCBoYW5kbGVDaGFuZ2UpO1xuICAgIH07XG4gIH0sIFtdKTtcblxuICBjb25zdCBoYXNTZWxlY3RlZEZpbHRlcnMgPSBpdGVtcy5zb21lKChpdGVtKSA9PiB7XG4gICAgcmV0dXJuIGl0ZW0uc2VsZWN0ZWQ7XG4gIH0pO1xuXG4gIGNvbnN0IGFjdGl2ZUl0ZW1zID0gaXRlbXMuZmlsdGVyKChpdGVtKSA9PiBpdGVtLnNlbGVjdGVkKTtcblxuICByZXR1cm4gKFxuICAgIDw+XG4gICAgICB7aXNOYXJyb3dTY3JlZW4gJiYgKFxuICAgICAgICA8U3R5bGVkQnV0dG9uc1dyYXBwZXI+XG4gICAgICAgICAge2FjdGl2ZUl0ZW1zLm1hcCgoaXRlbTogSXRlbVByb3BzKSA9PiAoXG4gICAgICAgICAgICA8U3R5bGVkQnV0dG9uRWxlbWVudFdyYXBwZXIga2V5PXtpdGVtLnZhbHVlfT5cbiAgICAgICAgICAgICAgPEJ1dHRvblxuICAgICAgICAgICAgICAgIHR5cGU9XCJidXR0b25cIlxuICAgICAgICAgICAgICAgIHNpemU9XCJub3JtYWxcIlxuICAgICAgICAgICAgICAgIGJvcmRlclNoYXBlPVwicm91bmRlZFwiXG4gICAgICAgICAgICAgICAgb25DbGljaz17KCkgPT4ge1xuICAgICAgICAgICAgICAgICAgb25GaWx0ZXJUb2dnbGUoaXRlbS52YWx1ZSk7XG4gICAgICAgICAgICAgICAgfX0+XG4gICAgICAgICAgICAgICAgPFN0eWxlZEJ1dHRvbkNvbnRlbnQ+e2l0ZW0ubGFiZWx9PC9TdHlsZWRCdXR0b25Db250ZW50PlxuICAgICAgICAgICAgICAgIDxTdHlsZWRCdXR0b25Db250ZW50U2VsZWN0ZWQ+XG4gICAgICAgICAgICAgICAgICA8Q3Jvc3NJY29uIC8+XG4gICAgICAgICAgICAgICAgPC9TdHlsZWRCdXR0b25Db250ZW50U2VsZWN0ZWQ+XG4gICAgICAgICAgICAgIDwvQnV0dG9uPlxuICAgICAgICAgICAgPC9TdHlsZWRCdXR0b25FbGVtZW50V3JhcHBlcj5cbiAgICAgICAgICApKX1cbiAgICAgICAgICA8TW9kYWxcbiAgICAgICAgICAgIHNpemU9XCJmdWxsc2NyZWVuXCJcbiAgICAgICAgICAgIGFuaW1hdGlvbj1cInN1YnRsZVwiXG4gICAgICAgICAgICBiYWNrZ3JvdW5kQ29sb3I9XCJ3aGl0ZVwiXG4gICAgICAgICAgICBhY3RpdmF0ZUJ1dHRvbj17XG4gICAgICAgICAgICAgIDxTdHlsZWRCdXR0b25FbGVtZW50V3JhcHBlcj5cbiAgICAgICAgICAgICAgICA8QnV0dG9uIHR5cGU9XCJidXR0b25cIiBzaXplPVwibm9ybWFsXCIgbGlnaHQgYm9yZGVyU2hhcGU9XCJyb3VuZGVkXCI+XG4gICAgICAgICAgICAgICAgICA8U3R5bGVkQnV0dG9uQ29udGVudD57bGFiZWxzLm9wZW5GaWx0ZXJ9PC9TdHlsZWRCdXR0b25Db250ZW50PlxuICAgICAgICAgICAgICAgICAgPFN0eWxlZEJ1dHRvbkNvbnRlbnRTZWxlY3RlZD5cbiAgICAgICAgICAgICAgICAgICAgPFBsdXNJY29uIC8+XG4gICAgICAgICAgICAgICAgICA8L1N0eWxlZEJ1dHRvbkNvbnRlbnRTZWxlY3RlZD5cbiAgICAgICAgICAgICAgICA8L0J1dHRvbj5cbiAgICAgICAgICAgICAgPC9TdHlsZWRCdXR0b25FbGVtZW50V3JhcHBlcj5cbiAgICAgICAgICAgIH0+
|
|
67
|
+
}), "{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":"AAuC4B","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 */\n\nimport React, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\n// @ts-ignore\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\n// @ts-ignore\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\n// @ts-ignore\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\n\n// @ts-ignore\nimport ToggleItem from './ToggleItem';\n\nconst StyledHeading = styled.h3`\n  ${fonts.sizes('16px', '32px')};\n  margin: 0 0 ${spacing.small};\n  color: ${colors.text.light};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledButtonsWrapper = styled.div`\n  display: flex;\n  flex-wrap: wrap;\n`;\n\nconst StyledButtonElementWrapper = styled.div`\n  margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n  break-inside: avoid;\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`;\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};\ntype Props = {\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 }: Props) => {\n  const { t } = useTranslation();\n  const [isNarrowScreen, setIsNarrowScreen] = useState(false);\n\n  useEffect(() => {\n    const isNarrowScreenMatch = window.matchMedia('(max-width: 767px)');\n    const handleChange = (e: MediaQueryListEvent | MediaQueryList) => {\n      setIsNarrowScreen(e.matches);\n    };\n    isNarrowScreenMatch.addEventListener('change', handleChange);\n    handleChange(isNarrowScreenMatch);\n    return () => {\n      isNarrowScreenMatch.removeEventListener('change', handleChange);\n    };\n  }, []);\n\n  const hasSelectedFilters = items.some((item) => {\n    return item.selected;\n  });\n\n  const activeItems = items.filter((item) => item.selected);\n\n  return (\n    <>\n      {isNarrowScreen && (\n        <StyledButtonsWrapper>\n          {activeItems.map((item: ItemProps) => (\n            <StyledButtonElementWrapper key={item.value}>\n              <Button\n                type=\"button\"\n                size=\"normal\"\n                borderShape=\"rounded\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}>\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </Button>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal\n            size=\"fullscreen\"\n            animation=\"subtle\"\n            backgroundColor=\"white\"\n            activateButton={\n              <StyledButtonElementWrapper>\n                <Button type=\"button\" size=\"normal\" light borderShape=\"rounded\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </Button>\n              </StyledButtonElementWrapper>\n            }>\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier={['left-align']}>\n                  <h1>{heading}</h1>\n                  <ModalCloseButton title={t('modal.closeModal')} onClick={onClose} />\n                </ModalHeader>\n                <ModalBody modifier=\"slide-in-left\">\n                  <StyledList>\n                    {items.map((item: ItemProps) => (\n                      <StyledListItem key={item.value}>\n                        <ToggleItem\n                          id={item.value}\n                          value={item.value}\n                          checked={item.selected}\n                          label={item.label}\n                          component=\"div\"\n                          onChange={() => {\n                            onFilterToggle(item.value);\n                          }}\n                        />\n                      </StyledListItem>\n                    ))}\n                  </StyledList>\n                </ModalBody>\n              </>\n            )}\n          </Modal>\n        </StyledButtonsWrapper>\n      )}\n      {!isNarrowScreen && (\n        <>\n          <StyledHeading>{heading}</StyledHeading>\n          <StyledButtonsWrapper>\n            {items.map((item: ItemProps) => (\n              <StyledButtonElementWrapper key={item.value}>\n                <Button\n                  type=\"button\"\n                  size=\"normal\"\n                  greyLightest={!item.selected}\n                  borderShape=\"rounded\"\n                  onClick={() => {\n                    onFilterToggle(item.value);\n                  }}>\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </Button>\n              </StyledButtonElementWrapper>\n            ))}\n          </StyledButtonsWrapper>\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"]} */"));
|
|
68
68
|
|
|
69
69
|
var StyledListItem = _styled("li", {
|
|
70
70
|
target: "e1yaxziw4",
|
|
@@ -75,29 +75,29 @@ var StyledListItem = _styled("li", {
|
|
|
75
75
|
} : {
|
|
76
76
|
name: "1gj47mt",
|
|
77
77
|
styles: "margin-bottom:0;break-inside:avoid;",
|
|
78
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZpbHRlckJ1dHRvbnMudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW9EZ0MiLCJmaWxlIjoiRmlsdGVyQnV0dG9ucy50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMS1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCwgeyB1c2VFZmZlY3QsIHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuLy8gQHRzLWlnbm9yZVxuaW1wb3J0IEJ1dHRvbiBmcm9tICdAbmRsYS9idXR0b24nO1xuaW1wb3J0IHsgYnJlYWtwb2ludHMsIGNvbG9ycywgZm9udHMsIG1xLCBzcGFjaW5nIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgeyB1c2VUcmFuc2xhdGlvbiB9IGZyb20gJ3JlYWN0LWkxOG5leHQnO1xuLy8gQHRzLWlnbm9yZVxuaW1wb3J0IHsgQ3Jvc3MgYXMgQ3Jvc3NJY29uLCBQbHVzIGFzIFBsdXNJY29uIH0gZnJvbSAnQG5kbGEvaWNvbnMvYWN0aW9uJztcbi8vIEB0cy1pZ25vcmVcbmltcG9ydCBNb2RhbCwgeyBNb2RhbEhlYWRlciwgTW9kYWxCb2R5LCBNb2RhbENsb3NlQnV0dG9uIH0gZnJvbSAnQG5kbGEvbW9kYWwnO1xuXG4vLyBAdHMtaWdub3JlXG5pbXBvcnQgVG9nZ2xlSXRlbSBmcm9tICcuL1RvZ2dsZUl0ZW0nO1xuXG5jb25zdCBTdHlsZWRIZWFkaW5nID0gc3R5bGVkLmgzYFxuICAke2ZvbnRzLnNpemVzKCcxNnB4JywgJzMycHgnKX07XG4gIG1hcmdpbjogMCAwICR7c3BhY2luZy5zbWFsbH07XG4gIGNvbG9yOiAke2NvbG9ycy50ZXh0LmxpZ2h0fTtcbiAgZm9udC13ZWlnaHQ6ICR7Zm9udHMud2VpZ2h0LnNlbWlib2xkfTtcbmA7XG5cbmNvbnN0IFN0eWxlZEJ1dHRvbnNXcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC13cmFwOiB3cmFwO1xuYDtcblxuY29uc3QgU3R5bGVkQnV0dG9uRWxlbWVudFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICBtYXJnaW46IDAgJHtzcGFjaW5nLnhzbWFsbH0gJHtzcGFjaW5nLnhzbWFsbH0gMDtcbiAgYnJlYWstaW5zaWRlOiBhdm9pZDtcbmA7XG5cbmNvbnN0IFN0eWxlZExpc3QgPSBzdHlsZWQudWxgXG4gIGxpc3Qtc3R5bGU6IG5vbmU7XG4gIG1hcmdpbjogMDtcbiAgcGFkZGluZzogMDtcbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLnRhYmxldCB9KX0ge1xuICAgIGNvbHVtbi1jb3VudDogMjtcbiAgICBjb2x1bW4tZ2FwOiAyMHB4O1xuICB9XG4gICR7bXEucmFuZ2UoeyBmcm9tOiBicmVha3BvaW50cy50YWJsZXRXaWRlIH0pfSB7XG4gICAgY29sdW1uLWNvdW50OiAzO1xuICAgIGNvbHVtbi1nYXA6IDIwcHg7XG4gIH1cbmA7XG5jb25zdCBTdHlsZWRMaXN0SXRlbSA9IHN0eWxlZC5saWBcbiAgbWFyZ2luLWJvdHRvbTogMDtcbiAgYnJlYWstaW5zaWRlOiBhdm9pZDtcbmA7XG5cbmNvbnN0IFN0eWxlZEJ1dHRvbkNvbnRlbnQgPSBzdHlsZWQuc3BhbmBgO1xuXG5jb25zdCBTdHlsZWRCdXR0b25Db250ZW50U2VsZWN0ZWQgPSBzdHlsZWQuc3BhbmBcbiAgbWFyZ2luLWxlZnQ6ICR7c3BhY2luZy5zbWFsbH07XG4gIGRpc3BsYXk6IGlubGluZS1mbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuYDtcblxuY29uc3QgU3R5bGVkUmVtb3ZlV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIG1hcmdpbi10b3A6ICR7c3BhY2luZy54c21hbGx9O1xuYDtcblxuY29uc3QgQnV0dG9uUmVtb3ZlVGV4dCA9IHN0eWxlZC5zcGFuYFxuICAke2ZvbnRzLnNpemVzKCcxNnB4JywgJzMycHgnKX07XG4gIGZvbnQtd2VpZ2h0OiAke2ZvbnRzLndlaWdodC5zZW1pYm9sZH07XG5gO1xuXG5leHBvcnQgdHlwZSBJdGVtUHJvcHMgPSB7XG4gIGxhYmVsOiBzdHJpbmc7XG4gIHZhbHVlOiBzdHJpbmc7XG4gIHNlbGVjdGVkPzogYm9vbGVhbjtcbn07XG50eXBlIFByb3BzID0ge1xuICBoZWFkaW5nOiBzdHJpbmc7XG4gIGl0ZW1zOiBJdGVtUHJvcHNbXTtcbiAgb25GaWx0ZXJUb2dnbGU6ICh2YWx1ZTogc3RyaW5nKSA9PiB2b2lkO1xuICBvblJlbW92ZUFsbEZpbHRlcnM6ICgpID0+IHZvaWQ7XG4gIGxhYmVsczoge1xuICAgIG9wZW5GaWx0ZXI6IHN0cmluZztcbiAgfTtcbn07XG5cbmV4cG9ydCBjb25zdCBGaWx0ZXJCdXR0b25zID0gKHsgaGVhZGluZywgaXRlbXMsIG9uRmlsdGVyVG9nZ2xlLCBvblJlbW92ZUFsbEZpbHRlcnMsIGxhYmVscyB9OiBQcm9wcykgPT4ge1xuICBjb25zdCB7IHQgfSA9IHVzZVRyYW5zbGF0aW9uKCk7XG4gIGNvbnN0IFtpc05hcnJvd1NjcmVlbiwgc2V0SXNOYXJyb3dTY3JlZW5dID0gdXNlU3RhdGUoZmFsc2UpO1xuXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgY29uc3QgaXNOYXJyb3dTY3JlZW5NYXRjaCA9IHdpbmRvdy5tYXRjaE1lZGlhKCcobWF4LXdpZHRoOiA3NjdweCknKTtcbiAgICBjb25zdCBoYW5kbGVDaGFuZ2UgPSAoZTogTWVkaWFRdWVyeUxpc3RFdmVudCB8IE1lZGlhUXVlcnlMaXN0KSA9PiB7XG4gICAgICBzZXRJc05hcnJvd1NjcmVlbihlLm1hdGNoZXMpO1xuICAgIH07XG4gICAgaXNOYXJyb3dTY3JlZW5NYXRjaC5hZGRFdmVudExpc3RlbmVyKCdjaGFuZ2UnLCBoYW5kbGVDaGFuZ2UpO1xuICAgIGhhbmRsZUNoYW5nZShpc05hcnJvd1NjcmVlbk1hdGNoKTtcbiAgICByZXR1cm4gKCkgPT4ge1xuICAgICAgaXNOYXJyb3dTY3JlZW5NYXRjaC5yZW1vdmVFdmVudExpc3RlbmVyKCdjaGFuZ2UnLCBoYW5kbGVDaGFuZ2UpO1xuICAgIH07XG4gIH0sIFtdKTtcblxuICBjb25zdCBoYXNTZWxlY3RlZEZpbHRlcnMgPSBpdGVtcy5zb21lKChpdGVtKSA9PiB7XG4gICAgcmV0dXJuIGl0ZW0uc2VsZWN0ZWQ7XG4gIH0pO1xuXG4gIGNvbnN0IGFjdGl2ZUl0ZW1zID0gaXRlbXMuZmlsdGVyKChpdGVtKSA9PiBpdGVtLnNlbGVjdGVkKTtcblxuICByZXR1cm4gKFxuICAgIDw+XG4gICAgICB7aXNOYXJyb3dTY3JlZW4gJiYgKFxuICAgICAgICA8U3R5bGVkQnV0dG9uc1dyYXBwZXI+XG4gICAgICAgICAge2FjdGl2ZUl0ZW1zLm1hcCgoaXRlbTogSXRlbVByb3BzKSA9PiAoXG4gICAgICAgICAgICA8U3R5bGVkQnV0dG9uRWxlbWVudFdyYXBwZXIga2V5PXtpdGVtLnZhbHVlfT5cbiAgICAgICAgICAgICAgPEJ1dHRvblxuICAgICAgICAgICAgICAgIHR5cGU9XCJidXR0b25cIlxuICAgICAgICAgICAgICAgIHNpemU9XCJub3JtYWxcIlxuICAgICAgICAgICAgICAgIGJvcmRlclNoYXBlPVwicm91bmRlZFwiXG4gICAgICAgICAgICAgICAgb25DbGljaz17KCkgPT4ge1xuICAgICAgICAgICAgICAgICAgb25GaWx0ZXJUb2dnbGUoaXRlbS52YWx1ZSk7XG4gICAgICAgICAgICAgICAgfX0+XG4gICAgICAgICAgICAgICAgPFN0eWxlZEJ1dHRvbkNvbnRlbnQ+e2l0ZW0ubGFiZWx9PC9TdHlsZWRCdXR0b25Db250ZW50PlxuICAgICAgICAgICAgICAgIDxTdHlsZWRCdXR0b25Db250ZW50U2VsZWN0ZWQ+XG4gICAgICAgICAgICAgICAgICA8Q3Jvc3NJY29uIC8+XG4gICAgICAgICAgICAgICAgPC9TdHlsZWRCdXR0b25Db250ZW50U2VsZWN0ZWQ+XG4gICAgICAgICAgICAgIDwvQnV0dG9uPlxuICAgICAgICAgICAgPC9TdHlsZWRCdXR0b25FbGVtZW50V3JhcHBlcj5cbiAgICAgICAgICApKX1cbiAgICAgICAgICA8TW9kYWxcbiAgICAgICAgICAgIHNpemU9XCJmdWxsc2NyZWVuXCJcbiAgICAgICAgICAgIGFuaW1hdGlvbj1cInN1YnRsZVwiXG4gICAgICAgICAgICBiYWNrZ3JvdW5kQ29sb3I9XCJ3aGl0ZVwiXG4gICAgICAgICAgICBhY3RpdmF0ZUJ1dHRvbj17XG4gICAgICAgICAgICAgIDxTdHlsZWRCdXR0b25FbGVtZW50V3JhcHBlcj5cbiAgICAgICAgICAgICAgICA8QnV0dG9uIHR5cGU9XCJidXR0b25cIiBzaXplPVwibm9ybWFsXCIgbGlnaHQgYm9yZGVyU2hhcGU9XCJyb3VuZGVkXCI+XG4gICAgICAgICAgICAgICAgICA8U3R5bGVkQnV0dG9uQ29udGVudD57bGFiZWxzLm9wZW5GaWx0ZXJ9PC9TdHlsZWRCdXR0b25Db250ZW50PlxuICAgICAgICAgICAgICAgICAgPFN0eWxlZEJ1dHRvbkNvbnRlbnRTZWxlY3RlZD5cbiAgICAgICAgICAgICAgICAgICAgPFBsdXNJY29uIC8+XG4gICAgICAgICAgICAgICAgICA8L1N0eWxlZEJ1dHRvbkNvbnRlbnRTZWxlY3RlZD5cbiAgICAgICAgICAgICAgICA8L0J1dHRvbj5cbiAgICAgICAgICAgICAgPC9TdHlsZWRCdXR0b25FbGVtZW50V3JhcHBlcj5cbiAgICAgICAgICAgIH0+
|
|
78
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilterButtons.tsx"],"names":[],"mappings":"AAoDgC","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 */\n\nimport React, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\n// @ts-ignore\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\n// @ts-ignore\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\n// @ts-ignore\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\n\n// @ts-ignore\nimport ToggleItem from './ToggleItem';\n\nconst StyledHeading = styled.h3`\n  ${fonts.sizes('16px', '32px')};\n  margin: 0 0 ${spacing.small};\n  color: ${colors.text.light};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledButtonsWrapper = styled.div`\n  display: flex;\n  flex-wrap: wrap;\n`;\n\nconst StyledButtonElementWrapper = styled.div`\n  margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n  break-inside: avoid;\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`;\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};\ntype Props = {\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 }: Props) => {\n  const { t } = useTranslation();\n  const [isNarrowScreen, setIsNarrowScreen] = useState(false);\n\n  useEffect(() => {\n    const isNarrowScreenMatch = window.matchMedia('(max-width: 767px)');\n    const handleChange = (e: MediaQueryListEvent | MediaQueryList) => {\n      setIsNarrowScreen(e.matches);\n    };\n    isNarrowScreenMatch.addEventListener('change', handleChange);\n    handleChange(isNarrowScreenMatch);\n    return () => {\n      isNarrowScreenMatch.removeEventListener('change', handleChange);\n    };\n  }, []);\n\n  const hasSelectedFilters = items.some((item) => {\n    return item.selected;\n  });\n\n  const activeItems = items.filter((item) => item.selected);\n\n  return (\n    <>\n      {isNarrowScreen && (\n        <StyledButtonsWrapper>\n          {activeItems.map((item: ItemProps) => (\n            <StyledButtonElementWrapper key={item.value}>\n              <Button\n                type=\"button\"\n                size=\"normal\"\n                borderShape=\"rounded\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}>\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </Button>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal\n            size=\"fullscreen\"\n            animation=\"subtle\"\n            backgroundColor=\"white\"\n            activateButton={\n              <StyledButtonElementWrapper>\n                <Button type=\"button\" size=\"normal\" light borderShape=\"rounded\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </Button>\n              </StyledButtonElementWrapper>\n            }>\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier={['left-align']}>\n                  <h1>{heading}</h1>\n                  <ModalCloseButton title={t('modal.closeModal')} onClick={onClose} />\n                </ModalHeader>\n                <ModalBody modifier=\"slide-in-left\">\n                  <StyledList>\n                    {items.map((item: ItemProps) => (\n                      <StyledListItem key={item.value}>\n                        <ToggleItem\n                          id={item.value}\n                          value={item.value}\n                          checked={item.selected}\n                          label={item.label}\n                          component=\"div\"\n                          onChange={() => {\n                            onFilterToggle(item.value);\n                          }}\n                        />\n                      </StyledListItem>\n                    ))}\n                  </StyledList>\n                </ModalBody>\n              </>\n            )}\n          </Modal>\n        </StyledButtonsWrapper>\n      )}\n      {!isNarrowScreen && (\n        <>\n          <StyledHeading>{heading}</StyledHeading>\n          <StyledButtonsWrapper>\n            {items.map((item: ItemProps) => (\n              <StyledButtonElementWrapper key={item.value}>\n                <Button\n                  type=\"button\"\n                  size=\"normal\"\n                  greyLightest={!item.selected}\n                  borderShape=\"rounded\"\n                  onClick={() => {\n                    onFilterToggle(item.value);\n                  }}>\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </Button>\n              </StyledButtonElementWrapper>\n            ))}\n          </StyledButtonsWrapper>\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"]} */",
|
|
79
79
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
80
80
|
});
|
|
81
81
|
|
|
82
82
|
var StyledButtonContent = _styled("span", {
|
|
83
83
|
target: "e1yaxziw5",
|
|
84
84
|
label: "StyledButtonContent"
|
|
85
|
-
})(process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZpbHRlckJ1dHRvbnMudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXlEdUMiLCJmaWxlIjoiRmlsdGVyQnV0dG9ucy50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMS1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCwgeyB1c2VFZmZlY3QsIHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuLy8gQHRzLWlnbm9yZVxuaW1wb3J0IEJ1dHRvbiBmcm9tICdAbmRsYS9idXR0b24nO1xuaW1wb3J0IHsgYnJlYWtwb2ludHMsIGNvbG9ycywgZm9udHMsIG1xLCBzcGFjaW5nIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgeyB1c2VUcmFuc2xhdGlvbiB9IGZyb20gJ3JlYWN0LWkxOG5leHQnO1xuLy8gQHRzLWlnbm9yZVxuaW1wb3J0IHsgQ3Jvc3MgYXMgQ3Jvc3NJY29uLCBQbHVzIGFzIFBsdXNJY29uIH0gZnJvbSAnQG5kbGEvaWNvbnMvYWN0aW9uJztcbi8vIEB0cy1pZ25vcmVcbmltcG9ydCBNb2RhbCwgeyBNb2RhbEhlYWRlciwgTW9kYWxCb2R5LCBNb2RhbENsb3NlQnV0dG9uIH0gZnJvbSAnQG5kbGEvbW9kYWwnO1xuXG4vLyBAdHMtaWdub3JlXG5pbXBvcnQgVG9nZ2xlSXRlbSBmcm9tICcuL1RvZ2dsZUl0ZW0nO1xuXG5jb25zdCBTdHlsZWRIZWFkaW5nID0gc3R5bGVkLmgzYFxuICAke2ZvbnRzLnNpemVzKCcxNnB4JywgJzMycHgnKX07XG4gIG1hcmdpbjogMCAwICR7c3BhY2luZy5zbWFsbH07XG4gIGNvbG9yOiAke2NvbG9ycy50ZXh0LmxpZ2h0fTtcbiAgZm9udC13ZWlnaHQ6ICR7Zm9udHMud2VpZ2h0LnNlbWlib2xkfTtcbmA7XG5cbmNvbnN0IFN0eWxlZEJ1dHRvbnNXcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC13cmFwOiB3cmFwO1xuYDtcblxuY29uc3QgU3R5bGVkQnV0dG9uRWxlbWVudFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICBtYXJnaW46IDAgJHtzcGFjaW5nLnhzbWFsbH0gJHtzcGFjaW5nLnhzbWFsbH0gMDtcbiAgYnJlYWstaW5zaWRlOiBhdm9pZDtcbmA7XG5cbmNvbnN0IFN0eWxlZExpc3QgPSBzdHlsZWQudWxgXG4gIGxpc3Qtc3R5bGU6IG5vbmU7XG4gIG1hcmdpbjogMDtcbiAgcGFkZGluZzogMDtcbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLnRhYmxldCB9KX0ge1xuICAgIGNvbHVtbi1jb3VudDogMjtcbiAgICBjb2x1bW4tZ2FwOiAyMHB4O1xuICB9XG4gICR7bXEucmFuZ2UoeyBmcm9tOiBicmVha3BvaW50cy50YWJsZXRXaWRlIH0pfSB7XG4gICAgY29sdW1uLWNvdW50OiAzO1xuICAgIGNvbHVtbi1nYXA6IDIwcHg7XG4gIH1cbmA7XG5jb25zdCBTdHlsZWRMaXN0SXRlbSA9IHN0eWxlZC5saWBcbiAgbWFyZ2luLWJvdHRvbTogMDtcbiAgYnJlYWstaW5zaWRlOiBhdm9pZDtcbmA7XG5cbmNvbnN0IFN0eWxlZEJ1dHRvbkNvbnRlbnQgPSBzdHlsZWQuc3BhbmBgO1xuXG5jb25zdCBTdHlsZWRCdXR0b25Db250ZW50U2VsZWN0ZWQgPSBzdHlsZWQuc3BhbmBcbiAgbWFyZ2luLWxlZnQ6ICR7c3BhY2luZy5zbWFsbH07XG4gIGRpc3BsYXk6IGlubGluZS1mbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuYDtcblxuY29uc3QgU3R5bGVkUmVtb3ZlV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIG1hcmdpbi10b3A6ICR7c3BhY2luZy54c21hbGx9O1xuYDtcblxuY29uc3QgQnV0dG9uUmVtb3ZlVGV4dCA9IHN0eWxlZC5zcGFuYFxuICAke2ZvbnRzLnNpemVzKCcxNnB4JywgJzMycHgnKX07XG4gIGZvbnQtd2VpZ2h0OiAke2ZvbnRzLndlaWdodC5zZW1pYm9sZH07XG5gO1xuXG5leHBvcnQgdHlwZSBJdGVtUHJvcHMgPSB7XG4gIGxhYmVsOiBzdHJpbmc7XG4gIHZhbHVlOiBzdHJpbmc7XG4gIHNlbGVjdGVkPzogYm9vbGVhbjtcbn07XG50eXBlIFByb3BzID0ge1xuICBoZWFkaW5nOiBzdHJpbmc7XG4gIGl0ZW1zOiBJdGVtUHJvcHNbXTtcbiAgb25GaWx0ZXJUb2dnbGU6ICh2YWx1ZTogc3RyaW5nKSA9PiB2b2lkO1xuICBvblJlbW92ZUFsbEZpbHRlcnM6ICgpID0+IHZvaWQ7XG4gIGxhYmVsczoge1xuICAgIG9wZW5GaWx0ZXI6IHN0cmluZztcbiAgfTtcbn07XG5cbmV4cG9ydCBjb25zdCBGaWx0ZXJCdXR0b25zID0gKHsgaGVhZGluZywgaXRlbXMsIG9uRmlsdGVyVG9nZ2xlLCBvblJlbW92ZUFsbEZpbHRlcnMsIGxhYmVscyB9OiBQcm9wcykgPT4ge1xuICBjb25zdCB7IHQgfSA9IHVzZVRyYW5zbGF0aW9uKCk7XG4gIGNvbnN0IFtpc05hcnJvd1NjcmVlbiwgc2V0SXNOYXJyb3dTY3JlZW5dID0gdXNlU3RhdGUoZmFsc2UpO1xuXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgY29uc3QgaXNOYXJyb3dTY3JlZW5NYXRjaCA9IHdpbmRvdy5tYXRjaE1lZGlhKCcobWF4LXdpZHRoOiA3NjdweCknKTtcbiAgICBjb25zdCBoYW5kbGVDaGFuZ2UgPSAoZTogTWVkaWFRdWVyeUxpc3RFdmVudCB8IE1lZGlhUXVlcnlMaXN0KSA9PiB7XG4gICAgICBzZXRJc05hcnJvd1NjcmVlbihlLm1hdGNoZXMpO1xuICAgIH07XG4gICAgaXNOYXJyb3dTY3JlZW5NYXRjaC5hZGRFdmVudExpc3RlbmVyKCdjaGFuZ2UnLCBoYW5kbGVDaGFuZ2UpO1xuICAgIGhhbmRsZUNoYW5nZShpc05hcnJvd1NjcmVlbk1hdGNoKTtcbiAgICByZXR1cm4gKCkgPT4ge1xuICAgICAgaXNOYXJyb3dTY3JlZW5NYXRjaC5yZW1vdmVFdmVudExpc3RlbmVyKCdjaGFuZ2UnLCBoYW5kbGVDaGFuZ2UpO1xuICAgIH07XG4gIH0sIFtdKTtcblxuICBjb25zdCBoYXNTZWxlY3RlZEZpbHRlcnMgPSBpdGVtcy5zb21lKChpdGVtKSA9PiB7XG4gICAgcmV0dXJuIGl0ZW0uc2VsZWN0ZWQ7XG4gIH0pO1xuXG4gIGNvbnN0IGFjdGl2ZUl0ZW1zID0gaXRlbXMuZmlsdGVyKChpdGVtKSA9PiBpdGVtLnNlbGVjdGVkKTtcblxuICByZXR1cm4gKFxuICAgIDw+XG4gICAgICB7aXNOYXJyb3dTY3JlZW4gJiYgKFxuICAgICAgICA8U3R5bGVkQnV0dG9uc1dyYXBwZXI+XG4gICAgICAgICAge2FjdGl2ZUl0ZW1zLm1hcCgoaXRlbTogSXRlbVByb3BzKSA9PiAoXG4gICAgICAgICAgICA8U3R5bGVkQnV0dG9uRWxlbWVudFdyYXBwZXIga2V5PXtpdGVtLnZhbHVlfT5cbiAgICAgICAgICAgICAgPEJ1dHRvblxuICAgICAgICAgICAgICAgIHR5cGU9XCJidXR0b25cIlxuICAgICAgICAgICAgICAgIHNpemU9XCJub3JtYWxcIlxuICAgICAgICAgICAgICAgIGJvcmRlclNoYXBlPVwicm91bmRlZFwiXG4gICAgICAgICAgICAgICAgb25DbGljaz17KCkgPT4ge1xuICAgICAgICAgICAgICAgICAgb25GaWx0ZXJUb2dnbGUoaXRlbS52YWx1ZSk7XG4gICAgICAgICAgICAgICAgfX0+XG4gICAgICAgICAgICAgICAgPFN0eWxlZEJ1dHRvbkNvbnRlbnQ+e2l0ZW0ubGFiZWx9PC9TdHlsZWRCdXR0b25Db250ZW50PlxuICAgICAgICAgICAgICAgIDxTdHlsZWRCdXR0b25Db250ZW50U2VsZWN0ZWQ+XG4gICAgICAgICAgICAgICAgICA8Q3Jvc3NJY29uIC8+XG4gICAgICAgICAgICAgICAgPC9TdHlsZWRCdXR0b25Db250ZW50U2VsZWN0ZWQ+XG4gICAgICAgICAgICAgIDwvQnV0dG9uPlxuICAgICAgICAgICAgPC9TdHlsZWRCdXR0b25FbGVtZW50V3JhcHBlcj5cbiAgICAgICAgICApKX1cbiAgICAgICAgICA8TW9kYWxcbiAgICAgICAgICAgIHNpemU9XCJmdWxsc2NyZWVuXCJcbiAgICAgICAgICAgIGFuaW1hdGlvbj1cInN1YnRsZVwiXG4gICAgICAgICAgICBiYWNrZ3JvdW5kQ29sb3I9XCJ3aGl0ZVwiXG4gICAgICAgICAgICBhY3RpdmF0ZUJ1dHRvbj17XG4gICAgICAgICAgICAgIDxTdHlsZWRCdXR0b25FbGVtZW50V3JhcHBlcj5cbiAgICAgICAgICAgICAgICA8QnV0dG9uIHR5cGU9XCJidXR0b25cIiBzaXplPVwibm9ybWFsXCIgbGlnaHQgYm9yZGVyU2hhcGU9XCJyb3VuZGVkXCI+XG4gICAgICAgICAgICAgICAgICA8U3R5bGVkQnV0dG9uQ29udGVudD57bGFiZWxzLm9wZW5GaWx0ZXJ9PC9TdHlsZWRCdXR0b25Db250ZW50PlxuICAgICAgICAgICAgICAgICAgPFN0eWxlZEJ1dHRvbkNvbnRlbnRTZWxlY3RlZD5cbiAgICAgICAgICAgICAgICAgICAgPFBsdXNJY29uIC8+XG4gICAgICAgICAgICAgICAgICA8L1N0eWxlZEJ1dHRvbkNvbnRlbnRTZWxlY3RlZD5cbiAgICAgICAgICAgICAgICA8L0J1dHRvbj5cbiAgICAgICAgICAgICAgPC9TdHlsZWRCdXR0b25FbGVtZW50V3JhcHBlcj5cbiAgICAgICAgICAgIH0+
|
|
85
|
+
})(process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilterButtons.tsx"],"names":[],"mappings":"AAyDuC","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 */\n\nimport React, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\n// @ts-ignore\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\n// @ts-ignore\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\n// @ts-ignore\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\n\n// @ts-ignore\nimport ToggleItem from './ToggleItem';\n\nconst StyledHeading = styled.h3`\n  ${fonts.sizes('16px', '32px')};\n  margin: 0 0 ${spacing.small};\n  color: ${colors.text.light};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledButtonsWrapper = styled.div`\n  display: flex;\n  flex-wrap: wrap;\n`;\n\nconst StyledButtonElementWrapper = styled.div`\n  margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n  break-inside: avoid;\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`;\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};\ntype Props = {\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 }: Props) => {\n  const { t } = useTranslation();\n  const [isNarrowScreen, setIsNarrowScreen] = useState(false);\n\n  useEffect(() => {\n    const isNarrowScreenMatch = window.matchMedia('(max-width: 767px)');\n    const handleChange = (e: MediaQueryListEvent | MediaQueryList) => {\n      setIsNarrowScreen(e.matches);\n    };\n    isNarrowScreenMatch.addEventListener('change', handleChange);\n    handleChange(isNarrowScreenMatch);\n    return () => {\n      isNarrowScreenMatch.removeEventListener('change', handleChange);\n    };\n  }, []);\n\n  const hasSelectedFilters = items.some((item) => {\n    return item.selected;\n  });\n\n  const activeItems = items.filter((item) => item.selected);\n\n  return (\n    <>\n      {isNarrowScreen && (\n        <StyledButtonsWrapper>\n          {activeItems.map((item: ItemProps) => (\n            <StyledButtonElementWrapper key={item.value}>\n              <Button\n                type=\"button\"\n                size=\"normal\"\n                borderShape=\"rounded\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}>\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </Button>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal\n            size=\"fullscreen\"\n            animation=\"subtle\"\n            backgroundColor=\"white\"\n            activateButton={\n              <StyledButtonElementWrapper>\n                <Button type=\"button\" size=\"normal\" light borderShape=\"rounded\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </Button>\n              </StyledButtonElementWrapper>\n            }>\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier={['left-align']}>\n                  <h1>{heading}</h1>\n                  <ModalCloseButton title={t('modal.closeModal')} onClick={onClose} />\n                </ModalHeader>\n                <ModalBody modifier=\"slide-in-left\">\n                  <StyledList>\n                    {items.map((item: ItemProps) => (\n                      <StyledListItem key={item.value}>\n                        <ToggleItem\n                          id={item.value}\n                          value={item.value}\n                          checked={item.selected}\n                          label={item.label}\n                          component=\"div\"\n                          onChange={() => {\n                            onFilterToggle(item.value);\n                          }}\n                        />\n                      </StyledListItem>\n                    ))}\n                  </StyledList>\n                </ModalBody>\n              </>\n            )}\n          </Modal>\n        </StyledButtonsWrapper>\n      )}\n      {!isNarrowScreen && (\n        <>\n          <StyledHeading>{heading}</StyledHeading>\n          <StyledButtonsWrapper>\n            {items.map((item: ItemProps) => (\n              <StyledButtonElementWrapper key={item.value}>\n                <Button\n                  type=\"button\"\n                  size=\"normal\"\n                  greyLightest={!item.selected}\n                  borderShape=\"rounded\"\n                  onClick={() => {\n                    onFilterToggle(item.value);\n                  }}>\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </Button>\n              </StyledButtonElementWrapper>\n            ))}\n          </StyledButtonsWrapper>\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"]} */");
|
|
86
86
|
|
|
87
87
|
var StyledButtonContentSelected = _styled("span", {
|
|
88
88
|
target: "e1yaxziw6",
|
|
89
89
|
label: "StyledButtonContentSelected"
|
|
90
|
-
})("margin-left:", spacing.small, ";display:inline-flex;align-items:center;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZpbHRlckJ1dHRvbnMudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTJEK0MiLCJmaWxlIjoiRmlsdGVyQnV0dG9ucy50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMS1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCwgeyB1c2VFZmZlY3QsIHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuLy8gQHRzLWlnbm9yZVxuaW1wb3J0IEJ1dHRvbiBmcm9tICdAbmRsYS9idXR0b24nO1xuaW1wb3J0IHsgYnJlYWtwb2ludHMsIGNvbG9ycywgZm9udHMsIG1xLCBzcGFjaW5nIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgeyB1c2VUcmFuc2xhdGlvbiB9IGZyb20gJ3JlYWN0LWkxOG5leHQnO1xuLy8gQHRzLWlnbm9yZVxuaW1wb3J0IHsgQ3Jvc3MgYXMgQ3Jvc3NJY29uLCBQbHVzIGFzIFBsdXNJY29uIH0gZnJvbSAnQG5kbGEvaWNvbnMvYWN0aW9uJztcbi8vIEB0cy1pZ25vcmVcbmltcG9ydCBNb2RhbCwgeyBNb2RhbEhlYWRlciwgTW9kYWxCb2R5LCBNb2RhbENsb3NlQnV0dG9uIH0gZnJvbSAnQG5kbGEvbW9kYWwnO1xuXG4vLyBAdHMtaWdub3JlXG5pbXBvcnQgVG9nZ2xlSXRlbSBmcm9tICcuL1RvZ2dsZUl0ZW0nO1xuXG5jb25zdCBTdHlsZWRIZWFkaW5nID0gc3R5bGVkLmgzYFxuICAke2ZvbnRzLnNpemVzKCcxNnB4JywgJzMycHgnKX07XG4gIG1hcmdpbjogMCAwICR7c3BhY2luZy5zbWFsbH07XG4gIGNvbG9yOiAke2NvbG9ycy50ZXh0LmxpZ2h0fTtcbiAgZm9udC13ZWlnaHQ6ICR7Zm9udHMud2VpZ2h0LnNlbWlib2xkfTtcbmA7XG5cbmNvbnN0IFN0eWxlZEJ1dHRvbnNXcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC13cmFwOiB3cmFwO1xuYDtcblxuY29uc3QgU3R5bGVkQnV0dG9uRWxlbWVudFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICBtYXJnaW46IDAgJHtzcGFjaW5nLnhzbWFsbH0gJHtzcGFjaW5nLnhzbWFsbH0gMDtcbiAgYnJlYWstaW5zaWRlOiBhdm9pZDtcbmA7XG5cbmNvbnN0IFN0eWxlZExpc3QgPSBzdHlsZWQudWxgXG4gIGxpc3Qtc3R5bGU6IG5vbmU7XG4gIG1hcmdpbjogMDtcbiAgcGFkZGluZzogMDtcbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLnRhYmxldCB9KX0ge1xuICAgIGNvbHVtbi1jb3VudDogMjtcbiAgICBjb2x1bW4tZ2FwOiAyMHB4O1xuICB9XG4gICR7bXEucmFuZ2UoeyBmcm9tOiBicmVha3BvaW50cy50YWJsZXRXaWRlIH0pfSB7XG4gICAgY29sdW1uLWNvdW50OiAzO1xuICAgIGNvbHVtbi1nYXA6IDIwcHg7XG4gIH1cbmA7XG5jb25zdCBTdHlsZWRMaXN0SXRlbSA9IHN0eWxlZC5saWBcbiAgbWFyZ2luLWJvdHRvbTogMDtcbiAgYnJlYWstaW5zaWRlOiBhdm9pZDtcbmA7XG5cbmNvbnN0IFN0eWxlZEJ1dHRvbkNvbnRlbnQgPSBzdHlsZWQuc3BhbmBgO1xuXG5jb25zdCBTdHlsZWRCdXR0b25Db250ZW50U2VsZWN0ZWQgPSBzdHlsZWQuc3BhbmBcbiAgbWFyZ2luLWxlZnQ6ICR7c3BhY2luZy5zbWFsbH07XG4gIGRpc3BsYXk6IGlubGluZS1mbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuYDtcblxuY29uc3QgU3R5bGVkUmVtb3ZlV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIG1hcmdpbi10b3A6ICR7c3BhY2luZy54c21hbGx9O1xuYDtcblxuY29uc3QgQnV0dG9uUmVtb3ZlVGV4dCA9IHN0eWxlZC5zcGFuYFxuICAke2ZvbnRzLnNpemVzKCcxNnB4JywgJzMycHgnKX07XG4gIGZvbnQtd2VpZ2h0OiAke2ZvbnRzLndlaWdodC5zZW1pYm9sZH07XG5gO1xuXG5leHBvcnQgdHlwZSBJdGVtUHJvcHMgPSB7XG4gIGxhYmVsOiBzdHJpbmc7XG4gIHZhbHVlOiBzdHJpbmc7XG4gIHNlbGVjdGVkPzogYm9vbGVhbjtcbn07XG50eXBlIFByb3BzID0ge1xuICBoZWFkaW5nOiBzdHJpbmc7XG4gIGl0ZW1zOiBJdGVtUHJvcHNbXTtcbiAgb25GaWx0ZXJUb2dnbGU6ICh2YWx1ZTogc3RyaW5nKSA9PiB2b2lkO1xuICBvblJlbW92ZUFsbEZpbHRlcnM6ICgpID0+IHZvaWQ7XG4gIGxhYmVsczoge1xuICAgIG9wZW5GaWx0ZXI6IHN0cmluZztcbiAgfTtcbn07XG5cbmV4cG9ydCBjb25zdCBGaWx0ZXJCdXR0b25zID0gKHsgaGVhZGluZywgaXRlbXMsIG9uRmlsdGVyVG9nZ2xlLCBvblJlbW92ZUFsbEZpbHRlcnMsIGxhYmVscyB9OiBQcm9wcykgPT4ge1xuICBjb25zdCB7IHQgfSA9IHVzZVRyYW5zbGF0aW9uKCk7XG4gIGNvbnN0IFtpc05hcnJvd1NjcmVlbiwgc2V0SXNOYXJyb3dTY3JlZW5dID0gdXNlU3RhdGUoZmFsc2UpO1xuXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgY29uc3QgaXNOYXJyb3dTY3JlZW5NYXRjaCA9IHdpbmRvdy5tYXRjaE1lZGlhKCcobWF4LXdpZHRoOiA3NjdweCknKTtcbiAgICBjb25zdCBoYW5kbGVDaGFuZ2UgPSAoZTogTWVkaWFRdWVyeUxpc3RFdmVudCB8IE1lZGlhUXVlcnlMaXN0KSA9PiB7XG4gICAgICBzZXRJc05hcnJvd1NjcmVlbihlLm1hdGNoZXMpO1xuICAgIH07XG4gICAgaXNOYXJyb3dTY3JlZW5NYXRjaC5hZGRFdmVudExpc3RlbmVyKCdjaGFuZ2UnLCBoYW5kbGVDaGFuZ2UpO1xuICAgIGhhbmRsZUNoYW5nZShpc05hcnJvd1NjcmVlbk1hdGNoKTtcbiAgICByZXR1cm4gKCkgPT4ge1xuICAgICAgaXNOYXJyb3dTY3JlZW5NYXRjaC5yZW1vdmVFdmVudExpc3RlbmVyKCdjaGFuZ2UnLCBoYW5kbGVDaGFuZ2UpO1xuICAgIH07XG4gIH0sIFtdKTtcblxuICBjb25zdCBoYXNTZWxlY3RlZEZpbHRlcnMgPSBpdGVtcy5zb21lKChpdGVtKSA9PiB7XG4gICAgcmV0dXJuIGl0ZW0uc2VsZWN0ZWQ7XG4gIH0pO1xuXG4gIGNvbnN0IGFjdGl2ZUl0ZW1zID0gaXRlbXMuZmlsdGVyKChpdGVtKSA9PiBpdGVtLnNlbGVjdGVkKTtcblxuICByZXR1cm4gKFxuICAgIDw+XG4gICAgICB7aXNOYXJyb3dTY3JlZW4gJiYgKFxuICAgICAgICA8U3R5bGVkQnV0dG9uc1dyYXBwZXI+XG4gICAgICAgICAge2FjdGl2ZUl0ZW1zLm1hcCgoaXRlbTogSXRlbVByb3BzKSA9PiAoXG4gICAgICAgICAgICA8U3R5bGVkQnV0dG9uRWxlbWVudFdyYXBwZXIga2V5PXtpdGVtLnZhbHVlfT5cbiAgICAgICAgICAgICAgPEJ1dHRvblxuICAgICAgICAgICAgICAgIHR5cGU9XCJidXR0b25cIlxuICAgICAgICAgICAgICAgIHNpemU9XCJub3JtYWxcIlxuICAgICAgICAgICAgICAgIGJvcmRlclNoYXBlPVwicm91bmRlZFwiXG4gICAgICAgICAgICAgICAgb25DbGljaz17KCkgPT4ge1xuICAgICAgICAgICAgICAgICAgb25GaWx0ZXJUb2dnbGUoaXRlbS52YWx1ZSk7XG4gICAgICAgICAgICAgICAgfX0+XG4gICAgICAgICAgICAgICAgPFN0eWxlZEJ1dHRvbkNvbnRlbnQ+e2l0ZW0ubGFiZWx9PC9TdHlsZWRCdXR0b25Db250ZW50PlxuICAgICAgICAgICAgICAgIDxTdHlsZWRCdXR0b25Db250ZW50U2VsZWN0ZWQ+XG4gICAgICAgICAgICAgICAgICA8Q3Jvc3NJY29uIC8+XG4gICAgICAgICAgICAgICAgPC9TdHlsZWRCdXR0b25Db250ZW50U2VsZWN0ZWQ+XG4gICAgICAgICAgICAgIDwvQnV0dG9uPlxuICAgICAgICAgICAgPC9TdHlsZWRCdXR0b25FbGVtZW50V3JhcHBlcj5cbiAgICAgICAgICApKX1cbiAgICAgICAgICA8TW9kYWxcbiAgICAgICAgICAgIHNpemU9XCJmdWxsc2NyZWVuXCJcbiAgICAgICAgICAgIGFuaW1hdGlvbj1cInN1YnRsZVwiXG4gICAgICAgICAgICBiYWNrZ3JvdW5kQ29sb3I9XCJ3aGl0ZVwiXG4gICAgICAgICAgICBhY3RpdmF0ZUJ1dHRvbj17XG4gICAgICAgICAgICAgIDxTdHlsZWRCdXR0b25FbGVtZW50V3JhcHBlcj5cbiAgICAgICAgICAgICAgICA8QnV0dG9uIHR5cGU9XCJidXR0b25cIiBzaXplPVwibm9ybWFsXCIgbGlnaHQgYm9yZGVyU2hhcGU9XCJyb3VuZGVkXCI+XG4gICAgICAgICAgICAgICAgICA8U3R5bGVkQnV0dG9uQ29udGVudD57bGFiZWxzLm9wZW5GaWx0ZXJ9PC9TdHlsZWRCdXR0b25Db250ZW50PlxuICAgICAgICAgICAgICAgICAgPFN0eWxlZEJ1dHRvbkNvbnRlbnRTZWxlY3RlZD5cbiAgICAgICAgICAgICAgICAgICAgPFBsdXNJY29uIC8+XG4gICAgICAgICAgICAgICAgICA8L1N0eWxlZEJ1dHRvbkNvbnRlbnRTZWxlY3RlZD5cbiAgICAgICAgICAgICAgICA8L0J1dHRvbj5cbiAgICAgICAgICAgICAgPC9TdHlsZWRCdXR0b25FbGVtZW50V3JhcHBlcj5cbiAgICAgICAgICAgIH0+
|
|
90
|
+
})("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":"AA2D+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 */\n\nimport React, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\n// @ts-ignore\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\n// @ts-ignore\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\n// @ts-ignore\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\n\n// @ts-ignore\nimport ToggleItem from './ToggleItem';\n\nconst StyledHeading = styled.h3`\n  ${fonts.sizes('16px', '32px')};\n  margin: 0 0 ${spacing.small};\n  color: ${colors.text.light};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledButtonsWrapper = styled.div`\n  display: flex;\n  flex-wrap: wrap;\n`;\n\nconst StyledButtonElementWrapper = styled.div`\n  margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n  break-inside: avoid;\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`;\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};\ntype Props = {\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 }: Props) => {\n  const { t } = useTranslation();\n  const [isNarrowScreen, setIsNarrowScreen] = useState(false);\n\n  useEffect(() => {\n    const isNarrowScreenMatch = window.matchMedia('(max-width: 767px)');\n    const handleChange = (e: MediaQueryListEvent | MediaQueryList) => {\n      setIsNarrowScreen(e.matches);\n    };\n    isNarrowScreenMatch.addEventListener('change', handleChange);\n    handleChange(isNarrowScreenMatch);\n    return () => {\n      isNarrowScreenMatch.removeEventListener('change', handleChange);\n    };\n  }, []);\n\n  const hasSelectedFilters = items.some((item) => {\n    return item.selected;\n  });\n\n  const activeItems = items.filter((item) => item.selected);\n\n  return (\n    <>\n      {isNarrowScreen && (\n        <StyledButtonsWrapper>\n          {activeItems.map((item: ItemProps) => (\n            <StyledButtonElementWrapper key={item.value}>\n              <Button\n                type=\"button\"\n                size=\"normal\"\n                borderShape=\"rounded\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}>\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </Button>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal\n            size=\"fullscreen\"\n            animation=\"subtle\"\n            backgroundColor=\"white\"\n            activateButton={\n              <StyledButtonElementWrapper>\n                <Button type=\"button\" size=\"normal\" light borderShape=\"rounded\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </Button>\n              </StyledButtonElementWrapper>\n            }>\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier={['left-align']}>\n                  <h1>{heading}</h1>\n                  <ModalCloseButton title={t('modal.closeModal')} onClick={onClose} />\n                </ModalHeader>\n                <ModalBody modifier=\"slide-in-left\">\n                  <StyledList>\n                    {items.map((item: ItemProps) => (\n                      <StyledListItem key={item.value}>\n                        <ToggleItem\n                          id={item.value}\n                          value={item.value}\n                          checked={item.selected}\n                          label={item.label}\n                          component=\"div\"\n                          onChange={() => {\n                            onFilterToggle(item.value);\n                          }}\n                        />\n                      </StyledListItem>\n                    ))}\n                  </StyledList>\n                </ModalBody>\n              </>\n            )}\n          </Modal>\n        </StyledButtonsWrapper>\n      )}\n      {!isNarrowScreen && (\n        <>\n          <StyledHeading>{heading}</StyledHeading>\n          <StyledButtonsWrapper>\n            {items.map((item: ItemProps) => (\n              <StyledButtonElementWrapper key={item.value}>\n                <Button\n                  type=\"button\"\n                  size=\"normal\"\n                  greyLightest={!item.selected}\n                  borderShape=\"rounded\"\n                  onClick={() => {\n                    onFilterToggle(item.value);\n                  }}>\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </Button>\n              </StyledButtonElementWrapper>\n            ))}\n          </StyledButtonsWrapper>\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"]} */"));
|
|
91
91
|
|
|
92
92
|
var StyledRemoveWrapper = _styled("div", {
|
|
93
93
|
target: "e1yaxziw7",
|
|
94
94
|
label: "StyledRemoveWrapper"
|
|
95
|
-
})("margin-top:", spacing.xsmall, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZpbHRlckJ1dHRvbnMudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWlFc0MiLCJmaWxlIjoiRmlsdGVyQnV0dG9ucy50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMS1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCwgeyB1c2VFZmZlY3QsIHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuLy8gQHRzLWlnbm9yZVxuaW1wb3J0IEJ1dHRvbiBmcm9tICdAbmRsYS9idXR0b24nO1xuaW1wb3J0IHsgYnJlYWtwb2ludHMsIGNvbG9ycywgZm9udHMsIG1xLCBzcGFjaW5nIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgeyB1c2VUcmFuc2xhdGlvbiB9IGZyb20gJ3JlYWN0LWkxOG5leHQnO1xuLy8gQHRzLWlnbm9yZVxuaW1wb3J0IHsgQ3Jvc3MgYXMgQ3Jvc3NJY29uLCBQbHVzIGFzIFBsdXNJY29uIH0gZnJvbSAnQG5kbGEvaWNvbnMvYWN0aW9uJztcbi8vIEB0cy1pZ25vcmVcbmltcG9ydCBNb2RhbCwgeyBNb2RhbEhlYWRlciwgTW9kYWxCb2R5LCBNb2RhbENsb3NlQnV0dG9uIH0gZnJvbSAnQG5kbGEvbW9kYWwnO1xuXG4vLyBAdHMtaWdub3JlXG5pbXBvcnQgVG9nZ2xlSXRlbSBmcm9tICcuL1RvZ2dsZUl0ZW0nO1xuXG5jb25zdCBTdHlsZWRIZWFkaW5nID0gc3R5bGVkLmgzYFxuICAke2ZvbnRzLnNpemVzKCcxNnB4JywgJzMycHgnKX07XG4gIG1hcmdpbjogMCAwICR7c3BhY2luZy5zbWFsbH07XG4gIGNvbG9yOiAke2NvbG9ycy50ZXh0LmxpZ2h0fTtcbiAgZm9udC13ZWlnaHQ6ICR7Zm9udHMud2VpZ2h0LnNlbWlib2xkfTtcbmA7XG5cbmNvbnN0IFN0eWxlZEJ1dHRvbnNXcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC13cmFwOiB3cmFwO1xuYDtcblxuY29uc3QgU3R5bGVkQnV0dG9uRWxlbWVudFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICBtYXJnaW46IDAgJHtzcGFjaW5nLnhzbWFsbH0gJHtzcGFjaW5nLnhzbWFsbH0gMDtcbiAgYnJlYWstaW5zaWRlOiBhdm9pZDtcbmA7XG5cbmNvbnN0IFN0eWxlZExpc3QgPSBzdHlsZWQudWxgXG4gIGxpc3Qtc3R5bGU6IG5vbmU7XG4gIG1hcmdpbjogMDtcbiAgcGFkZGluZzogMDtcbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLnRhYmxldCB9KX0ge1xuICAgIGNvbHVtbi1jb3VudDogMjtcbiAgICBjb2x1bW4tZ2FwOiAyMHB4O1xuICB9XG4gICR7bXEucmFuZ2UoeyBmcm9tOiBicmVha3BvaW50cy50YWJsZXRXaWRlIH0pfSB7XG4gICAgY29sdW1uLWNvdW50OiAzO1xuICAgIGNvbHVtbi1nYXA6IDIwcHg7XG4gIH1cbmA7XG5jb25zdCBTdHlsZWRMaXN0SXRlbSA9IHN0eWxlZC5saWBcbiAgbWFyZ2luLWJvdHRvbTogMDtcbiAgYnJlYWstaW5zaWRlOiBhdm9pZDtcbmA7XG5cbmNvbnN0IFN0eWxlZEJ1dHRvbkNvbnRlbnQgPSBzdHlsZWQuc3BhbmBgO1xuXG5jb25zdCBTdHlsZWRCdXR0b25Db250ZW50U2VsZWN0ZWQgPSBzdHlsZWQuc3BhbmBcbiAgbWFyZ2luLWxlZnQ6ICR7c3BhY2luZy5zbWFsbH07XG4gIGRpc3BsYXk6IGlubGluZS1mbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuYDtcblxuY29uc3QgU3R5bGVkUmVtb3ZlV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIG1hcmdpbi10b3A6ICR7c3BhY2luZy54c21hbGx9O1xuYDtcblxuY29uc3QgQnV0dG9uUmVtb3ZlVGV4dCA9IHN0eWxlZC5zcGFuYFxuICAke2ZvbnRzLnNpemVzKCcxNnB4JywgJzMycHgnKX07XG4gIGZvbnQtd2VpZ2h0OiAke2ZvbnRzLndlaWdodC5zZW1pYm9sZH07XG5gO1xuXG5leHBvcnQgdHlwZSBJdGVtUHJvcHMgPSB7XG4gIGxhYmVsOiBzdHJpbmc7XG4gIHZhbHVlOiBzdHJpbmc7XG4gIHNlbGVjdGVkPzogYm9vbGVhbjtcbn07XG50eXBlIFByb3BzID0ge1xuICBoZWFkaW5nOiBzdHJpbmc7XG4gIGl0ZW1zOiBJdGVtUHJvcHNbXTtcbiAgb25GaWx0ZXJUb2dnbGU6ICh2YWx1ZTogc3RyaW5nKSA9PiB2b2lkO1xuICBvblJlbW92ZUFsbEZpbHRlcnM6ICgpID0+IHZvaWQ7XG4gIGxhYmVsczoge1xuICAgIG9wZW5GaWx0ZXI6IHN0cmluZztcbiAgfTtcbn07XG5cbmV4cG9ydCBjb25zdCBGaWx0ZXJCdXR0b25zID0gKHsgaGVhZGluZywgaXRlbXMsIG9uRmlsdGVyVG9nZ2xlLCBvblJlbW92ZUFsbEZpbHRlcnMsIGxhYmVscyB9OiBQcm9wcykgPT4ge1xuICBjb25zdCB7IHQgfSA9IHVzZVRyYW5zbGF0aW9uKCk7XG4gIGNvbnN0IFtpc05hcnJvd1NjcmVlbiwgc2V0SXNOYXJyb3dTY3JlZW5dID0gdXNlU3RhdGUoZmFsc2UpO1xuXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgY29uc3QgaXNOYXJyb3dTY3JlZW5NYXRjaCA9IHdpbmRvdy5tYXRjaE1lZGlhKCcobWF4LXdpZHRoOiA3NjdweCknKTtcbiAgICBjb25zdCBoYW5kbGVDaGFuZ2UgPSAoZTogTWVkaWFRdWVyeUxpc3RFdmVudCB8IE1lZGlhUXVlcnlMaXN0KSA9PiB7XG4gICAgICBzZXRJc05hcnJvd1NjcmVlbihlLm1hdGNoZXMpO1xuICAgIH07XG4gICAgaXNOYXJyb3dTY3JlZW5NYXRjaC5hZGRFdmVudExpc3RlbmVyKCdjaGFuZ2UnLCBoYW5kbGVDaGFuZ2UpO1xuICAgIGhhbmRsZUNoYW5nZShpc05hcnJvd1NjcmVlbk1hdGNoKTtcbiAgICByZXR1cm4gKCkgPT4ge1xuICAgICAgaXNOYXJyb3dTY3JlZW5NYXRjaC5yZW1vdmVFdmVudExpc3RlbmVyKCdjaGFuZ2UnLCBoYW5kbGVDaGFuZ2UpO1xuICAgIH07XG4gIH0sIFtdKTtcblxuICBjb25zdCBoYXNTZWxlY3RlZEZpbHRlcnMgPSBpdGVtcy5zb21lKChpdGVtKSA9PiB7XG4gICAgcmV0dXJuIGl0ZW0uc2VsZWN0ZWQ7XG4gIH0pO1xuXG4gIGNvbnN0IGFjdGl2ZUl0ZW1zID0gaXRlbXMuZmlsdGVyKChpdGVtKSA9PiBpdGVtLnNlbGVjdGVkKTtcblxuICByZXR1cm4gKFxuICAgIDw+XG4gICAgICB7aXNOYXJyb3dTY3JlZW4gJiYgKFxuICAgICAgICA8U3R5bGVkQnV0dG9uc1dyYXBwZXI+XG4gICAgICAgICAge2FjdGl2ZUl0ZW1zLm1hcCgoaXRlbTogSXRlbVByb3BzKSA9PiAoXG4gICAgICAgICAgICA8U3R5bGVkQnV0dG9uRWxlbWVudFdyYXBwZXIga2V5PXtpdGVtLnZhbHVlfT5cbiAgICAgICAgICAgICAgPEJ1dHRvblxuICAgICAgICAgICAgICAgIHR5cGU9XCJidXR0b25cIlxuICAgICAgICAgICAgICAgIHNpemU9XCJub3JtYWxcIlxuICAgICAgICAgICAgICAgIGJvcmRlclNoYXBlPVwicm91bmRlZFwiXG4gICAgICAgICAgICAgICAgb25DbGljaz17KCkgPT4ge1xuICAgICAgICAgICAgICAgICAgb25GaWx0ZXJUb2dnbGUoaXRlbS52YWx1ZSk7XG4gICAgICAgICAgICAgICAgfX0+XG4gICAgICAgICAgICAgICAgPFN0eWxlZEJ1dHRvbkNvbnRlbnQ+e2l0ZW0ubGFiZWx9PC9TdHlsZWRCdXR0b25Db250ZW50PlxuICAgICAgICAgICAgICAgIDxTdHlsZWRCdXR0b25Db250ZW50U2VsZWN0ZWQ+XG4gICAgICAgICAgICAgICAgICA8Q3Jvc3NJY29uIC8+XG4gICAgICAgICAgICAgICAgPC9TdHlsZWRCdXR0b25Db250ZW50U2VsZWN0ZWQ+XG4gICAgICAgICAgICAgIDwvQnV0dG9uPlxuICAgICAgICAgICAgPC9TdHlsZWRCdXR0b25FbGVtZW50V3JhcHBlcj5cbiAgICAgICAgICApKX1cbiAgICAgICAgICA8TW9kYWxcbiAgICAgICAgICAgIHNpemU9XCJmdWxsc2NyZWVuXCJcbiAgICAgICAgICAgIGFuaW1hdGlvbj1cInN1YnRsZVwiXG4gICAgICAgICAgICBiYWNrZ3JvdW5kQ29sb3I9XCJ3aGl0ZVwiXG4gICAgICAgICAgICBhY3RpdmF0ZUJ1dHRvbj17XG4gICAgICAgICAgICAgIDxTdHlsZWRCdXR0b25FbGVtZW50V3JhcHBlcj5cbiAgICAgICAgICAgICAgICA8QnV0dG9uIHR5cGU9XCJidXR0b25cIiBzaXplPVwibm9ybWFsXCIgbGlnaHQgYm9yZGVyU2hhcGU9XCJyb3VuZGVkXCI+XG4gICAgICAgICAgICAgICAgICA8U3R5bGVkQnV0dG9uQ29udGVudD57bGFiZWxzLm9wZW5GaWx0ZXJ9PC9TdHlsZWRCdXR0b25Db250ZW50PlxuICAgICAgICAgICAgICAgICAgPFN0eWxlZEJ1dHRvbkNvbnRlbnRTZWxlY3RlZD5cbiAgICAgICAgICAgICAgICAgICAgPFBsdXNJY29uIC8+XG4gICAgICAgICAgICAgICAgICA8L1N0eWxlZEJ1dHRvbkNvbnRlbnRTZWxlY3RlZD5cbiAgICAgICAgICAgICAgICA8L0J1dHRvbj5cbiAgICAgICAgICAgICAgPC9TdHlsZWRCdXR0b25FbGVtZW50V3JhcHBlcj5cbiAgICAgICAgICAgIH0+
|
|
95
|
+
})("margin-top:", spacing.xsmall, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilterButtons.tsx"],"names":[],"mappings":"AAiEsC","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 */\n\nimport React, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\n// @ts-ignore\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\n// @ts-ignore\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\n// @ts-ignore\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\n\n// @ts-ignore\nimport ToggleItem from './ToggleItem';\n\nconst StyledHeading = styled.h3`\n  ${fonts.sizes('16px', '32px')};\n  margin: 0 0 ${spacing.small};\n  color: ${colors.text.light};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledButtonsWrapper = styled.div`\n  display: flex;\n  flex-wrap: wrap;\n`;\n\nconst StyledButtonElementWrapper = styled.div`\n  margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n  break-inside: avoid;\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`;\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};\ntype Props = {\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 }: Props) => {\n  const { t } = useTranslation();\n  const [isNarrowScreen, setIsNarrowScreen] = useState(false);\n\n  useEffect(() => {\n    const isNarrowScreenMatch = window.matchMedia('(max-width: 767px)');\n    const handleChange = (e: MediaQueryListEvent | MediaQueryList) => {\n      setIsNarrowScreen(e.matches);\n    };\n    isNarrowScreenMatch.addEventListener('change', handleChange);\n    handleChange(isNarrowScreenMatch);\n    return () => {\n      isNarrowScreenMatch.removeEventListener('change', handleChange);\n    };\n  }, []);\n\n  const hasSelectedFilters = items.some((item) => {\n    return item.selected;\n  });\n\n  const activeItems = items.filter((item) => item.selected);\n\n  return (\n    <>\n      {isNarrowScreen && (\n        <StyledButtonsWrapper>\n          {activeItems.map((item: ItemProps) => (\n            <StyledButtonElementWrapper key={item.value}>\n              <Button\n                type=\"button\"\n                size=\"normal\"\n                borderShape=\"rounded\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}>\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </Button>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal\n            size=\"fullscreen\"\n            animation=\"subtle\"\n            backgroundColor=\"white\"\n            activateButton={\n              <StyledButtonElementWrapper>\n                <Button type=\"button\" size=\"normal\" light borderShape=\"rounded\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </Button>\n              </StyledButtonElementWrapper>\n            }>\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier={['left-align']}>\n                  <h1>{heading}</h1>\n                  <ModalCloseButton title={t('modal.closeModal')} onClick={onClose} />\n                </ModalHeader>\n                <ModalBody modifier=\"slide-in-left\">\n                  <StyledList>\n                    {items.map((item: ItemProps) => (\n                      <StyledListItem key={item.value}>\n                        <ToggleItem\n                          id={item.value}\n                          value={item.value}\n                          checked={item.selected}\n                          label={item.label}\n                          component=\"div\"\n                          onChange={() => {\n                            onFilterToggle(item.value);\n                          }}\n                        />\n                      </StyledListItem>\n                    ))}\n                  </StyledList>\n                </ModalBody>\n              </>\n            )}\n          </Modal>\n        </StyledButtonsWrapper>\n      )}\n      {!isNarrowScreen && (\n        <>\n          <StyledHeading>{heading}</StyledHeading>\n          <StyledButtonsWrapper>\n            {items.map((item: ItemProps) => (\n              <StyledButtonElementWrapper key={item.value}>\n                <Button\n                  type=\"button\"\n                  size=\"normal\"\n                  greyLightest={!item.selected}\n                  borderShape=\"rounded\"\n                  onClick={() => {\n                    onFilterToggle(item.value);\n                  }}>\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </Button>\n              </StyledButtonElementWrapper>\n            ))}\n          </StyledButtonsWrapper>\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"]} */"));
|
|
96
96
|
|
|
97
97
|
var ButtonRemoveText = _styled("span", {
|
|
98
98
|
target: "e1yaxziw8",
|
|
99
99
|
label: "ButtonRemoveText"
|
|
100
|
-
})(fonts.sizes('16px', '32px'), ";font-weight:", fonts.weight.semibold, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZpbHRlckJ1dHRvbnMudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXFFb0MiLCJmaWxlIjoiRmlsdGVyQnV0dG9ucy50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMS1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCwgeyB1c2VFZmZlY3QsIHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuLy8gQHRzLWlnbm9yZVxuaW1wb3J0IEJ1dHRvbiBmcm9tICdAbmRsYS9idXR0b24nO1xuaW1wb3J0IHsgYnJlYWtwb2ludHMsIGNvbG9ycywgZm9udHMsIG1xLCBzcGFjaW5nIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgeyB1c2VUcmFuc2xhdGlvbiB9IGZyb20gJ3JlYWN0LWkxOG5leHQnO1xuLy8gQHRzLWlnbm9yZVxuaW1wb3J0IHsgQ3Jvc3MgYXMgQ3Jvc3NJY29uLCBQbHVzIGFzIFBsdXNJY29uIH0gZnJvbSAnQG5kbGEvaWNvbnMvYWN0aW9uJztcbi8vIEB0cy1pZ25vcmVcbmltcG9ydCBNb2RhbCwgeyBNb2RhbEhlYWRlciwgTW9kYWxCb2R5LCBNb2RhbENsb3NlQnV0dG9uIH0gZnJvbSAnQG5kbGEvbW9kYWwnO1xuXG4vLyBAdHMtaWdub3JlXG5pbXBvcnQgVG9nZ2xlSXRlbSBmcm9tICcuL1RvZ2dsZUl0ZW0nO1xuXG5jb25zdCBTdHlsZWRIZWFkaW5nID0gc3R5bGVkLmgzYFxuICAke2ZvbnRzLnNpemVzKCcxNnB4JywgJzMycHgnKX07XG4gIG1hcmdpbjogMCAwICR7c3BhY2luZy5zbWFsbH07XG4gIGNvbG9yOiAke2NvbG9ycy50ZXh0LmxpZ2h0fTtcbiAgZm9udC13ZWlnaHQ6ICR7Zm9udHMud2VpZ2h0LnNlbWlib2xkfTtcbmA7XG5cbmNvbnN0IFN0eWxlZEJ1dHRvbnNXcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC13cmFwOiB3cmFwO1xuYDtcblxuY29uc3QgU3R5bGVkQnV0dG9uRWxlbWVudFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICBtYXJnaW46IDAgJHtzcGFjaW5nLnhzbWFsbH0gJHtzcGFjaW5nLnhzbWFsbH0gMDtcbiAgYnJlYWstaW5zaWRlOiBhdm9pZDtcbmA7XG5cbmNvbnN0IFN0eWxlZExpc3QgPSBzdHlsZWQudWxgXG4gIGxpc3Qtc3R5bGU6IG5vbmU7XG4gIG1hcmdpbjogMDtcbiAgcGFkZGluZzogMDtcbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLnRhYmxldCB9KX0ge1xuICAgIGNvbHVtbi1jb3VudDogMjtcbiAgICBjb2x1bW4tZ2FwOiAyMHB4O1xuICB9XG4gICR7bXEucmFuZ2UoeyBmcm9tOiBicmVha3BvaW50cy50YWJsZXRXaWRlIH0pfSB7XG4gICAgY29sdW1uLWNvdW50OiAzO1xuICAgIGNvbHVtbi1nYXA6IDIwcHg7XG4gIH1cbmA7XG5jb25zdCBTdHlsZWRMaXN0SXRlbSA9IHN0eWxlZC5saWBcbiAgbWFyZ2luLWJvdHRvbTogMDtcbiAgYnJlYWstaW5zaWRlOiBhdm9pZDtcbmA7XG5cbmNvbnN0IFN0eWxlZEJ1dHRvbkNvbnRlbnQgPSBzdHlsZWQuc3BhbmBgO1xuXG5jb25zdCBTdHlsZWRCdXR0b25Db250ZW50U2VsZWN0ZWQgPSBzdHlsZWQuc3BhbmBcbiAgbWFyZ2luLWxlZnQ6ICR7c3BhY2luZy5zbWFsbH07XG4gIGRpc3BsYXk6IGlubGluZS1mbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuYDtcblxuY29uc3QgU3R5bGVkUmVtb3ZlV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIG1hcmdpbi10b3A6ICR7c3BhY2luZy54c21hbGx9O1xuYDtcblxuY29uc3QgQnV0dG9uUmVtb3ZlVGV4dCA9IHN0eWxlZC5zcGFuYFxuICAke2ZvbnRzLnNpemVzKCcxNnB4JywgJzMycHgnKX07XG4gIGZvbnQtd2VpZ2h0OiAke2ZvbnRzLndlaWdodC5zZW1pYm9sZH07XG5gO1xuXG5leHBvcnQgdHlwZSBJdGVtUHJvcHMgPSB7XG4gIGxhYmVsOiBzdHJpbmc7XG4gIHZhbHVlOiBzdHJpbmc7XG4gIHNlbGVjdGVkPzogYm9vbGVhbjtcbn07XG50eXBlIFByb3BzID0ge1xuICBoZWFkaW5nOiBzdHJpbmc7XG4gIGl0ZW1zOiBJdGVtUHJvcHNbXTtcbiAgb25GaWx0ZXJUb2dnbGU6ICh2YWx1ZTogc3RyaW5nKSA9PiB2b2lkO1xuICBvblJlbW92ZUFsbEZpbHRlcnM6ICgpID0+IHZvaWQ7XG4gIGxhYmVsczoge1xuICAgIG9wZW5GaWx0ZXI6IHN0cmluZztcbiAgfTtcbn07XG5cbmV4cG9ydCBjb25zdCBGaWx0ZXJCdXR0b25zID0gKHsgaGVhZGluZywgaXRlbXMsIG9uRmlsdGVyVG9nZ2xlLCBvblJlbW92ZUFsbEZpbHRlcnMsIGxhYmVscyB9OiBQcm9wcykgPT4ge1xuICBjb25zdCB7IHQgfSA9IHVzZVRyYW5zbGF0aW9uKCk7XG4gIGNvbnN0IFtpc05hcnJvd1NjcmVlbiwgc2V0SXNOYXJyb3dTY3JlZW5dID0gdXNlU3RhdGUoZmFsc2UpO1xuXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgY29uc3QgaXNOYXJyb3dTY3JlZW5NYXRjaCA9IHdpbmRvdy5tYXRjaE1lZGlhKCcobWF4LXdpZHRoOiA3NjdweCknKTtcbiAgICBjb25zdCBoYW5kbGVDaGFuZ2UgPSAoZTogTWVkaWFRdWVyeUxpc3RFdmVudCB8IE1lZGlhUXVlcnlMaXN0KSA9PiB7XG4gICAgICBzZXRJc05hcnJvd1NjcmVlbihlLm1hdGNoZXMpO1xuICAgIH07XG4gICAgaXNOYXJyb3dTY3JlZW5NYXRjaC5hZGRFdmVudExpc3RlbmVyKCdjaGFuZ2UnLCBoYW5kbGVDaGFuZ2UpO1xuICAgIGhhbmRsZUNoYW5nZShpc05hcnJvd1NjcmVlbk1hdGNoKTtcbiAgICByZXR1cm4gKCkgPT4ge1xuICAgICAgaXNOYXJyb3dTY3JlZW5NYXRjaC5yZW1vdmVFdmVudExpc3RlbmVyKCdjaGFuZ2UnLCBoYW5kbGVDaGFuZ2UpO1xuICAgIH07XG4gIH0sIFtdKTtcblxuICBjb25zdCBoYXNTZWxlY3RlZEZpbHRlcnMgPSBpdGVtcy5zb21lKChpdGVtKSA9PiB7XG4gICAgcmV0dXJuIGl0ZW0uc2VsZWN0ZWQ7XG4gIH0pO1xuXG4gIGNvbnN0IGFjdGl2ZUl0ZW1zID0gaXRlbXMuZmlsdGVyKChpdGVtKSA9PiBpdGVtLnNlbGVjdGVkKTtcblxuICByZXR1cm4gKFxuICAgIDw+XG4gICAgICB7aXNOYXJyb3dTY3JlZW4gJiYgKFxuICAgICAgICA8U3R5bGVkQnV0dG9uc1dyYXBwZXI+XG4gICAgICAgICAge2FjdGl2ZUl0ZW1zLm1hcCgoaXRlbTogSXRlbVByb3BzKSA9PiAoXG4gICAgICAgICAgICA8U3R5bGVkQnV0dG9uRWxlbWVudFdyYXBwZXIga2V5PXtpdGVtLnZhbHVlfT5cbiAgICAgICAgICAgICAgPEJ1dHRvblxuICAgICAgICAgICAgICAgIHR5cGU9XCJidXR0b25cIlxuICAgICAgICAgICAgICAgIHNpemU9XCJub3JtYWxcIlxuICAgICAgICAgICAgICAgIGJvcmRlclNoYXBlPVwicm91bmRlZFwiXG4gICAgICAgICAgICAgICAgb25DbGljaz17KCkgPT4ge1xuICAgICAgICAgICAgICAgICAgb25GaWx0ZXJUb2dnbGUoaXRlbS52YWx1ZSk7XG4gICAgICAgICAgICAgICAgfX0+XG4gICAgICAgICAgICAgICAgPFN0eWxlZEJ1dHRvbkNvbnRlbnQ+e2l0ZW0ubGFiZWx9PC9TdHlsZWRCdXR0b25Db250ZW50PlxuICAgICAgICAgICAgICAgIDxTdHlsZWRCdXR0b25Db250ZW50U2VsZWN0ZWQ+XG4gICAgICAgICAgICAgICAgICA8Q3Jvc3NJY29uIC8+XG4gICAgICAgICAgICAgICAgPC9TdHlsZWRCdXR0b25Db250ZW50U2VsZWN0ZWQ+XG4gICAgICAgICAgICAgIDwvQnV0dG9uPlxuICAgICAgICAgICAgPC9TdHlsZWRCdXR0b25FbGVtZW50V3JhcHBlcj5cbiAgICAgICAgICApKX1cbiAgICAgICAgICA8TW9kYWxcbiAgICAgICAgICAgIHNpemU9XCJmdWxsc2NyZWVuXCJcbiAgICAgICAgICAgIGFuaW1hdGlvbj1cInN1YnRsZVwiXG4gICAgICAgICAgICBiYWNrZ3JvdW5kQ29sb3I9XCJ3aGl0ZVwiXG4gICAgICAgICAgICBhY3RpdmF0ZUJ1dHRvbj17XG4gICAgICAgICAgICAgIDxTdHlsZWRCdXR0b25FbGVtZW50V3JhcHBlcj5cbiAgICAgICAgICAgICAgICA8QnV0dG9uIHR5cGU9XCJidXR0b25cIiBzaXplPVwibm9ybWFsXCIgbGlnaHQgYm9yZGVyU2hhcGU9XCJyb3VuZGVkXCI+XG4gICAgICAgICAgICAgICAgICA8U3R5bGVkQnV0dG9uQ29udGVudD57bGFiZWxzLm9wZW5GaWx0ZXJ9PC9TdHlsZWRCdXR0b25Db250ZW50PlxuICAgICAgICAgICAgICAgICAgPFN0eWxlZEJ1dHRvbkNvbnRlbnRTZWxlY3RlZD5cbiAgICAgICAgICAgICAgICAgICAgPFBsdXNJY29uIC8+XG4gICAgICAgICAgICAgICAgICA8L1N0eWxlZEJ1dHRvbkNvbnRlbnRTZWxlY3RlZD5cbiAgICAgICAgICAgICAgICA8L0J1dHRvbj5cbiAgICAgICAgICAgICAgPC9TdHlsZWRCdXR0b25FbGVtZW50V3JhcHBlcj5cbiAgICAgICAgICAgIH0+
|
|
100
|
+
})(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":"AAqEoC","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 */\n\nimport React, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\n// @ts-ignore\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\n// @ts-ignore\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\n// @ts-ignore\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\n\n// @ts-ignore\nimport ToggleItem from './ToggleItem';\n\nconst StyledHeading = styled.h3`\n  ${fonts.sizes('16px', '32px')};\n  margin: 0 0 ${spacing.small};\n  color: ${colors.text.light};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledButtonsWrapper = styled.div`\n  display: flex;\n  flex-wrap: wrap;\n`;\n\nconst StyledButtonElementWrapper = styled.div`\n  margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n  break-inside: avoid;\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`;\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};\ntype Props = {\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 }: Props) => {\n  const { t } = useTranslation();\n  const [isNarrowScreen, setIsNarrowScreen] = useState(false);\n\n  useEffect(() => {\n    const isNarrowScreenMatch = window.matchMedia('(max-width: 767px)');\n    const handleChange = (e: MediaQueryListEvent | MediaQueryList) => {\n      setIsNarrowScreen(e.matches);\n    };\n    isNarrowScreenMatch.addEventListener('change', handleChange);\n    handleChange(isNarrowScreenMatch);\n    return () => {\n      isNarrowScreenMatch.removeEventListener('change', handleChange);\n    };\n  }, []);\n\n  const hasSelectedFilters = items.some((item) => {\n    return item.selected;\n  });\n\n  const activeItems = items.filter((item) => item.selected);\n\n  return (\n    <>\n      {isNarrowScreen && (\n        <StyledButtonsWrapper>\n          {activeItems.map((item: ItemProps) => (\n            <StyledButtonElementWrapper key={item.value}>\n              <Button\n                type=\"button\"\n                size=\"normal\"\n                borderShape=\"rounded\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}>\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </Button>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal\n            size=\"fullscreen\"\n            animation=\"subtle\"\n            backgroundColor=\"white\"\n            activateButton={\n              <StyledButtonElementWrapper>\n                <Button type=\"button\" size=\"normal\" light borderShape=\"rounded\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </Button>\n              </StyledButtonElementWrapper>\n            }>\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier={['left-align']}>\n                  <h1>{heading}</h1>\n                  <ModalCloseButton title={t('modal.closeModal')} onClick={onClose} />\n                </ModalHeader>\n                <ModalBody modifier=\"slide-in-left\">\n                  <StyledList>\n                    {items.map((item: ItemProps) => (\n                      <StyledListItem key={item.value}>\n                        <ToggleItem\n                          id={item.value}\n                          value={item.value}\n                          checked={item.selected}\n                          label={item.label}\n                          component=\"div\"\n                          onChange={() => {\n                            onFilterToggle(item.value);\n                          }}\n                        />\n                      </StyledListItem>\n                    ))}\n                  </StyledList>\n                </ModalBody>\n              </>\n            )}\n          </Modal>\n        </StyledButtonsWrapper>\n      )}\n      {!isNarrowScreen && (\n        <>\n          <StyledHeading>{heading}</StyledHeading>\n          <StyledButtonsWrapper>\n            {items.map((item: ItemProps) => (\n              <StyledButtonElementWrapper key={item.value}>\n                <Button\n                  type=\"button\"\n                  size=\"normal\"\n                  greyLightest={!item.selected}\n                  borderShape=\"rounded\"\n                  onClick={() => {\n                    onFilterToggle(item.value);\n                  }}>\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </Button>\n              </StyledButtonElementWrapper>\n            ))}\n          </StyledButtonsWrapper>\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"]} */"));
|
|
101
101
|
|
|
102
102
|
export var FilterButtons = function FilterButtons(_ref) {
|
|
103
103
|
var heading = _ref.heading,
|
|
@@ -32,7 +32,7 @@ var privacyTexts = function privacyTexts(lang) {
|
|
|
32
32
|
var StyledPrivacyButton = _styled("button", {
|
|
33
33
|
target: "e1yo4d830",
|
|
34
34
|
label: "StyledPrivacyButton"
|
|
35
|
-
})("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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZvb3RlclByaXZhY3kudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW1DeUMiLCJmaWxlIjoiRm9vdGVyUHJpdmFjeS50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxNi1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG4vLyBAdHMtaWdub3JlXG5pbXBvcnQgTW9kYWwsIHsgTW9kYWxIZWFkZXIsIE1vZGFsQm9keSwgTW9kYWxDbG9zZUJ1dHRvbiB9IGZyb20gJ0BuZGxhL21vZGFsJztcbmltcG9ydCB7IHNwYWNpbmcsIGZvbnRzLCBtaXNjLCBtcSwgYnJlYWtwb2ludHMgfSBmcm9tICdAbmRsYS9jb3JlJztcbmltcG9ydCB7IE9uZUNvbHVtbiB9IGZyb20gJy4uL0xheW91dCc7XG5pbXBvcnQgeyBMb2NhbGUgfSBmcm9tICcuLi90eXBlcyc7XG5cbmltcG9ydCBQcml2YWN5TmIgZnJvbSAnLi9wcml2YWN5X25iJztcbmltcG9ydCBQcml2YWN5Tm4gZnJvbSAnLi9wcml2YWN5X25uJztcbmltcG9ydCBQcml2YWN5RW4gZnJvbSAnLi9wcml2YWN5X2VuJztcblxudHlwZSBGb290ZXJQcml2YWN5UHJvcHMgPSB7XG4gIGxhYmVsOiBzdHJpbmc7XG4gIGxhbmc6IExvY2FsZTtcbn07XG5cbmNvbnN0IHByaXZhY3lUZXh0cyA9IChsYW5nOiBzdHJpbmcpID0+IHtcbiAgaWYgKGxhbmcgPT09ICdubicpIHtcbiAgICByZXR1cm4gPFByaXZhY3lObiAvPjtcbiAgfVxuICBpZiAobGFuZyA9PT0gJ2VuJykge1xuICAgIHJldHVybiA8UHJpdmFjeUVuIC8+O1xuICB9XG4gIHJldHVybiA8UHJpdmFjeU5iIC8+O1xufTtcblxuY29uc3QgU3R5bGVkUHJpdmFjeUJ1dHRvbiA9IHN0eWxlZC5idXR0b25gXG4gIGJhY2tncm91bmQ6IG5vbmU7XG4gIGNvbG9yOiAjZmZmO1xuICBib3JkZXI6IDA7XG4gIHBhZGRpbmc6IDA7XG4gIGJveC1zaGFkb3c6ICR7bWlzYy50ZXh0TGlua0JveFNoYWRvd307XG4gIGN1cnNvcjogcG9pbnRlcjtcbiAgbWFyZ2luLWJvdHRvbTogJHtzcGFjaW5nLmxhcmdlfTtcbiAgJjpob3ZlcixcbiAgJjpmb2N1cyB7XG4gICAgYm94LXNoYWRvdzogbm9uZTtcbiAgfVxuYDtcbmNvbnN0IFN0eWxlZEZvb3RlclRleHQgPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICA+IHNwYW4ge1xuICAgIHBhZGRpbmc6ICR7c3BhY2luZy54c21hbGx9IDA7XG4gICAgdGV4dC1hbGlnbjogY2VudGVyO1xuICB9XG4gICR7bXEucmFuZ2UoeyB1bnRpbDogYnJlYWtwb2ludHMudGFibGV0V2lkZSB9KX0ge1xuICAgICR7Zm9udHMuc2l6ZXMoMTYsIDEuNSl9O1xuICAgID4gc3BhbiB7XG4gICAgICBwYWRkaW5nOiAwO1xuICAgIH1cbiAgfVxuICAke21xLnJhbmdlKHsgdW50aWw6IGJyZWFrcG9pbnRzLm1vYmlsZVdpZGUgfSl9IHtcbiAgICAke2ZvbnRzLnNpemVzKDE0LCAxLjMpfTtcbiAgICA+IHNwYW4ge1xuICAgICAgcGFkZGluZy1ib3R0b206ICR7c3BhY2luZy54c21hbGx9O1xuICAgIH1cbiAgfVxuYDtcblxuY29uc3QgRm9vdGVyUHJpdmFjeTogUmVhY3QuRnVuY3Rpb25Db21wb25lbnQ8Rm9vdGVyUHJpdmFjeVByb3BzPiA9ICh7IGxhbmcsIGxhYmVsIH0pID0+IChcbiAgPFN0eWxlZEZvb3RlclRleHQ+XG4gICAgPE1vZGFsIGFjdGl2YXRlQnV0dG9uPXs8U3R5bGVkUHJpdmFjeUJ1dHRvbiB0eXBlPVwiYnV0dG9uXCI+e2xhYmVsfTwvU3R5bGVkUHJpdmFjeUJ1dHRvbj59IHNpemU9XCJmdWxsc2NyZWVuXCI+
|
|
35
|
+
})("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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZvb3RlclByaXZhY3kudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW1DeUMiLCJmaWxlIjoiRm9vdGVyUHJpdmFjeS50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxNi1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG4vLyBAdHMtaWdub3JlXG5pbXBvcnQgTW9kYWwsIHsgTW9kYWxIZWFkZXIsIE1vZGFsQm9keSwgTW9kYWxDbG9zZUJ1dHRvbiB9IGZyb20gJ0BuZGxhL21vZGFsJztcbmltcG9ydCB7IHNwYWNpbmcsIGZvbnRzLCBtaXNjLCBtcSwgYnJlYWtwb2ludHMgfSBmcm9tICdAbmRsYS9jb3JlJztcbmltcG9ydCB7IE9uZUNvbHVtbiB9IGZyb20gJy4uL0xheW91dCc7XG5pbXBvcnQgeyBMb2NhbGUgfSBmcm9tICcuLi90eXBlcyc7XG5cbmltcG9ydCBQcml2YWN5TmIgZnJvbSAnLi9wcml2YWN5X25iJztcbmltcG9ydCBQcml2YWN5Tm4gZnJvbSAnLi9wcml2YWN5X25uJztcbmltcG9ydCBQcml2YWN5RW4gZnJvbSAnLi9wcml2YWN5X2VuJztcblxudHlwZSBGb290ZXJQcml2YWN5UHJvcHMgPSB7XG4gIGxhYmVsOiBzdHJpbmc7XG4gIGxhbmc6IExvY2FsZTtcbn07XG5cbmNvbnN0IHByaXZhY3lUZXh0cyA9IChsYW5nOiBzdHJpbmcpID0+IHtcbiAgaWYgKGxhbmcgPT09ICdubicpIHtcbiAgICByZXR1cm4gPFByaXZhY3lObiAvPjtcbiAgfVxuICBpZiAobGFuZyA9PT0gJ2VuJykge1xuICAgIHJldHVybiA8UHJpdmFjeUVuIC8+O1xuICB9XG4gIHJldHVybiA8UHJpdmFjeU5iIC8+O1xufTtcblxuY29uc3QgU3R5bGVkUHJpdmFjeUJ1dHRvbiA9IHN0eWxlZC5idXR0b25gXG4gIGJhY2tncm91bmQ6IG5vbmU7XG4gIGNvbG9yOiAjZmZmO1xuICBib3JkZXI6IDA7XG4gIHBhZGRpbmc6IDA7XG4gIGJveC1zaGFkb3c6ICR7bWlzYy50ZXh0TGlua0JveFNoYWRvd307XG4gIGN1cnNvcjogcG9pbnRlcjtcbiAgbWFyZ2luLWJvdHRvbTogJHtzcGFjaW5nLmxhcmdlfTtcbiAgJjpob3ZlcixcbiAgJjpmb2N1cyB7XG4gICAgYm94LXNoYWRvdzogbm9uZTtcbiAgfVxuYDtcbmNvbnN0IFN0eWxlZEZvb3RlclRleHQgPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICA+IHNwYW4ge1xuICAgIHBhZGRpbmc6ICR7c3BhY2luZy54c21hbGx9IDA7XG4gICAgdGV4dC1hbGlnbjogY2VudGVyO1xuICB9XG4gICR7bXEucmFuZ2UoeyB1bnRpbDogYnJlYWtwb2ludHMudGFibGV0V2lkZSB9KX0ge1xuICAgICR7Zm9udHMuc2l6ZXMoMTYsIDEuNSl9O1xuICAgID4gc3BhbiB7XG4gICAgICBwYWRkaW5nOiAwO1xuICAgIH1cbiAgfVxuICAke21xLnJhbmdlKHsgdW50aWw6IGJyZWFrcG9pbnRzLm1vYmlsZVdpZGUgfSl9IHtcbiAgICAke2ZvbnRzLnNpemVzKDE0LCAxLjMpfTtcbiAgICA+IHNwYW4ge1xuICAgICAgcGFkZGluZy1ib3R0b206ICR7c3BhY2luZy54c21hbGx9O1xuICAgIH1cbiAgfVxuYDtcblxuY29uc3QgRm9vdGVyUHJpdmFjeTogUmVhY3QuRnVuY3Rpb25Db21wb25lbnQ8Rm9vdGVyUHJpdmFjeVByb3BzPiA9ICh7IGxhbmcsIGxhYmVsIH0pID0+IChcbiAgPFN0eWxlZEZvb3RlclRleHQ+XG4gICAgPE1vZGFsIGFjdGl2YXRlQnV0dG9uPXs8U3R5bGVkUHJpdmFjeUJ1dHRvbiB0eXBlPVwiYnV0dG9uXCI+e2xhYmVsfTwvU3R5bGVkUHJpdmFjeUJ1dHRvbj59IHNpemU9XCJmdWxsc2NyZWVuXCI+XG4gICAgICB7KG9uQ2xvc2U6ICgpID0+IHZvaWQpID0+IChcbiAgICAgICAgPE9uZUNvbHVtbiBjc3NNb2RpZmllcj1cIm1lZGl1bVwiPlxuICAgICAgICAgIDxNb2RhbEhlYWRlcj5cbiAgICAgICAgICAgIDxNb2RhbENsb3NlQnV0dG9uIG9uQ2xpY2s9e29uQ2xvc2V9IHRpdGxlPVwiTHVra1wiIC8+XG4gICAgICAgICAgPC9Nb2RhbEhlYWRlcj5cbiAgICAgICAgICA8TW9kYWxCb2R5Pntwcml2YWN5VGV4dHMobGFuZyl9PC9Nb2RhbEJvZHk+XG4gICAgICAgIDwvT25lQ29sdW1uPlxuICAgICAgKX1cbiAgICA8L01vZGFsPlxuICA8L1N0eWxlZEZvb3RlclRleHQ+XG4pO1xuXG5leHBvcnQgZGVmYXVsdCBGb290ZXJQcml2YWN5O1xuIl19 */"));
|
|
36
36
|
|
|
37
37
|
var StyledFooterText = _styled("div", {
|
|
38
38
|
target: "e1yo4d831",
|
|
@@ -41,7 +41,7 @@ var StyledFooterText = _styled("div", {
|
|
|
41
41
|
until: breakpoints.tabletWide
|
|
42
42
|
}), "{", fonts.sizes(16, 1.5), ";> span{padding:0;}}", mq.range({
|
|
43
43
|
until: breakpoints.mobileWide
|
|
44
|
-
}), "{", fonts.sizes(14, 1.3), ";> span{padding-bottom:", spacing.xsmall, ";}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZvb3RlclByaXZhY3kudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWdEbUMiLCJmaWxlIjoiRm9vdGVyUHJpdmFjeS50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxNi1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG4vLyBAdHMtaWdub3JlXG5pbXBvcnQgTW9kYWwsIHsgTW9kYWxIZWFkZXIsIE1vZGFsQm9keSwgTW9kYWxDbG9zZUJ1dHRvbiB9IGZyb20gJ0BuZGxhL21vZGFsJztcbmltcG9ydCB7IHNwYWNpbmcsIGZvbnRzLCBtaXNjLCBtcSwgYnJlYWtwb2ludHMgfSBmcm9tICdAbmRsYS9jb3JlJztcbmltcG9ydCB7IE9uZUNvbHVtbiB9IGZyb20gJy4uL0xheW91dCc7XG5pbXBvcnQgeyBMb2NhbGUgfSBmcm9tICcuLi90eXBlcyc7XG5cbmltcG9ydCBQcml2YWN5TmIgZnJvbSAnLi9wcml2YWN5X25iJztcbmltcG9ydCBQcml2YWN5Tm4gZnJvbSAnLi9wcml2YWN5X25uJztcbmltcG9ydCBQcml2YWN5RW4gZnJvbSAnLi9wcml2YWN5X2VuJztcblxudHlwZSBGb290ZXJQcml2YWN5UHJvcHMgPSB7XG4gIGxhYmVsOiBzdHJpbmc7XG4gIGxhbmc6IExvY2FsZTtcbn07XG5cbmNvbnN0IHByaXZhY3lUZXh0cyA9IChsYW5nOiBzdHJpbmcpID0+IHtcbiAgaWYgKGxhbmcgPT09ICdubicpIHtcbiAgICByZXR1cm4gPFByaXZhY3lObiAvPjtcbiAgfVxuICBpZiAobGFuZyA9PT0gJ2VuJykge1xuICAgIHJldHVybiA8UHJpdmFjeUVuIC8+O1xuICB9XG4gIHJldHVybiA8UHJpdmFjeU5iIC8+O1xufTtcblxuY29uc3QgU3R5bGVkUHJpdmFjeUJ1dHRvbiA9IHN0eWxlZC5idXR0b25gXG4gIGJhY2tncm91bmQ6IG5vbmU7XG4gIGNvbG9yOiAjZmZmO1xuICBib3JkZXI6IDA7XG4gIHBhZGRpbmc6IDA7XG4gIGJveC1zaGFkb3c6ICR7bWlzYy50ZXh0TGlua0JveFNoYWRvd307XG4gIGN1cnNvcjogcG9pbnRlcjtcbiAgbWFyZ2luLWJvdHRvbTogJHtzcGFjaW5nLmxhcmdlfTtcbiAgJjpob3ZlcixcbiAgJjpmb2N1cyB7XG4gICAgYm94LXNoYWRvdzogbm9uZTtcbiAgfVxuYDtcbmNvbnN0IFN0eWxlZEZvb3RlclRleHQgPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICA+IHNwYW4ge1xuICAgIHBhZGRpbmc6ICR7c3BhY2luZy54c21hbGx9IDA7XG4gICAgdGV4dC1hbGlnbjogY2VudGVyO1xuICB9XG4gICR7bXEucmFuZ2UoeyB1bnRpbDogYnJlYWtwb2ludHMudGFibGV0V2lkZSB9KX0ge1xuICAgICR7Zm9udHMuc2l6ZXMoMTYsIDEuNSl9O1xuICAgID4gc3BhbiB7XG4gICAgICBwYWRkaW5nOiAwO1xuICAgIH1cbiAgfVxuICAke21xLnJhbmdlKHsgdW50aWw6IGJyZWFrcG9pbnRzLm1vYmlsZVdpZGUgfSl9IHtcbiAgICAke2ZvbnRzLnNpemVzKDE0LCAxLjMpfTtcbiAgICA+IHNwYW4ge1xuICAgICAgcGFkZGluZy1ib3R0b206ICR7c3BhY2luZy54c21hbGx9O1xuICAgIH1cbiAgfVxuYDtcblxuY29uc3QgRm9vdGVyUHJpdmFjeTogUmVhY3QuRnVuY3Rpb25Db21wb25lbnQ8Rm9vdGVyUHJpdmFjeVByb3BzPiA9ICh7IGxhbmcsIGxhYmVsIH0pID0+IChcbiAgPFN0eWxlZEZvb3RlclRleHQ+XG4gICAgPE1vZGFsIGFjdGl2YXRlQnV0dG9uPXs8U3R5bGVkUHJpdmFjeUJ1dHRvbiB0eXBlPVwiYnV0dG9uXCI+e2xhYmVsfTwvU3R5bGVkUHJpdmFjeUJ1dHRvbj59IHNpemU9XCJmdWxsc2NyZWVuXCI+
|
|
44
|
+
}), "{", fonts.sizes(14, 1.3), ";> span{padding-bottom:", spacing.xsmall, ";}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZvb3RlclByaXZhY3kudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWdEbUMiLCJmaWxlIjoiRm9vdGVyUHJpdmFjeS50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxNi1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG4vLyBAdHMtaWdub3JlXG5pbXBvcnQgTW9kYWwsIHsgTW9kYWxIZWFkZXIsIE1vZGFsQm9keSwgTW9kYWxDbG9zZUJ1dHRvbiB9IGZyb20gJ0BuZGxhL21vZGFsJztcbmltcG9ydCB7IHNwYWNpbmcsIGZvbnRzLCBtaXNjLCBtcSwgYnJlYWtwb2ludHMgfSBmcm9tICdAbmRsYS9jb3JlJztcbmltcG9ydCB7IE9uZUNvbHVtbiB9IGZyb20gJy4uL0xheW91dCc7XG5pbXBvcnQgeyBMb2NhbGUgfSBmcm9tICcuLi90eXBlcyc7XG5cbmltcG9ydCBQcml2YWN5TmIgZnJvbSAnLi9wcml2YWN5X25iJztcbmltcG9ydCBQcml2YWN5Tm4gZnJvbSAnLi9wcml2YWN5X25uJztcbmltcG9ydCBQcml2YWN5RW4gZnJvbSAnLi9wcml2YWN5X2VuJztcblxudHlwZSBGb290ZXJQcml2YWN5UHJvcHMgPSB7XG4gIGxhYmVsOiBzdHJpbmc7XG4gIGxhbmc6IExvY2FsZTtcbn07XG5cbmNvbnN0IHByaXZhY3lUZXh0cyA9IChsYW5nOiBzdHJpbmcpID0+IHtcbiAgaWYgKGxhbmcgPT09ICdubicpIHtcbiAgICByZXR1cm4gPFByaXZhY3lObiAvPjtcbiAgfVxuICBpZiAobGFuZyA9PT0gJ2VuJykge1xuICAgIHJldHVybiA8UHJpdmFjeUVuIC8+O1xuICB9XG4gIHJldHVybiA8UHJpdmFjeU5iIC8+O1xufTtcblxuY29uc3QgU3R5bGVkUHJpdmFjeUJ1dHRvbiA9IHN0eWxlZC5idXR0b25gXG4gIGJhY2tncm91bmQ6IG5vbmU7XG4gIGNvbG9yOiAjZmZmO1xuICBib3JkZXI6IDA7XG4gIHBhZGRpbmc6IDA7XG4gIGJveC1zaGFkb3c6ICR7bWlzYy50ZXh0TGlua0JveFNoYWRvd307XG4gIGN1cnNvcjogcG9pbnRlcjtcbiAgbWFyZ2luLWJvdHRvbTogJHtzcGFjaW5nLmxhcmdlfTtcbiAgJjpob3ZlcixcbiAgJjpmb2N1cyB7XG4gICAgYm94LXNoYWRvdzogbm9uZTtcbiAgfVxuYDtcbmNvbnN0IFN0eWxlZEZvb3RlclRleHQgPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICA+IHNwYW4ge1xuICAgIHBhZGRpbmc6ICR7c3BhY2luZy54c21hbGx9IDA7XG4gICAgdGV4dC1hbGlnbjogY2VudGVyO1xuICB9XG4gICR7bXEucmFuZ2UoeyB1bnRpbDogYnJlYWtwb2ludHMudGFibGV0V2lkZSB9KX0ge1xuICAgICR7Zm9udHMuc2l6ZXMoMTYsIDEuNSl9O1xuICAgID4gc3BhbiB7XG4gICAgICBwYWRkaW5nOiAwO1xuICAgIH1cbiAgfVxuICAke21xLnJhbmdlKHsgdW50aWw6IGJyZWFrcG9pbnRzLm1vYmlsZVdpZGUgfSl9IHtcbiAgICAke2ZvbnRzLnNpemVzKDE0LCAxLjMpfTtcbiAgICA+IHNwYW4ge1xuICAgICAgcGFkZGluZy1ib3R0b206ICR7c3BhY2luZy54c21hbGx9O1xuICAgIH1cbiAgfVxuYDtcblxuY29uc3QgRm9vdGVyUHJpdmFjeTogUmVhY3QuRnVuY3Rpb25Db21wb25lbnQ8Rm9vdGVyUHJpdmFjeVByb3BzPiA9ICh7IGxhbmcsIGxhYmVsIH0pID0+IChcbiAgPFN0eWxlZEZvb3RlclRleHQ+XG4gICAgPE1vZGFsIGFjdGl2YXRlQnV0dG9uPXs8U3R5bGVkUHJpdmFjeUJ1dHRvbiB0eXBlPVwiYnV0dG9uXCI+e2xhYmVsfTwvU3R5bGVkUHJpdmFjeUJ1dHRvbj59IHNpemU9XCJmdWxsc2NyZWVuXCI+XG4gICAgICB7KG9uQ2xvc2U6ICgpID0+IHZvaWQpID0+IChcbiAgICAgICAgPE9uZUNvbHVtbiBjc3NNb2RpZmllcj1cIm1lZGl1bVwiPlxuICAgICAgICAgIDxNb2RhbEhlYWRlcj5cbiAgICAgICAgICAgIDxNb2RhbENsb3NlQnV0dG9uIG9uQ2xpY2s9e29uQ2xvc2V9IHRpdGxlPVwiTHVra1wiIC8+XG4gICAgICAgICAgPC9Nb2RhbEhlYWRlcj5cbiAgICAgICAgICA8TW9kYWxCb2R5Pntwcml2YWN5VGV4dHMobGFuZyl9PC9Nb2RhbEJvZHk+XG4gICAgICAgIDwvT25lQ29sdW1uPlxuICAgICAgKX1cbiAgICA8L01vZGFsPlxuICA8L1N0eWxlZEZvb3RlclRleHQ+XG4pO1xuXG5leHBvcnQgZGVmYXVsdCBGb290ZXJQcml2YWN5O1xuIl19 */"));
|
|
45
45
|
|
|
46
46
|
var FooterPrivacy = function FooterPrivacy(_ref) {
|
|
47
47
|
var lang = _ref.lang,
|
package/es/Table/Table.js
CHANGED
|
@@ -12,7 +12,6 @@ function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) r
|
|
|
12
12
|
*
|
|
13
13
|
*/
|
|
14
14
|
import React from 'react';
|
|
15
|
-
import PropTypes from 'prop-types';
|
|
16
15
|
import BEMHelper from 'react-bem-helper';
|
|
17
16
|
import { ZoomOutMap } from '@ndla/icons/common';
|
|
18
17
|
import { uuid } from '@ndla/util';
|
|
@@ -49,12 +48,4 @@ var Table = function Table(_ref) {
|
|
|
49
48
|
}, ___EmotionJSX("div", classes('dialog'), ___EmotionJSX("div", classes('expanded-table-wrapper'), ___EmotionJSX("div", classes('content'))))));
|
|
50
49
|
};
|
|
51
50
|
|
|
52
|
-
Table.propTypes = {
|
|
53
|
-
id: PropTypes.string,
|
|
54
|
-
messages: PropTypes.shape({
|
|
55
|
-
dialogCloseButton: PropTypes.string.isRequired,
|
|
56
|
-
expandButtonLabel: PropTypes.string.isRequired
|
|
57
|
-
}).isRequired,
|
|
58
|
-
children: PropTypes.node
|
|
59
|
-
};
|
|
60
51
|
export default Table;
|