@ndla/ui 34.6.5 → 34.6.6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/es/AudioPlayer/AudioPlayer.js +19 -19
- package/es/ErrorMessage/ErrorResourceAccessDenied.js +3 -3
- package/es/FactBox/FactBox.js +3 -3
- package/es/Figure/Figure.js +8 -10
- package/es/Filter/FilterButtons.js +20 -23
- package/es/Filter/FilterListPhone.js +7 -7
- package/es/Footer/FooterAuth.js +12 -11
- package/es/Frontpage/FrontpageProgramMenu.js +16 -16
- package/es/LearningPaths/LearningPathMenuModalWrapper.js +3 -3
- package/es/Navigation/NavigationTopicAbout.js +17 -17
- package/es/NoContentBox/NoContentBox.js +3 -3
- package/es/RelatedArticleList/RelatedArticleList.js +3 -3
- package/es/Search/ContentTypeResult.js +5 -4
- package/es/Search/ToggleSearchButton.js +4 -4
- package/es/SearchTypeResult/ActiveFilters.js +9 -10
- package/es/SearchTypeResult/PopupFilter.js +14 -14
- package/es/SearchTypeResult/ResultNavigation.js +9 -9
- package/es/SearchTypeResult/SearchHeader.js +11 -11
- package/es/SearchTypeResult/SearchNotionItem.js +18 -18
- package/es/SearchTypeResult/SearchTypeHeader.js +13 -13
- package/es/SearchTypeResult/SearchViewType.js +9 -8
- package/es/SearchTypeResult/components/SubjectFilters.js +5 -5
- package/es/User/AuthModal.js +9 -9
- package/lib/AudioPlayer/AudioPlayer.js +19 -19
- package/lib/ErrorMessage/ErrorResourceAccessDenied.js +3 -3
- package/lib/FactBox/FactBox.js +3 -3
- package/lib/Figure/Figure.js +8 -10
- package/lib/Filter/FilterButtons.js +20 -23
- package/lib/Filter/FilterListPhone.js +7 -7
- package/lib/Footer/FooterAuth.js +12 -11
- package/lib/Frontpage/FrontpageProgramMenu.js +16 -16
- package/lib/LearningPaths/LearningPathMenuModalWrapper.js +3 -3
- package/lib/Navigation/NavigationTopicAbout.js +17 -17
- package/lib/NoContentBox/NoContentBox.js +3 -3
- package/lib/RelatedArticleList/RelatedArticleList.js +3 -3
- package/lib/Search/ContentTypeResult.js +5 -4
- package/lib/Search/ToggleSearchButton.js +4 -4
- package/lib/SearchTypeResult/ActiveFilters.js +9 -10
- package/lib/SearchTypeResult/PopupFilter.js +14 -14
- package/lib/SearchTypeResult/ResultNavigation.js +9 -9
- package/lib/SearchTypeResult/SearchHeader.js +11 -11
- package/lib/SearchTypeResult/SearchNotionItem.js +18 -18
- package/lib/SearchTypeResult/SearchTypeHeader.js +13 -13
- package/lib/SearchTypeResult/SearchViewType.js +9 -8
- package/lib/SearchTypeResult/components/SubjectFilters.js +5 -5
- package/lib/User/AuthModal.js +9 -9
- package/package.json +2 -2
- package/src/AudioPlayer/AudioPlayer.tsx +9 -9
- package/src/ErrorMessage/ErrorResourceAccessDenied.tsx +3 -3
- package/src/FactBox/FactBox.tsx +3 -3
- package/src/Figure/Figure.tsx +7 -13
- package/src/Filter/FilterButtons.tsx +12 -14
- package/src/Filter/FilterListPhone.tsx +7 -7
- package/src/Footer/FooterAuth.tsx +4 -4
- package/src/Frontpage/FrontpageProgramMenu.tsx +13 -5
- package/src/LearningPaths/LearningPathMenuModalWrapper.tsx +3 -3
- package/src/Navigation/NavigationTopicAbout.tsx +4 -4
- package/src/NoContentBox/NoContentBox.tsx +3 -3
- package/src/RelatedArticleList/RelatedArticleList.tsx +4 -4
- package/src/Search/ContentTypeResult.tsx +5 -4
- package/src/Search/ToggleSearchButton.tsx +2 -2
- package/src/SearchTypeResult/ActiveFilters.tsx +4 -5
- package/src/SearchTypeResult/PopupFilter.tsx +9 -9
- package/src/SearchTypeResult/ResultNavigation.tsx +5 -5
- package/src/SearchTypeResult/SearchHeader.tsx +3 -3
- package/src/SearchTypeResult/SearchNotionItem.tsx +5 -5
- package/src/SearchTypeResult/SearchTypeHeader.tsx +5 -5
- package/src/SearchTypeResult/SearchViewType.tsx +5 -4
- package/src/SearchTypeResult/components/SubjectFilters.tsx +3 -3
- package/src/User/AuthModal.tsx +3 -3
|
@@ -11,14 +11,14 @@ import React from 'react';
|
|
|
11
11
|
import { useTranslation } from 'react-i18next';
|
|
12
12
|
import { spacing } from '@ndla/core';
|
|
13
13
|
import { HumanMaleBoard, LogIn } from '@ndla/icons/common';
|
|
14
|
-
import
|
|
14
|
+
import { ButtonV2 } from '@ndla/button';
|
|
15
15
|
import ErrorMessage from './ErrorMessage';
|
|
16
16
|
import { jsx as _jsx } from "@emotion/react/jsx-runtime";
|
|
17
17
|
import { jsxs as _jsxs } from "@emotion/react/jsx-runtime";
|
|
18
18
|
var StyledLogInIconWrapper = /*#__PURE__*/_styled("span", {
|
|
19
19
|
target: "e1a7kjll0",
|
|
20
20
|
label: "StyledLogInIconWrapper"
|
|
21
|
-
})("margin-left:", spacing.xsmall, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
21
|
+
})("margin-left:", spacing.xsmall, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkVycm9yUmVzb3VyY2VBY2Nlc3NEZW5pZWQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWlCMEMiLCJmaWxlIjoiRXJyb3JSZXNvdXJjZUFjY2Vzc0RlbmllZC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMS1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyB1c2VUcmFuc2xhdGlvbiB9IGZyb20gJ3JlYWN0LWkxOG5leHQnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgc3BhY2luZyB9IGZyb20gJ0BuZGxhL2NvcmUnO1xuaW1wb3J0IHsgSHVtYW5NYWxlQm9hcmQsIExvZ0luIH0gZnJvbSAnQG5kbGEvaWNvbnMvY29tbW9uJztcbmltcG9ydCB7IEJ1dHRvblYyIH0gZnJvbSAnQG5kbGEvYnV0dG9uJztcblxuaW1wb3J0IEVycm9yTWVzc2FnZSBmcm9tICcuL0Vycm9yTWVzc2FnZSc7XG5cbmNvbnN0IFN0eWxlZExvZ0luSWNvbldyYXBwZXIgPSBzdHlsZWQuc3BhbmBcbiAgbWFyZ2luLWxlZnQ6ICR7c3BhY2luZy54c21hbGx9O1xuYDtcblxudHlwZSBQcm9wcyA9IHtcbiAgb25BdXRoZW50aWNhdGVDbGljazogKCkgPT4gdm9pZDtcbn07XG5jb25zdCBFcnJvclJlc291cmNlQWNjZXNzRGVuaWVkID0gKHsgb25BdXRoZW50aWNhdGVDbGljayB9OiBQcm9wcykgPT4ge1xuICBjb25zdCB7IHQgfSA9IHVzZVRyYW5zbGF0aW9uKCk7XG4gIHJldHVybiAoXG4gICAgPEVycm9yTWVzc2FnZVxuICAgICAgbWVzc2FnZXM9e3tcbiAgICAgICAgdGl0bGU6IHQoJ3VzZXIucmVzb3VyY2UuYWNjZXNzRGVuaWVkJyksXG4gICAgICAgIGJhY2s6IHQoJ2Vycm9yTWVzc2FnZS5iYWNrJyksXG4gICAgICAgIGdvVG9Gcm9udFBhZ2U6IHQoJ2Vycm9yTWVzc2FnZS5nb1RvRnJvbnRQYWdlJyksXG4gICAgICB9fVxuICAgICAgaWxsdXN0cmF0aW9uRWxlbWVudD17PEh1bWFuTWFsZUJvYXJkIGNsYXNzTmFtZT1cImMtaWNvbi0tbGFyZ2VcIiAvPn1cbiAgICAgIGN1c3RvbUVsZW1lbnQ9e1xuICAgICAgICA8QnV0dG9uVjIgc2l6ZT1cIm1lZGl1bVwiIG9uQ2xpY2s9e29uQXV0aGVudGljYXRlQ2xpY2t9PlxuICAgICAgICAgIHt0KCd1c2VyLmJ1dHRvbkxvZ0luJyl9XG4gICAgICAgICAgPFN0eWxlZExvZ0luSWNvbldyYXBwZXIgYXJpYS1oaWRkZW4+XG4gICAgICAgICAgICA8TG9nSW4gY2xhc3NOYW1lPVwiYy1pY29uLS1tZWRpdW1cIiAvPlxuICAgICAgICAgIDwvU3R5bGVkTG9nSW5JY29uV3JhcHBlcj5cbiAgICAgICAgPC9CdXR0b25WMj5cbiAgICAgIH1cbiAgICAvPlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgRXJyb3JSZXNvdXJjZUFjY2Vzc0RlbmllZDtcbiJdfQ== */"));
|
|
22
22
|
var ErrorResourceAccessDenied = function ErrorResourceAccessDenied(_ref) {
|
|
23
23
|
var onAuthenticateClick = _ref.onAuthenticateClick;
|
|
24
24
|
var _useTranslation = useTranslation(),
|
|
@@ -32,7 +32,7 @@ var ErrorResourceAccessDenied = function ErrorResourceAccessDenied(_ref) {
|
|
|
32
32
|
illustrationElement: _jsx(HumanMaleBoard, {
|
|
33
33
|
className: "c-icon--large"
|
|
34
34
|
}),
|
|
35
|
-
customElement: _jsxs(
|
|
35
|
+
customElement: _jsxs(ButtonV2, {
|
|
36
36
|
size: "medium",
|
|
37
37
|
onClick: onAuthenticateClick,
|
|
38
38
|
children: [t('user.buttonLogIn'), _jsx(StyledLogInIconWrapper, {
|
package/es/FactBox/FactBox.js
CHANGED
|
@@ -11,7 +11,7 @@ function _defineProperty(obj, key, value) { if (key in obj) { Object.definePrope
|
|
|
11
11
|
|
|
12
12
|
import React from 'react';
|
|
13
13
|
import BEMHelper from 'react-bem-helper';
|
|
14
|
-
import
|
|
14
|
+
import { ButtonV2 } from '@ndla/button';
|
|
15
15
|
import { useTranslation } from 'react-i18next';
|
|
16
16
|
import { jsx as _jsx } from "@emotion/react/jsx-runtime";
|
|
17
17
|
import { jsxs as _jsxs } from "@emotion/react/jsx-runtime";
|
|
@@ -34,10 +34,10 @@ var FactBox = function FactBox(_ref) {
|
|
|
34
34
|
children: [_jsx("div", _objectSpread(_objectSpread({}, classes('content')), {}, {
|
|
35
35
|
dangerouslySetInnerHTML: dangerouslySetInnerHTML,
|
|
36
36
|
children: children
|
|
37
|
-
})), _jsx(
|
|
37
|
+
})), _jsx(ButtonV2, _objectSpread(_objectSpread({}, classes('button', 'collapsed')), {}, {
|
|
38
38
|
onClick: toggleFactBox,
|
|
39
39
|
title: t('factbox.open')
|
|
40
|
-
})), _jsx(
|
|
40
|
+
})), _jsx(ButtonV2, _objectSpread(_objectSpread({}, classes('button', 'open')), {}, {
|
|
41
41
|
onClick: toggleFactBox,
|
|
42
42
|
title: t('factbox.close')
|
|
43
43
|
}))]
|
package/es/Figure/Figure.js
CHANGED
|
@@ -21,7 +21,7 @@ import { isFunction as isFunctionHelper, parseMarkdown } from '@ndla/util';
|
|
|
21
21
|
import { Link as LinkIcon } from '@ndla/icons/common';
|
|
22
22
|
import { LicenseByline } from '@ndla/notion';
|
|
23
23
|
import SafeLink from '@ndla/safelink';
|
|
24
|
-
import
|
|
24
|
+
import { ButtonV2 } from '@ndla/button';
|
|
25
25
|
import { isMobile } from 'react-device-detect';
|
|
26
26
|
import { jsx as _jsx } from "@emotion/react/jsx-runtime";
|
|
27
27
|
import { jsxs as _jsxs } from "@emotion/react/jsx-runtime";
|
|
@@ -61,19 +61,17 @@ export var FigureCaption = function FigureCaption(_ref) {
|
|
|
61
61
|
return author.name;
|
|
62
62
|
}).join(', ')
|
|
63
63
|
})), _jsxs("div", {
|
|
64
|
-
children: [modalButton ? modalButton : _jsx(
|
|
65
|
-
|
|
66
|
-
|
|
64
|
+
children: [modalButton ? modalButton : _jsx(ButtonV2, {
|
|
65
|
+
shape: "pill",
|
|
66
|
+
variant: "outline",
|
|
67
67
|
size: "small",
|
|
68
|
-
type: "button",
|
|
69
68
|
"data-dialog-trigger-id": id,
|
|
70
69
|
"data-dialog-source-id": figureId,
|
|
71
70
|
children: reuseLabel
|
|
72
|
-
}), hasLinkedVideo && (linkedVideoButton ? linkedVideoButton : _jsxs(
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
size: "small"
|
|
76
|
-
type: "button"
|
|
71
|
+
}), hasLinkedVideo && (linkedVideoButton ? linkedVideoButton : _jsxs(ButtonV2, _objectSpread(_objectSpread({
|
|
72
|
+
shape: "pill",
|
|
73
|
+
variant: "outline",
|
|
74
|
+
size: "small"
|
|
77
75
|
}, classes('toggleAlternativeVideo')), {}, {
|
|
78
76
|
children: [_jsx("span", {
|
|
79
77
|
className: "original",
|
|
@@ -14,7 +14,7 @@ function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringif
|
|
|
14
14
|
*
|
|
15
15
|
*/
|
|
16
16
|
import React, { useEffect, useState } from 'react';
|
|
17
|
-
import
|
|
17
|
+
import { ButtonV2 } from '@ndla/button';
|
|
18
18
|
import { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';
|
|
19
19
|
import { useTranslation } from 'react-i18next';
|
|
20
20
|
import { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';
|
|
@@ -27,7 +27,7 @@ import { Fragment as _Fragment } from "@emotion/react/jsx-runtime";
|
|
|
27
27
|
var StyledHeading = /*#__PURE__*/_styled("h3", {
|
|
28
28
|
target: "e1yaxziw8",
|
|
29
29
|
label: "StyledHeading"
|
|
30
|
-
})(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,
|
|
30
|
+
})(fonts.sizes('16px', '32px'), ";margin:0 0 ", spacing.small, ";color:", colors.text.light, ";font-weight:", fonts.weight.semibold, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilterButtons.tsx"],"names":[],"mappings":"AAiB+B","file":"FilterButtons.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\nimport React, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\nimport ToggleItem from './ToggleItem';\nimport FilterCarousel from './FilterCarousel';\n\nconst StyledHeading = styled.h3`\n  ${fonts.sizes('16px', '32px')};\n  margin: 0 0 ${spacing.small};\n  color: ${colors.text.light};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledButtonsWrapper = styled.div`\n  display: inline-flex;\n  flex-wrap: wrap;\n`;\n\nconst StyledButtonElementWrapper = styled.div`\n  margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n  break-inside: avoid;\n  flex-shrink: 0;\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    column-count: 2;\n    column-gap: 20px;\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    column-count: 3;\n    column-gap: 20px;\n  }\n`;\nconst StyledListItem = styled.li`\n  margin-bottom: 0;\n  break-inside: avoid;\n`;\n\nconst StyledButtonContent = styled.span``;\n\nconst StyledButtonContentSelected = styled.span`\n  margin-left: ${spacing.small};\n  display: inline-flex;\n  align-items: center;\n`;\n\nconst StyledRemoveWrapper = styled.div`\n  margin-top: ${spacing.xsmall};\n  margin-left: 10px;\n`;\n\nconst ButtonRemoveText = styled.span`\n  ${fonts.sizes('16px', '32px')};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nexport type ItemProps = {\n  label: string;\n  value: string;\n  selected?: boolean;\n};\nexport type FilterButtonsProps = {\n  heading?: string;\n  items: ItemProps[];\n  onFilterToggle: (value: string) => void;\n  onRemoveAllFilters: () => void;\n  labels: {\n    openFilter: string;\n  };\n};\n\nexport const FilterButtons = ({ heading, items, onFilterToggle, onRemoveAllFilters, labels }: FilterButtonsProps) => {\n  const { t } = useTranslation();\n  const [isNarrowScreen, setIsNarrowScreen] = useState(false);\n\n  useEffect(() => {\n    const isNarrowScreenMatch = window.matchMedia('(max-width: 767px)');\n    const handleChange = (e: MediaQueryListEvent | MediaQueryList) => {\n      setIsNarrowScreen(e.matches);\n    };\n    isNarrowScreenMatch.addEventListener('change', handleChange);\n    handleChange(isNarrowScreenMatch);\n    return () => {\n      isNarrowScreenMatch.removeEventListener('change', handleChange);\n    };\n  }, []);\n\n  const hasSelectedFilters = items.some((item) => {\n    return item.selected;\n  });\n\n  const activeItems = items.filter((item) => item.selected);\n\n  return (\n    <>\n      {isNarrowScreen && (\n        <StyledButtonsWrapper>\n          {activeItems.map((item: ItemProps) => (\n            <StyledButtonElementWrapper key={item.value}>\n              <ButtonV2\n                size=\"normal\"\n                shape=\"pill\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}>\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </ButtonV2>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal\n            label={t('searchPage.searchFilterMessages.resourceTypeFilter.button')}\n            size=\"fullscreen\"\n            animation=\"subtle\"\n            backgroundColor=\"white\"\n            activateButton={\n              <StyledButtonElementWrapper>\n                <ButtonV2 colorTheme=\"light\" size=\"normal\" shape=\"pill\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </ButtonV2>\n              </StyledButtonElementWrapper>\n            }>\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier={['left-align']}>\n                  <h1>{heading}</h1>\n                  <ModalCloseButton title={t('modal.closeModal')} onClick={onClose} />\n                </ModalHeader>\n                <ModalBody modifier=\"slide-in-left\">\n                  <StyledList>\n                    {items.map((item: ItemProps) => (\n                      <StyledListItem key={item.value}>\n                        <ToggleItem\n                          id={item.value}\n                          value={item.value}\n                          checked={item.selected}\n                          label={item.label}\n                          component=\"div\"\n                          onChange={() => onFilterToggle(item.value)}\n                        />\n                      </StyledListItem>\n                    ))}\n                  </StyledList>\n                </ModalBody>\n              </>\n            )}\n          </Modal>\n        </StyledButtonsWrapper>\n      )}\n      {!isNarrowScreen && (\n        <>\n          {heading && <StyledHeading>{heading}</StyledHeading>}\n          <FilterCarousel>\n            {items.map((item: ItemProps) => (\n              <StyledButtonElementWrapper key={item.value}>\n                <ButtonV2\n                  size=\"normal\"\n                  colorTheme={!item.selected ? 'greyLighter' : undefined}\n                  shape=\"pill\"\n                  onClick={() => onFilterToggle(item.value)}>\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </ButtonV2>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <ButtonV2 variant=\"link\" onClick={onRemoveAllFilters}>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </ButtonV2>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */"));
|
|
31
31
|
var StyledButtonsWrapper = /*#__PURE__*/_styled("div", {
|
|
32
32
|
target: "e1yaxziw7",
|
|
33
33
|
label: "StyledButtonsWrapper"
|
|
@@ -37,13 +37,13 @@ var StyledButtonsWrapper = /*#__PURE__*/_styled("div", {
|
|
|
37
37
|
} : {
|
|
38
38
|
name: "1uo5tpo",
|
|
39
39
|
styles: "display:inline-flex;flex-wrap:wrap",
|
|
40
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
40
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilterButtons.tsx"],"names":[],"mappings":"AAwBuC","file":"FilterButtons.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\nimport React, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\nimport ToggleItem from './ToggleItem';\nimport FilterCarousel from './FilterCarousel';\n\nconst StyledHeading = styled.h3`\n  ${fonts.sizes('16px', '32px')};\n  margin: 0 0 ${spacing.small};\n  color: ${colors.text.light};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledButtonsWrapper = styled.div`\n  display: inline-flex;\n  flex-wrap: wrap;\n`;\n\nconst StyledButtonElementWrapper = styled.div`\n  margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n  break-inside: avoid;\n  flex-shrink: 0;\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    column-count: 2;\n    column-gap: 20px;\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    column-count: 3;\n    column-gap: 20px;\n  }\n`;\nconst StyledListItem = styled.li`\n  margin-bottom: 0;\n  break-inside: avoid;\n`;\n\nconst StyledButtonContent = styled.span``;\n\nconst StyledButtonContentSelected = styled.span`\n  margin-left: ${spacing.small};\n  display: inline-flex;\n  align-items: center;\n`;\n\nconst StyledRemoveWrapper = styled.div`\n  margin-top: ${spacing.xsmall};\n  margin-left: 10px;\n`;\n\nconst ButtonRemoveText = styled.span`\n  ${fonts.sizes('16px', '32px')};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nexport type ItemProps = {\n  label: string;\n  value: string;\n  selected?: boolean;\n};\nexport type FilterButtonsProps = {\n  heading?: string;\n  items: ItemProps[];\n  onFilterToggle: (value: string) => void;\n  onRemoveAllFilters: () => void;\n  labels: {\n    openFilter: string;\n  };\n};\n\nexport const FilterButtons = ({ heading, items, onFilterToggle, onRemoveAllFilters, labels }: FilterButtonsProps) => {\n  const { t } = useTranslation();\n  const [isNarrowScreen, setIsNarrowScreen] = useState(false);\n\n  useEffect(() => {\n    const isNarrowScreenMatch = window.matchMedia('(max-width: 767px)');\n    const handleChange = (e: MediaQueryListEvent | MediaQueryList) => {\n      setIsNarrowScreen(e.matches);\n    };\n    isNarrowScreenMatch.addEventListener('change', handleChange);\n    handleChange(isNarrowScreenMatch);\n    return () => {\n      isNarrowScreenMatch.removeEventListener('change', handleChange);\n    };\n  }, []);\n\n  const hasSelectedFilters = items.some((item) => {\n    return item.selected;\n  });\n\n  const activeItems = items.filter((item) => item.selected);\n\n  return (\n    <>\n      {isNarrowScreen && (\n        <StyledButtonsWrapper>\n          {activeItems.map((item: ItemProps) => (\n            <StyledButtonElementWrapper key={item.value}>\n              <ButtonV2\n                size=\"normal\"\n                shape=\"pill\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}>\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </ButtonV2>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal\n            label={t('searchPage.searchFilterMessages.resourceTypeFilter.button')}\n            size=\"fullscreen\"\n            animation=\"subtle\"\n            backgroundColor=\"white\"\n            activateButton={\n              <StyledButtonElementWrapper>\n                <ButtonV2 colorTheme=\"light\" size=\"normal\" shape=\"pill\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </ButtonV2>\n              </StyledButtonElementWrapper>\n            }>\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier={['left-align']}>\n                  <h1>{heading}</h1>\n                  <ModalCloseButton title={t('modal.closeModal')} onClick={onClose} />\n                </ModalHeader>\n                <ModalBody modifier=\"slide-in-left\">\n                  <StyledList>\n                    {items.map((item: ItemProps) => (\n                      <StyledListItem key={item.value}>\n                        <ToggleItem\n                          id={item.value}\n                          value={item.value}\n                          checked={item.selected}\n                          label={item.label}\n                          component=\"div\"\n                          onChange={() => onFilterToggle(item.value)}\n                        />\n                      </StyledListItem>\n                    ))}\n                  </StyledList>\n                </ModalBody>\n              </>\n            )}\n          </Modal>\n        </StyledButtonsWrapper>\n      )}\n      {!isNarrowScreen && (\n        <>\n          {heading && <StyledHeading>{heading}</StyledHeading>}\n          <FilterCarousel>\n            {items.map((item: ItemProps) => (\n              <StyledButtonElementWrapper key={item.value}>\n                <ButtonV2\n                  size=\"normal\"\n                  colorTheme={!item.selected ? 'greyLighter' : undefined}\n                  shape=\"pill\"\n                  onClick={() => onFilterToggle(item.value)}>\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </ButtonV2>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <ButtonV2 variant=\"link\" onClick={onRemoveAllFilters}>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </ButtonV2>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */",
|
|
41
41
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
42
42
|
});
|
|
43
43
|
var StyledButtonElementWrapper = /*#__PURE__*/_styled("div", {
|
|
44
44
|
target: "e1yaxziw6",
|
|
45
45
|
label: "StyledButtonElementWrapper"
|
|
46
|
-
})("margin:0 ", spacing.xsmall, " ", spacing.xsmall, " 0;break-inside:avoid;flex-shrink:0;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
46
|
+
})("margin:0 ", spacing.xsmall, " ", spacing.xsmall, " 0;break-inside:avoid;flex-shrink:0;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilterButtons.tsx"],"names":[],"mappings":"AA6B6C","file":"FilterButtons.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\nimport React, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\nimport ToggleItem from './ToggleItem';\nimport FilterCarousel from './FilterCarousel';\n\nconst StyledHeading = styled.h3`\n  ${fonts.sizes('16px', '32px')};\n  margin: 0 0 ${spacing.small};\n  color: ${colors.text.light};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledButtonsWrapper = styled.div`\n  display: inline-flex;\n  flex-wrap: wrap;\n`;\n\nconst StyledButtonElementWrapper = styled.div`\n  margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n  break-inside: avoid;\n  flex-shrink: 0;\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    column-count: 2;\n    column-gap: 20px;\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    column-count: 3;\n    column-gap: 20px;\n  }\n`;\nconst StyledListItem = styled.li`\n  margin-bottom: 0;\n  break-inside: avoid;\n`;\n\nconst StyledButtonContent = styled.span``;\n\nconst StyledButtonContentSelected = styled.span`\n  margin-left: ${spacing.small};\n  display: inline-flex;\n  align-items: center;\n`;\n\nconst StyledRemoveWrapper = styled.div`\n  margin-top: ${spacing.xsmall};\n  margin-left: 10px;\n`;\n\nconst ButtonRemoveText = styled.span`\n  ${fonts.sizes('16px', '32px')};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nexport type ItemProps = {\n  label: string;\n  value: string;\n  selected?: boolean;\n};\nexport type FilterButtonsProps = {\n  heading?: string;\n  items: ItemProps[];\n  onFilterToggle: (value: string) => void;\n  onRemoveAllFilters: () => void;\n  labels: {\n    openFilter: string;\n  };\n};\n\nexport const FilterButtons = ({ heading, items, onFilterToggle, onRemoveAllFilters, labels }: FilterButtonsProps) => {\n  const { t } = useTranslation();\n  const [isNarrowScreen, setIsNarrowScreen] = useState(false);\n\n  useEffect(() => {\n    const isNarrowScreenMatch = window.matchMedia('(max-width: 767px)');\n    const handleChange = (e: MediaQueryListEvent | MediaQueryList) => {\n      setIsNarrowScreen(e.matches);\n    };\n    isNarrowScreenMatch.addEventListener('change', handleChange);\n    handleChange(isNarrowScreenMatch);\n    return () => {\n      isNarrowScreenMatch.removeEventListener('change', handleChange);\n    };\n  }, []);\n\n  const hasSelectedFilters = items.some((item) => {\n    return item.selected;\n  });\n\n  const activeItems = items.filter((item) => item.selected);\n\n  return (\n    <>\n      {isNarrowScreen && (\n        <StyledButtonsWrapper>\n          {activeItems.map((item: ItemProps) => (\n            <StyledButtonElementWrapper key={item.value}>\n              <ButtonV2\n                size=\"normal\"\n                shape=\"pill\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}>\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </ButtonV2>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal\n            label={t('searchPage.searchFilterMessages.resourceTypeFilter.button')}\n            size=\"fullscreen\"\n            animation=\"subtle\"\n            backgroundColor=\"white\"\n            activateButton={\n              <StyledButtonElementWrapper>\n                <ButtonV2 colorTheme=\"light\" size=\"normal\" shape=\"pill\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </ButtonV2>\n              </StyledButtonElementWrapper>\n            }>\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier={['left-align']}>\n                  <h1>{heading}</h1>\n                  <ModalCloseButton title={t('modal.closeModal')} onClick={onClose} />\n                </ModalHeader>\n                <ModalBody modifier=\"slide-in-left\">\n                  <StyledList>\n                    {items.map((item: ItemProps) => (\n                      <StyledListItem key={item.value}>\n                        <ToggleItem\n                          id={item.value}\n                          value={item.value}\n                          checked={item.selected}\n                          label={item.label}\n                          component=\"div\"\n                          onChange={() => onFilterToggle(item.value)}\n                        />\n                      </StyledListItem>\n                    ))}\n                  </StyledList>\n                </ModalBody>\n              </>\n            )}\n          </Modal>\n        </StyledButtonsWrapper>\n      )}\n      {!isNarrowScreen && (\n        <>\n          {heading && <StyledHeading>{heading}</StyledHeading>}\n          <FilterCarousel>\n            {items.map((item: ItemProps) => (\n              <StyledButtonElementWrapper key={item.value}>\n                <ButtonV2\n                  size=\"normal\"\n                  colorTheme={!item.selected ? 'greyLighter' : undefined}\n                  shape=\"pill\"\n                  onClick={() => onFilterToggle(item.value)}>\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </ButtonV2>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <ButtonV2 variant=\"link\" onClick={onRemoveAllFilters}>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </ButtonV2>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */"));
|
|
47
47
|
var StyledList = /*#__PURE__*/_styled("ul", {
|
|
48
48
|
target: "e1yaxziw5",
|
|
49
49
|
label: "StyledList"
|
|
@@ -51,7 +51,7 @@ var StyledList = /*#__PURE__*/_styled("ul", {
|
|
|
51
51
|
from: breakpoints.tablet
|
|
52
52
|
}), "{column-count:2;column-gap:20px;}", mq.range({
|
|
53
53
|
from: breakpoints.tabletWide
|
|
54
|
-
}), "{column-count:3;column-gap:20px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
54
|
+
}), "{column-count:3;column-gap:20px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilterButtons.tsx"],"names":[],"mappings":"AAmC4B","file":"FilterButtons.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\nimport React, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\nimport ToggleItem from './ToggleItem';\nimport FilterCarousel from './FilterCarousel';\n\nconst StyledHeading = styled.h3`\n  ${fonts.sizes('16px', '32px')};\n  margin: 0 0 ${spacing.small};\n  color: ${colors.text.light};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledButtonsWrapper = styled.div`\n  display: inline-flex;\n  flex-wrap: wrap;\n`;\n\nconst StyledButtonElementWrapper = styled.div`\n  margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n  break-inside: avoid;\n  flex-shrink: 0;\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    column-count: 2;\n    column-gap: 20px;\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    column-count: 3;\n    column-gap: 20px;\n  }\n`;\nconst StyledListItem = styled.li`\n  margin-bottom: 0;\n  break-inside: avoid;\n`;\n\nconst StyledButtonContent = styled.span``;\n\nconst StyledButtonContentSelected = styled.span`\n  margin-left: ${spacing.small};\n  display: inline-flex;\n  align-items: center;\n`;\n\nconst StyledRemoveWrapper = styled.div`\n  margin-top: ${spacing.xsmall};\n  margin-left: 10px;\n`;\n\nconst ButtonRemoveText = styled.span`\n  ${fonts.sizes('16px', '32px')};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nexport type ItemProps = {\n  label: string;\n  value: string;\n  selected?: boolean;\n};\nexport type FilterButtonsProps = {\n  heading?: string;\n  items: ItemProps[];\n  onFilterToggle: (value: string) => void;\n  onRemoveAllFilters: () => void;\n  labels: {\n    openFilter: string;\n  };\n};\n\nexport const FilterButtons = ({ heading, items, onFilterToggle, onRemoveAllFilters, labels }: FilterButtonsProps) => {\n  const { t } = useTranslation();\n  const [isNarrowScreen, setIsNarrowScreen] = useState(false);\n\n  useEffect(() => {\n    const isNarrowScreenMatch = window.matchMedia('(max-width: 767px)');\n    const handleChange = (e: MediaQueryListEvent | MediaQueryList) => {\n      setIsNarrowScreen(e.matches);\n    };\n    isNarrowScreenMatch.addEventListener('change', handleChange);\n    handleChange(isNarrowScreenMatch);\n    return () => {\n      isNarrowScreenMatch.removeEventListener('change', handleChange);\n    };\n  }, []);\n\n  const hasSelectedFilters = items.some((item) => {\n    return item.selected;\n  });\n\n  const activeItems = items.filter((item) => item.selected);\n\n  return (\n    <>\n      {isNarrowScreen && (\n        <StyledButtonsWrapper>\n          {activeItems.map((item: ItemProps) => (\n            <StyledButtonElementWrapper key={item.value}>\n              <ButtonV2\n                size=\"normal\"\n                shape=\"pill\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}>\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </ButtonV2>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal\n            label={t('searchPage.searchFilterMessages.resourceTypeFilter.button')}\n            size=\"fullscreen\"\n            animation=\"subtle\"\n            backgroundColor=\"white\"\n            activateButton={\n              <StyledButtonElementWrapper>\n                <ButtonV2 colorTheme=\"light\" size=\"normal\" shape=\"pill\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </ButtonV2>\n              </StyledButtonElementWrapper>\n            }>\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier={['left-align']}>\n                  <h1>{heading}</h1>\n                  <ModalCloseButton title={t('modal.closeModal')} onClick={onClose} />\n                </ModalHeader>\n                <ModalBody modifier=\"slide-in-left\">\n                  <StyledList>\n                    {items.map((item: ItemProps) => (\n                      <StyledListItem key={item.value}>\n                        <ToggleItem\n                          id={item.value}\n                          value={item.value}\n                          checked={item.selected}\n                          label={item.label}\n                          component=\"div\"\n                          onChange={() => onFilterToggle(item.value)}\n                        />\n                      </StyledListItem>\n                    ))}\n                  </StyledList>\n                </ModalBody>\n              </>\n            )}\n          </Modal>\n        </StyledButtonsWrapper>\n      )}\n      {!isNarrowScreen && (\n        <>\n          {heading && <StyledHeading>{heading}</StyledHeading>}\n          <FilterCarousel>\n            {items.map((item: ItemProps) => (\n              <StyledButtonElementWrapper key={item.value}>\n                <ButtonV2\n                  size=\"normal\"\n                  colorTheme={!item.selected ? 'greyLighter' : undefined}\n                  shape=\"pill\"\n                  onClick={() => onFilterToggle(item.value)}>\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </ButtonV2>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <ButtonV2 variant=\"link\" onClick={onRemoveAllFilters}>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </ButtonV2>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */"));
|
|
55
55
|
var StyledListItem = /*#__PURE__*/_styled("li", {
|
|
56
56
|
target: "e1yaxziw4",
|
|
57
57
|
label: "StyledListItem"
|
|
@@ -61,25 +61,25 @@ var StyledListItem = /*#__PURE__*/_styled("li", {
|
|
|
61
61
|
} : {
|
|
62
62
|
name: "19qqojn",
|
|
63
63
|
styles: "margin-bottom:0;break-inside:avoid",
|
|
64
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
64
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilterButtons.tsx"],"names":[],"mappings":"AAgDgC","file":"FilterButtons.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\nimport React, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\nimport ToggleItem from './ToggleItem';\nimport FilterCarousel from './FilterCarousel';\n\nconst StyledHeading = styled.h3`\n  ${fonts.sizes('16px', '32px')};\n  margin: 0 0 ${spacing.small};\n  color: ${colors.text.light};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledButtonsWrapper = styled.div`\n  display: inline-flex;\n  flex-wrap: wrap;\n`;\n\nconst StyledButtonElementWrapper = styled.div`\n  margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n  break-inside: avoid;\n  flex-shrink: 0;\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    column-count: 2;\n    column-gap: 20px;\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    column-count: 3;\n    column-gap: 20px;\n  }\n`;\nconst StyledListItem = styled.li`\n  margin-bottom: 0;\n  break-inside: avoid;\n`;\n\nconst StyledButtonContent = styled.span``;\n\nconst StyledButtonContentSelected = styled.span`\n  margin-left: ${spacing.small};\n  display: inline-flex;\n  align-items: center;\n`;\n\nconst StyledRemoveWrapper = styled.div`\n  margin-top: ${spacing.xsmall};\n  margin-left: 10px;\n`;\n\nconst ButtonRemoveText = styled.span`\n  ${fonts.sizes('16px', '32px')};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nexport type ItemProps = {\n  label: string;\n  value: string;\n  selected?: boolean;\n};\nexport type FilterButtonsProps = {\n  heading?: string;\n  items: ItemProps[];\n  onFilterToggle: (value: string) => void;\n  onRemoveAllFilters: () => void;\n  labels: {\n    openFilter: string;\n  };\n};\n\nexport const FilterButtons = ({ heading, items, onFilterToggle, onRemoveAllFilters, labels }: FilterButtonsProps) => {\n  const { t } = useTranslation();\n  const [isNarrowScreen, setIsNarrowScreen] = useState(false);\n\n  useEffect(() => {\n    const isNarrowScreenMatch = window.matchMedia('(max-width: 767px)');\n    const handleChange = (e: MediaQueryListEvent | MediaQueryList) => {\n      setIsNarrowScreen(e.matches);\n    };\n    isNarrowScreenMatch.addEventListener('change', handleChange);\n    handleChange(isNarrowScreenMatch);\n    return () => {\n      isNarrowScreenMatch.removeEventListener('change', handleChange);\n    };\n  }, []);\n\n  const hasSelectedFilters = items.some((item) => {\n    return item.selected;\n  });\n\n  const activeItems = items.filter((item) => item.selected);\n\n  return (\n    <>\n      {isNarrowScreen && (\n        <StyledButtonsWrapper>\n          {activeItems.map((item: ItemProps) => (\n            <StyledButtonElementWrapper key={item.value}>\n              <ButtonV2\n                size=\"normal\"\n                shape=\"pill\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}>\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </ButtonV2>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal\n            label={t('searchPage.searchFilterMessages.resourceTypeFilter.button')}\n            size=\"fullscreen\"\n            animation=\"subtle\"\n            backgroundColor=\"white\"\n            activateButton={\n              <StyledButtonElementWrapper>\n                <ButtonV2 colorTheme=\"light\" size=\"normal\" shape=\"pill\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </ButtonV2>\n              </StyledButtonElementWrapper>\n            }>\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier={['left-align']}>\n                  <h1>{heading}</h1>\n                  <ModalCloseButton title={t('modal.closeModal')} onClick={onClose} />\n                </ModalHeader>\n                <ModalBody modifier=\"slide-in-left\">\n                  <StyledList>\n                    {items.map((item: ItemProps) => (\n                      <StyledListItem key={item.value}>\n                        <ToggleItem\n                          id={item.value}\n                          value={item.value}\n                          checked={item.selected}\n                          label={item.label}\n                          component=\"div\"\n                          onChange={() => onFilterToggle(item.value)}\n                        />\n                      </StyledListItem>\n                    ))}\n                  </StyledList>\n                </ModalBody>\n              </>\n            )}\n          </Modal>\n        </StyledButtonsWrapper>\n      )}\n      {!isNarrowScreen && (\n        <>\n          {heading && <StyledHeading>{heading}</StyledHeading>}\n          <FilterCarousel>\n            {items.map((item: ItemProps) => (\n              <StyledButtonElementWrapper key={item.value}>\n                <ButtonV2\n                  size=\"normal\"\n                  colorTheme={!item.selected ? 'greyLighter' : undefined}\n                  shape=\"pill\"\n                  onClick={() => onFilterToggle(item.value)}>\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </ButtonV2>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <ButtonV2 variant=\"link\" onClick={onRemoveAllFilters}>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </ButtonV2>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */",
|
|
65
65
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
66
66
|
});
|
|
67
67
|
var StyledButtonContent = /*#__PURE__*/_styled("span", {
|
|
68
68
|
target: "e1yaxziw3",
|
|
69
69
|
label: "StyledButtonContent"
|
|
70
|
-
})(process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
70
|
+
})(process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilterButtons.tsx"],"names":[],"mappings":"AAqDuC","file":"FilterButtons.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\nimport React, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\nimport ToggleItem from './ToggleItem';\nimport FilterCarousel from './FilterCarousel';\n\nconst StyledHeading = styled.h3`\n  ${fonts.sizes('16px', '32px')};\n  margin: 0 0 ${spacing.small};\n  color: ${colors.text.light};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledButtonsWrapper = styled.div`\n  display: inline-flex;\n  flex-wrap: wrap;\n`;\n\nconst StyledButtonElementWrapper = styled.div`\n  margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n  break-inside: avoid;\n  flex-shrink: 0;\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    column-count: 2;\n    column-gap: 20px;\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    column-count: 3;\n    column-gap: 20px;\n  }\n`;\nconst StyledListItem = styled.li`\n  margin-bottom: 0;\n  break-inside: avoid;\n`;\n\nconst StyledButtonContent = styled.span``;\n\nconst StyledButtonContentSelected = styled.span`\n  margin-left: ${spacing.small};\n  display: inline-flex;\n  align-items: center;\n`;\n\nconst StyledRemoveWrapper = styled.div`\n  margin-top: ${spacing.xsmall};\n  margin-left: 10px;\n`;\n\nconst ButtonRemoveText = styled.span`\n  ${fonts.sizes('16px', '32px')};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nexport type ItemProps = {\n  label: string;\n  value: string;\n  selected?: boolean;\n};\nexport type FilterButtonsProps = {\n  heading?: string;\n  items: ItemProps[];\n  onFilterToggle: (value: string) => void;\n  onRemoveAllFilters: () => void;\n  labels: {\n    openFilter: string;\n  };\n};\n\nexport const FilterButtons = ({ heading, items, onFilterToggle, onRemoveAllFilters, labels }: FilterButtonsProps) => {\n  const { t } = useTranslation();\n  const [isNarrowScreen, setIsNarrowScreen] = useState(false);\n\n  useEffect(() => {\n    const isNarrowScreenMatch = window.matchMedia('(max-width: 767px)');\n    const handleChange = (e: MediaQueryListEvent | MediaQueryList) => {\n      setIsNarrowScreen(e.matches);\n    };\n    isNarrowScreenMatch.addEventListener('change', handleChange);\n    handleChange(isNarrowScreenMatch);\n    return () => {\n      isNarrowScreenMatch.removeEventListener('change', handleChange);\n    };\n  }, []);\n\n  const hasSelectedFilters = items.some((item) => {\n    return item.selected;\n  });\n\n  const activeItems = items.filter((item) => item.selected);\n\n  return (\n    <>\n      {isNarrowScreen && (\n        <StyledButtonsWrapper>\n          {activeItems.map((item: ItemProps) => (\n            <StyledButtonElementWrapper key={item.value}>\n              <ButtonV2\n                size=\"normal\"\n                shape=\"pill\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}>\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </ButtonV2>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal\n            label={t('searchPage.searchFilterMessages.resourceTypeFilter.button')}\n            size=\"fullscreen\"\n            animation=\"subtle\"\n            backgroundColor=\"white\"\n            activateButton={\n              <StyledButtonElementWrapper>\n                <ButtonV2 colorTheme=\"light\" size=\"normal\" shape=\"pill\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </ButtonV2>\n              </StyledButtonElementWrapper>\n            }>\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier={['left-align']}>\n                  <h1>{heading}</h1>\n                  <ModalCloseButton title={t('modal.closeModal')} onClick={onClose} />\n                </ModalHeader>\n                <ModalBody modifier=\"slide-in-left\">\n                  <StyledList>\n                    {items.map((item: ItemProps) => (\n                      <StyledListItem key={item.value}>\n                        <ToggleItem\n                          id={item.value}\n                          value={item.value}\n                          checked={item.selected}\n                          label={item.label}\n                          component=\"div\"\n                          onChange={() => onFilterToggle(item.value)}\n                        />\n                      </StyledListItem>\n                    ))}\n                  </StyledList>\n                </ModalBody>\n              </>\n            )}\n          </Modal>\n        </StyledButtonsWrapper>\n      )}\n      {!isNarrowScreen && (\n        <>\n          {heading && <StyledHeading>{heading}</StyledHeading>}\n          <FilterCarousel>\n            {items.map((item: ItemProps) => (\n              <StyledButtonElementWrapper key={item.value}>\n                <ButtonV2\n                  size=\"normal\"\n                  colorTheme={!item.selected ? 'greyLighter' : undefined}\n                  shape=\"pill\"\n                  onClick={() => onFilterToggle(item.value)}>\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </ButtonV2>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <ButtonV2 variant=\"link\" onClick={onRemoveAllFilters}>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </ButtonV2>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */");
|
|
71
71
|
var StyledButtonContentSelected = /*#__PURE__*/_styled("span", {
|
|
72
72
|
target: "e1yaxziw2",
|
|
73
73
|
label: "StyledButtonContentSelected"
|
|
74
|
-
})("margin-left:", spacing.small, ";display:inline-flex;align-items:center;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
74
|
+
})("margin-left:", spacing.small, ";display:inline-flex;align-items:center;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilterButtons.tsx"],"names":[],"mappings":"AAuD+C","file":"FilterButtons.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\nimport React, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\nimport ToggleItem from './ToggleItem';\nimport FilterCarousel from './FilterCarousel';\n\nconst StyledHeading = styled.h3`\n  ${fonts.sizes('16px', '32px')};\n  margin: 0 0 ${spacing.small};\n  color: ${colors.text.light};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledButtonsWrapper = styled.div`\n  display: inline-flex;\n  flex-wrap: wrap;\n`;\n\nconst StyledButtonElementWrapper = styled.div`\n  margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n  break-inside: avoid;\n  flex-shrink: 0;\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    column-count: 2;\n    column-gap: 20px;\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    column-count: 3;\n    column-gap: 20px;\n  }\n`;\nconst StyledListItem = styled.li`\n  margin-bottom: 0;\n  break-inside: avoid;\n`;\n\nconst StyledButtonContent = styled.span``;\n\nconst StyledButtonContentSelected = styled.span`\n  margin-left: ${spacing.small};\n  display: inline-flex;\n  align-items: center;\n`;\n\nconst StyledRemoveWrapper = styled.div`\n  margin-top: ${spacing.xsmall};\n  margin-left: 10px;\n`;\n\nconst ButtonRemoveText = styled.span`\n  ${fonts.sizes('16px', '32px')};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nexport type ItemProps = {\n  label: string;\n  value: string;\n  selected?: boolean;\n};\nexport type FilterButtonsProps = {\n  heading?: string;\n  items: ItemProps[];\n  onFilterToggle: (value: string) => void;\n  onRemoveAllFilters: () => void;\n  labels: {\n    openFilter: string;\n  };\n};\n\nexport const FilterButtons = ({ heading, items, onFilterToggle, onRemoveAllFilters, labels }: FilterButtonsProps) => {\n  const { t } = useTranslation();\n  const [isNarrowScreen, setIsNarrowScreen] = useState(false);\n\n  useEffect(() => {\n    const isNarrowScreenMatch = window.matchMedia('(max-width: 767px)');\n    const handleChange = (e: MediaQueryListEvent | MediaQueryList) => {\n      setIsNarrowScreen(e.matches);\n    };\n    isNarrowScreenMatch.addEventListener('change', handleChange);\n    handleChange(isNarrowScreenMatch);\n    return () => {\n      isNarrowScreenMatch.removeEventListener('change', handleChange);\n    };\n  }, []);\n\n  const hasSelectedFilters = items.some((item) => {\n    return item.selected;\n  });\n\n  const activeItems = items.filter((item) => item.selected);\n\n  return (\n    <>\n      {isNarrowScreen && (\n        <StyledButtonsWrapper>\n          {activeItems.map((item: ItemProps) => (\n            <StyledButtonElementWrapper key={item.value}>\n              <ButtonV2\n                size=\"normal\"\n                shape=\"pill\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}>\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </ButtonV2>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal\n            label={t('searchPage.searchFilterMessages.resourceTypeFilter.button')}\n            size=\"fullscreen\"\n            animation=\"subtle\"\n            backgroundColor=\"white\"\n            activateButton={\n              <StyledButtonElementWrapper>\n                <ButtonV2 colorTheme=\"light\" size=\"normal\" shape=\"pill\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </ButtonV2>\n              </StyledButtonElementWrapper>\n            }>\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier={['left-align']}>\n                  <h1>{heading}</h1>\n                  <ModalCloseButton title={t('modal.closeModal')} onClick={onClose} />\n                </ModalHeader>\n                <ModalBody modifier=\"slide-in-left\">\n                  <StyledList>\n                    {items.map((item: ItemProps) => (\n                      <StyledListItem key={item.value}>\n                        <ToggleItem\n                          id={item.value}\n                          value={item.value}\n                          checked={item.selected}\n                          label={item.label}\n                          component=\"div\"\n                          onChange={() => onFilterToggle(item.value)}\n                        />\n                      </StyledListItem>\n                    ))}\n                  </StyledList>\n                </ModalBody>\n              </>\n            )}\n          </Modal>\n        </StyledButtonsWrapper>\n      )}\n      {!isNarrowScreen && (\n        <>\n          {heading && <StyledHeading>{heading}</StyledHeading>}\n          <FilterCarousel>\n            {items.map((item: ItemProps) => (\n              <StyledButtonElementWrapper key={item.value}>\n                <ButtonV2\n                  size=\"normal\"\n                  colorTheme={!item.selected ? 'greyLighter' : undefined}\n                  shape=\"pill\"\n                  onClick={() => onFilterToggle(item.value)}>\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </ButtonV2>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <ButtonV2 variant=\"link\" onClick={onRemoveAllFilters}>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </ButtonV2>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */"));
|
|
75
75
|
var StyledRemoveWrapper = /*#__PURE__*/_styled("div", {
|
|
76
76
|
target: "e1yaxziw1",
|
|
77
77
|
label: "StyledRemoveWrapper"
|
|
78
|
-
})("margin-top:", spacing.xsmall, ";margin-left:10px;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
78
|
+
})("margin-top:", spacing.xsmall, ";margin-left:10px;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilterButtons.tsx"],"names":[],"mappings":"AA6DsC","file":"FilterButtons.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\nimport React, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\nimport ToggleItem from './ToggleItem';\nimport FilterCarousel from './FilterCarousel';\n\nconst StyledHeading = styled.h3`\n  ${fonts.sizes('16px', '32px')};\n  margin: 0 0 ${spacing.small};\n  color: ${colors.text.light};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledButtonsWrapper = styled.div`\n  display: inline-flex;\n  flex-wrap: wrap;\n`;\n\nconst StyledButtonElementWrapper = styled.div`\n  margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n  break-inside: avoid;\n  flex-shrink: 0;\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    column-count: 2;\n    column-gap: 20px;\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    column-count: 3;\n    column-gap: 20px;\n  }\n`;\nconst StyledListItem = styled.li`\n  margin-bottom: 0;\n  break-inside: avoid;\n`;\n\nconst StyledButtonContent = styled.span``;\n\nconst StyledButtonContentSelected = styled.span`\n  margin-left: ${spacing.small};\n  display: inline-flex;\n  align-items: center;\n`;\n\nconst StyledRemoveWrapper = styled.div`\n  margin-top: ${spacing.xsmall};\n  margin-left: 10px;\n`;\n\nconst ButtonRemoveText = styled.span`\n  ${fonts.sizes('16px', '32px')};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nexport type ItemProps = {\n  label: string;\n  value: string;\n  selected?: boolean;\n};\nexport type FilterButtonsProps = {\n  heading?: string;\n  items: ItemProps[];\n  onFilterToggle: (value: string) => void;\n  onRemoveAllFilters: () => void;\n  labels: {\n    openFilter: string;\n  };\n};\n\nexport const FilterButtons = ({ heading, items, onFilterToggle, onRemoveAllFilters, labels }: FilterButtonsProps) => {\n  const { t } = useTranslation();\n  const [isNarrowScreen, setIsNarrowScreen] = useState(false);\n\n  useEffect(() => {\n    const isNarrowScreenMatch = window.matchMedia('(max-width: 767px)');\n    const handleChange = (e: MediaQueryListEvent | MediaQueryList) => {\n      setIsNarrowScreen(e.matches);\n    };\n    isNarrowScreenMatch.addEventListener('change', handleChange);\n    handleChange(isNarrowScreenMatch);\n    return () => {\n      isNarrowScreenMatch.removeEventListener('change', handleChange);\n    };\n  }, []);\n\n  const hasSelectedFilters = items.some((item) => {\n    return item.selected;\n  });\n\n  const activeItems = items.filter((item) => item.selected);\n\n  return (\n    <>\n      {isNarrowScreen && (\n        <StyledButtonsWrapper>\n          {activeItems.map((item: ItemProps) => (\n            <StyledButtonElementWrapper key={item.value}>\n              <ButtonV2\n                size=\"normal\"\n                shape=\"pill\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}>\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </ButtonV2>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal\n            label={t('searchPage.searchFilterMessages.resourceTypeFilter.button')}\n            size=\"fullscreen\"\n            animation=\"subtle\"\n            backgroundColor=\"white\"\n            activateButton={\n              <StyledButtonElementWrapper>\n                <ButtonV2 colorTheme=\"light\" size=\"normal\" shape=\"pill\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </ButtonV2>\n              </StyledButtonElementWrapper>\n            }>\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier={['left-align']}>\n                  <h1>{heading}</h1>\n                  <ModalCloseButton title={t('modal.closeModal')} onClick={onClose} />\n                </ModalHeader>\n                <ModalBody modifier=\"slide-in-left\">\n                  <StyledList>\n                    {items.map((item: ItemProps) => (\n                      <StyledListItem key={item.value}>\n                        <ToggleItem\n                          id={item.value}\n                          value={item.value}\n                          checked={item.selected}\n                          label={item.label}\n                          component=\"div\"\n                          onChange={() => onFilterToggle(item.value)}\n                        />\n                      </StyledListItem>\n                    ))}\n                  </StyledList>\n                </ModalBody>\n              </>\n            )}\n          </Modal>\n        </StyledButtonsWrapper>\n      )}\n      {!isNarrowScreen && (\n        <>\n          {heading && <StyledHeading>{heading}</StyledHeading>}\n          <FilterCarousel>\n            {items.map((item: ItemProps) => (\n              <StyledButtonElementWrapper key={item.value}>\n                <ButtonV2\n                  size=\"normal\"\n                  colorTheme={!item.selected ? 'greyLighter' : undefined}\n                  shape=\"pill\"\n                  onClick={() => onFilterToggle(item.value)}>\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </ButtonV2>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <ButtonV2 variant=\"link\" onClick={onRemoveAllFilters}>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </ButtonV2>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */"));
|
|
79
79
|
var ButtonRemoveText = /*#__PURE__*/_styled("span", {
|
|
80
80
|
target: "e1yaxziw0",
|
|
81
81
|
label: "ButtonRemoveText"
|
|
82
|
-
})(fonts.sizes('16px', '32px'), ";font-weight:", fonts.weight.semibold, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
82
|
+
})(fonts.sizes('16px', '32px'), ";font-weight:", fonts.weight.semibold, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilterButtons.tsx"],"names":[],"mappings":"AAkEoC","file":"FilterButtons.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\nimport React, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { Cross as CrossIcon, Plus as PlusIcon } from '@ndla/icons/action';\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\nimport ToggleItem from './ToggleItem';\nimport FilterCarousel from './FilterCarousel';\n\nconst StyledHeading = styled.h3`\n  ${fonts.sizes('16px', '32px')};\n  margin: 0 0 ${spacing.small};\n  color: ${colors.text.light};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledButtonsWrapper = styled.div`\n  display: inline-flex;\n  flex-wrap: wrap;\n`;\n\nconst StyledButtonElementWrapper = styled.div`\n  margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n  break-inside: avoid;\n  flex-shrink: 0;\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    column-count: 2;\n    column-gap: 20px;\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    column-count: 3;\n    column-gap: 20px;\n  }\n`;\nconst StyledListItem = styled.li`\n  margin-bottom: 0;\n  break-inside: avoid;\n`;\n\nconst StyledButtonContent = styled.span``;\n\nconst StyledButtonContentSelected = styled.span`\n  margin-left: ${spacing.small};\n  display: inline-flex;\n  align-items: center;\n`;\n\nconst StyledRemoveWrapper = styled.div`\n  margin-top: ${spacing.xsmall};\n  margin-left: 10px;\n`;\n\nconst ButtonRemoveText = styled.span`\n  ${fonts.sizes('16px', '32px')};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nexport type ItemProps = {\n  label: string;\n  value: string;\n  selected?: boolean;\n};\nexport type FilterButtonsProps = {\n  heading?: string;\n  items: ItemProps[];\n  onFilterToggle: (value: string) => void;\n  onRemoveAllFilters: () => void;\n  labels: {\n    openFilter: string;\n  };\n};\n\nexport const FilterButtons = ({ heading, items, onFilterToggle, onRemoveAllFilters, labels }: FilterButtonsProps) => {\n  const { t } = useTranslation();\n  const [isNarrowScreen, setIsNarrowScreen] = useState(false);\n\n  useEffect(() => {\n    const isNarrowScreenMatch = window.matchMedia('(max-width: 767px)');\n    const handleChange = (e: MediaQueryListEvent | MediaQueryList) => {\n      setIsNarrowScreen(e.matches);\n    };\n    isNarrowScreenMatch.addEventListener('change', handleChange);\n    handleChange(isNarrowScreenMatch);\n    return () => {\n      isNarrowScreenMatch.removeEventListener('change', handleChange);\n    };\n  }, []);\n\n  const hasSelectedFilters = items.some((item) => {\n    return item.selected;\n  });\n\n  const activeItems = items.filter((item) => item.selected);\n\n  return (\n    <>\n      {isNarrowScreen && (\n        <StyledButtonsWrapper>\n          {activeItems.map((item: ItemProps) => (\n            <StyledButtonElementWrapper key={item.value}>\n              <ButtonV2\n                size=\"normal\"\n                shape=\"pill\"\n                onClick={() => {\n                  onFilterToggle(item.value);\n                }}>\n                <StyledButtonContent>{item.label}</StyledButtonContent>\n                <StyledButtonContentSelected>\n                  <CrossIcon />\n                </StyledButtonContentSelected>\n              </ButtonV2>\n            </StyledButtonElementWrapper>\n          ))}\n          <Modal\n            label={t('searchPage.searchFilterMessages.resourceTypeFilter.button')}\n            size=\"fullscreen\"\n            animation=\"subtle\"\n            backgroundColor=\"white\"\n            activateButton={\n              <StyledButtonElementWrapper>\n                <ButtonV2 colorTheme=\"light\" size=\"normal\" shape=\"pill\">\n                  <StyledButtonContent>{labels.openFilter}</StyledButtonContent>\n                  <StyledButtonContentSelected>\n                    <PlusIcon />\n                  </StyledButtonContentSelected>\n                </ButtonV2>\n              </StyledButtonElementWrapper>\n            }>\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier={['left-align']}>\n                  <h1>{heading}</h1>\n                  <ModalCloseButton title={t('modal.closeModal')} onClick={onClose} />\n                </ModalHeader>\n                <ModalBody modifier=\"slide-in-left\">\n                  <StyledList>\n                    {items.map((item: ItemProps) => (\n                      <StyledListItem key={item.value}>\n                        <ToggleItem\n                          id={item.value}\n                          value={item.value}\n                          checked={item.selected}\n                          label={item.label}\n                          component=\"div\"\n                          onChange={() => onFilterToggle(item.value)}\n                        />\n                      </StyledListItem>\n                    ))}\n                  </StyledList>\n                </ModalBody>\n              </>\n            )}\n          </Modal>\n        </StyledButtonsWrapper>\n      )}\n      {!isNarrowScreen && (\n        <>\n          {heading && <StyledHeading>{heading}</StyledHeading>}\n          <FilterCarousel>\n            {items.map((item: ItemProps) => (\n              <StyledButtonElementWrapper key={item.value}>\n                <ButtonV2\n                  size=\"normal\"\n                  colorTheme={!item.selected ? 'greyLighter' : undefined}\n                  shape=\"pill\"\n                  onClick={() => onFilterToggle(item.value)}>\n                  <StyledButtonContent>{item.label}</StyledButtonContent>\n                  {item.selected && (\n                    <StyledButtonContentSelected>\n                      <CrossIcon />\n                    </StyledButtonContentSelected>\n                  )}\n                </ButtonV2>\n              </StyledButtonElementWrapper>\n            ))}\n          </FilterCarousel>\n          <StyledRemoveWrapper>\n            {hasSelectedFilters && (\n              <ButtonV2 variant=\"link\" onClick={onRemoveAllFilters}>\n                <ButtonRemoveText>{t(`filterButtons.removeAllFilters`)}</ButtonRemoveText>\n              </ButtonV2>\n            )}\n          </StyledRemoveWrapper>\n        </>\n      )}\n    </>\n  );\n};\n\nexport default FilterButtons;\n"]} */"));
|
|
83
83
|
export var FilterButtons = function FilterButtons(_ref) {
|
|
84
84
|
var heading = _ref.heading,
|
|
85
85
|
items = _ref.items,
|
|
@@ -113,10 +113,9 @@ export var FilterButtons = function FilterButtons(_ref) {
|
|
|
113
113
|
children: [isNarrowScreen && _jsxs(StyledButtonsWrapper, {
|
|
114
114
|
children: [activeItems.map(function (item) {
|
|
115
115
|
return _jsx(StyledButtonElementWrapper, {
|
|
116
|
-
children: _jsxs(
|
|
117
|
-
type: "button",
|
|
116
|
+
children: _jsxs(ButtonV2, {
|
|
118
117
|
size: "normal",
|
|
119
|
-
|
|
118
|
+
shape: "pill",
|
|
120
119
|
onClick: function onClick() {
|
|
121
120
|
onFilterToggle(item.value);
|
|
122
121
|
},
|
|
@@ -133,11 +132,10 @@ export var FilterButtons = function FilterButtons(_ref) {
|
|
|
133
132
|
animation: "subtle",
|
|
134
133
|
backgroundColor: "white",
|
|
135
134
|
activateButton: _jsx(StyledButtonElementWrapper, {
|
|
136
|
-
children: _jsxs(
|
|
137
|
-
|
|
135
|
+
children: _jsxs(ButtonV2, {
|
|
136
|
+
colorTheme: "light",
|
|
138
137
|
size: "normal",
|
|
139
|
-
|
|
140
|
-
borderShape: "rounded",
|
|
138
|
+
shape: "pill",
|
|
141
139
|
children: [_jsx(StyledButtonContent, {
|
|
142
140
|
children: labels.openFilter
|
|
143
141
|
}), _jsx(StyledButtonContentSelected, {
|
|
@@ -183,11 +181,10 @@ export var FilterButtons = function FilterButtons(_ref) {
|
|
|
183
181
|
}), _jsx(FilterCarousel, {
|
|
184
182
|
children: items.map(function (item) {
|
|
185
183
|
return _jsx(StyledButtonElementWrapper, {
|
|
186
|
-
children: _jsxs(
|
|
187
|
-
type: "button",
|
|
184
|
+
children: _jsxs(ButtonV2, {
|
|
188
185
|
size: "normal",
|
|
189
|
-
|
|
190
|
-
|
|
186
|
+
colorTheme: !item.selected ? 'greyLighter' : undefined,
|
|
187
|
+
shape: "pill",
|
|
191
188
|
onClick: function onClick() {
|
|
192
189
|
return onFilterToggle(item.value);
|
|
193
190
|
},
|
|
@@ -200,9 +197,9 @@ export var FilterButtons = function FilterButtons(_ref) {
|
|
|
200
197
|
}, item.value);
|
|
201
198
|
})
|
|
202
199
|
}), _jsx(StyledRemoveWrapper, {
|
|
203
|
-
children: hasSelectedFilters && _jsx(
|
|
200
|
+
children: hasSelectedFilters && _jsx(ButtonV2, {
|
|
201
|
+
variant: "link",
|
|
204
202
|
onClick: onRemoveAllFilters,
|
|
205
|
-
link: true,
|
|
206
203
|
children: _jsx(ButtonRemoveText, {
|
|
207
204
|
children: t("filterButtons.removeAllFilters")
|
|
208
205
|
})
|