@ndla/ui 40.0.0 → 41.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/es/Article/Article.js +2 -4
- package/es/Article/ArticleHeaderWrapper.js +3 -64
- package/es/LearningPaths/LearningPathMenuContent.js +6 -6
- package/es/LearningPaths/LearningPathMenuIntro.js +8 -8
- package/es/LearningPaths/LearningPathMenuModalWrapper.js +2 -2
- package/es/Masthead/MastheadSearchModal.js +2 -2
- package/es/index.js +0 -1
- package/lib/Article/Article.d.ts +3 -10
- package/lib/Article/Article.js +2 -4
- package/lib/Article/ArticleHeaderWrapper.d.ts +3 -11
- package/lib/Article/ArticleHeaderWrapper.js +11 -71
- package/lib/LearningPaths/LearningPathMenuContent.js +6 -6
- package/lib/LearningPaths/LearningPathMenuIntro.js +8 -8
- package/lib/LearningPaths/LearningPathMenuModalWrapper.d.ts +2 -2
- package/lib/LearningPaths/LearningPathMenuModalWrapper.js +2 -2
- package/lib/Masthead/MastheadSearchModal.d.ts +2 -2
- package/lib/Masthead/MastheadSearchModal.js +2 -2
- package/lib/index.d.ts +0 -1
- package/lib/index.js +0 -7
- package/package.json +4 -4
- package/src/Article/Article.tsx +3 -8
- package/src/Article/ArticleHeaderWrapper.tsx +4 -52
- package/src/LearningPaths/LearningPathMenu.stories.tsx +68 -0
- package/src/LearningPaths/LearningPathMenuContent.tsx +1 -1
- package/src/LearningPaths/LearningPathMenuIntro.tsx +1 -1
- package/src/LearningPaths/LearningPathMenuModalWrapper.tsx +2 -2
- package/src/Masthead/MastheadSearchModal.tsx +2 -2
- package/src/index.ts +0 -2
- package/es/CompetenceGoals/CompetenceGoalsDialog.js +0 -79
- package/es/CompetenceGoals/index.js +0 -1
- package/lib/CompetenceGoals/CompetenceGoalsDialog.d.ts +0 -8
- package/lib/CompetenceGoals/CompetenceGoalsDialog.js +0 -84
- package/lib/CompetenceGoals/index.d.ts +0 -1
- package/lib/CompetenceGoals/index.js +0 -13
- package/src/CompetenceGoals/CompetenceGoalsDialog.tsx +0 -70
- package/src/CompetenceGoals/index.ts +0 -1
|
@@ -1,66 +1,35 @@
|
|
|
1
1
|
"use strict";
|
|
2
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
3
|
Object.defineProperty(exports, "__esModule", {
|
|
5
4
|
value: true
|
|
6
5
|
});
|
|
7
6
|
exports["default"] = void 0;
|
|
8
|
-
var _base = _interopRequireDefault(require("@emotion/styled/base"));
|
|
9
7
|
var _react = _interopRequireWildcard(require("react"));
|
|
10
8
|
var _reactBemHelper = _interopRequireDefault(require("react-bem-helper"));
|
|
11
|
-
var _reactI18next = require("react-i18next");
|
|
12
|
-
var _button = require("@ndla/button");
|
|
13
9
|
var _reactDeviceDetect = require("react-device-detect");
|
|
14
|
-
var _common = require("@ndla/icons/common");
|
|
15
|
-
var _CompetenceGoalsDialog = _interopRequireDefault(require("../CompetenceGoals/CompetenceGoalsDialog"));
|
|
16
10
|
var _jsxRuntime = require("@emotion/react/jsx-runtime");
|
|
11
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
|
17
12
|
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); }
|
|
18
13
|
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; }
|
|
19
|
-
function
|
|
14
|
+
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); }
|
|
20
15
|
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; }
|
|
21
16
|
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; }
|
|
22
17
|
function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
|
23
18
|
function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return _typeof(key) === "symbol" ? key : String(key); }
|
|
24
|
-
function _toPrimitive(input, hint) { if (_typeof(input) !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (_typeof(res) !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
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)."; } /**
|
|
32
|
-
* Copyright (c) 2016-present, NDLA.
|
|
33
|
-
*
|
|
34
|
-
* This source code is licensed under the GPLv3 license found in the
|
|
35
|
-
* LICENSE file in the root directory of this source tree.
|
|
36
|
-
*
|
|
37
|
-
*/
|
|
19
|
+
function _toPrimitive(input, hint) { if (_typeof(input) !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (_typeof(res) !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); } /**
|
|
20
|
+
* Copyright (c) 2016-present, NDLA.
|
|
21
|
+
*
|
|
22
|
+
* This source code is licensed under the GPLv3 license found in the
|
|
23
|
+
* LICENSE file in the root directory of this source tree.
|
|
24
|
+
*
|
|
25
|
+
*/
|
|
38
26
|
var classes = new _reactBemHelper["default"]({
|
|
39
27
|
name: 'article',
|
|
40
28
|
prefix: 'c-'
|
|
41
29
|
});
|
|
42
|
-
var CompetenceBadgeText = /*#__PURE__*/(0, _base["default"])("span", {
|
|
43
|
-
target: "e1daii1f0",
|
|
44
|
-
label: "CompetenceBadgeText"
|
|
45
|
-
})(process.env.NODE_ENV === "production" ? {
|
|
46
|
-
name: "x85wbw",
|
|
47
|
-
styles: "padding:0 5px"
|
|
48
|
-
} : {
|
|
49
|
-
name: "x85wbw",
|
|
50
|
-
styles: "padding:0 5px",
|
|
51
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkFydGljbGVIZWFkZXJXcmFwcGVyLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF1QnVDIiwiZmlsZSI6IkFydGljbGVIZWFkZXJXcmFwcGVyLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE2LXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IFJlYWN0LCB7IENvbXBvbmVudFR5cGUsIFJlYWN0Tm9kZSwgdXNlRWZmZWN0LCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCBCRU1IZWxwZXIgZnJvbSAncmVhY3QtYmVtLWhlbHBlcic7XG5pbXBvcnQgeyB1c2VUcmFuc2xhdGlvbiB9IGZyb20gJ3JlYWN0LWkxOG5leHQnO1xuaW1wb3J0IHsgQnV0dG9uVjIgfSBmcm9tICdAbmRsYS9idXR0b24nO1xuaW1wb3J0IHsgaXNNb2JpbGUgfSBmcm9tICdyZWFjdC1kZXZpY2UtZGV0ZWN0JztcblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgRm9vdGVySGVhZGVySWNvbiB9IGZyb20gJ0BuZGxhL2ljb25zL2NvbW1vbic7XG5pbXBvcnQgQ29tcGV0ZW5jZUdvYWxzRGlhbG9nIGZyb20gJy4uL0NvbXBldGVuY2VHb2Fscy9Db21wZXRlbmNlR29hbHNEaWFsb2cnO1xuXG5jb25zdCBjbGFzc2VzID0gbmV3IEJFTUhlbHBlcih7XG4gIG5hbWU6ICdhcnRpY2xlJyxcbiAgcHJlZml4OiAnYy0nLFxufSk7XG5cbmNvbnN0IENvbXBldGVuY2VCYWRnZVRleHQgPSBzdHlsZWQuc3BhbmBcbiAgcGFkZGluZzogMCA1cHg7XG5gO1xuXG50eXBlIFByb3BzID0ge1xuICBjb21wZXRlbmNlR29hbHM/OiAoaW5wOiB7XG4gICAgRGlhbG9nOiBDb21wb25lbnRUeXBlO1xuICAgIGRpYWxvZ1Byb3BzOiB7IGlzT3BlbjogYm9vbGVhbjsgb25DbG9zZTogKCkgPT4gdm9pZDsgY29udHJvbGxlZDogdHJ1ZSB9O1xuICB9KSA9PiBSZWFjdE5vZGU7XG4gIGNvbXBldGVuY2VHb2Fsc0xvYWRpbmc/OiBib29sZWFuO1xuICBjaGlsZHJlbjogUmVhY3ROb2RlO1xufTtcblxuY29uc3QgQXJ0aWNsZUhlYWRlcldyYXBwZXIgPSAoeyBjaGlsZHJlbiwgY29tcGV0ZW5jZUdvYWxzLCBjb21wZXRlbmNlR29hbHNMb2FkaW5nIH06IFByb3BzKSA9PiB7XG4gIGNvbnN0IFtpc09wZW4sIHNldElzT3Blbl0gPSB1c2VTdGF0ZShmYWxzZSk7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGlmIChpc01vYmlsZSkge1xuICAgICAgY29uc3QgaGVyb0NvbnRlbnRMaXN0OiBOb2RlTGlzdE9mPEhUTUxFbGVtZW50PiA9IGRvY3VtZW50LnF1ZXJ5U2VsZWN0b3JBbGwoJy5jLWFydGljbGVfX2hlYWRlcicpO1xuICAgICAgaWYgKGhlcm9Db250ZW50TGlzdC5sZW5ndGggPT09IDEpIHtcbiAgICAgICAgaGVyb0NvbnRlbnRMaXN0WzBdLnNjcm9sbEludG9WaWV3KHRydWUpO1xuICAgICAgICB3aW5kb3cuc2Nyb2xsQnkoMCwgaGVyb0NvbnRlbnRMaXN0WzBdLm9mZnNldFRvcCAtIDEyMCk7IC8vIEFkanVzdCBmb3IgaGVhZGVyXG4gICAgICB9XG4gICAgfVxuICB9LCBbXSk7XG5cbiAgY29uc3Qgb3BlbkRpYWxvZyA9ICgpID0+IHtcbiAgICBzZXRJc09wZW4odHJ1ZSk7XG4gIH07XG5cbiAgY29uc3QgY2xvc2VEaWFsb2cgPSAoKSA9PiB7XG4gICAgc2V0SXNPcGVuKGZhbHNlKTtcbiAgfTtcblxuICBpZiAoIWNvbXBldGVuY2VHb2Fscykge1xuICAgIHJldHVybiA8ZGl2IHsuLi5jbGFzc2VzKCdoZWFkZXInKX0+e2NoaWxkcmVufTwvZGl2PjtcbiAgfVxuXG4gIGNvbnN0IGRpYWxvZyA9IGNvbXBldGVuY2VHb2Fscyh7XG4gICAgRGlhbG9nOiBDb21wZXRlbmNlR29hbHNEaWFsb2csXG4gICAgZGlhbG9nUHJvcHM6IHtcbiAgICAgIGlzT3BlbjogaXNPcGVuLFxuICAgICAgb25DbG9zZTogY2xvc2VEaWFsb2csXG4gICAgICBjb250cm9sbGVkOiB0cnVlLFxuICAgIH0sXG4gIH0pO1xuICByZXR1cm4gKFxuICAgIDxkaXYgey4uLmNsYXNzZXMoJ2hlYWRlcicpfT5cbiAgICAgIHtjaGlsZHJlbn1cbiAgICAgIDxCdXR0b25WMlxuICAgICAgICBhcmlhLWJ1c3k9e2NvbXBldGVuY2VHb2Fsc0xvYWRpbmd9XG4gICAgICAgIHNpemU9XCJ4c21hbGxcIlxuICAgICAgICBjb2xvclRoZW1lPVwibGlnaHRcIlxuICAgICAgICBzaGFwZT1cInBpbGxcIlxuICAgICAgICBvbkNsaWNrPXtvcGVuRGlhbG9nfVxuICAgICAgICBkaXNhYmxlZD17Y29tcGV0ZW5jZUdvYWxzTG9hZGluZ31cbiAgICAgID5cbiAgICAgICAgPEZvb3RlckhlYWRlckljb24gLz5cbiAgICAgICAgPENvbXBldGVuY2VCYWRnZVRleHQ+e3QoJ2NvbXBldGVuY2VHb2Fscy5zaG93Q29tcGV0ZW5jZUdvYWxzJyl9PC9Db21wZXRlbmNlQmFkZ2VUZXh0PlxuICAgICAgPC9CdXR0b25WMj5cbiAgICAgIHtkaWFsb2d9XG4gICAgPC9kaXY+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBBcnRpY2xlSGVhZGVyV3JhcHBlcjtcbiJdfQ== */",
|
|
52
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
53
|
-
});
|
|
54
30
|
var ArticleHeaderWrapper = function ArticleHeaderWrapper(_ref) {
|
|
55
31
|
var children = _ref.children,
|
|
56
|
-
competenceGoals = _ref.competenceGoals
|
|
57
|
-
competenceGoalsLoading = _ref.competenceGoalsLoading;
|
|
58
|
-
var _useState = (0, _react.useState)(false),
|
|
59
|
-
_useState2 = _slicedToArray(_useState, 2),
|
|
60
|
-
isOpen = _useState2[0],
|
|
61
|
-
setIsOpen = _useState2[1];
|
|
62
|
-
var _useTranslation = (0, _reactI18next.useTranslation)(),
|
|
63
|
-
t = _useTranslation.t;
|
|
32
|
+
competenceGoals = _ref.competenceGoals;
|
|
64
33
|
(0, _react.useEffect)(function () {
|
|
65
34
|
if (_reactDeviceDetect.isMobile) {
|
|
66
35
|
var heroContentList = document.querySelectorAll('.c-article__header');
|
|
@@ -70,37 +39,8 @@ var ArticleHeaderWrapper = function ArticleHeaderWrapper(_ref) {
|
|
|
70
39
|
}
|
|
71
40
|
}
|
|
72
41
|
}, []);
|
|
73
|
-
var openDialog = function openDialog() {
|
|
74
|
-
setIsOpen(true);
|
|
75
|
-
};
|
|
76
|
-
var closeDialog = function closeDialog() {
|
|
77
|
-
setIsOpen(false);
|
|
78
|
-
};
|
|
79
|
-
if (!competenceGoals) {
|
|
80
|
-
return (0, _jsxRuntime.jsx)("div", _objectSpread(_objectSpread({}, classes('header')), {}, {
|
|
81
|
-
children: children
|
|
82
|
-
}));
|
|
83
|
-
}
|
|
84
|
-
var dialog = competenceGoals({
|
|
85
|
-
Dialog: _CompetenceGoalsDialog["default"],
|
|
86
|
-
dialogProps: {
|
|
87
|
-
isOpen: isOpen,
|
|
88
|
-
onClose: closeDialog,
|
|
89
|
-
controlled: true
|
|
90
|
-
}
|
|
91
|
-
});
|
|
92
42
|
return (0, _jsxRuntime.jsxs)("div", _objectSpread(_objectSpread({}, classes('header')), {}, {
|
|
93
|
-
children: [children,
|
|
94
|
-
"aria-busy": competenceGoalsLoading,
|
|
95
|
-
size: "xsmall",
|
|
96
|
-
colorTheme: "light",
|
|
97
|
-
shape: "pill",
|
|
98
|
-
onClick: openDialog,
|
|
99
|
-
disabled: competenceGoalsLoading,
|
|
100
|
-
children: [(0, _jsxRuntime.jsx)(_common.FooterHeaderIcon, {}), (0, _jsxRuntime.jsx)(CompetenceBadgeText, {
|
|
101
|
-
children: t('competenceGoals.showCompetenceGoals')
|
|
102
|
-
})]
|
|
103
|
-
}), dialog]
|
|
43
|
+
children: [children, competenceGoals]
|
|
104
44
|
}));
|
|
105
45
|
};
|
|
106
46
|
var _default = ArticleHeaderWrapper;
|
|
@@ -47,15 +47,15 @@ var StyledMenuItem = /*#__PURE__*/(0, _base["default"])("li", {
|
|
|
47
47
|
return !props.afterCurrent && !props.current && props.invertedStyle && "\n ".concat(_core.mq.range({
|
|
48
48
|
from: _core.breakpoints.tablet
|
|
49
49
|
}), " {\n a {\n > span {\n color: #fff;\n }\n color: #fff;\n }\n }\n ");
|
|
50
|
-
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlYXJuaW5nUGF0aE1lbnVDb250ZW50LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE2QnFEIiwiZmlsZSI6IkxlYXJuaW5nUGF0aE1lbnVDb250ZW50LnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE5LXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IGNvbG9ycywgc3BhY2luZywgc3BhY2luZ1VuaXQsIGZvbnRzLCBtcSwgYnJlYWtwb2ludHMsIGFuaW1hdGlvbnMsIHV0aWxzIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgU2FmZUxpbmsgZnJvbSAnQG5kbGEvc2FmZWxpbmsnO1xuaW1wb3J0IHsgTGVhcm5pbmdQYXRoUmVhZCB9IGZyb20gJ0BuZGxhL2ljb25zL2NvbnRlbnRUeXBlJztcbmltcG9ydCB7IFN0ZXBQcm9wcyB9IGZyb20gJy4vTGVhcm5pbmdQYXRoTWVudSc7XG5pbXBvcnQgQ29udGVudFR5cGVCYWRnZSBmcm9tICcuLi9Db250ZW50VHlwZUJhZGdlJztcbmltcG9ydCBjb25zdGFudHMgZnJvbSAnLi4vbW9kZWwnO1xuXG5jb25zdCBTSURFX05BVl9XSURUSCA9ICczNzJweCc7XG5cbnR5cGUgU3R5bGVkTWVudUl0ZW1Qcm9wcyA9IHtcbiAgY3VycmVudD86IGJvb2xlYW47XG4gIGlzT3BlbjogYm9vbGVhbjtcbiAgYWZ0ZXJDdXJyZW50OiBib29sZWFuO1xuICBpbmRleE51bWJlcjogbnVtYmVyO1xuICBoYXNSZWFkPzogYm9vbGVhbjtcbiAgaW52ZXJ0ZWRTdHlsZT86IGJvb2xlYW47XG59O1xuXG5jb25zdCBTdHlsZWRNZW51SXRlbSA9IHN0eWxlZC5saTxTdHlsZWRNZW51SXRlbVByb3BzPmBcbiAgbWFyZ2luOiAwO1xuICBhIHtcbiAgICBib3gtc2hhZG93OiBub25lO1xuICAgIGRpc3BsYXk6IGlubGluZS1mbGV4O1xuICAgIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gICAgcGFkZGluZzogJHtzcGFjaW5nLnNtYWxsfTtcbiAgICA+IHNwYW4ge1xuICAgICAgZGlzcGxheTogZmxleDtcbiAgICAgIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gICAgICAke2ZvbnRzLnNpemVzKDE0LCAxLjIpfTtcbiAgICAgIGNvbG9yOiAke2NvbG9ycy5icmFuZC5wcmltYXJ5fTtcbiAgICAgICR7bXEucmFuZ2UoeyBmcm9tOiBicmVha3BvaW50cy50YWJsZXQgfSl9IHtcbiAgICAgICAgY29sb3I6ICR7KHsgaW52ZXJ0ZWRTdHlsZSB9KSA9PiAoaW52ZXJ0ZWRTdHlsZSA/ICcjZmZmJyA6IGNvbG9ycy5icmFuZC5wcmltYXJ5KX07XG4gICAgICAgIGZvbnQtd2VpZ2h0OiAke2ZvbnRzLndlaWdodC5zZW1pYm9sZH07XG4gICAgICB9XG4gICAgfVxuICAgICY6aG92ZXIsXG4gICAgJjpmb2N1cyB7XG4gICAgICA+IHNwYW4ge1xuICAgICAgICB0ZXh0LWRlY29yYXRpb246IHVuZGVybGluZTtcbiAgICAgIH1cbiAgICB9XG4gIH1cbiAgJHttcS5yYW5nZSh7IHVudGlsOiBicmVha3BvaW50cy5kZXNrdG9wIH0pfSB7XG4gICAgJHsocHJvcHMpID0+XG4gICAgICAhcHJvcHMuaXNPcGVuICYmXG4gICAgICBgXG4gICAgICBtYXJnaW4tYm90dG9tOiAtJHtzcGFjaW5nLnhzbWFsbH07XG4gICAgICBtYXJnaW4tdG9wOiAtJHtzcGFjaW5nLnhzbWFsbH07XG4gICAgICB0cmFuc2l0aW9uOiBtYXJnaW4gJHthbmltYXRpb25zLmR1cmF0aW9ucy5zdXBlckZhc3R9IGVhc2U7XG4gICAgYH1cbiAgICAkeyhwcm9wcykgPT5cbiAgICAgIHByb3BzLmlzT3BlbiAmJlxuICAgICAgYFxuICAgICAgYSBzcGFuIHtcbiAgICAgICAgJHthbmltYXRpb25zLmZhZGVJbkxlZnRGcm9tWmVybygpfVxuICAgICAgICBhbmltYXRpb24tZGVsYXk6ICR7cGFyc2VJbnQoYW5pbWF0aW9ucy5kdXJhdGlvbnMuc3VwZXJGYXN0KSAqIDEuNSArIDIwICogcHJvcHMuaW5kZXhOdW1iZXJ9bXM7XG4gICAgICB9XG4gICAgYH1cbiAgICAmOmZpcnN0LW9mLXR5cGUsICY6bGFzdC1vZi10eXBlIHtcbiAgICAgIG1hcmdpbi10b3A6IDA7XG4gICAgICBtYXJnaW4tYm90dG9tOiAwO1xuICAgIH1cbiAgfVxuICAkeyhwcm9wcykgPT5cbiAgICBwcm9wcy5jdXJyZW50ICYmXG4gICAgcHJvcHMuaXNPcGVuICYmXG4gICAgYFxuICAgIGEge1xuICAgICAgJjpiZWZvcmUge1xuICAgICAgICBwb3NpdGlvbjogYWJzb2x1dGU7XG4gICAgICAgIGNvbnRlbnQ6ICcnO1xuICAgICAgICBkaXNwbGF5OiBibG9jaztcbiAgICAgICAgYmFja2dyb3VuZDogI2ZmZjtcbiAgICAgICAgaGVpZ2h0OiAke3NwYWNpbmcubGFyZ2V9O1xuICAgICAgICB3aWR0aDogY2FsYygke1NJREVfTkFWX1dJRFRIfSAtICR7c3BhY2luZy5zbWFsbH0pO1xuICAgICAgICB0cmFuc2Zvcm06IHRyYW5zbGF0ZVgoLSR7c3BhY2luZy5zbWFsbH0pO1xuICAgICAgfVxuICAgIH1cbiAgYH1cbiAgJHsocHJvcHMpID0+XG4gICAgcHJvcHMuY3VycmVudCAmJlxuICAgIGBcbiAgICAgIGJhY2tncm91bmQ6ICNmZmY7XG4gIGB9XG4gICY6YWZ0ZXIge1xuICAgIGNvbnRlbnQ6ICcnO1xuICAgIGRpc3BsYXk6IGJsb2NrO1xuICAgIGhlaWdodDogJHtzcGFjaW5nLmxhcmdlfTtcbiAgICB3aWR0aDogMnB4O1xuICAgIGJhY2tncm91bmQ6ICR7Y29sb3JzLmJyYW5kLmdyZXlMaWdodH07XG4gICAgcG9zaXRpb246IGFic29sdXRlO1xuICAgIHRyYW5zZm9ybTogdHJhbnNsYXRlKDI5cHgsIC0ke3NwYWNpbmdVbml0ICogM31weCk7XG4gIH1cbiAgJHsocHJvcHMpID0+
|
|
50
|
+
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["LearningPathMenuContent.tsx"],"names":[],"mappings":"AA6BqD","file":"LearningPathMenuContent.tsx","sourcesContent":["/**\n * Copyright (c) 2019-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 from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { colors, spacing, spacingUnit, fonts, mq, breakpoints, animations, utils } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\nimport { LearningPathRead } from '@ndla/icons/contentType';\nimport { StepProps } from './LearningPathMenu';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport constants from '../model';\n\nconst SIDE_NAV_WIDTH = '372px';\n\ntype StyledMenuItemProps = {\n  current?: boolean;\n  isOpen: boolean;\n  afterCurrent: boolean;\n  indexNumber: number;\n  hasRead?: boolean;\n  invertedStyle?: boolean;\n};\n\nconst StyledMenuItem = styled.li<StyledMenuItemProps>`\n  margin: 0;\n  a {\n    box-shadow: none;\n    display: inline-flex;\n    align-items: center;\n    padding: ${spacing.small};\n    > span {\n      display: flex;\n      align-items: center;\n      ${fonts.sizes(14, 1.2)};\n      color: ${colors.brand.primary};\n      ${mq.range({ from: breakpoints.tablet })} {\n        color: ${({ invertedStyle }) => (invertedStyle ? '#fff' : colors.brand.primary)};\n        font-weight: ${fonts.weight.semibold};\n      }\n    }\n    &:hover,\n    &:focus {\n      > span {\n        text-decoration: underline;\n      }\n    }\n  }\n  ${mq.range({ until: breakpoints.desktop })} {\n    ${(props) =>\n      !props.isOpen &&\n      `\n      margin-bottom: -${spacing.xsmall};\n      margin-top: -${spacing.xsmall};\n      transition: margin ${animations.durations.superFast} ease;\n    `}\n    ${(props) =>\n      props.isOpen &&\n      `\n      a span {\n        ${animations.fadeInLeftFromZero()}\n        animation-delay: ${parseInt(animations.durations.superFast) * 1.5 + 20 * props.indexNumber}ms;\n      }\n    `}\n    &:first-of-type, &:last-of-type {\n      margin-top: 0;\n      margin-bottom: 0;\n    }\n  }\n  ${(props) =>\n    props.current &&\n    props.isOpen &&\n    `\n    a {\n      &:before {\n        position: absolute;\n        content: '';\n        display: block;\n        background: #fff;\n        height: ${spacing.large};\n        width: calc(${SIDE_NAV_WIDTH} - ${spacing.small});\n        transform: translateX(-${spacing.small});\n      }\n    }\n  `}\n  ${(props) =>\n    props.current &&\n    `\n      background: #fff;\n  `}\n  &:after {\n    content: '';\n    display: block;\n    height: ${spacing.large};\n    width: 2px;\n    background: ${colors.brand.greyLight};\n    position: absolute;\n    transform: translate(29px, -${spacingUnit * 3}px);\n  }\n  ${(props) =>\n    !props.afterCurrent &&\n    `\n    a {\n      > span {\n        color: ${colors.text.primary};\n        font-weight: ${fonts.weight.normal};\n      }\n      color: ${colors.text.primary};\n      font-weight: ${fonts.weight.normal};\n    }\n    &:after {\n      width: 4px;\n      background: ${colors.text.light};\n      transform: translate(28px, -${spacingUnit * 3}px);\n    }\n  `}\n  ${(props) =>\n    !props.afterCurrent &&\n    !props.current &&\n    props.invertedStyle &&\n    `\n    ${mq.range({ from: breakpoints.tablet })} {\n      a {\n        > span {\n          color: #fff;\n        }\n        color: #fff;\n      }\n    }\n    `}\n`;\n\nconst StyledContentType = styled.div`\n  position: relative;\n  z-index: 1;\n  margin-right: ${spacingUnit * 0.75}px;\n  max-height: 35px;\n`;\n\nconst HiddenSpan = styled.span`\n  ${utils.visuallyHidden};\n`;\n\ntype StyledNavigationProps = {\n  isOpen: boolean;\n  invertedStyle?: boolean;\n};\n\nconst StyledNavigation = styled.nav<StyledNavigationProps>`\n  > ul {\n    list-style: none;\n    margin: 0;\n    padding: 0;\n  }\n  margin-bottom: ${spacing.medium};\n  ${(props) =>\n    !props.isOpen &&\n    css`\n      ${mq.range({ until: breakpoints.tablet })} {\n        margin-left: -28px;\n      }\n      ${mq.range({ from: breakpoints.tablet, until: breakpoints.desktop })} {\n        ${StyledMenuItem} {\n          span {\n            display: none;\n          }\n          &:first-of-type {\n            &:after {\n              display: none !important;\n            }\n          }\n          a:hover,\n          a:focus {\n            position: relative;\n            z-index: 1;\n            width: ${SIDE_NAV_WIDTH};\n            background: ${colors.brand.greyLighter};\n            span {\n              display: flex;\n            }\n          }\n        }\n      }\n    `}\n`;\n\nconst ReadIcon = styled.div`\n  border-radius: 100%;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  position: absolute;\n  top: -6px;\n  right: 0;\n  width: 16px;\n  height: 16px;\n  background: ${colors.brand.secondary};\n  color: ${colors.text.light};\n  transform: translateX(4px);\n  svg {\n    width: 12px;\n    height: 12px;\n    fill: ${colors.brand.lighter};\n  }\n`;\n\ntype Props = {\n  learningsteps: StepProps[];\n  learningPathId: number;\n  isOpen: boolean;\n  toLearningPathUrl(pathId: number, stepId: number): string;\n  currentIndex: number;\n  invertedStyle?: boolean;\n  cookies: {\n    [key: string]: string;\n  };\n  onStepNavigate: () => void;\n};\n\nconst hasRead = (\n  id: number,\n  cookies: {\n    [key: string]: string;\n  },\n) => !!cookies[id];\n\nconst LearningPathMenuContent = ({\n  isOpen,\n  currentIndex,\n  cookies,\n  learningPathId,\n  learningsteps,\n  toLearningPathUrl,\n  invertedStyle,\n  onStepNavigate,\n}: Props) => {\n  return (\n    <StyledNavigation isOpen={isOpen} invertedStyle={invertedStyle}>\n      <ul>\n        {learningsteps.map(({ id, title, type }: StepProps, index: number) => (\n          <StyledMenuItem\n            key={id}\n            current={index === currentIndex}\n            afterCurrent={index > currentIndex}\n            isOpen={isOpen}\n            invertedStyle={invertedStyle}\n            indexNumber={index}\n          >\n            <SafeLink\n              onClick={onStepNavigate}\n              to={toLearningPathUrl(learningPathId, id)}\n              aria-describedby={`read-${id}`}\n            >\n              <StyledContentType>\n                <ContentTypeBadge type={type ?? constants.contentTypes.LEARNING_PATH} background size=\"small\" />\n                {hasRead(id, cookies) && (\n                  <div id={`read-${id}`} aria-hidden>\n                    <HiddenSpan>Lest</HiddenSpan>\n                    <ReadIcon>\n                      <LearningPathRead />\n                    </ReadIcon>\n                  </div>\n                )}\n              </StyledContentType>\n              <span>{title}</span>\n            </SafeLink>\n          </StyledMenuItem>\n        ))}\n      </ul>\n    </StyledNavigation>\n  );\n};\n\nexport default LearningPathMenuContent;\n"]} */"));
|
|
51
51
|
var StyledContentType = /*#__PURE__*/(0, _base["default"])("div", {
|
|
52
52
|
target: "eipwgxz3",
|
|
53
53
|
label: "StyledContentType"
|
|
54
|
-
})("position:relative;z-index:1;margin-right:", _core.spacingUnit * 0.75, "px;max-height:
|
|
54
|
+
})("position:relative;z-index:1;margin-right:", _core.spacingUnit * 0.75, "px;max-height:35px;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["LearningPathMenuContent.tsx"],"names":[],"mappings":"AAyIoC","file":"LearningPathMenuContent.tsx","sourcesContent":["/**\n * Copyright (c) 2019-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 from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { colors, spacing, spacingUnit, fonts, mq, breakpoints, animations, utils } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\nimport { LearningPathRead } from '@ndla/icons/contentType';\nimport { StepProps } from './LearningPathMenu';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport constants from '../model';\n\nconst SIDE_NAV_WIDTH = '372px';\n\ntype StyledMenuItemProps = {\n  current?: boolean;\n  isOpen: boolean;\n  afterCurrent: boolean;\n  indexNumber: number;\n  hasRead?: boolean;\n  invertedStyle?: boolean;\n};\n\nconst StyledMenuItem = styled.li<StyledMenuItemProps>`\n  margin: 0;\n  a {\n    box-shadow: none;\n    display: inline-flex;\n    align-items: center;\n    padding: ${spacing.small};\n    > span {\n      display: flex;\n      align-items: center;\n      ${fonts.sizes(14, 1.2)};\n      color: ${colors.brand.primary};\n      ${mq.range({ from: breakpoints.tablet })} {\n        color: ${({ invertedStyle }) => (invertedStyle ? '#fff' : colors.brand.primary)};\n        font-weight: ${fonts.weight.semibold};\n      }\n    }\n    &:hover,\n    &:focus {\n      > span {\n        text-decoration: underline;\n      }\n    }\n  }\n  ${mq.range({ until: breakpoints.desktop })} {\n    ${(props) =>\n      !props.isOpen &&\n      `\n      margin-bottom: -${spacing.xsmall};\n      margin-top: -${spacing.xsmall};\n      transition: margin ${animations.durations.superFast} ease;\n    `}\n    ${(props) =>\n      props.isOpen &&\n      `\n      a span {\n        ${animations.fadeInLeftFromZero()}\n        animation-delay: ${parseInt(animations.durations.superFast) * 1.5 + 20 * props.indexNumber}ms;\n      }\n    `}\n    &:first-of-type, &:last-of-type {\n      margin-top: 0;\n      margin-bottom: 0;\n    }\n  }\n  ${(props) =>\n    props.current &&\n    props.isOpen &&\n    `\n    a {\n      &:before {\n        position: absolute;\n        content: '';\n        display: block;\n        background: #fff;\n        height: ${spacing.large};\n        width: calc(${SIDE_NAV_WIDTH} - ${spacing.small});\n        transform: translateX(-${spacing.small});\n      }\n    }\n  `}\n  ${(props) =>\n    props.current &&\n    `\n      background: #fff;\n  `}\n  &:after {\n    content: '';\n    display: block;\n    height: ${spacing.large};\n    width: 2px;\n    background: ${colors.brand.greyLight};\n    position: absolute;\n    transform: translate(29px, -${spacingUnit * 3}px);\n  }\n  ${(props) =>\n    !props.afterCurrent &&\n    `\n    a {\n      > span {\n        color: ${colors.text.primary};\n        font-weight: ${fonts.weight.normal};\n      }\n      color: ${colors.text.primary};\n      font-weight: ${fonts.weight.normal};\n    }\n    &:after {\n      width: 4px;\n      background: ${colors.text.light};\n      transform: translate(28px, -${spacingUnit * 3}px);\n    }\n  `}\n  ${(props) =>\n    !props.afterCurrent &&\n    !props.current &&\n    props.invertedStyle &&\n    `\n    ${mq.range({ from: breakpoints.tablet })} {\n      a {\n        > span {\n          color: #fff;\n        }\n        color: #fff;\n      }\n    }\n    `}\n`;\n\nconst StyledContentType = styled.div`\n  position: relative;\n  z-index: 1;\n  margin-right: ${spacingUnit * 0.75}px;\n  max-height: 35px;\n`;\n\nconst HiddenSpan = styled.span`\n  ${utils.visuallyHidden};\n`;\n\ntype StyledNavigationProps = {\n  isOpen: boolean;\n  invertedStyle?: boolean;\n};\n\nconst StyledNavigation = styled.nav<StyledNavigationProps>`\n  > ul {\n    list-style: none;\n    margin: 0;\n    padding: 0;\n  }\n  margin-bottom: ${spacing.medium};\n  ${(props) =>\n    !props.isOpen &&\n    css`\n      ${mq.range({ until: breakpoints.tablet })} {\n        margin-left: -28px;\n      }\n      ${mq.range({ from: breakpoints.tablet, until: breakpoints.desktop })} {\n        ${StyledMenuItem} {\n          span {\n            display: none;\n          }\n          &:first-of-type {\n            &:after {\n              display: none !important;\n            }\n          }\n          a:hover,\n          a:focus {\n            position: relative;\n            z-index: 1;\n            width: ${SIDE_NAV_WIDTH};\n            background: ${colors.brand.greyLighter};\n            span {\n              display: flex;\n            }\n          }\n        }\n      }\n    `}\n`;\n\nconst ReadIcon = styled.div`\n  border-radius: 100%;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  position: absolute;\n  top: -6px;\n  right: 0;\n  width: 16px;\n  height: 16px;\n  background: ${colors.brand.secondary};\n  color: ${colors.text.light};\n  transform: translateX(4px);\n  svg {\n    width: 12px;\n    height: 12px;\n    fill: ${colors.brand.lighter};\n  }\n`;\n\ntype Props = {\n  learningsteps: StepProps[];\n  learningPathId: number;\n  isOpen: boolean;\n  toLearningPathUrl(pathId: number, stepId: number): string;\n  currentIndex: number;\n  invertedStyle?: boolean;\n  cookies: {\n    [key: string]: string;\n  };\n  onStepNavigate: () => void;\n};\n\nconst hasRead = (\n  id: number,\n  cookies: {\n    [key: string]: string;\n  },\n) => !!cookies[id];\n\nconst LearningPathMenuContent = ({\n  isOpen,\n  currentIndex,\n  cookies,\n  learningPathId,\n  learningsteps,\n  toLearningPathUrl,\n  invertedStyle,\n  onStepNavigate,\n}: Props) => {\n  return (\n    <StyledNavigation isOpen={isOpen} invertedStyle={invertedStyle}>\n      <ul>\n        {learningsteps.map(({ id, title, type }: StepProps, index: number) => (\n          <StyledMenuItem\n            key={id}\n            current={index === currentIndex}\n            afterCurrent={index > currentIndex}\n            isOpen={isOpen}\n            invertedStyle={invertedStyle}\n            indexNumber={index}\n          >\n            <SafeLink\n              onClick={onStepNavigate}\n              to={toLearningPathUrl(learningPathId, id)}\n              aria-describedby={`read-${id}`}\n            >\n              <StyledContentType>\n                <ContentTypeBadge type={type ?? constants.contentTypes.LEARNING_PATH} background size=\"small\" />\n                {hasRead(id, cookies) && (\n                  <div id={`read-${id}`} aria-hidden>\n                    <HiddenSpan>Lest</HiddenSpan>\n                    <ReadIcon>\n                      <LearningPathRead />\n                    </ReadIcon>\n                  </div>\n                )}\n              </StyledContentType>\n              <span>{title}</span>\n            </SafeLink>\n          </StyledMenuItem>\n        ))}\n      </ul>\n    </StyledNavigation>\n  );\n};\n\nexport default LearningPathMenuContent;\n"]} */"));
|
|
55
55
|
var HiddenSpan = /*#__PURE__*/(0, _base["default"])("span", {
|
|
56
56
|
target: "eipwgxz2",
|
|
57
57
|
label: "HiddenSpan"
|
|
58
|
-
})(_core.utils.visuallyHidden, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlYXJuaW5nUGF0aE1lbnVDb250ZW50LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFnSjhCIiwiZmlsZSI6IkxlYXJuaW5nUGF0aE1lbnVDb250ZW50LnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE5LXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IGNvbG9ycywgc3BhY2luZywgc3BhY2luZ1VuaXQsIGZvbnRzLCBtcSwgYnJlYWtwb2ludHMsIGFuaW1hdGlvbnMsIHV0aWxzIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgU2FmZUxpbmsgZnJvbSAnQG5kbGEvc2FmZWxpbmsnO1xuaW1wb3J0IHsgTGVhcm5pbmdQYXRoUmVhZCB9IGZyb20gJ0BuZGxhL2ljb25zL2NvbnRlbnRUeXBlJztcbmltcG9ydCB7IFN0ZXBQcm9wcyB9IGZyb20gJy4vTGVhcm5pbmdQYXRoTWVudSc7XG5pbXBvcnQgQ29udGVudFR5cGVCYWRnZSBmcm9tICcuLi9Db250ZW50VHlwZUJhZGdlJztcbmltcG9ydCBjb25zdGFudHMgZnJvbSAnLi4vbW9kZWwnO1xuXG5jb25zdCBTSURFX05BVl9XSURUSCA9ICczNzJweCc7XG5cbnR5cGUgU3R5bGVkTWVudUl0ZW1Qcm9wcyA9IHtcbiAgY3VycmVudD86IGJvb2xlYW47XG4gIGlzT3BlbjogYm9vbGVhbjtcbiAgYWZ0ZXJDdXJyZW50OiBib29sZWFuO1xuICBpbmRleE51bWJlcjogbnVtYmVyO1xuICBoYXNSZWFkPzogYm9vbGVhbjtcbiAgaW52ZXJ0ZWRTdHlsZT86IGJvb2xlYW47XG59O1xuXG5jb25zdCBTdHlsZWRNZW51SXRlbSA9IHN0eWxlZC5saTxTdHlsZWRNZW51SXRlbVByb3BzPmBcbiAgbWFyZ2luOiAwO1xuICBhIHtcbiAgICBib3gtc2hhZG93OiBub25lO1xuICAgIGRpc3BsYXk6IGlubGluZS1mbGV4O1xuICAgIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gICAgcGFkZGluZzogJHtzcGFjaW5nLnNtYWxsfTtcbiAgICA+IHNwYW4ge1xuICAgICAgZGlzcGxheTogZmxleDtcbiAgICAgIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gICAgICAke2ZvbnRzLnNpemVzKDE0LCAxLjIpfTtcbiAgICAgIGNvbG9yOiAke2NvbG9ycy5icmFuZC5wcmltYXJ5fTtcbiAgICAgICR7bXEucmFuZ2UoeyBmcm9tOiBicmVha3BvaW50cy50YWJsZXQgfSl9IHtcbiAgICAgICAgY29sb3I6ICR7KHsgaW52ZXJ0ZWRTdHlsZSB9KSA9PiAoaW52ZXJ0ZWRTdHlsZSA/ICcjZmZmJyA6IGNvbG9ycy5icmFuZC5wcmltYXJ5KX07XG4gICAgICAgIGZvbnQtd2VpZ2h0OiAke2ZvbnRzLndlaWdodC5zZW1pYm9sZH07XG4gICAgICB9XG4gICAgfVxuICAgICY6aG92ZXIsXG4gICAgJjpmb2N1cyB7XG4gICAgICA+IHNwYW4ge1xuICAgICAgICB0ZXh0LWRlY29yYXRpb246IHVuZGVybGluZTtcbiAgICAgIH1cbiAgICB9XG4gIH1cbiAgJHttcS5yYW5nZSh7IHVudGlsOiBicmVha3BvaW50cy5kZXNrdG9wIH0pfSB7XG4gICAgJHsocHJvcHMpID0+XG4gICAgICAhcHJvcHMuaXNPcGVuICYmXG4gICAgICBgXG4gICAgICBtYXJnaW4tYm90dG9tOiAtJHtzcGFjaW5nLnhzbWFsbH07XG4gICAgICBtYXJnaW4tdG9wOiAtJHtzcGFjaW5nLnhzbWFsbH07XG4gICAgICB0cmFuc2l0aW9uOiBtYXJnaW4gJHthbmltYXRpb25zLmR1cmF0aW9ucy5zdXBlckZhc3R9IGVhc2U7XG4gICAgYH1cbiAgICAkeyhwcm9wcykgPT5cbiAgICAgIHByb3BzLmlzT3BlbiAmJlxuICAgICAgYFxuICAgICAgYSBzcGFuIHtcbiAgICAgICAgJHthbmltYXRpb25zLmZhZGVJbkxlZnRGcm9tWmVybygpfVxuICAgICAgICBhbmltYXRpb24tZGVsYXk6ICR7cGFyc2VJbnQoYW5pbWF0aW9ucy5kdXJhdGlvbnMuc3VwZXJGYXN0KSAqIDEuNSArIDIwICogcHJvcHMuaW5kZXhOdW1iZXJ9bXM7XG4gICAgICB9XG4gICAgYH1cbiAgICAmOmZpcnN0LW9mLXR5cGUsICY6bGFzdC1vZi10eXBlIHtcbiAgICAgIG1hcmdpbi10b3A6IDA7XG4gICAgICBtYXJnaW4tYm90dG9tOiAwO1xuICAgIH1cbiAgfVxuICAkeyhwcm9wcykgPT5cbiAgICBwcm9wcy5jdXJyZW50ICYmXG4gICAgcHJvcHMuaXNPcGVuICYmXG4gICAgYFxuICAgIGEge1xuICAgICAgJjpiZWZvcmUge1xuICAgICAgICBwb3NpdGlvbjogYWJzb2x1dGU7XG4gICAgICAgIGNvbnRlbnQ6ICcnO1xuICAgICAgICBkaXNwbGF5OiBibG9jaztcbiAgICAgICAgYmFja2dyb3VuZDogI2ZmZjtcbiAgICAgICAgaGVpZ2h0OiAke3NwYWNpbmcubGFyZ2V9O1xuICAgICAgICB3aWR0aDogY2FsYygke1NJREVfTkFWX1dJRFRIfSAtICR7c3BhY2luZy5zbWFsbH0pO1xuICAgICAgICB0cmFuc2Zvcm06IHRyYW5zbGF0ZVgoLSR7c3BhY2luZy5zbWFsbH0pO1xuICAgICAgfVxuICAgIH1cbiAgYH1cbiAgJHsocHJvcHMpID0+XG4gICAgcHJvcHMuY3VycmVudCAmJlxuICAgIGBcbiAgICAgIGJhY2tncm91bmQ6ICNmZmY7XG4gIGB9XG4gICY6YWZ0ZXIge1xuICAgIGNvbnRlbnQ6ICcnO1xuICAgIGRpc3BsYXk6IGJsb2NrO1xuICAgIGhlaWdodDogJHtzcGFjaW5nLmxhcmdlfTtcbiAgICB3aWR0aDogMnB4O1xuICAgIGJhY2tncm91bmQ6ICR7Y29sb3JzLmJyYW5kLmdyZXlMaWdodH07XG4gICAgcG9zaXRpb246IGFic29sdXRlO1xuICAgIHRyYW5zZm9ybTogdHJhbnNsYXRlKDI5cHgsIC0ke3NwYWNpbmdVbml0ICogM31weCk7XG4gIH1cbiAgJHsocHJvcHMpID0+
|
|
58
|
+
})(_core.utils.visuallyHidden, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["LearningPathMenuContent.tsx"],"names":[],"mappings":"AAgJ8B","file":"LearningPathMenuContent.tsx","sourcesContent":["/**\n * Copyright (c) 2019-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 from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { colors, spacing, spacingUnit, fonts, mq, breakpoints, animations, utils } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\nimport { LearningPathRead } from '@ndla/icons/contentType';\nimport { StepProps } from './LearningPathMenu';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport constants from '../model';\n\nconst SIDE_NAV_WIDTH = '372px';\n\ntype StyledMenuItemProps = {\n  current?: boolean;\n  isOpen: boolean;\n  afterCurrent: boolean;\n  indexNumber: number;\n  hasRead?: boolean;\n  invertedStyle?: boolean;\n};\n\nconst StyledMenuItem = styled.li<StyledMenuItemProps>`\n  margin: 0;\n  a {\n    box-shadow: none;\n    display: inline-flex;\n    align-items: center;\n    padding: ${spacing.small};\n    > span {\n      display: flex;\n      align-items: center;\n      ${fonts.sizes(14, 1.2)};\n      color: ${colors.brand.primary};\n      ${mq.range({ from: breakpoints.tablet })} {\n        color: ${({ invertedStyle }) => (invertedStyle ? '#fff' : colors.brand.primary)};\n        font-weight: ${fonts.weight.semibold};\n      }\n    }\n    &:hover,\n    &:focus {\n      > span {\n        text-decoration: underline;\n      }\n    }\n  }\n  ${mq.range({ until: breakpoints.desktop })} {\n    ${(props) =>\n      !props.isOpen &&\n      `\n      margin-bottom: -${spacing.xsmall};\n      margin-top: -${spacing.xsmall};\n      transition: margin ${animations.durations.superFast} ease;\n    `}\n    ${(props) =>\n      props.isOpen &&\n      `\n      a span {\n        ${animations.fadeInLeftFromZero()}\n        animation-delay: ${parseInt(animations.durations.superFast) * 1.5 + 20 * props.indexNumber}ms;\n      }\n    `}\n    &:first-of-type, &:last-of-type {\n      margin-top: 0;\n      margin-bottom: 0;\n    }\n  }\n  ${(props) =>\n    props.current &&\n    props.isOpen &&\n    `\n    a {\n      &:before {\n        position: absolute;\n        content: '';\n        display: block;\n        background: #fff;\n        height: ${spacing.large};\n        width: calc(${SIDE_NAV_WIDTH} - ${spacing.small});\n        transform: translateX(-${spacing.small});\n      }\n    }\n  `}\n  ${(props) =>\n    props.current &&\n    `\n      background: #fff;\n  `}\n  &:after {\n    content: '';\n    display: block;\n    height: ${spacing.large};\n    width: 2px;\n    background: ${colors.brand.greyLight};\n    position: absolute;\n    transform: translate(29px, -${spacingUnit * 3}px);\n  }\n  ${(props) =>\n    !props.afterCurrent &&\n    `\n    a {\n      > span {\n        color: ${colors.text.primary};\n        font-weight: ${fonts.weight.normal};\n      }\n      color: ${colors.text.primary};\n      font-weight: ${fonts.weight.normal};\n    }\n    &:after {\n      width: 4px;\n      background: ${colors.text.light};\n      transform: translate(28px, -${spacingUnit * 3}px);\n    }\n  `}\n  ${(props) =>\n    !props.afterCurrent &&\n    !props.current &&\n    props.invertedStyle &&\n    `\n    ${mq.range({ from: breakpoints.tablet })} {\n      a {\n        > span {\n          color: #fff;\n        }\n        color: #fff;\n      }\n    }\n    `}\n`;\n\nconst StyledContentType = styled.div`\n  position: relative;\n  z-index: 1;\n  margin-right: ${spacingUnit * 0.75}px;\n  max-height: 35px;\n`;\n\nconst HiddenSpan = styled.span`\n  ${utils.visuallyHidden};\n`;\n\ntype StyledNavigationProps = {\n  isOpen: boolean;\n  invertedStyle?: boolean;\n};\n\nconst StyledNavigation = styled.nav<StyledNavigationProps>`\n  > ul {\n    list-style: none;\n    margin: 0;\n    padding: 0;\n  }\n  margin-bottom: ${spacing.medium};\n  ${(props) =>\n    !props.isOpen &&\n    css`\n      ${mq.range({ until: breakpoints.tablet })} {\n        margin-left: -28px;\n      }\n      ${mq.range({ from: breakpoints.tablet, until: breakpoints.desktop })} {\n        ${StyledMenuItem} {\n          span {\n            display: none;\n          }\n          &:first-of-type {\n            &:after {\n              display: none !important;\n            }\n          }\n          a:hover,\n          a:focus {\n            position: relative;\n            z-index: 1;\n            width: ${SIDE_NAV_WIDTH};\n            background: ${colors.brand.greyLighter};\n            span {\n              display: flex;\n            }\n          }\n        }\n      }\n    `}\n`;\n\nconst ReadIcon = styled.div`\n  border-radius: 100%;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  position: absolute;\n  top: -6px;\n  right: 0;\n  width: 16px;\n  height: 16px;\n  background: ${colors.brand.secondary};\n  color: ${colors.text.light};\n  transform: translateX(4px);\n  svg {\n    width: 12px;\n    height: 12px;\n    fill: ${colors.brand.lighter};\n  }\n`;\n\ntype Props = {\n  learningsteps: StepProps[];\n  learningPathId: number;\n  isOpen: boolean;\n  toLearningPathUrl(pathId: number, stepId: number): string;\n  currentIndex: number;\n  invertedStyle?: boolean;\n  cookies: {\n    [key: string]: string;\n  };\n  onStepNavigate: () => void;\n};\n\nconst hasRead = (\n  id: number,\n  cookies: {\n    [key: string]: string;\n  },\n) => !!cookies[id];\n\nconst LearningPathMenuContent = ({\n  isOpen,\n  currentIndex,\n  cookies,\n  learningPathId,\n  learningsteps,\n  toLearningPathUrl,\n  invertedStyle,\n  onStepNavigate,\n}: Props) => {\n  return (\n    <StyledNavigation isOpen={isOpen} invertedStyle={invertedStyle}>\n      <ul>\n        {learningsteps.map(({ id, title, type }: StepProps, index: number) => (\n          <StyledMenuItem\n            key={id}\n            current={index === currentIndex}\n            afterCurrent={index > currentIndex}\n            isOpen={isOpen}\n            invertedStyle={invertedStyle}\n            indexNumber={index}\n          >\n            <SafeLink\n              onClick={onStepNavigate}\n              to={toLearningPathUrl(learningPathId, id)}\n              aria-describedby={`read-${id}`}\n            >\n              <StyledContentType>\n                <ContentTypeBadge type={type ?? constants.contentTypes.LEARNING_PATH} background size=\"small\" />\n                {hasRead(id, cookies) && (\n                  <div id={`read-${id}`} aria-hidden>\n                    <HiddenSpan>Lest</HiddenSpan>\n                    <ReadIcon>\n                      <LearningPathRead />\n                    </ReadIcon>\n                  </div>\n                )}\n              </StyledContentType>\n              <span>{title}</span>\n            </SafeLink>\n          </StyledMenuItem>\n        ))}\n      </ul>\n    </StyledNavigation>\n  );\n};\n\nexport default LearningPathMenuContent;\n"]} */"));
|
|
59
59
|
var StyledNavigation = /*#__PURE__*/(0, _base["default"])("nav", {
|
|
60
60
|
target: "eipwgxz1",
|
|
61
61
|
label: "StyledNavigation"
|
|
@@ -65,12 +65,12 @@ var StyledNavigation = /*#__PURE__*/(0, _base["default"])("nav", {
|
|
|
65
65
|
}), "{margin-left:-28px;}", _core.mq.range({
|
|
66
66
|
from: _core.breakpoints.tablet,
|
|
67
67
|
until: _core.breakpoints.desktop
|
|
68
|
-
}), "{", StyledMenuItem, "{span{display:none;}&:first-of-type{&:after{display:none!important;}}a:hover,a:focus{position:relative;z-index:1;width:", SIDE_NAV_WIDTH, ";background:", _core.colors.brand.greyLighter, ";span{display:flex;}}}};label:StyledNavigation;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlYXJuaW5nUGF0aE1lbnVDb250ZW50LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFrS08iLCJmaWxlIjoiTGVhcm5pbmdQYXRoTWVudUNvbnRlbnQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMTktcHJlc2VudCwgTkRMQS5cbiAqXG4gKiBUaGlzIHNvdXJjZSBjb2RlIGlzIGxpY2Vuc2VkIHVuZGVyIHRoZSBHUEx2MyBsaWNlbnNlIGZvdW5kIGluIHRoZVxuICogTElDRU5TRSBmaWxlIGluIHRoZSByb290IGRpcmVjdG9yeSBvZiB0aGlzIHNvdXJjZSB0cmVlLlxuICpcbiAqL1xuXG5pbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgY29sb3JzLCBzcGFjaW5nLCBzcGFjaW5nVW5pdCwgZm9udHMsIG1xLCBicmVha3BvaW50cywgYW5pbWF0aW9ucywgdXRpbHMgfSBmcm9tICdAbmRsYS9jb3JlJztcbmltcG9ydCBTYWZlTGluayBmcm9tICdAbmRsYS9zYWZlbGluayc7XG5pbXBvcnQgeyBMZWFybmluZ1BhdGhSZWFkIH0gZnJvbSAnQG5kbGEvaWNvbnMvY29udGVudFR5cGUnO1xuaW1wb3J0IHsgU3RlcFByb3BzIH0gZnJvbSAnLi9MZWFybmluZ1BhdGhNZW51JztcbmltcG9ydCBDb250ZW50VHlwZUJhZGdlIGZyb20gJy4uL0NvbnRlbnRUeXBlQmFkZ2UnO1xuaW1wb3J0IGNvbnN0YW50cyBmcm9tICcuLi9tb2RlbCc7XG5cbmNvbnN0IFNJREVfTkFWX1dJRFRIID0gJzM3MnB4JztcblxudHlwZSBTdHlsZWRNZW51SXRlbVByb3BzID0ge1xuICBjdXJyZW50PzogYm9vbGVhbjtcbiAgaXNPcGVuOiBib29sZWFuO1xuICBhZnRlckN1cnJlbnQ6IGJvb2xlYW47XG4gIGluZGV4TnVtYmVyOiBudW1iZXI7XG4gIGhhc1JlYWQ/OiBib29sZWFuO1xuICBpbnZlcnRlZFN0eWxlPzogYm9vbGVhbjtcbn07XG5cbmNvbnN0IFN0eWxlZE1lbnVJdGVtID0gc3R5bGVkLmxpPFN0eWxlZE1lbnVJdGVtUHJvcHM+YFxuICBtYXJnaW46IDA7XG4gIGEge1xuICAgIGJveC1zaGFkb3c6IG5vbmU7XG4gICAgZGlzcGxheTogaW5saW5lLWZsZXg7XG4gICAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgICBwYWRkaW5nOiAke3NwYWNpbmcuc21hbGx9O1xuICAgID4gc3BhbiB7XG4gICAgICBkaXNwbGF5OiBmbGV4O1xuICAgICAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgICAgICR7Zm9udHMuc2l6ZXMoMTQsIDEuMil9O1xuICAgICAgY29sb3I6ICR7Y29sb3JzLmJyYW5kLnByaW1hcnl9O1xuICAgICAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLnRhYmxldCB9KX0ge1xuICAgICAgICBjb2xvcjogJHsoeyBpbnZlcnRlZFN0eWxlIH0pID0+IChpbnZlcnRlZFN0eWxlID8gJyNmZmYnIDogY29sb3JzLmJyYW5kLnByaW1hcnkpfTtcbiAgICAgICAgZm9udC13ZWlnaHQ6ICR7Zm9udHMud2VpZ2h0LnNlbWlib2xkfTtcbiAgICAgIH1cbiAgICB9XG4gICAgJjpob3ZlcixcbiAgICAmOmZvY3VzIHtcbiAgICAgID4gc3BhbiB7XG4gICAgICAgIHRleHQtZGVjb3JhdGlvbjogdW5kZXJsaW5lO1xuICAgICAgfVxuICAgIH1cbiAgfVxuICAke21xLnJhbmdlKHsgdW50aWw6IGJyZWFrcG9pbnRzLmRlc2t0b3AgfSl9IHtcbiAgICAkeyhwcm9wcykgPT5cbiAgICAgICFwcm9wcy5pc09wZW4gJiZcbiAgICAgIGBcbiAgICAgIG1hcmdpbi1ib3R0b206IC0ke3NwYWNpbmcueHNtYWxsfTtcbiAgICAgIG1hcmdpbi10b3A6IC0ke3NwYWNpbmcueHNtYWxsfTtcbiAgICAgIHRyYW5zaXRpb246IG1hcmdpbiAke2FuaW1hdGlvbnMuZHVyYXRpb25zLnN1cGVyRmFzdH0gZWFzZTtcbiAgICBgfVxuICAgICR7KHByb3BzKSA9PlxuICAgICAgcHJvcHMuaXNPcGVuICYmXG4gICAgICBgXG4gICAgICBhIHNwYW4ge1xuICAgICAgICAke2FuaW1hdGlvbnMuZmFkZUluTGVmdEZyb21aZXJvKCl9XG4gICAgICAgIGFuaW1hdGlvbi1kZWxheTogJHtwYXJzZUludChhbmltYXRpb25zLmR1cmF0aW9ucy5zdXBlckZhc3QpICogMS41ICsgMjAgKiBwcm9wcy5pbmRleE51bWJlcn1tcztcbiAgICAgIH1cbiAgICBgfVxuICAgICY6Zmlyc3Qtb2YtdHlwZSwgJjpsYXN0LW9mLXR5cGUge1xuICAgICAgbWFyZ2luLXRvcDogMDtcbiAgICAgIG1hcmdpbi1ib3R0b206IDA7XG4gICAgfVxuICB9XG4gICR7KHByb3BzKSA9PlxuICAgIHByb3BzLmN1cnJlbnQgJiZcbiAgICBwcm9wcy5pc09wZW4gJiZcbiAgICBgXG4gICAgYSB7XG4gICAgICAmOmJlZm9yZSB7XG4gICAgICAgIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgICAgICAgY29udGVudDogJyc7XG4gICAgICAgIGRpc3BsYXk6IGJsb2NrO1xuICAgICAgICBiYWNrZ3JvdW5kOiAjZmZmO1xuICAgICAgICBoZWlnaHQ6ICR7c3BhY2luZy5sYXJnZX07XG4gICAgICAgIHdpZHRoOiBjYWxjKCR7U0lERV9OQVZfV0lEVEh9IC0gJHtzcGFjaW5nLnNtYWxsfSk7XG4gICAgICAgIHRyYW5zZm9ybTogdHJhbnNsYXRlWCgtJHtzcGFjaW5nLnNtYWxsfSk7XG4gICAgICB9XG4gICAgfVxuICBgfVxuICAkeyhwcm9wcykgPT5cbiAgICBwcm9wcy5jdXJyZW50ICYmXG4gICAgYFxuICAgICAgYmFja2dyb3VuZDogI2ZmZjtcbiAgYH1cbiAgJjphZnRlciB7XG4gICAgY29udGVudDogJyc7XG4gICAgZGlzcGxheTogYmxvY2s7XG4gICAgaGVpZ2h0OiAke3NwYWNpbmcubGFyZ2V9O1xuICAgIHdpZHRoOiAycHg7XG4gICAgYmFja2dyb3VuZDogJHtjb2xvcnMuYnJhbmQuZ3JleUxpZ2h0fTtcbiAgICBwb3NpdGlvbjogYWJzb2x1dGU7XG4gICAgdHJhbnNmb3JtOiB0cmFuc2xhdGUoMjlweCwgLSR7c3BhY2luZ1VuaXQgKiAzfXB4KTtcbiAgfVxuICAkeyhwcm9wcykgPT5cbiAgICAhcHJvcHMuYWZ0ZXJDdXJyZW50ICYmXG4gICAgYFxuICAgIGEge1xuICAgICAgPiBzcGFuIHtcbiAgICAgICAgY29sb3I6ICR7Y29sb3JzLnRleHQucHJpbWFyeX07XG4gICAgICAgIGZvbnQtd2VpZ2h0OiAke2ZvbnRzLndlaWdodC5ub3JtYWx9O1xuICAgICAgfVxuICAgICAgY29sb3I6ICR7Y29sb3JzLnRleHQucHJpbWFyeX07XG4gICAgICBmb250LXdlaWdodDogJHtmb250cy53ZWlnaHQubm9ybWFsfTtcbiAgICB9XG4gICAgJjphZnRlciB7XG4gICAgICB3aWR0aDogNHB4O1xuICAgICAgYmFja2dyb3VuZDogJHtjb2xvcnMudGV4dC5saWdodH07XG4gICAgICB0cmFuc2Zvcm06IHRyYW5zbGF0ZSgyOHB4LCAtJHtzcGFjaW5nVW5pdCAqIDN9cHgpO1xuICAgIH1cbiAgYH1cbiAgJHsocHJvcHMpID0+
|
|
69
|
-
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlYXJuaW5nUGF0aE1lbnVDb250ZW50LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF5SjBEIiwiZmlsZSI6IkxlYXJuaW5nUGF0aE1lbnVDb250ZW50LnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE5LXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IGNvbG9ycywgc3BhY2luZywgc3BhY2luZ1VuaXQsIGZvbnRzLCBtcSwgYnJlYWtwb2ludHMsIGFuaW1hdGlvbnMsIHV0aWxzIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgU2FmZUxpbmsgZnJvbSAnQG5kbGEvc2FmZWxpbmsnO1xuaW1wb3J0IHsgTGVhcm5pbmdQYXRoUmVhZCB9IGZyb20gJ0BuZGxhL2ljb25zL2NvbnRlbnRUeXBlJztcbmltcG9ydCB7IFN0ZXBQcm9wcyB9IGZyb20gJy4vTGVhcm5pbmdQYXRoTWVudSc7XG5pbXBvcnQgQ29udGVudFR5cGVCYWRnZSBmcm9tICcuLi9Db250ZW50VHlwZUJhZGdlJztcbmltcG9ydCBjb25zdGFudHMgZnJvbSAnLi4vbW9kZWwnO1xuXG5jb25zdCBTSURFX05BVl9XSURUSCA9ICczNzJweCc7XG5cbnR5cGUgU3R5bGVkTWVudUl0ZW1Qcm9wcyA9IHtcbiAgY3VycmVudD86IGJvb2xlYW47XG4gIGlzT3BlbjogYm9vbGVhbjtcbiAgYWZ0ZXJDdXJyZW50OiBib29sZWFuO1xuICBpbmRleE51bWJlcjogbnVtYmVyO1xuICBoYXNSZWFkPzogYm9vbGVhbjtcbiAgaW52ZXJ0ZWRTdHlsZT86IGJvb2xlYW47XG59O1xuXG5jb25zdCBTdHlsZWRNZW51SXRlbSA9IHN0eWxlZC5saTxTdHlsZWRNZW51SXRlbVByb3BzPmBcbiAgbWFyZ2luOiAwO1xuICBhIHtcbiAgICBib3gtc2hhZG93OiBub25lO1xuICAgIGRpc3BsYXk6IGlubGluZS1mbGV4O1xuICAgIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gICAgcGFkZGluZzogJHtzcGFjaW5nLnNtYWxsfTtcbiAgICA+IHNwYW4ge1xuICAgICAgZGlzcGxheTogZmxleDtcbiAgICAgIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gICAgICAke2ZvbnRzLnNpemVzKDE0LCAxLjIpfTtcbiAgICAgIGNvbG9yOiAke2NvbG9ycy5icmFuZC5wcmltYXJ5fTtcbiAgICAgICR7bXEucmFuZ2UoeyBmcm9tOiBicmVha3BvaW50cy50YWJsZXQgfSl9IHtcbiAgICAgICAgY29sb3I6ICR7KHsgaW52ZXJ0ZWRTdHlsZSB9KSA9PiAoaW52ZXJ0ZWRTdHlsZSA/ICcjZmZmJyA6IGNvbG9ycy5icmFuZC5wcmltYXJ5KX07XG4gICAgICAgIGZvbnQtd2VpZ2h0OiAke2ZvbnRzLndlaWdodC5zZW1pYm9sZH07XG4gICAgICB9XG4gICAgfVxuICAgICY6aG92ZXIsXG4gICAgJjpmb2N1cyB7XG4gICAgICA+IHNwYW4ge1xuICAgICAgICB0ZXh0LWRlY29yYXRpb246IHVuZGVybGluZTtcbiAgICAgIH1cbiAgICB9XG4gIH1cbiAgJHttcS5yYW5nZSh7IHVudGlsOiBicmVha3BvaW50cy5kZXNrdG9wIH0pfSB7XG4gICAgJHsocHJvcHMpID0+XG4gICAgICAhcHJvcHMuaXNPcGVuICYmXG4gICAgICBgXG4gICAgICBtYXJnaW4tYm90dG9tOiAtJHtzcGFjaW5nLnhzbWFsbH07XG4gICAgICBtYXJnaW4tdG9wOiAtJHtzcGFjaW5nLnhzbWFsbH07XG4gICAgICB0cmFuc2l0aW9uOiBtYXJnaW4gJHthbmltYXRpb25zLmR1cmF0aW9ucy5zdXBlckZhc3R9IGVhc2U7XG4gICAgYH1cbiAgICAkeyhwcm9wcykgPT5cbiAgICAgIHByb3BzLmlzT3BlbiAmJlxuICAgICAgYFxuICAgICAgYSBzcGFuIHtcbiAgICAgICAgJHthbmltYXRpb25zLmZhZGVJbkxlZnRGcm9tWmVybygpfVxuICAgICAgICBhbmltYXRpb24tZGVsYXk6ICR7cGFyc2VJbnQoYW5pbWF0aW9ucy5kdXJhdGlvbnMuc3VwZXJGYXN0KSAqIDEuNSArIDIwICogcHJvcHMuaW5kZXhOdW1iZXJ9bXM7XG4gICAgICB9XG4gICAgYH1cbiAgICAmOmZpcnN0LW9mLXR5cGUsICY6bGFzdC1vZi10eXBlIHtcbiAgICAgIG1hcmdpbi10b3A6IDA7XG4gICAgICBtYXJnaW4tYm90dG9tOiAwO1xuICAgIH1cbiAgfVxuICAkeyhwcm9wcykgPT5cbiAgICBwcm9wcy5jdXJyZW50ICYmXG4gICAgcHJvcHMuaXNPcGVuICYmXG4gICAgYFxuICAgIGEge1xuICAgICAgJjpiZWZvcmUge1xuICAgICAgICBwb3NpdGlvbjogYWJzb2x1dGU7XG4gICAgICAgIGNvbnRlbnQ6ICcnO1xuICAgICAgICBkaXNwbGF5OiBibG9jaztcbiAgICAgICAgYmFja2dyb3VuZDogI2ZmZjtcbiAgICAgICAgaGVpZ2h0OiAke3NwYWNpbmcubGFyZ2V9O1xuICAgICAgICB3aWR0aDogY2FsYygke1NJREVfTkFWX1dJRFRIfSAtICR7c3BhY2luZy5zbWFsbH0pO1xuICAgICAgICB0cmFuc2Zvcm06IHRyYW5zbGF0ZVgoLSR7c3BhY2luZy5zbWFsbH0pO1xuICAgICAgfVxuICAgIH1cbiAgYH1cbiAgJHsocHJvcHMpID0+XG4gICAgcHJvcHMuY3VycmVudCAmJlxuICAgIGBcbiAgICAgIGJhY2tncm91bmQ6ICNmZmY7XG4gIGB9XG4gICY6YWZ0ZXIge1xuICAgIGNvbnRlbnQ6ICcnO1xuICAgIGRpc3BsYXk6IGJsb2NrO1xuICAgIGhlaWdodDogJHtzcGFjaW5nLmxhcmdlfTtcbiAgICB3aWR0aDogMnB4O1xuICAgIGJhY2tncm91bmQ6ICR7Y29sb3JzLmJyYW5kLmdyZXlMaWdodH07XG4gICAgcG9zaXRpb246IGFic29sdXRlO1xuICAgIHRyYW5zZm9ybTogdHJhbnNsYXRlKDI5cHgsIC0ke3NwYWNpbmdVbml0ICogM31weCk7XG4gIH1cbiAgJHsocHJvcHMpID0+
|
|
68
|
+
}), "{", StyledMenuItem, "{span{display:none;}&:first-of-type{&:after{display:none!important;}}a:hover,a:focus{position:relative;z-index:1;width:", SIDE_NAV_WIDTH, ";background:", _core.colors.brand.greyLighter, ";span{display:flex;}}}};label:StyledNavigation;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["LearningPathMenuContent.tsx"],"names":[],"mappings":"AAkKO","file":"LearningPathMenuContent.tsx","sourcesContent":["/**\n * Copyright (c) 2019-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 from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { colors, spacing, spacingUnit, fonts, mq, breakpoints, animations, utils } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\nimport { LearningPathRead } from '@ndla/icons/contentType';\nimport { StepProps } from './LearningPathMenu';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport constants from '../model';\n\nconst SIDE_NAV_WIDTH = '372px';\n\ntype StyledMenuItemProps = {\n  current?: boolean;\n  isOpen: boolean;\n  afterCurrent: boolean;\n  indexNumber: number;\n  hasRead?: boolean;\n  invertedStyle?: boolean;\n};\n\nconst StyledMenuItem = styled.li<StyledMenuItemProps>`\n  margin: 0;\n  a {\n    box-shadow: none;\n    display: inline-flex;\n    align-items: center;\n    padding: ${spacing.small};\n    > span {\n      display: flex;\n      align-items: center;\n      ${fonts.sizes(14, 1.2)};\n      color: ${colors.brand.primary};\n      ${mq.range({ from: breakpoints.tablet })} {\n        color: ${({ invertedStyle }) => (invertedStyle ? '#fff' : colors.brand.primary)};\n        font-weight: ${fonts.weight.semibold};\n      }\n    }\n    &:hover,\n    &:focus {\n      > span {\n        text-decoration: underline;\n      }\n    }\n  }\n  ${mq.range({ until: breakpoints.desktop })} {\n    ${(props) =>\n      !props.isOpen &&\n      `\n      margin-bottom: -${spacing.xsmall};\n      margin-top: -${spacing.xsmall};\n      transition: margin ${animations.durations.superFast} ease;\n    `}\n    ${(props) =>\n      props.isOpen &&\n      `\n      a span {\n        ${animations.fadeInLeftFromZero()}\n        animation-delay: ${parseInt(animations.durations.superFast) * 1.5 + 20 * props.indexNumber}ms;\n      }\n    `}\n    &:first-of-type, &:last-of-type {\n      margin-top: 0;\n      margin-bottom: 0;\n    }\n  }\n  ${(props) =>\n    props.current &&\n    props.isOpen &&\n    `\n    a {\n      &:before {\n        position: absolute;\n        content: '';\n        display: block;\n        background: #fff;\n        height: ${spacing.large};\n        width: calc(${SIDE_NAV_WIDTH} - ${spacing.small});\n        transform: translateX(-${spacing.small});\n      }\n    }\n  `}\n  ${(props) =>\n    props.current &&\n    `\n      background: #fff;\n  `}\n  &:after {\n    content: '';\n    display: block;\n    height: ${spacing.large};\n    width: 2px;\n    background: ${colors.brand.greyLight};\n    position: absolute;\n    transform: translate(29px, -${spacingUnit * 3}px);\n  }\n  ${(props) =>\n    !props.afterCurrent &&\n    `\n    a {\n      > span {\n        color: ${colors.text.primary};\n        font-weight: ${fonts.weight.normal};\n      }\n      color: ${colors.text.primary};\n      font-weight: ${fonts.weight.normal};\n    }\n    &:after {\n      width: 4px;\n      background: ${colors.text.light};\n      transform: translate(28px, -${spacingUnit * 3}px);\n    }\n  `}\n  ${(props) =>\n    !props.afterCurrent &&\n    !props.current &&\n    props.invertedStyle &&\n    `\n    ${mq.range({ from: breakpoints.tablet })} {\n      a {\n        > span {\n          color: #fff;\n        }\n        color: #fff;\n      }\n    }\n    `}\n`;\n\nconst StyledContentType = styled.div`\n  position: relative;\n  z-index: 1;\n  margin-right: ${spacingUnit * 0.75}px;\n  max-height: 35px;\n`;\n\nconst HiddenSpan = styled.span`\n  ${utils.visuallyHidden};\n`;\n\ntype StyledNavigationProps = {\n  isOpen: boolean;\n  invertedStyle?: boolean;\n};\n\nconst StyledNavigation = styled.nav<StyledNavigationProps>`\n  > ul {\n    list-style: none;\n    margin: 0;\n    padding: 0;\n  }\n  margin-bottom: ${spacing.medium};\n  ${(props) =>\n    !props.isOpen &&\n    css`\n      ${mq.range({ until: breakpoints.tablet })} {\n        margin-left: -28px;\n      }\n      ${mq.range({ from: breakpoints.tablet, until: breakpoints.desktop })} {\n        ${StyledMenuItem} {\n          span {\n            display: none;\n          }\n          &:first-of-type {\n            &:after {\n              display: none !important;\n            }\n          }\n          a:hover,\n          a:focus {\n            position: relative;\n            z-index: 1;\n            width: ${SIDE_NAV_WIDTH};\n            background: ${colors.brand.greyLighter};\n            span {\n              display: flex;\n            }\n          }\n        }\n      }\n    `}\n`;\n\nconst ReadIcon = styled.div`\n  border-radius: 100%;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  position: absolute;\n  top: -6px;\n  right: 0;\n  width: 16px;\n  height: 16px;\n  background: ${colors.brand.secondary};\n  color: ${colors.text.light};\n  transform: translateX(4px);\n  svg {\n    width: 12px;\n    height: 12px;\n    fill: ${colors.brand.lighter};\n  }\n`;\n\ntype Props = {\n  learningsteps: StepProps[];\n  learningPathId: number;\n  isOpen: boolean;\n  toLearningPathUrl(pathId: number, stepId: number): string;\n  currentIndex: number;\n  invertedStyle?: boolean;\n  cookies: {\n    [key: string]: string;\n  };\n  onStepNavigate: () => void;\n};\n\nconst hasRead = (\n  id: number,\n  cookies: {\n    [key: string]: string;\n  },\n) => !!cookies[id];\n\nconst LearningPathMenuContent = ({\n  isOpen,\n  currentIndex,\n  cookies,\n  learningPathId,\n  learningsteps,\n  toLearningPathUrl,\n  invertedStyle,\n  onStepNavigate,\n}: Props) => {\n  return (\n    <StyledNavigation isOpen={isOpen} invertedStyle={invertedStyle}>\n      <ul>\n        {learningsteps.map(({ id, title, type }: StepProps, index: number) => (\n          <StyledMenuItem\n            key={id}\n            current={index === currentIndex}\n            afterCurrent={index > currentIndex}\n            isOpen={isOpen}\n            invertedStyle={invertedStyle}\n            indexNumber={index}\n          >\n            <SafeLink\n              onClick={onStepNavigate}\n              to={toLearningPathUrl(learningPathId, id)}\n              aria-describedby={`read-${id}`}\n            >\n              <StyledContentType>\n                <ContentTypeBadge type={type ?? constants.contentTypes.LEARNING_PATH} background size=\"small\" />\n                {hasRead(id, cookies) && (\n                  <div id={`read-${id}`} aria-hidden>\n                    <HiddenSpan>Lest</HiddenSpan>\n                    <ReadIcon>\n                      <LearningPathRead />\n                    </ReadIcon>\n                  </div>\n                )}\n              </StyledContentType>\n              <span>{title}</span>\n            </SafeLink>\n          </StyledMenuItem>\n        ))}\n      </ul>\n    </StyledNavigation>\n  );\n};\n\nexport default LearningPathMenuContent;\n"]} */"));
|
|
69
|
+
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["LearningPathMenuContent.tsx"],"names":[],"mappings":"AAyJ0D","file":"LearningPathMenuContent.tsx","sourcesContent":["/**\n * Copyright (c) 2019-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 from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { colors, spacing, spacingUnit, fonts, mq, breakpoints, animations, utils } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\nimport { LearningPathRead } from '@ndla/icons/contentType';\nimport { StepProps } from './LearningPathMenu';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport constants from '../model';\n\nconst SIDE_NAV_WIDTH = '372px';\n\ntype StyledMenuItemProps = {\n  current?: boolean;\n  isOpen: boolean;\n  afterCurrent: boolean;\n  indexNumber: number;\n  hasRead?: boolean;\n  invertedStyle?: boolean;\n};\n\nconst StyledMenuItem = styled.li<StyledMenuItemProps>`\n  margin: 0;\n  a {\n    box-shadow: none;\n    display: inline-flex;\n    align-items: center;\n    padding: ${spacing.small};\n    > span {\n      display: flex;\n      align-items: center;\n      ${fonts.sizes(14, 1.2)};\n      color: ${colors.brand.primary};\n      ${mq.range({ from: breakpoints.tablet })} {\n        color: ${({ invertedStyle }) => (invertedStyle ? '#fff' : colors.brand.primary)};\n        font-weight: ${fonts.weight.semibold};\n      }\n    }\n    &:hover,\n    &:focus {\n      > span {\n        text-decoration: underline;\n      }\n    }\n  }\n  ${mq.range({ until: breakpoints.desktop })} {\n    ${(props) =>\n      !props.isOpen &&\n      `\n      margin-bottom: -${spacing.xsmall};\n      margin-top: -${spacing.xsmall};\n      transition: margin ${animations.durations.superFast} ease;\n    `}\n    ${(props) =>\n      props.isOpen &&\n      `\n      a span {\n        ${animations.fadeInLeftFromZero()}\n        animation-delay: ${parseInt(animations.durations.superFast) * 1.5 + 20 * props.indexNumber}ms;\n      }\n    `}\n    &:first-of-type, &:last-of-type {\n      margin-top: 0;\n      margin-bottom: 0;\n    }\n  }\n  ${(props) =>\n    props.current &&\n    props.isOpen &&\n    `\n    a {\n      &:before {\n        position: absolute;\n        content: '';\n        display: block;\n        background: #fff;\n        height: ${spacing.large};\n        width: calc(${SIDE_NAV_WIDTH} - ${spacing.small});\n        transform: translateX(-${spacing.small});\n      }\n    }\n  `}\n  ${(props) =>\n    props.current &&\n    `\n      background: #fff;\n  `}\n  &:after {\n    content: '';\n    display: block;\n    height: ${spacing.large};\n    width: 2px;\n    background: ${colors.brand.greyLight};\n    position: absolute;\n    transform: translate(29px, -${spacingUnit * 3}px);\n  }\n  ${(props) =>\n    !props.afterCurrent &&\n    `\n    a {\n      > span {\n        color: ${colors.text.primary};\n        font-weight: ${fonts.weight.normal};\n      }\n      color: ${colors.text.primary};\n      font-weight: ${fonts.weight.normal};\n    }\n    &:after {\n      width: 4px;\n      background: ${colors.text.light};\n      transform: translate(28px, -${spacingUnit * 3}px);\n    }\n  `}\n  ${(props) =>\n    !props.afterCurrent &&\n    !props.current &&\n    props.invertedStyle &&\n    `\n    ${mq.range({ from: breakpoints.tablet })} {\n      a {\n        > span {\n          color: #fff;\n        }\n        color: #fff;\n      }\n    }\n    `}\n`;\n\nconst StyledContentType = styled.div`\n  position: relative;\n  z-index: 1;\n  margin-right: ${spacingUnit * 0.75}px;\n  max-height: 35px;\n`;\n\nconst HiddenSpan = styled.span`\n  ${utils.visuallyHidden};\n`;\n\ntype StyledNavigationProps = {\n  isOpen: boolean;\n  invertedStyle?: boolean;\n};\n\nconst StyledNavigation = styled.nav<StyledNavigationProps>`\n  > ul {\n    list-style: none;\n    margin: 0;\n    padding: 0;\n  }\n  margin-bottom: ${spacing.medium};\n  ${(props) =>\n    !props.isOpen &&\n    css`\n      ${mq.range({ until: breakpoints.tablet })} {\n        margin-left: -28px;\n      }\n      ${mq.range({ from: breakpoints.tablet, until: breakpoints.desktop })} {\n        ${StyledMenuItem} {\n          span {\n            display: none;\n          }\n          &:first-of-type {\n            &:after {\n              display: none !important;\n            }\n          }\n          a:hover,\n          a:focus {\n            position: relative;\n            z-index: 1;\n            width: ${SIDE_NAV_WIDTH};\n            background: ${colors.brand.greyLighter};\n            span {\n              display: flex;\n            }\n          }\n        }\n      }\n    `}\n`;\n\nconst ReadIcon = styled.div`\n  border-radius: 100%;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  position: absolute;\n  top: -6px;\n  right: 0;\n  width: 16px;\n  height: 16px;\n  background: ${colors.brand.secondary};\n  color: ${colors.text.light};\n  transform: translateX(4px);\n  svg {\n    width: 12px;\n    height: 12px;\n    fill: ${colors.brand.lighter};\n  }\n`;\n\ntype Props = {\n  learningsteps: StepProps[];\n  learningPathId: number;\n  isOpen: boolean;\n  toLearningPathUrl(pathId: number, stepId: number): string;\n  currentIndex: number;\n  invertedStyle?: boolean;\n  cookies: {\n    [key: string]: string;\n  };\n  onStepNavigate: () => void;\n};\n\nconst hasRead = (\n  id: number,\n  cookies: {\n    [key: string]: string;\n  },\n) => !!cookies[id];\n\nconst LearningPathMenuContent = ({\n  isOpen,\n  currentIndex,\n  cookies,\n  learningPathId,\n  learningsteps,\n  toLearningPathUrl,\n  invertedStyle,\n  onStepNavigate,\n}: Props) => {\n  return (\n    <StyledNavigation isOpen={isOpen} invertedStyle={invertedStyle}>\n      <ul>\n        {learningsteps.map(({ id, title, type }: StepProps, index: number) => (\n          <StyledMenuItem\n            key={id}\n            current={index === currentIndex}\n            afterCurrent={index > currentIndex}\n            isOpen={isOpen}\n            invertedStyle={invertedStyle}\n            indexNumber={index}\n          >\n            <SafeLink\n              onClick={onStepNavigate}\n              to={toLearningPathUrl(learningPathId, id)}\n              aria-describedby={`read-${id}`}\n            >\n              <StyledContentType>\n                <ContentTypeBadge type={type ?? constants.contentTypes.LEARNING_PATH} background size=\"small\" />\n                {hasRead(id, cookies) && (\n                  <div id={`read-${id}`} aria-hidden>\n                    <HiddenSpan>Lest</HiddenSpan>\n                    <ReadIcon>\n                      <LearningPathRead />\n                    </ReadIcon>\n                  </div>\n                )}\n              </StyledContentType>\n              <span>{title}</span>\n            </SafeLink>\n          </StyledMenuItem>\n        ))}\n      </ul>\n    </StyledNavigation>\n  );\n};\n\nexport default LearningPathMenuContent;\n"]} */"));
|
|
70
70
|
var ReadIcon = /*#__PURE__*/(0, _base["default"])("div", {
|
|
71
71
|
target: "eipwgxz0",
|
|
72
72
|
label: "ReadIcon"
|
|
73
|
-
})("border-radius:100%;display:flex;align-items:center;justify-content:center;position:absolute;top:-6px;right:0;width:16px;height:16px;background:", _core.colors.brand.secondary, ";color:", _core.colors.text.light, ";transform:translateX(4px);svg{width:12px;height:12px;fill:", _core.colors.brand.lighter, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlYXJuaW5nUGF0aE1lbnVDb250ZW50LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUErTDJCIiwiZmlsZSI6IkxlYXJuaW5nUGF0aE1lbnVDb250ZW50LnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE5LXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IGNvbG9ycywgc3BhY2luZywgc3BhY2luZ1VuaXQsIGZvbnRzLCBtcSwgYnJlYWtwb2ludHMsIGFuaW1hdGlvbnMsIHV0aWxzIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgU2FmZUxpbmsgZnJvbSAnQG5kbGEvc2FmZWxpbmsnO1xuaW1wb3J0IHsgTGVhcm5pbmdQYXRoUmVhZCB9IGZyb20gJ0BuZGxhL2ljb25zL2NvbnRlbnRUeXBlJztcbmltcG9ydCB7IFN0ZXBQcm9wcyB9IGZyb20gJy4vTGVhcm5pbmdQYXRoTWVudSc7XG5pbXBvcnQgQ29udGVudFR5cGVCYWRnZSBmcm9tICcuLi9Db250ZW50VHlwZUJhZGdlJztcbmltcG9ydCBjb25zdGFudHMgZnJvbSAnLi4vbW9kZWwnO1xuXG5jb25zdCBTSURFX05BVl9XSURUSCA9ICczNzJweCc7XG5cbnR5cGUgU3R5bGVkTWVudUl0ZW1Qcm9wcyA9IHtcbiAgY3VycmVudD86IGJvb2xlYW47XG4gIGlzT3BlbjogYm9vbGVhbjtcbiAgYWZ0ZXJDdXJyZW50OiBib29sZWFuO1xuICBpbmRleE51bWJlcjogbnVtYmVyO1xuICBoYXNSZWFkPzogYm9vbGVhbjtcbiAgaW52ZXJ0ZWRTdHlsZT86IGJvb2xlYW47XG59O1xuXG5jb25zdCBTdHlsZWRNZW51SXRlbSA9IHN0eWxlZC5saTxTdHlsZWRNZW51SXRlbVByb3BzPmBcbiAgbWFyZ2luOiAwO1xuICBhIHtcbiAgICBib3gtc2hhZG93OiBub25lO1xuICAgIGRpc3BsYXk6IGlubGluZS1mbGV4O1xuICAgIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gICAgcGFkZGluZzogJHtzcGFjaW5nLnNtYWxsfTtcbiAgICA+IHNwYW4ge1xuICAgICAgZGlzcGxheTogZmxleDtcbiAgICAgIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gICAgICAke2ZvbnRzLnNpemVzKDE0LCAxLjIpfTtcbiAgICAgIGNvbG9yOiAke2NvbG9ycy5icmFuZC5wcmltYXJ5fTtcbiAgICAgICR7bXEucmFuZ2UoeyBmcm9tOiBicmVha3BvaW50cy50YWJsZXQgfSl9IHtcbiAgICAgICAgY29sb3I6ICR7KHsgaW52ZXJ0ZWRTdHlsZSB9KSA9PiAoaW52ZXJ0ZWRTdHlsZSA/ICcjZmZmJyA6IGNvbG9ycy5icmFuZC5wcmltYXJ5KX07XG4gICAgICAgIGZvbnQtd2VpZ2h0OiAke2ZvbnRzLndlaWdodC5zZW1pYm9sZH07XG4gICAgICB9XG4gICAgfVxuICAgICY6aG92ZXIsXG4gICAgJjpmb2N1cyB7XG4gICAgICA+IHNwYW4ge1xuICAgICAgICB0ZXh0LWRlY29yYXRpb246IHVuZGVybGluZTtcbiAgICAgIH1cbiAgICB9XG4gIH1cbiAgJHttcS5yYW5nZSh7IHVudGlsOiBicmVha3BvaW50cy5kZXNrdG9wIH0pfSB7XG4gICAgJHsocHJvcHMpID0+XG4gICAgICAhcHJvcHMuaXNPcGVuICYmXG4gICAgICBgXG4gICAgICBtYXJnaW4tYm90dG9tOiAtJHtzcGFjaW5nLnhzbWFsbH07XG4gICAgICBtYXJnaW4tdG9wOiAtJHtzcGFjaW5nLnhzbWFsbH07XG4gICAgICB0cmFuc2l0aW9uOiBtYXJnaW4gJHthbmltYXRpb25zLmR1cmF0aW9ucy5zdXBlckZhc3R9IGVhc2U7XG4gICAgYH1cbiAgICAkeyhwcm9wcykgPT5cbiAgICAgIHByb3BzLmlzT3BlbiAmJlxuICAgICAgYFxuICAgICAgYSBzcGFuIHtcbiAgICAgICAgJHthbmltYXRpb25zLmZhZGVJbkxlZnRGcm9tWmVybygpfVxuICAgICAgICBhbmltYXRpb24tZGVsYXk6ICR7cGFyc2VJbnQoYW5pbWF0aW9ucy5kdXJhdGlvbnMuc3VwZXJGYXN0KSAqIDEuNSArIDIwICogcHJvcHMuaW5kZXhOdW1iZXJ9bXM7XG4gICAgICB9XG4gICAgYH1cbiAgICAmOmZpcnN0LW9mLXR5cGUsICY6bGFzdC1vZi10eXBlIHtcbiAgICAgIG1hcmdpbi10b3A6IDA7XG4gICAgICBtYXJnaW4tYm90dG9tOiAwO1xuICAgIH1cbiAgfVxuICAkeyhwcm9wcykgPT5cbiAgICBwcm9wcy5jdXJyZW50ICYmXG4gICAgcHJvcHMuaXNPcGVuICYmXG4gICAgYFxuICAgIGEge1xuICAgICAgJjpiZWZvcmUge1xuICAgICAgICBwb3NpdGlvbjogYWJzb2x1dGU7XG4gICAgICAgIGNvbnRlbnQ6ICcnO1xuICAgICAgICBkaXNwbGF5OiBibG9jaztcbiAgICAgICAgYmFja2dyb3VuZDogI2ZmZjtcbiAgICAgICAgaGVpZ2h0OiAke3NwYWNpbmcubGFyZ2V9O1xuICAgICAgICB3aWR0aDogY2FsYygke1NJREVfTkFWX1dJRFRIfSAtICR7c3BhY2luZy5zbWFsbH0pO1xuICAgICAgICB0cmFuc2Zvcm06IHRyYW5zbGF0ZVgoLSR7c3BhY2luZy5zbWFsbH0pO1xuICAgICAgfVxuICAgIH1cbiAgYH1cbiAgJHsocHJvcHMpID0+XG4gICAgcHJvcHMuY3VycmVudCAmJlxuICAgIGBcbiAgICAgIGJhY2tncm91bmQ6ICNmZmY7XG4gIGB9XG4gICY6YWZ0ZXIge1xuICAgIGNvbnRlbnQ6ICcnO1xuICAgIGRpc3BsYXk6IGJsb2NrO1xuICAgIGhlaWdodDogJHtzcGFjaW5nLmxhcmdlfTtcbiAgICB3aWR0aDogMnB4O1xuICAgIGJhY2tncm91bmQ6ICR7Y29sb3JzLmJyYW5kLmdyZXlMaWdodH07XG4gICAgcG9zaXRpb246IGFic29sdXRlO1xuICAgIHRyYW5zZm9ybTogdHJhbnNsYXRlKDI5cHgsIC0ke3NwYWNpbmdVbml0ICogM31weCk7XG4gIH1cbiAgJHsocHJvcHMpID0+
|
|
73
|
+
})("border-radius:100%;display:flex;align-items:center;justify-content:center;position:absolute;top:-6px;right:0;width:16px;height:16px;background:", _core.colors.brand.secondary, ";color:", _core.colors.text.light, ";transform:translateX(4px);svg{width:12px;height:12px;fill:", _core.colors.brand.lighter, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["LearningPathMenuContent.tsx"],"names":[],"mappings":"AA+L2B","file":"LearningPathMenuContent.tsx","sourcesContent":["/**\n * Copyright (c) 2019-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 from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { colors, spacing, spacingUnit, fonts, mq, breakpoints, animations, utils } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\nimport { LearningPathRead } from '@ndla/icons/contentType';\nimport { StepProps } from './LearningPathMenu';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport constants from '../model';\n\nconst SIDE_NAV_WIDTH = '372px';\n\ntype StyledMenuItemProps = {\n  current?: boolean;\n  isOpen: boolean;\n  afterCurrent: boolean;\n  indexNumber: number;\n  hasRead?: boolean;\n  invertedStyle?: boolean;\n};\n\nconst StyledMenuItem = styled.li<StyledMenuItemProps>`\n  margin: 0;\n  a {\n    box-shadow: none;\n    display: inline-flex;\n    align-items: center;\n    padding: ${spacing.small};\n    > span {\n      display: flex;\n      align-items: center;\n      ${fonts.sizes(14, 1.2)};\n      color: ${colors.brand.primary};\n      ${mq.range({ from: breakpoints.tablet })} {\n        color: ${({ invertedStyle }) => (invertedStyle ? '#fff' : colors.brand.primary)};\n        font-weight: ${fonts.weight.semibold};\n      }\n    }\n    &:hover,\n    &:focus {\n      > span {\n        text-decoration: underline;\n      }\n    }\n  }\n  ${mq.range({ until: breakpoints.desktop })} {\n    ${(props) =>\n      !props.isOpen &&\n      `\n      margin-bottom: -${spacing.xsmall};\n      margin-top: -${spacing.xsmall};\n      transition: margin ${animations.durations.superFast} ease;\n    `}\n    ${(props) =>\n      props.isOpen &&\n      `\n      a span {\n        ${animations.fadeInLeftFromZero()}\n        animation-delay: ${parseInt(animations.durations.superFast) * 1.5 + 20 * props.indexNumber}ms;\n      }\n    `}\n    &:first-of-type, &:last-of-type {\n      margin-top: 0;\n      margin-bottom: 0;\n    }\n  }\n  ${(props) =>\n    props.current &&\n    props.isOpen &&\n    `\n    a {\n      &:before {\n        position: absolute;\n        content: '';\n        display: block;\n        background: #fff;\n        height: ${spacing.large};\n        width: calc(${SIDE_NAV_WIDTH} - ${spacing.small});\n        transform: translateX(-${spacing.small});\n      }\n    }\n  `}\n  ${(props) =>\n    props.current &&\n    `\n      background: #fff;\n  `}\n  &:after {\n    content: '';\n    display: block;\n    height: ${spacing.large};\n    width: 2px;\n    background: ${colors.brand.greyLight};\n    position: absolute;\n    transform: translate(29px, -${spacingUnit * 3}px);\n  }\n  ${(props) =>\n    !props.afterCurrent &&\n    `\n    a {\n      > span {\n        color: ${colors.text.primary};\n        font-weight: ${fonts.weight.normal};\n      }\n      color: ${colors.text.primary};\n      font-weight: ${fonts.weight.normal};\n    }\n    &:after {\n      width: 4px;\n      background: ${colors.text.light};\n      transform: translate(28px, -${spacingUnit * 3}px);\n    }\n  `}\n  ${(props) =>\n    !props.afterCurrent &&\n    !props.current &&\n    props.invertedStyle &&\n    `\n    ${mq.range({ from: breakpoints.tablet })} {\n      a {\n        > span {\n          color: #fff;\n        }\n        color: #fff;\n      }\n    }\n    `}\n`;\n\nconst StyledContentType = styled.div`\n  position: relative;\n  z-index: 1;\n  margin-right: ${spacingUnit * 0.75}px;\n  max-height: 35px;\n`;\n\nconst HiddenSpan = styled.span`\n  ${utils.visuallyHidden};\n`;\n\ntype StyledNavigationProps = {\n  isOpen: boolean;\n  invertedStyle?: boolean;\n};\n\nconst StyledNavigation = styled.nav<StyledNavigationProps>`\n  > ul {\n    list-style: none;\n    margin: 0;\n    padding: 0;\n  }\n  margin-bottom: ${spacing.medium};\n  ${(props) =>\n    !props.isOpen &&\n    css`\n      ${mq.range({ until: breakpoints.tablet })} {\n        margin-left: -28px;\n      }\n      ${mq.range({ from: breakpoints.tablet, until: breakpoints.desktop })} {\n        ${StyledMenuItem} {\n          span {\n            display: none;\n          }\n          &:first-of-type {\n            &:after {\n              display: none !important;\n            }\n          }\n          a:hover,\n          a:focus {\n            position: relative;\n            z-index: 1;\n            width: ${SIDE_NAV_WIDTH};\n            background: ${colors.brand.greyLighter};\n            span {\n              display: flex;\n            }\n          }\n        }\n      }\n    `}\n`;\n\nconst ReadIcon = styled.div`\n  border-radius: 100%;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  position: absolute;\n  top: -6px;\n  right: 0;\n  width: 16px;\n  height: 16px;\n  background: ${colors.brand.secondary};\n  color: ${colors.text.light};\n  transform: translateX(4px);\n  svg {\n    width: 12px;\n    height: 12px;\n    fill: ${colors.brand.lighter};\n  }\n`;\n\ntype Props = {\n  learningsteps: StepProps[];\n  learningPathId: number;\n  isOpen: boolean;\n  toLearningPathUrl(pathId: number, stepId: number): string;\n  currentIndex: number;\n  invertedStyle?: boolean;\n  cookies: {\n    [key: string]: string;\n  };\n  onStepNavigate: () => void;\n};\n\nconst hasRead = (\n  id: number,\n  cookies: {\n    [key: string]: string;\n  },\n) => !!cookies[id];\n\nconst LearningPathMenuContent = ({\n  isOpen,\n  currentIndex,\n  cookies,\n  learningPathId,\n  learningsteps,\n  toLearningPathUrl,\n  invertedStyle,\n  onStepNavigate,\n}: Props) => {\n  return (\n    <StyledNavigation isOpen={isOpen} invertedStyle={invertedStyle}>\n      <ul>\n        {learningsteps.map(({ id, title, type }: StepProps, index: number) => (\n          <StyledMenuItem\n            key={id}\n            current={index === currentIndex}\n            afterCurrent={index > currentIndex}\n            isOpen={isOpen}\n            invertedStyle={invertedStyle}\n            indexNumber={index}\n          >\n            <SafeLink\n              onClick={onStepNavigate}\n              to={toLearningPathUrl(learningPathId, id)}\n              aria-describedby={`read-${id}`}\n            >\n              <StyledContentType>\n                <ContentTypeBadge type={type ?? constants.contentTypes.LEARNING_PATH} background size=\"small\" />\n                {hasRead(id, cookies) && (\n                  <div id={`read-${id}`} aria-hidden>\n                    <HiddenSpan>Lest</HiddenSpan>\n                    <ReadIcon>\n                      <LearningPathRead />\n                    </ReadIcon>\n                  </div>\n                )}\n              </StyledContentType>\n              <span>{title}</span>\n            </SafeLink>\n          </StyledMenuItem>\n        ))}\n      </ul>\n    </StyledNavigation>\n  );\n};\n\nexport default LearningPathMenuContent;\n"]} */"));
|
|
74
74
|
var hasRead = function hasRead(id, cookies) {
|
|
75
75
|
return !!cookies[id];
|
|
76
76
|
};
|