@ndla/ui 33.4.4 → 33.4.5
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/MyNdla/Resource/FolderInput.js +5 -5
- package/es/SnackBar/DefaultSnackbar.js +7 -10
- package/es/all.css +1 -1
- package/es/index.js +0 -2
- package/lib/MyNdla/Resource/FolderInput.js +4 -4
- package/lib/SnackBar/DefaultSnackbar.js +6 -9
- package/lib/all.css +1 -1
- package/lib/index.d.ts +0 -2
- package/lib/index.js +0 -202
- package/package.json +6 -6
- package/src/Filter/component.filter.scss +4 -4
- package/src/MyNdla/Resource/FolderInput.tsx +3 -3
- package/src/SnackBar/DefaultSnackbar.tsx +8 -16
- package/src/index.ts +0 -3
- package/src/main.scss +0 -1
- package/es/TopicMenu/SubtopicLinkList.js +0 -255
- package/es/TopicMenu/TopicMenu.js +0 -364
- package/es/TopicMenu/TopicMenuButton.js +0 -37
- package/es/TopicMenu/index.js +0 -11
- package/es/index-javascript.js +0 -9
- package/lib/TopicMenu/SubtopicLinkList.js +0 -255
- package/lib/TopicMenu/TopicMenu.js +0 -365
- package/lib/TopicMenu/TopicMenuButton.js +0 -36
- package/lib/TopicMenu/index.js +0 -24
- package/lib/index-javascript.js +0 -21
- package/src/TopicMenu/SubtopicLinkList.jsx +0 -247
- package/src/TopicMenu/TopicMenu.jsx +0 -370
- package/src/TopicMenu/TopicMenuButton.jsx +0 -51
- package/src/TopicMenu/component.topic-menu.scss +0 -960
- package/src/TopicMenu/index.js +0 -12
- package/src/index-javascript.js +0 -9
|
@@ -1,255 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
|
|
4
|
-
Object.defineProperty(exports, "__esModule", {
|
|
5
|
-
value: true
|
|
6
|
-
});
|
|
7
|
-
exports["default"] = void 0;
|
|
8
|
-
var _base = _interopRequireDefault(require("@emotion/styled/base"));
|
|
9
|
-
var _react = _interopRequireWildcard(require("react"));
|
|
10
|
-
var _common = require("@ndla/icons/common");
|
|
11
|
-
var _switch = require("@ndla/switch");
|
|
12
|
-
var _react2 = require("@emotion/react");
|
|
13
|
-
var _core = require("@ndla/core");
|
|
14
|
-
var _safelink = _interopRequireDefault(require("@ndla/safelink"));
|
|
15
|
-
var _reactI18next = require("react-i18next");
|
|
16
|
-
var _ContentTypeResult = _interopRequireDefault(require("../Search/ContentTypeResult"));
|
|
17
|
-
var _TopicMenu = require("./TopicMenu");
|
|
18
|
-
var _jsxRuntime = require("@emotion/react/jsx-runtime");
|
|
19
|
-
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
|
20
|
-
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
|
21
|
-
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
|
22
|
-
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
|
23
|
-
function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
|
|
24
|
-
function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
|
|
25
|
-
function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); Object.defineProperty(subClass, "prototype", { writable: false }); if (superClass) _setPrototypeOf(subClass, superClass); }
|
|
26
|
-
function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
|
|
27
|
-
function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
|
|
28
|
-
function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } else if (call !== void 0) { throw new TypeError("Derived constructors may only return object or undefined"); } return _assertThisInitialized(self); }
|
|
29
|
-
function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
|
|
30
|
-
function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
|
|
31
|
-
function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
|
|
32
|
-
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
33
|
-
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
34
|
-
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
|
35
|
-
function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
36
|
-
var switchLarge = /*#__PURE__*/(0, _react2.css)("display:none;", _core.mq.range({
|
|
37
|
-
from: _core.breakpoints.mobileWide
|
|
38
|
-
}), "{display:inline-flex;};label:switchLarge;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SubtopicLinkList.jsx"],"names":[],"mappings":"AAmBuB","file":"SubtopicLinkList.jsx","sourcesContent":["/**\n * Copyright (c) 2016-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, { Component } from 'react';\nimport { Back, ChevronRight } from '@ndla/icons/common';\nimport { Switch } from '@ndla/switch';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { mq, breakpoints, fonts, spacing } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\nimport { withTranslation } from 'react-i18next';\nimport ContentTypeResult from '../Search/ContentTypeResult';\nimport { renderAdditionalIcon } from './TopicMenu';\n\nconst switchLarge = css`\n  display: none;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    display: inline-flex;\n  }\n`;\n\nconst switchSmall = css`\n  display: inline-flex !important;\n  align-items: normal !important;\n  margin: 0 0 0 20px;\n  min-height: 0 !important;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    display: none !important;\n  }\n`;\n\nconst StyledHeader = styled.h1`\n  ${fonts.sizes('16px', '26px')};\n  margin: 0;\n  text-transform: uppercase;\n  padding-right: ${spacing.normal};\n`;\n\nconst StyledAside = styled.aside`\n  padding: ${spacing.normal};\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: ${spacing.small};\n    width: 600px;\n  }\n`;\n\nconst HeaderWrapper = styled.div`\n  display: flex;\n`;\n\nconst SubtopicLink = ({\n  classes,\n  to,\n  subtopic: { id, name, additional },\n  onSubtopicExpand,\n  expandedSubtopicId,\n  subtopicId,\n  additionalTooltipLabel,\n}) => {\n  const active = id === expandedSubtopicId;\n\n  return (\n    <li {...classes('subtopic-item', active && 'active')} key={id}>\n      <SafeLink\n        {...classes('link')}\n        onClick={(event) => {\n          event.preventDefault();\n          onSubtopicExpand(subtopicId);\n        }}\n        to={to}>\n        <span>\n          {name}\n          {renderAdditionalIcon(additional, additionalTooltipLabel)}\n        </span>\n        <ChevronRight />\n      </SafeLink>\n    </li>\n  );\n};\n\nclass SubtopicLinkList extends Component {\n  constructor(props) {\n    super(props);\n    this.state = {\n      showAdditionalResources: false,\n      animateUL: 0,\n    };\n    this.toggleAdditionalResources = this.toggleAdditionalResources.bind(this);\n    this.containerRef = null;\n  }\n\n  componentDidMount() {\n    this.setFocusOnFirstLink();\n  }\n\n  componentDidUpdate(prevProps) {\n    if (this.props.topic.id !== prevProps.topic.id) {\n      this.setFocusOnFirstLink();\n    }\n  }\n\n  setFocusOnFirstLink() {\n    this.containerRef.querySelector('a').focus();\n  }\n\n  toggleAdditionalResources() {\n    this.setState((prevState) => ({\n      showAdditionalResources: !prevState.showAdditionalResources,\n      animateUL: prevState.animateUL + 1,\n    }));\n  }\n\n  render() {\n    const {\n      className,\n      classes,\n      closeMenu,\n      topic,\n      toTopic,\n      expandedSubtopicId,\n      onSubtopicExpand,\n      onGoBack,\n      backLabel,\n      resourceToLinkProps,\n      lastOpen,\n      t,\n      isUngrouped,\n    } = this.props;\n\n    const { showAdditionalResources, animateUL } = this.state;\n\n    const hasSubTopics = topic.subtopics && topic.subtopics.length > 0;\n    const hasContentTypeResults = lastOpen && topic.contentTypeResults && topic.contentTypeResults.length > 0;\n\n    const someResourcesAreAdditional =\n      hasContentTypeResults &&\n      topic.contentTypeResults.some((result) => result.resources.some((resource) => resource.additional));\n\n    return (\n      <div\n        className={className}\n        ref={(ref) => {\n          this.containerRef = ref;\n        }}>\n        <button type=\"button\" {...classes('back-button')} onClick={onGoBack}>\n          <Back /> <span>{backLabel}</span>\n        </button>\n        <SafeLink {...classes('link', ['big'])} onClick={closeMenu} to={toTopic(topic.id)}>\n          <span {...classes('link-wrapper')}>\n            <span {...classes('link-label')}>{t('masthead.menu.goTo')}:</span>\n            <span {...classes('link-target')}>\n              <span {...classes('link-target-name')}>{topic.name} </span>\n              <ChevronRight className=\"c-icon--22\" />\n            </span>\n          </span>\n          <ChevronRight />\n        </SafeLink>\n        {hasSubTopics && (\n          <ul {...classes('list')}>\n            {topic.subtopics.map((subtopic) => (\n              <SubtopicLink\n                onSubtopicExpand={onSubtopicExpand}\n                expandedSubtopicId={expandedSubtopicId}\n                classes={classes}\n                key={subtopic.id}\n                to={toTopic(topic.id, subtopic.id)}\n                subtopicId={subtopic.id}\n                subtopic={subtopic}\n                additionalTooltipLabel={t('resource.additionalTooltip')}\n              />\n            ))}\n          </ul>\n        )}\n        {hasContentTypeResults && (\n          <StyledAside>\n            <HeaderWrapper>\n              <StyledHeader>{t('masthead.menu.learningResourcesHeading')}</StyledHeader>\n              {someResourcesAreAdditional && (\n                <Switch\n                  id=\"showAdditionalId\"\n                  checked={showAdditionalResources}\n                  label={t('masthead.menu.additionalFilterLabel')}\n                  onChange={this.toggleAdditionalResources}\n                  css={switchLarge}\n                />\n              )}\n            </HeaderWrapper>\n            {isUngrouped && (\n              <ContentTypeResult\n                animateUL={animateUL}\n                resourceToLinkProps={resourceToLinkProps}\n                onNavigate={closeMenu}\n                contentTypeResult={{\n                  resources: topic.contentTypeResults\n                    .flatMap((grouped) =>\n                      grouped.resources.map((res) => ({\n                        ...res,\n                        contentType: grouped.contentType,\n                      })),\n                    )\n                    .sort((a, b) => a.rank - b.rank),\n                }}\n                messages={{\n                  noHit: t(`masthead.menu.contentTypeResultsNoHit.unGrouped`),\n                }}\n                unGrouped={isUngrouped}\n                showAdditionalResources={showAdditionalResources}\n                inMenu\n              />\n            )}\n            {!isUngrouped &&\n              topic.contentTypeResults.map((result) => (\n                <ContentTypeResult\n                  animateUL={animateUL}\n                  resourceToLinkProps={resourceToLinkProps}\n                  onNavigate={closeMenu}\n                  key={result.title}\n                  contentTypeResult={result}\n                  messages={{\n                    noHit: t(`masthead.menu.contentTypeResultsNoHit.${result.contentType}`),\n                  }}\n                  showAdditionalResources={showAdditionalResources}\n                  inMenu\n                />\n              ))}\n            {someResourcesAreAdditional && (\n              <Switch\n                id=\"showSomeAdditionalId\"\n                checked={showAdditionalResources}\n                label={t('masthead.menu.additionalFilterLabel')}\n                onChange={this.toggleAdditionalResources}\n                css={switchSmall}\n              />\n            )}\n          </StyledAside>\n        )}\n      </div>\n    );\n  }\n}\n\nexport default withTranslation()(SubtopicLinkList);\n"]} */"));
|
|
39
|
-
var switchSmall = /*#__PURE__*/(0, _react2.css)("display:inline-flex!important;align-items:normal!important;margin:0 0 0 20px;min-height:0!important;", _core.mq.range({
|
|
40
|
-
from: _core.breakpoints.mobileWide
|
|
41
|
-
}), "{display:none!important;};label:switchSmall;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SubtopicLinkList.jsx"],"names":[],"mappings":"AA0BuB","file":"SubtopicLinkList.jsx","sourcesContent":["/**\n * Copyright (c) 2016-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, { Component } from 'react';\nimport { Back, ChevronRight } from '@ndla/icons/common';\nimport { Switch } from '@ndla/switch';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { mq, breakpoints, fonts, spacing } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\nimport { withTranslation } from 'react-i18next';\nimport ContentTypeResult from '../Search/ContentTypeResult';\nimport { renderAdditionalIcon } from './TopicMenu';\n\nconst switchLarge = css`\n  display: none;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    display: inline-flex;\n  }\n`;\n\nconst switchSmall = css`\n  display: inline-flex !important;\n  align-items: normal !important;\n  margin: 0 0 0 20px;\n  min-height: 0 !important;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    display: none !important;\n  }\n`;\n\nconst StyledHeader = styled.h1`\n  ${fonts.sizes('16px', '26px')};\n  margin: 0;\n  text-transform: uppercase;\n  padding-right: ${spacing.normal};\n`;\n\nconst StyledAside = styled.aside`\n  padding: ${spacing.normal};\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: ${spacing.small};\n    width: 600px;\n  }\n`;\n\nconst HeaderWrapper = styled.div`\n  display: flex;\n`;\n\nconst SubtopicLink = ({\n  classes,\n  to,\n  subtopic: { id, name, additional },\n  onSubtopicExpand,\n  expandedSubtopicId,\n  subtopicId,\n  additionalTooltipLabel,\n}) => {\n  const active = id === expandedSubtopicId;\n\n  return (\n    <li {...classes('subtopic-item', active && 'active')} key={id}>\n      <SafeLink\n        {...classes('link')}\n        onClick={(event) => {\n          event.preventDefault();\n          onSubtopicExpand(subtopicId);\n        }}\n        to={to}>\n        <span>\n          {name}\n          {renderAdditionalIcon(additional, additionalTooltipLabel)}\n        </span>\n        <ChevronRight />\n      </SafeLink>\n    </li>\n  );\n};\n\nclass SubtopicLinkList extends Component {\n  constructor(props) {\n    super(props);\n    this.state = {\n      showAdditionalResources: false,\n      animateUL: 0,\n    };\n    this.toggleAdditionalResources = this.toggleAdditionalResources.bind(this);\n    this.containerRef = null;\n  }\n\n  componentDidMount() {\n    this.setFocusOnFirstLink();\n  }\n\n  componentDidUpdate(prevProps) {\n    if (this.props.topic.id !== prevProps.topic.id) {\n      this.setFocusOnFirstLink();\n    }\n  }\n\n  setFocusOnFirstLink() {\n    this.containerRef.querySelector('a').focus();\n  }\n\n  toggleAdditionalResources() {\n    this.setState((prevState) => ({\n      showAdditionalResources: !prevState.showAdditionalResources,\n      animateUL: prevState.animateUL + 1,\n    }));\n  }\n\n  render() {\n    const {\n      className,\n      classes,\n      closeMenu,\n      topic,\n      toTopic,\n      expandedSubtopicId,\n      onSubtopicExpand,\n      onGoBack,\n      backLabel,\n      resourceToLinkProps,\n      lastOpen,\n      t,\n      isUngrouped,\n    } = this.props;\n\n    const { showAdditionalResources, animateUL } = this.state;\n\n    const hasSubTopics = topic.subtopics && topic.subtopics.length > 0;\n    const hasContentTypeResults = lastOpen && topic.contentTypeResults && topic.contentTypeResults.length > 0;\n\n    const someResourcesAreAdditional =\n      hasContentTypeResults &&\n      topic.contentTypeResults.some((result) => result.resources.some((resource) => resource.additional));\n\n    return (\n      <div\n        className={className}\n        ref={(ref) => {\n          this.containerRef = ref;\n        }}>\n        <button type=\"button\" {...classes('back-button')} onClick={onGoBack}>\n          <Back /> <span>{backLabel}</span>\n        </button>\n        <SafeLink {...classes('link', ['big'])} onClick={closeMenu} to={toTopic(topic.id)}>\n          <span {...classes('link-wrapper')}>\n            <span {...classes('link-label')}>{t('masthead.menu.goTo')}:</span>\n            <span {...classes('link-target')}>\n              <span {...classes('link-target-name')}>{topic.name} </span>\n              <ChevronRight className=\"c-icon--22\" />\n            </span>\n          </span>\n          <ChevronRight />\n        </SafeLink>\n        {hasSubTopics && (\n          <ul {...classes('list')}>\n            {topic.subtopics.map((subtopic) => (\n              <SubtopicLink\n                onSubtopicExpand={onSubtopicExpand}\n                expandedSubtopicId={expandedSubtopicId}\n                classes={classes}\n                key={subtopic.id}\n                to={toTopic(topic.id, subtopic.id)}\n                subtopicId={subtopic.id}\n                subtopic={subtopic}\n                additionalTooltipLabel={t('resource.additionalTooltip')}\n              />\n            ))}\n          </ul>\n        )}\n        {hasContentTypeResults && (\n          <StyledAside>\n            <HeaderWrapper>\n              <StyledHeader>{t('masthead.menu.learningResourcesHeading')}</StyledHeader>\n              {someResourcesAreAdditional && (\n                <Switch\n                  id=\"showAdditionalId\"\n                  checked={showAdditionalResources}\n                  label={t('masthead.menu.additionalFilterLabel')}\n                  onChange={this.toggleAdditionalResources}\n                  css={switchLarge}\n                />\n              )}\n            </HeaderWrapper>\n            {isUngrouped && (\n              <ContentTypeResult\n                animateUL={animateUL}\n                resourceToLinkProps={resourceToLinkProps}\n                onNavigate={closeMenu}\n                contentTypeResult={{\n                  resources: topic.contentTypeResults\n                    .flatMap((grouped) =>\n                      grouped.resources.map((res) => ({\n                        ...res,\n                        contentType: grouped.contentType,\n                      })),\n                    )\n                    .sort((a, b) => a.rank - b.rank),\n                }}\n                messages={{\n                  noHit: t(`masthead.menu.contentTypeResultsNoHit.unGrouped`),\n                }}\n                unGrouped={isUngrouped}\n                showAdditionalResources={showAdditionalResources}\n                inMenu\n              />\n            )}\n            {!isUngrouped &&\n              topic.contentTypeResults.map((result) => (\n                <ContentTypeResult\n                  animateUL={animateUL}\n                  resourceToLinkProps={resourceToLinkProps}\n                  onNavigate={closeMenu}\n                  key={result.title}\n                  contentTypeResult={result}\n                  messages={{\n                    noHit: t(`masthead.menu.contentTypeResultsNoHit.${result.contentType}`),\n                  }}\n                  showAdditionalResources={showAdditionalResources}\n                  inMenu\n                />\n              ))}\n            {someResourcesAreAdditional && (\n              <Switch\n                id=\"showSomeAdditionalId\"\n                checked={showAdditionalResources}\n                label={t('masthead.menu.additionalFilterLabel')}\n                onChange={this.toggleAdditionalResources}\n                css={switchSmall}\n              />\n            )}\n          </StyledAside>\n        )}\n      </div>\n    );\n  }\n}\n\nexport default withTranslation()(SubtopicLinkList);\n"]} */"));
|
|
42
|
-
var StyledHeader = /*#__PURE__*/(0, _base["default"])("h1", {
|
|
43
|
-
target: "e11boizo2",
|
|
44
|
-
label: "StyledHeader"
|
|
45
|
-
})(_core.fonts.sizes('16px', '26px'), ";margin:0;text-transform:uppercase;padding-right:", _core.spacing.normal, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SubtopicLinkList.jsx"],"names":[],"mappings":"AAoC8B","file":"SubtopicLinkList.jsx","sourcesContent":["/**\n * Copyright (c) 2016-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, { Component } from 'react';\nimport { Back, ChevronRight } from '@ndla/icons/common';\nimport { Switch } from '@ndla/switch';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { mq, breakpoints, fonts, spacing } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\nimport { withTranslation } from 'react-i18next';\nimport ContentTypeResult from '../Search/ContentTypeResult';\nimport { renderAdditionalIcon } from './TopicMenu';\n\nconst switchLarge = css`\n  display: none;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    display: inline-flex;\n  }\n`;\n\nconst switchSmall = css`\n  display: inline-flex !important;\n  align-items: normal !important;\n  margin: 0 0 0 20px;\n  min-height: 0 !important;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    display: none !important;\n  }\n`;\n\nconst StyledHeader = styled.h1`\n  ${fonts.sizes('16px', '26px')};\n  margin: 0;\n  text-transform: uppercase;\n  padding-right: ${spacing.normal};\n`;\n\nconst StyledAside = styled.aside`\n  padding: ${spacing.normal};\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: ${spacing.small};\n    width: 600px;\n  }\n`;\n\nconst HeaderWrapper = styled.div`\n  display: flex;\n`;\n\nconst SubtopicLink = ({\n  classes,\n  to,\n  subtopic: { id, name, additional },\n  onSubtopicExpand,\n  expandedSubtopicId,\n  subtopicId,\n  additionalTooltipLabel,\n}) => {\n  const active = id === expandedSubtopicId;\n\n  return (\n    <li {...classes('subtopic-item', active && 'active')} key={id}>\n      <SafeLink\n        {...classes('link')}\n        onClick={(event) => {\n          event.preventDefault();\n          onSubtopicExpand(subtopicId);\n        }}\n        to={to}>\n        <span>\n          {name}\n          {renderAdditionalIcon(additional, additionalTooltipLabel)}\n        </span>\n        <ChevronRight />\n      </SafeLink>\n    </li>\n  );\n};\n\nclass SubtopicLinkList extends Component {\n  constructor(props) {\n    super(props);\n    this.state = {\n      showAdditionalResources: false,\n      animateUL: 0,\n    };\n    this.toggleAdditionalResources = this.toggleAdditionalResources.bind(this);\n    this.containerRef = null;\n  }\n\n  componentDidMount() {\n    this.setFocusOnFirstLink();\n  }\n\n  componentDidUpdate(prevProps) {\n    if (this.props.topic.id !== prevProps.topic.id) {\n      this.setFocusOnFirstLink();\n    }\n  }\n\n  setFocusOnFirstLink() {\n    this.containerRef.querySelector('a').focus();\n  }\n\n  toggleAdditionalResources() {\n    this.setState((prevState) => ({\n      showAdditionalResources: !prevState.showAdditionalResources,\n      animateUL: prevState.animateUL + 1,\n    }));\n  }\n\n  render() {\n    const {\n      className,\n      classes,\n      closeMenu,\n      topic,\n      toTopic,\n      expandedSubtopicId,\n      onSubtopicExpand,\n      onGoBack,\n      backLabel,\n      resourceToLinkProps,\n      lastOpen,\n      t,\n      isUngrouped,\n    } = this.props;\n\n    const { showAdditionalResources, animateUL } = this.state;\n\n    const hasSubTopics = topic.subtopics && topic.subtopics.length > 0;\n    const hasContentTypeResults = lastOpen && topic.contentTypeResults && topic.contentTypeResults.length > 0;\n\n    const someResourcesAreAdditional =\n      hasContentTypeResults &&\n      topic.contentTypeResults.some((result) => result.resources.some((resource) => resource.additional));\n\n    return (\n      <div\n        className={className}\n        ref={(ref) => {\n          this.containerRef = ref;\n        }}>\n        <button type=\"button\" {...classes('back-button')} onClick={onGoBack}>\n          <Back /> <span>{backLabel}</span>\n        </button>\n        <SafeLink {...classes('link', ['big'])} onClick={closeMenu} to={toTopic(topic.id)}>\n          <span {...classes('link-wrapper')}>\n            <span {...classes('link-label')}>{t('masthead.menu.goTo')}:</span>\n            <span {...classes('link-target')}>\n              <span {...classes('link-target-name')}>{topic.name} </span>\n              <ChevronRight className=\"c-icon--22\" />\n            </span>\n          </span>\n          <ChevronRight />\n        </SafeLink>\n        {hasSubTopics && (\n          <ul {...classes('list')}>\n            {topic.subtopics.map((subtopic) => (\n              <SubtopicLink\n                onSubtopicExpand={onSubtopicExpand}\n                expandedSubtopicId={expandedSubtopicId}\n                classes={classes}\n                key={subtopic.id}\n                to={toTopic(topic.id, subtopic.id)}\n                subtopicId={subtopic.id}\n                subtopic={subtopic}\n                additionalTooltipLabel={t('resource.additionalTooltip')}\n              />\n            ))}\n          </ul>\n        )}\n        {hasContentTypeResults && (\n          <StyledAside>\n            <HeaderWrapper>\n              <StyledHeader>{t('masthead.menu.learningResourcesHeading')}</StyledHeader>\n              {someResourcesAreAdditional && (\n                <Switch\n                  id=\"showAdditionalId\"\n                  checked={showAdditionalResources}\n                  label={t('masthead.menu.additionalFilterLabel')}\n                  onChange={this.toggleAdditionalResources}\n                  css={switchLarge}\n                />\n              )}\n            </HeaderWrapper>\n            {isUngrouped && (\n              <ContentTypeResult\n                animateUL={animateUL}\n                resourceToLinkProps={resourceToLinkProps}\n                onNavigate={closeMenu}\n                contentTypeResult={{\n                  resources: topic.contentTypeResults\n                    .flatMap((grouped) =>\n                      grouped.resources.map((res) => ({\n                        ...res,\n                        contentType: grouped.contentType,\n                      })),\n                    )\n                    .sort((a, b) => a.rank - b.rank),\n                }}\n                messages={{\n                  noHit: t(`masthead.menu.contentTypeResultsNoHit.unGrouped`),\n                }}\n                unGrouped={isUngrouped}\n                showAdditionalResources={showAdditionalResources}\n                inMenu\n              />\n            )}\n            {!isUngrouped &&\n              topic.contentTypeResults.map((result) => (\n                <ContentTypeResult\n                  animateUL={animateUL}\n                  resourceToLinkProps={resourceToLinkProps}\n                  onNavigate={closeMenu}\n                  key={result.title}\n                  contentTypeResult={result}\n                  messages={{\n                    noHit: t(`masthead.menu.contentTypeResultsNoHit.${result.contentType}`),\n                  }}\n                  showAdditionalResources={showAdditionalResources}\n                  inMenu\n                />\n              ))}\n            {someResourcesAreAdditional && (\n              <Switch\n                id=\"showSomeAdditionalId\"\n                checked={showAdditionalResources}\n                label={t('masthead.menu.additionalFilterLabel')}\n                onChange={this.toggleAdditionalResources}\n                css={switchSmall}\n              />\n            )}\n          </StyledAside>\n        )}\n      </div>\n    );\n  }\n}\n\nexport default withTranslation()(SubtopicLinkList);\n"]} */"));
|
|
46
|
-
var StyledAside = /*#__PURE__*/(0, _base["default"])("aside", {
|
|
47
|
-
target: "e11boizo1",
|
|
48
|
-
label: "StyledAside"
|
|
49
|
-
})("padding:", _core.spacing.normal, ";", _core.mq.range({
|
|
50
|
-
from: _core.breakpoints.tabletWide
|
|
51
|
-
}), "{padding:", _core.spacing.small, ";width:600px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SubtopicLinkList.jsx"],"names":[],"mappings":"AA2CgC","file":"SubtopicLinkList.jsx","sourcesContent":["/**\n * Copyright (c) 2016-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, { Component } from 'react';\nimport { Back, ChevronRight } from '@ndla/icons/common';\nimport { Switch } from '@ndla/switch';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { mq, breakpoints, fonts, spacing } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\nimport { withTranslation } from 'react-i18next';\nimport ContentTypeResult from '../Search/ContentTypeResult';\nimport { renderAdditionalIcon } from './TopicMenu';\n\nconst switchLarge = css`\n  display: none;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    display: inline-flex;\n  }\n`;\n\nconst switchSmall = css`\n  display: inline-flex !important;\n  align-items: normal !important;\n  margin: 0 0 0 20px;\n  min-height: 0 !important;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    display: none !important;\n  }\n`;\n\nconst StyledHeader = styled.h1`\n  ${fonts.sizes('16px', '26px')};\n  margin: 0;\n  text-transform: uppercase;\n  padding-right: ${spacing.normal};\n`;\n\nconst StyledAside = styled.aside`\n  padding: ${spacing.normal};\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: ${spacing.small};\n    width: 600px;\n  }\n`;\n\nconst HeaderWrapper = styled.div`\n  display: flex;\n`;\n\nconst SubtopicLink = ({\n  classes,\n  to,\n  subtopic: { id, name, additional },\n  onSubtopicExpand,\n  expandedSubtopicId,\n  subtopicId,\n  additionalTooltipLabel,\n}) => {\n  const active = id === expandedSubtopicId;\n\n  return (\n    <li {...classes('subtopic-item', active && 'active')} key={id}>\n      <SafeLink\n        {...classes('link')}\n        onClick={(event) => {\n          event.preventDefault();\n          onSubtopicExpand(subtopicId);\n        }}\n        to={to}>\n        <span>\n          {name}\n          {renderAdditionalIcon(additional, additionalTooltipLabel)}\n        </span>\n        <ChevronRight />\n      </SafeLink>\n    </li>\n  );\n};\n\nclass SubtopicLinkList extends Component {\n  constructor(props) {\n    super(props);\n    this.state = {\n      showAdditionalResources: false,\n      animateUL: 0,\n    };\n    this.toggleAdditionalResources = this.toggleAdditionalResources.bind(this);\n    this.containerRef = null;\n  }\n\n  componentDidMount() {\n    this.setFocusOnFirstLink();\n  }\n\n  componentDidUpdate(prevProps) {\n    if (this.props.topic.id !== prevProps.topic.id) {\n      this.setFocusOnFirstLink();\n    }\n  }\n\n  setFocusOnFirstLink() {\n    this.containerRef.querySelector('a').focus();\n  }\n\n  toggleAdditionalResources() {\n    this.setState((prevState) => ({\n      showAdditionalResources: !prevState.showAdditionalResources,\n      animateUL: prevState.animateUL + 1,\n    }));\n  }\n\n  render() {\n    const {\n      className,\n      classes,\n      closeMenu,\n      topic,\n      toTopic,\n      expandedSubtopicId,\n      onSubtopicExpand,\n      onGoBack,\n      backLabel,\n      resourceToLinkProps,\n      lastOpen,\n      t,\n      isUngrouped,\n    } = this.props;\n\n    const { showAdditionalResources, animateUL } = this.state;\n\n    const hasSubTopics = topic.subtopics && topic.subtopics.length > 0;\n    const hasContentTypeResults = lastOpen && topic.contentTypeResults && topic.contentTypeResults.length > 0;\n\n    const someResourcesAreAdditional =\n      hasContentTypeResults &&\n      topic.contentTypeResults.some((result) => result.resources.some((resource) => resource.additional));\n\n    return (\n      <div\n        className={className}\n        ref={(ref) => {\n          this.containerRef = ref;\n        }}>\n        <button type=\"button\" {...classes('back-button')} onClick={onGoBack}>\n          <Back /> <span>{backLabel}</span>\n        </button>\n        <SafeLink {...classes('link', ['big'])} onClick={closeMenu} to={toTopic(topic.id)}>\n          <span {...classes('link-wrapper')}>\n            <span {...classes('link-label')}>{t('masthead.menu.goTo')}:</span>\n            <span {...classes('link-target')}>\n              <span {...classes('link-target-name')}>{topic.name} </span>\n              <ChevronRight className=\"c-icon--22\" />\n            </span>\n          </span>\n          <ChevronRight />\n        </SafeLink>\n        {hasSubTopics && (\n          <ul {...classes('list')}>\n            {topic.subtopics.map((subtopic) => (\n              <SubtopicLink\n                onSubtopicExpand={onSubtopicExpand}\n                expandedSubtopicId={expandedSubtopicId}\n                classes={classes}\n                key={subtopic.id}\n                to={toTopic(topic.id, subtopic.id)}\n                subtopicId={subtopic.id}\n                subtopic={subtopic}\n                additionalTooltipLabel={t('resource.additionalTooltip')}\n              />\n            ))}\n          </ul>\n        )}\n        {hasContentTypeResults && (\n          <StyledAside>\n            <HeaderWrapper>\n              <StyledHeader>{t('masthead.menu.learningResourcesHeading')}</StyledHeader>\n              {someResourcesAreAdditional && (\n                <Switch\n                  id=\"showAdditionalId\"\n                  checked={showAdditionalResources}\n                  label={t('masthead.menu.additionalFilterLabel')}\n                  onChange={this.toggleAdditionalResources}\n                  css={switchLarge}\n                />\n              )}\n            </HeaderWrapper>\n            {isUngrouped && (\n              <ContentTypeResult\n                animateUL={animateUL}\n                resourceToLinkProps={resourceToLinkProps}\n                onNavigate={closeMenu}\n                contentTypeResult={{\n                  resources: topic.contentTypeResults\n                    .flatMap((grouped) =>\n                      grouped.resources.map((res) => ({\n                        ...res,\n                        contentType: grouped.contentType,\n                      })),\n                    )\n                    .sort((a, b) => a.rank - b.rank),\n                }}\n                messages={{\n                  noHit: t(`masthead.menu.contentTypeResultsNoHit.unGrouped`),\n                }}\n                unGrouped={isUngrouped}\n                showAdditionalResources={showAdditionalResources}\n                inMenu\n              />\n            )}\n            {!isUngrouped &&\n              topic.contentTypeResults.map((result) => (\n                <ContentTypeResult\n                  animateUL={animateUL}\n                  resourceToLinkProps={resourceToLinkProps}\n                  onNavigate={closeMenu}\n                  key={result.title}\n                  contentTypeResult={result}\n                  messages={{\n                    noHit: t(`masthead.menu.contentTypeResultsNoHit.${result.contentType}`),\n                  }}\n                  showAdditionalResources={showAdditionalResources}\n                  inMenu\n                />\n              ))}\n            {someResourcesAreAdditional && (\n              <Switch\n                id=\"showSomeAdditionalId\"\n                checked={showAdditionalResources}\n                label={t('masthead.menu.additionalFilterLabel')}\n                onChange={this.toggleAdditionalResources}\n                css={switchSmall}\n              />\n            )}\n          </StyledAside>\n        )}\n      </div>\n    );\n  }\n}\n\nexport default withTranslation()(SubtopicLinkList);\n"]} */"));
|
|
52
|
-
var HeaderWrapper = /*#__PURE__*/(0, _base["default"])("div", {
|
|
53
|
-
target: "e11boizo0",
|
|
54
|
-
label: "HeaderWrapper"
|
|
55
|
-
})(process.env.NODE_ENV === "production" ? {
|
|
56
|
-
name: "zjik7",
|
|
57
|
-
styles: "display:flex"
|
|
58
|
-
} : {
|
|
59
|
-
name: "zjik7",
|
|
60
|
-
styles: "display:flex",
|
|
61
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SubtopicLinkList.jsx"],"names":[],"mappings":"AAmDgC","file":"SubtopicLinkList.jsx","sourcesContent":["/**\n * Copyright (c) 2016-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, { Component } from 'react';\nimport { Back, ChevronRight } from '@ndla/icons/common';\nimport { Switch } from '@ndla/switch';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { mq, breakpoints, fonts, spacing } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\nimport { withTranslation } from 'react-i18next';\nimport ContentTypeResult from '../Search/ContentTypeResult';\nimport { renderAdditionalIcon } from './TopicMenu';\n\nconst switchLarge = css`\n  display: none;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    display: inline-flex;\n  }\n`;\n\nconst switchSmall = css`\n  display: inline-flex !important;\n  align-items: normal !important;\n  margin: 0 0 0 20px;\n  min-height: 0 !important;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    display: none !important;\n  }\n`;\n\nconst StyledHeader = styled.h1`\n  ${fonts.sizes('16px', '26px')};\n  margin: 0;\n  text-transform: uppercase;\n  padding-right: ${spacing.normal};\n`;\n\nconst StyledAside = styled.aside`\n  padding: ${spacing.normal};\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: ${spacing.small};\n    width: 600px;\n  }\n`;\n\nconst HeaderWrapper = styled.div`\n  display: flex;\n`;\n\nconst SubtopicLink = ({\n  classes,\n  to,\n  subtopic: { id, name, additional },\n  onSubtopicExpand,\n  expandedSubtopicId,\n  subtopicId,\n  additionalTooltipLabel,\n}) => {\n  const active = id === expandedSubtopicId;\n\n  return (\n    <li {...classes('subtopic-item', active && 'active')} key={id}>\n      <SafeLink\n        {...classes('link')}\n        onClick={(event) => {\n          event.preventDefault();\n          onSubtopicExpand(subtopicId);\n        }}\n        to={to}>\n        <span>\n          {name}\n          {renderAdditionalIcon(additional, additionalTooltipLabel)}\n        </span>\n        <ChevronRight />\n      </SafeLink>\n    </li>\n  );\n};\n\nclass SubtopicLinkList extends Component {\n  constructor(props) {\n    super(props);\n    this.state = {\n      showAdditionalResources: false,\n      animateUL: 0,\n    };\n    this.toggleAdditionalResources = this.toggleAdditionalResources.bind(this);\n    this.containerRef = null;\n  }\n\n  componentDidMount() {\n    this.setFocusOnFirstLink();\n  }\n\n  componentDidUpdate(prevProps) {\n    if (this.props.topic.id !== prevProps.topic.id) {\n      this.setFocusOnFirstLink();\n    }\n  }\n\n  setFocusOnFirstLink() {\n    this.containerRef.querySelector('a').focus();\n  }\n\n  toggleAdditionalResources() {\n    this.setState((prevState) => ({\n      showAdditionalResources: !prevState.showAdditionalResources,\n      animateUL: prevState.animateUL + 1,\n    }));\n  }\n\n  render() {\n    const {\n      className,\n      classes,\n      closeMenu,\n      topic,\n      toTopic,\n      expandedSubtopicId,\n      onSubtopicExpand,\n      onGoBack,\n      backLabel,\n      resourceToLinkProps,\n      lastOpen,\n      t,\n      isUngrouped,\n    } = this.props;\n\n    const { showAdditionalResources, animateUL } = this.state;\n\n    const hasSubTopics = topic.subtopics && topic.subtopics.length > 0;\n    const hasContentTypeResults = lastOpen && topic.contentTypeResults && topic.contentTypeResults.length > 0;\n\n    const someResourcesAreAdditional =\n      hasContentTypeResults &&\n      topic.contentTypeResults.some((result) => result.resources.some((resource) => resource.additional));\n\n    return (\n      <div\n        className={className}\n        ref={(ref) => {\n          this.containerRef = ref;\n        }}>\n        <button type=\"button\" {...classes('back-button')} onClick={onGoBack}>\n          <Back /> <span>{backLabel}</span>\n        </button>\n        <SafeLink {...classes('link', ['big'])} onClick={closeMenu} to={toTopic(topic.id)}>\n          <span {...classes('link-wrapper')}>\n            <span {...classes('link-label')}>{t('masthead.menu.goTo')}:</span>\n            <span {...classes('link-target')}>\n              <span {...classes('link-target-name')}>{topic.name} </span>\n              <ChevronRight className=\"c-icon--22\" />\n            </span>\n          </span>\n          <ChevronRight />\n        </SafeLink>\n        {hasSubTopics && (\n          <ul {...classes('list')}>\n            {topic.subtopics.map((subtopic) => (\n              <SubtopicLink\n                onSubtopicExpand={onSubtopicExpand}\n                expandedSubtopicId={expandedSubtopicId}\n                classes={classes}\n                key={subtopic.id}\n                to={toTopic(topic.id, subtopic.id)}\n                subtopicId={subtopic.id}\n                subtopic={subtopic}\n                additionalTooltipLabel={t('resource.additionalTooltip')}\n              />\n            ))}\n          </ul>\n        )}\n        {hasContentTypeResults && (\n          <StyledAside>\n            <HeaderWrapper>\n              <StyledHeader>{t('masthead.menu.learningResourcesHeading')}</StyledHeader>\n              {someResourcesAreAdditional && (\n                <Switch\n                  id=\"showAdditionalId\"\n                  checked={showAdditionalResources}\n                  label={t('masthead.menu.additionalFilterLabel')}\n                  onChange={this.toggleAdditionalResources}\n                  css={switchLarge}\n                />\n              )}\n            </HeaderWrapper>\n            {isUngrouped && (\n              <ContentTypeResult\n                animateUL={animateUL}\n                resourceToLinkProps={resourceToLinkProps}\n                onNavigate={closeMenu}\n                contentTypeResult={{\n                  resources: topic.contentTypeResults\n                    .flatMap((grouped) =>\n                      grouped.resources.map((res) => ({\n                        ...res,\n                        contentType: grouped.contentType,\n                      })),\n                    )\n                    .sort((a, b) => a.rank - b.rank),\n                }}\n                messages={{\n                  noHit: t(`masthead.menu.contentTypeResultsNoHit.unGrouped`),\n                }}\n                unGrouped={isUngrouped}\n                showAdditionalResources={showAdditionalResources}\n                inMenu\n              />\n            )}\n            {!isUngrouped &&\n              topic.contentTypeResults.map((result) => (\n                <ContentTypeResult\n                  animateUL={animateUL}\n                  resourceToLinkProps={resourceToLinkProps}\n                  onNavigate={closeMenu}\n                  key={result.title}\n                  contentTypeResult={result}\n                  messages={{\n                    noHit: t(`masthead.menu.contentTypeResultsNoHit.${result.contentType}`),\n                  }}\n                  showAdditionalResources={showAdditionalResources}\n                  inMenu\n                />\n              ))}\n            {someResourcesAreAdditional && (\n              <Switch\n                id=\"showSomeAdditionalId\"\n                checked={showAdditionalResources}\n                label={t('masthead.menu.additionalFilterLabel')}\n                onChange={this.toggleAdditionalResources}\n                css={switchSmall}\n              />\n            )}\n          </StyledAside>\n        )}\n      </div>\n    );\n  }\n}\n\nexport default withTranslation()(SubtopicLinkList);\n"]} */",
|
|
62
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
63
|
-
});
|
|
64
|
-
var SubtopicLink = function SubtopicLink(_ref) {
|
|
65
|
-
var classes = _ref.classes,
|
|
66
|
-
to = _ref.to,
|
|
67
|
-
_ref$subtopic = _ref.subtopic,
|
|
68
|
-
id = _ref$subtopic.id,
|
|
69
|
-
name = _ref$subtopic.name,
|
|
70
|
-
additional = _ref$subtopic.additional,
|
|
71
|
-
onSubtopicExpand = _ref.onSubtopicExpand,
|
|
72
|
-
expandedSubtopicId = _ref.expandedSubtopicId,
|
|
73
|
-
subtopicId = _ref.subtopicId,
|
|
74
|
-
additionalTooltipLabel = _ref.additionalTooltipLabel;
|
|
75
|
-
var active = id === expandedSubtopicId;
|
|
76
|
-
return (0, _react2.createElement)("li", _objectSpread(_objectSpread({}, classes('subtopic-item', active && 'active')), {}, {
|
|
77
|
-
key: id
|
|
78
|
-
}), (0, _jsxRuntime.jsxs)(_safelink["default"], _objectSpread(_objectSpread({}, classes('link')), {}, {
|
|
79
|
-
onClick: function onClick(event) {
|
|
80
|
-
event.preventDefault();
|
|
81
|
-
onSubtopicExpand(subtopicId);
|
|
82
|
-
},
|
|
83
|
-
to: to,
|
|
84
|
-
children: [(0, _jsxRuntime.jsxs)("span", {
|
|
85
|
-
children: [name, (0, _TopicMenu.renderAdditionalIcon)(additional, additionalTooltipLabel)]
|
|
86
|
-
}), (0, _jsxRuntime.jsx)(_common.ChevronRight, {})]
|
|
87
|
-
})));
|
|
88
|
-
};
|
|
89
|
-
var SubtopicLinkList = /*#__PURE__*/function (_Component) {
|
|
90
|
-
_inherits(SubtopicLinkList, _Component);
|
|
91
|
-
var _super = _createSuper(SubtopicLinkList);
|
|
92
|
-
function SubtopicLinkList(props) {
|
|
93
|
-
var _this;
|
|
94
|
-
_classCallCheck(this, SubtopicLinkList);
|
|
95
|
-
_this = _super.call(this, props);
|
|
96
|
-
_this.state = {
|
|
97
|
-
showAdditionalResources: false,
|
|
98
|
-
animateUL: 0
|
|
99
|
-
};
|
|
100
|
-
_this.toggleAdditionalResources = _this.toggleAdditionalResources.bind(_assertThisInitialized(_this));
|
|
101
|
-
_this.containerRef = null;
|
|
102
|
-
return _this;
|
|
103
|
-
}
|
|
104
|
-
_createClass(SubtopicLinkList, [{
|
|
105
|
-
key: "componentDidMount",
|
|
106
|
-
value: function componentDidMount() {
|
|
107
|
-
this.setFocusOnFirstLink();
|
|
108
|
-
}
|
|
109
|
-
}, {
|
|
110
|
-
key: "componentDidUpdate",
|
|
111
|
-
value: function componentDidUpdate(prevProps) {
|
|
112
|
-
if (this.props.topic.id !== prevProps.topic.id) {
|
|
113
|
-
this.setFocusOnFirstLink();
|
|
114
|
-
}
|
|
115
|
-
}
|
|
116
|
-
}, {
|
|
117
|
-
key: "setFocusOnFirstLink",
|
|
118
|
-
value: function setFocusOnFirstLink() {
|
|
119
|
-
this.containerRef.querySelector('a').focus();
|
|
120
|
-
}
|
|
121
|
-
}, {
|
|
122
|
-
key: "toggleAdditionalResources",
|
|
123
|
-
value: function toggleAdditionalResources() {
|
|
124
|
-
this.setState(function (prevState) {
|
|
125
|
-
return {
|
|
126
|
-
showAdditionalResources: !prevState.showAdditionalResources,
|
|
127
|
-
animateUL: prevState.animateUL + 1
|
|
128
|
-
};
|
|
129
|
-
});
|
|
130
|
-
}
|
|
131
|
-
}, {
|
|
132
|
-
key: "render",
|
|
133
|
-
value: function render() {
|
|
134
|
-
var _this2 = this;
|
|
135
|
-
var _this$props = this.props,
|
|
136
|
-
className = _this$props.className,
|
|
137
|
-
classes = _this$props.classes,
|
|
138
|
-
closeMenu = _this$props.closeMenu,
|
|
139
|
-
topic = _this$props.topic,
|
|
140
|
-
toTopic = _this$props.toTopic,
|
|
141
|
-
expandedSubtopicId = _this$props.expandedSubtopicId,
|
|
142
|
-
onSubtopicExpand = _this$props.onSubtopicExpand,
|
|
143
|
-
onGoBack = _this$props.onGoBack,
|
|
144
|
-
backLabel = _this$props.backLabel,
|
|
145
|
-
resourceToLinkProps = _this$props.resourceToLinkProps,
|
|
146
|
-
lastOpen = _this$props.lastOpen,
|
|
147
|
-
t = _this$props.t,
|
|
148
|
-
isUngrouped = _this$props.isUngrouped;
|
|
149
|
-
var _this$state = this.state,
|
|
150
|
-
showAdditionalResources = _this$state.showAdditionalResources,
|
|
151
|
-
animateUL = _this$state.animateUL;
|
|
152
|
-
var hasSubTopics = topic.subtopics && topic.subtopics.length > 0;
|
|
153
|
-
var hasContentTypeResults = lastOpen && topic.contentTypeResults && topic.contentTypeResults.length > 0;
|
|
154
|
-
var someResourcesAreAdditional = hasContentTypeResults && topic.contentTypeResults.some(function (result) {
|
|
155
|
-
return result.resources.some(function (resource) {
|
|
156
|
-
return resource.additional;
|
|
157
|
-
});
|
|
158
|
-
});
|
|
159
|
-
return (0, _jsxRuntime.jsxs)("div", {
|
|
160
|
-
className: className,
|
|
161
|
-
ref: function ref(_ref2) {
|
|
162
|
-
_this2.containerRef = _ref2;
|
|
163
|
-
},
|
|
164
|
-
children: [(0, _jsxRuntime.jsxs)("button", _objectSpread(_objectSpread({
|
|
165
|
-
type: "button"
|
|
166
|
-
}, classes('back-button')), {}, {
|
|
167
|
-
onClick: onGoBack,
|
|
168
|
-
children: [(0, _jsxRuntime.jsx)(_common.Back, {}), " ", (0, _jsxRuntime.jsx)("span", {
|
|
169
|
-
children: backLabel
|
|
170
|
-
})]
|
|
171
|
-
})), (0, _jsxRuntime.jsxs)(_safelink["default"], _objectSpread(_objectSpread({}, classes('link', ['big'])), {}, {
|
|
172
|
-
onClick: closeMenu,
|
|
173
|
-
to: toTopic(topic.id),
|
|
174
|
-
children: [(0, _jsxRuntime.jsxs)("span", _objectSpread(_objectSpread({}, classes('link-wrapper')), {}, {
|
|
175
|
-
children: [(0, _jsxRuntime.jsxs)("span", _objectSpread(_objectSpread({}, classes('link-label')), {}, {
|
|
176
|
-
children: [t('masthead.menu.goTo'), ":"]
|
|
177
|
-
})), (0, _jsxRuntime.jsxs)("span", _objectSpread(_objectSpread({}, classes('link-target')), {}, {
|
|
178
|
-
children: [(0, _jsxRuntime.jsxs)("span", _objectSpread(_objectSpread({}, classes('link-target-name')), {}, {
|
|
179
|
-
children: [topic.name, " "]
|
|
180
|
-
})), (0, _jsxRuntime.jsx)(_common.ChevronRight, {
|
|
181
|
-
className: "c-icon--22"
|
|
182
|
-
})]
|
|
183
|
-
}))]
|
|
184
|
-
})), (0, _jsxRuntime.jsx)(_common.ChevronRight, {})]
|
|
185
|
-
})), hasSubTopics && (0, _jsxRuntime.jsx)("ul", _objectSpread(_objectSpread({}, classes('list')), {}, {
|
|
186
|
-
children: topic.subtopics.map(function (subtopic) {
|
|
187
|
-
return (0, _jsxRuntime.jsx)(SubtopicLink, {
|
|
188
|
-
onSubtopicExpand: onSubtopicExpand,
|
|
189
|
-
expandedSubtopicId: expandedSubtopicId,
|
|
190
|
-
classes: classes,
|
|
191
|
-
to: toTopic(topic.id, subtopic.id),
|
|
192
|
-
subtopicId: subtopic.id,
|
|
193
|
-
subtopic: subtopic,
|
|
194
|
-
additionalTooltipLabel: t('resource.additionalTooltip')
|
|
195
|
-
}, subtopic.id);
|
|
196
|
-
})
|
|
197
|
-
})), hasContentTypeResults && (0, _jsxRuntime.jsxs)(StyledAside, {
|
|
198
|
-
children: [(0, _jsxRuntime.jsxs)(HeaderWrapper, {
|
|
199
|
-
children: [(0, _jsxRuntime.jsx)(StyledHeader, {
|
|
200
|
-
children: t('masthead.menu.learningResourcesHeading')
|
|
201
|
-
}), someResourcesAreAdditional && (0, _jsxRuntime.jsx)(_switch.Switch, {
|
|
202
|
-
id: "showAdditionalId",
|
|
203
|
-
checked: showAdditionalResources,
|
|
204
|
-
label: t('masthead.menu.additionalFilterLabel'),
|
|
205
|
-
onChange: this.toggleAdditionalResources,
|
|
206
|
-
css: switchLarge
|
|
207
|
-
})]
|
|
208
|
-
}), isUngrouped && (0, _jsxRuntime.jsx)(_ContentTypeResult["default"], {
|
|
209
|
-
animateUL: animateUL,
|
|
210
|
-
resourceToLinkProps: resourceToLinkProps,
|
|
211
|
-
onNavigate: closeMenu,
|
|
212
|
-
contentTypeResult: {
|
|
213
|
-
resources: topic.contentTypeResults.flatMap(function (grouped) {
|
|
214
|
-
return grouped.resources.map(function (res) {
|
|
215
|
-
return _objectSpread(_objectSpread({}, res), {}, {
|
|
216
|
-
contentType: grouped.contentType
|
|
217
|
-
});
|
|
218
|
-
});
|
|
219
|
-
}).sort(function (a, b) {
|
|
220
|
-
return a.rank - b.rank;
|
|
221
|
-
})
|
|
222
|
-
},
|
|
223
|
-
messages: {
|
|
224
|
-
noHit: t("masthead.menu.contentTypeResultsNoHit.unGrouped")
|
|
225
|
-
},
|
|
226
|
-
unGrouped: isUngrouped,
|
|
227
|
-
showAdditionalResources: showAdditionalResources,
|
|
228
|
-
inMenu: true
|
|
229
|
-
}), !isUngrouped && topic.contentTypeResults.map(function (result) {
|
|
230
|
-
return (0, _jsxRuntime.jsx)(_ContentTypeResult["default"], {
|
|
231
|
-
animateUL: animateUL,
|
|
232
|
-
resourceToLinkProps: resourceToLinkProps,
|
|
233
|
-
onNavigate: closeMenu,
|
|
234
|
-
contentTypeResult: result,
|
|
235
|
-
messages: {
|
|
236
|
-
noHit: t("masthead.menu.contentTypeResultsNoHit.".concat(result.contentType))
|
|
237
|
-
},
|
|
238
|
-
showAdditionalResources: showAdditionalResources,
|
|
239
|
-
inMenu: true
|
|
240
|
-
}, result.title);
|
|
241
|
-
}), someResourcesAreAdditional && (0, _jsxRuntime.jsx)(_switch.Switch, {
|
|
242
|
-
id: "showSomeAdditionalId",
|
|
243
|
-
checked: showAdditionalResources,
|
|
244
|
-
label: t('masthead.menu.additionalFilterLabel'),
|
|
245
|
-
onChange: this.toggleAdditionalResources,
|
|
246
|
-
css: switchSmall
|
|
247
|
-
})]
|
|
248
|
-
})]
|
|
249
|
-
});
|
|
250
|
-
}
|
|
251
|
-
}]);
|
|
252
|
-
return SubtopicLinkList;
|
|
253
|
-
}(_react.Component);
|
|
254
|
-
var _default = (0, _reactI18next.withTranslation)()(SubtopicLinkList);
|
|
255
|
-
exports["default"] = _default;
|