@ndla/ui 42.1.1 → 42.1.2

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.
Files changed (36) hide show
  1. package/es/AudioPlayer/AudioPlayer.js +27 -33
  2. package/es/CampaignBlock/CampaignBlock.js +32 -18
  3. package/es/LicenseByline/EmbedByline.js +5 -5
  4. package/es/MyNdla/Resource/Folder.js +27 -66
  5. package/es/Resource/BlockResource.js +13 -22
  6. package/es/Resource/ListResource.js +12 -14
  7. package/es/Resource/resourceComponents.js +59 -29
  8. package/es/TreeStructure/ComboboxButton.js +17 -20
  9. package/es/TreeStructure/FolderItem.js +42 -65
  10. package/es/TreeStructure/FolderItems.js +25 -19
  11. package/es/TreeStructure/TreeStructure.js +19 -26
  12. package/lib/AudioPlayer/AudioPlayer.js +27 -33
  13. package/lib/CampaignBlock/CampaignBlock.js +32 -18
  14. package/lib/LicenseByline/EmbedByline.js +5 -5
  15. package/lib/MyNdla/Resource/Folder.js +27 -66
  16. package/lib/Resource/BlockResource.d.ts +1 -1
  17. package/lib/Resource/BlockResource.js +12 -21
  18. package/lib/Resource/ListResource.js +11 -13
  19. package/lib/Resource/resourceComponents.d.ts +5 -10
  20. package/lib/Resource/resourceComponents.js +63 -31
  21. package/lib/TreeStructure/ComboboxButton.js +17 -20
  22. package/lib/TreeStructure/FolderItem.js +40 -63
  23. package/lib/TreeStructure/FolderItems.js +31 -26
  24. package/lib/TreeStructure/TreeStructure.js +19 -26
  25. package/package.json +14 -14
  26. package/src/AudioPlayer/AudioPlayer.tsx +24 -34
  27. package/src/CampaignBlock/CampaignBlock.tsx +10 -10
  28. package/src/LicenseByline/EmbedByline.tsx +1 -1
  29. package/src/MyNdla/Resource/Folder.tsx +28 -35
  30. package/src/Resource/BlockResource.tsx +21 -18
  31. package/src/Resource/ListResource.tsx +17 -12
  32. package/src/Resource/resourceComponents.tsx +34 -15
  33. package/src/TreeStructure/ComboboxButton.tsx +5 -7
  34. package/src/TreeStructure/FolderItem.tsx +49 -32
  35. package/src/TreeStructure/FolderItems.tsx +6 -8
  36. package/src/TreeStructure/TreeStructure.tsx +16 -25
@@ -1,4 +1,13 @@
1
+ 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); }
1
2
  import _styled from "@emotion/styled/base";
3
+ var _excluded = ["contentType", "children"];
4
+ 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; }
5
+ 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; }
6
+ 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; }
7
+ function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return _typeof(key) === "symbol" ? key : String(key); }
8
+ 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); }
9
+ function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }
10
+ function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }
2
11
  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)."; }
3
12
  /**
4
13
  * Copyright (c) 2022-present, NDLA.
@@ -9,37 +18,35 @@ function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringif
9
18
  */
10
19
 
11
20
  import { colors, fonts, spacing } from '@ndla/core';
12
- import React from 'react';
21
+ import React, { useMemo } from 'react';
13
22
  import { useTranslation } from 'react-i18next';
14
23
  import { MenuButton } from '@ndla/button';
15
24
  import SafeLink from '@ndla/safelink';
16
25
  import { useNavigate } from 'react-router-dom';
17
26
  import { HashTag } from '@ndla/icons/common';
27
+ import { css } from '@emotion/react';
18
28
  import resourceTypeColor from '../utils/resourceTypeColor';
19
29
  import { resourceEmbedTypeMapping } from '../model/ContentType';
20
30
  import { jsx as _jsx } from "@emotion/react/jsx-runtime";
21
31
  import { jsxs as _jsxs } from "@emotion/react/jsx-runtime";
22
32
  import { Fragment as _Fragment } from "@emotion/react/jsx-runtime";
23
33
  export var ResourceTitleLink = /*#__PURE__*/_styled(SafeLink, {
24
- target: "e1lrrm6s9",
25
- label: "ResourceTitleLink"
26
- })("box-shadow:none;color:", colors.brand.primary, ";flex:1;:after{content:'';position:absolute;z-index:1;top:0;right:0;bottom:0;left:0;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInJlc291cmNlQ29tcG9uZW50cy50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBd0JpRCIsImZpbGUiOiJyZXNvdXJjZUNvbXBvbmVudHMudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjItcHJlc2VudCwgTkRMQS5cbiAqXG4gKiBUaGlzIHNvdXJjZSBjb2RlIGlzIGxpY2Vuc2VkIHVuZGVyIHRoZSBHUEx2MyBsaWNlbnNlIGZvdW5kIGluIHRoZVxuICogTElDRU5TRSBmaWxlIGluIHRoZSByb290IGRpcmVjdG9yeSBvZiB0aGlzIHNvdXJjZSB0cmVlLlxuICpcbiAqL1xuXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBjb2xvcnMsIGZvbnRzLCBzcGFjaW5nIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgUmVhY3QsIHsgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgdXNlVHJhbnNsYXRpb24gfSBmcm9tICdyZWFjdC1pMThuZXh0JztcbmltcG9ydCB7IE1lbnVCdXR0b24gfSBmcm9tICdAbmRsYS9idXR0b24nO1xuaW1wb3J0IFNhZmVMaW5rIGZyb20gJ0BuZGxhL3NhZmVsaW5rJztcbmltcG9ydCB7IHVzZU5hdmlnYXRlIH0gZnJvbSAncmVhY3Qtcm91dGVyLWRvbSc7XG5pbXBvcnQgeyBIYXNoVGFnIH0gZnJvbSAnQG5kbGEvaWNvbnMvY29tbW9uJztcbmltcG9ydCByZXNvdXJjZVR5cGVDb2xvciBmcm9tICcuLi91dGlscy9yZXNvdXJjZVR5cGVDb2xvcic7XG5pbXBvcnQgeyByZXNvdXJjZUVtYmVkVHlwZU1hcHBpbmcgfSBmcm9tICcuLi9tb2RlbC9Db250ZW50VHlwZSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgUmVzb3VyY2VJbWFnZVByb3BzIHtcbiAgYWx0OiBzdHJpbmc7XG4gIHNyYzogc3RyaW5nO1xufVxuXG5leHBvcnQgY29uc3QgUmVzb3VyY2VUaXRsZUxpbmsgPSBzdHlsZWQoU2FmZUxpbmspYFxuICBib3gtc2hhZG93OiBub25lO1xuICBjb2xvcjogJHtjb2xvcnMuYnJhbmQucHJpbWFyeX07XG4gIGZsZXg6IDE7XG4gIDphZnRlciB7XG4gICAgY29udGVudDogJyc7XG4gICAgcG9zaXRpb246IGFic29sdXRlO1xuICAgIHotaW5kZXg6IDE7XG4gICAgdG9wOiAwO1xuICAgIHJpZ2h0OiAwO1xuICAgIGJvdHRvbTogMDtcbiAgICBsZWZ0OiAwO1xuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgUmVzb3VyY2VUaXRsZSA9IHN0eWxlZC5zcGFuYFxuICBtYXJnaW46IDA7XG4gIG92ZXJmbG93OiBoaWRkZW47XG4gIHRleHQtb3ZlcmZsb3c6IGVsbGlwc2lzO1xuICBmb250LXdlaWdodDogJHtmb250cy53ZWlnaHQuYm9sZH07XG4gIC8vIFVuZm9ydHVuYXRlIGNzcyBuZWVkZWQgZm9yIG11bHRpLWxpbmUgdGV4dCBvdmVyZmxvdyBlbGxpcHNpcy5cbiAgbGluZS1oZWlnaHQ6IDE7XG4gIGRpc3BsYXk6IC13ZWJraXQtYm94O1xuICAtd2Via2l0LWxpbmUtY2xhbXA6IDE7XG4gIGxpbmUtY2xhbXA6IDE7XG4gIC13ZWJraXQtYm94LW9yaWVudDogdmVydGljYWw7XG4gIGdyaWQtYXJlYTogcmVzb3VyY2VUaXRsZTtcbiAgJHtmb250cy5zaXplcygnMTZweCcsICcyMHB4Jyl9O1xuYDtcblxuY29uc3QgU3R5bGVkVGFnTGlzdCA9IHN0eWxlZC51bGBcbiAgbGlzdC1zdHlsZTogbm9uZTtcbiAgZGlzcGxheTogZmxleDtcbiAgbWFyZ2luOiAwO1xuICBtYXJnaW4tbGVmdDogJHtzcGFjaW5nLnNtYWxsfTtcbiAgcGFkZGluZzogMnB4O1xuICBnYXA6ICR7c3BhY2luZy54c21hbGx9O1xuICBvdmVyZmxvdzogaGlkZGVuO1xuICA6bGFzdC1jaGlsZCB7XG4gICAgbWFyZ2luLXJpZ2h0OiAke3NwYWNpbmcuc21hbGx9O1xuICB9XG5gO1xuXG5jb25zdCBTdHlsZWRUYWdMaXN0RWxlbWVudCA9IHN0eWxlZC5saWBcbiAgbWFyZ2luOiAwO1xuICAke2ZvbnRzLnNpemVzKDE0KX07XG5gO1xuXG5jb25zdCBTdHlsZWRTYWZlTGluayA9IHN0eWxlZChTYWZlTGluaylgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGp1c3RpZnktY29udGVudDogZmxleC1lbmQ7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGJveC1zaGFkb3c6IG5vbmU7XG4gIGNvbG9yOiAke2NvbG9ycy5icmFuZC5ncmV5fTtcbiAgbWluLWhlaWdodDogNDRweDtcbiAgbWluLXdpZHRoOiA0NHB4O1xuICB3aGl0ZS1zcGFjZTogbm93cmFwO1xuICAmOmhvdmVyIHtcbiAgICBjb2xvcjogJHtjb2xvcnMuYnJhbmQucHJpbWFyeX07XG4gIH1cbmA7XG5cbmNvbnN0IFN0eWxlZFJlc291cmNlVHlwZUxpc3QgPSBzdHlsZWQudWxgXG4gIGxpc3Qtc3R5bGU6IG5vbmU7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIG1hcmdpbjogMDtcbiAgcGFkZGluZzogMDtcbiAgb3ZlcmZsb3c6IGhpZGRlbjtcbmA7XG5cbmNvbnN0IFN0eWxlZFRvcGljRGl2aWRlciA9IHN0eWxlZC5zcGFuYFxuICBtYXJnaW46IDA7XG4gIHBhZGRpbmc6IDAgJHtzcGFjaW5nLnh4c21hbGx9O1xuYDtcblxuY29uc3QgU3R5bGVkUmVzb3VyY2VMaXN0RWxlbWVudCA9IHN0eWxlZC5saWBcbiAgd2hpdGUtc3BhY2U6IG5vd3JhcDtcbiAgJHtmb250cy5zaXplcygxMil9O1xuICBtYXJnaW46IDA7XG4gIGxpbmUtaGVpZ2h0OiAxLjU7XG4gIHBhZGRpbmc6IDA7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5gO1xuXG5jb25zdCBUYWdDb3VudGVyV3JhcHBlciA9IHN0eWxlZC5zcGFuYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmb250LXdlaWdodDogJHtmb250cy53ZWlnaHQuc2VtaWJvbGR9O1xuICAke2ZvbnRzLnNpemVzKCcxNHB4JywgJzE0cHgnKX07XG5gO1xuXG5leHBvcnQgaW50ZXJmYWNlIENvbnRlbnRJY29uUHJvcHMge1xuICBjb250ZW50VHlwZTogc3RyaW5nO1xufVxuXG5leHBvcnQgY29uc3QgU3R5bGVkQ29udGVudEljb25XcmFwcGVyID0gc3R5bGVkLnNwYW48Q29udGVudEljb25Qcm9wcz5gXG4gIHdpZHRoOiAxMDAlO1xuICBhc3BlY3QtcmF0aW86IDQvMztcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG4gIGJhY2tncm91bmQtY29sb3I6ICR7KHsgY29udGVudFR5cGUgfSkgPT4gcmVzb3VyY2VUeXBlQ29sb3IoY29udGVudFR5cGUpfTtcbmA7XG5cbmludGVyZmFjZSBUYWdMaXN0UHJvcHMge1xuICB0YWdzPzogc3RyaW5nW107XG4gIHRhZ0xpbmtQcmVmaXg/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTG9hZGVyUHJvcHMge1xuICBsb2FkaW5nPzogYm9vbGVhbjtcbiAgY2hpbGRyZW4/OiBSZWFjdE5vZGU7XG59XG5cbmV4cG9ydCBjb25zdCBUYWdMaXN0ID0gKHsgdGFncywgdGFnTGlua1ByZWZpeCB9OiBUYWdMaXN0UHJvcHMpID0+IHtcbiAgY29uc3QgeyB0IH0gPSB1c2VUcmFuc2xhdGlvbigpO1xuICBpZiAoIXRhZ3MpIHJldHVybiBudWxsO1xuICByZXR1cm4gKFxuICAgIDxTdHlsZWRUYWdMaXN0IGFyaWEtbGFiZWw9e3QoJ215TmRsYS50YWdMaXN0Jyl9PlxuICAgICAge3RhZ3MubWFwKCh0YWcsIGkpID0+IChcbiAgICAgICAgPFN0eWxlZFRhZ0xpc3RFbGVtZW50IGtleT17YHRhZy0ke2l9YH0+XG4gICAgICAgICAgPFN0eWxlZFNhZmVMaW5rIHRvPXtgJHt0YWdMaW5rUHJlZml4ID8gdGFnTGlua1ByZWZpeCA6ICcnfS8ke2VuY29kZVVSSUNvbXBvbmVudCh0YWcpfWB9PlxuICAgICAgICAgICAgPEhhc2hUYWcgLz5cbiAgICAgICAgICAgIHt0YWd9XG4gICAgICAgICAgPC9TdHlsZWRTYWZlTGluaz5cbiAgICAgICAgPC9TdHlsZWRUYWdMaXN0RWxlbWVudD5cbiAgICAgICkpfVxuICAgIDwvU3R5bGVkVGFnTGlzdD5cbiAgKTtcbn07XG5cbmludGVyZmFjZSBDb21wcmVzc2VkVGFnTGlzdFByb3BzIHtcbiAgdGFnczogc3RyaW5nW107XG4gIHRhZ0xpbmtQcmVmaXg/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBjb25zdCBDb21wcmVzc2VkVGFnTGlzdCA9ICh7IHRhZ3MsIHRhZ0xpbmtQcmVmaXggfTogQ29tcHJlc3NlZFRhZ0xpc3RQcm9wcykgPT4ge1xuICBjb25zdCBuYXZpZ2F0ZSA9IHVzZU5hdmlnYXRlKCk7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcbiAgY29uc3QgdmlzaWJsZVRhZ3MgPSB0YWdzLnNsaWNlKDAsIDMpO1xuICBjb25zdCByZW1haW5pbmdUYWdzID0gdGFncy5zbGljZSgzLCB0YWdzLmxlbmd0aCkubWFwKCh0YWcpID0+IHtcbiAgICByZXR1cm4ge1xuICAgICAgaWNvbjogPEhhc2hUYWcgLz4sXG4gICAgICB0ZXh0OiB0YWcsXG4gICAgICBvbkNsaWNrOiAoKSA9PiB7XG4gICAgICAgIG5hdmlnYXRlKGAke3RhZ0xpbmtQcmVmaXggPyB0YWdMaW5rUHJlZml4IDogJyd9LyR7ZW5jb2RlVVJJQ29tcG9uZW50KHRhZyl9YCk7XG4gICAgICB9LFxuICAgIH07XG4gIH0pO1xuICByZXR1cm4gKFxuICAgIDw+XG4gICAgICA8VGFnTGlzdCB0YWdMaW5rUHJlZml4PXt0YWdMaW5rUHJlZml4fSB0YWdzPXt2aXNpYmxlVGFnc30gLz5cbiAgICAgIHtyZW1haW5pbmdUYWdzLmxlbmd0aCA+IDAgJiYgKFxuICAgICAgICA8TWVudUJ1dHRvblxuICAgICAgICAgIHNpemU9XCJzbWFsbFwiXG4gICAgICAgICAgbWVudUljb249ezxUYWdDb3VudGVyV3JhcHBlcj57YCske3JlbWFpbmluZ1RhZ3MubGVuZ3RofWB9PC9UYWdDb3VudGVyV3JhcHBlcj59XG4gICAgICAgICAgbWVudUl0ZW1zPXtyZW1haW5pbmdUYWdzfVxuICAgICAgICAgIGFsaWduPVwiZW5kXCJcbiAgICAgICAgICBhcmlhLWxhYmVsPXt0KCdteU5kbGEubW9yZVRhZ3MnLCB7IGNvdW50OiByZW1haW5pbmdUYWdzLmxlbmd0aCB9KX1cbiAgICAgICAgLz5cbiAgICAgICl9XG4gICAgPC8+XG4gICk7XG59O1xuXG5pbnRlcmZhY2UgUmVzb3VyY2VUeXBlTGlzdFByb3BzIHtcbiAgcmVzb3VyY2VUeXBlcz86IHsgaWQ6IHN0cmluZzsgbmFtZTogc3RyaW5nIH1bXTtcbn1cblxuZXhwb3J0IGNvbnN0IFJlc291cmNlVHlwZUxpc3QgPSAoeyByZXNvdXJjZVR5cGVzIH06IFJlc291cmNlVHlwZUxpc3RQcm9wcykgPT4ge1xuICBjb25zdCB7IHQgfSA9IHVzZVRyYW5zbGF0aW9uKCk7XG4gIGlmICghcmVzb3VyY2VUeXBlcykgcmV0dXJuIG51bGw7XG4gIHJldHVybiAoXG4gICAgPFN0eWxlZFJlc291cmNlVHlwZUxpc3QgYXJpYS1sYWJlbD17dCgnbmF2aWdhdGlvbi50b3BpY3MnKX0+XG4gICAgICB7cmVzb3VyY2VUeXBlcy5tYXAoKHJlc291cmNlLCBpKSA9PiAoXG4gICAgICAgIDxTdHlsZWRSZXNvdXJjZUxpc3RFbGVtZW50IGtleT17cmVzb3VyY2UuaWR9PlxuICAgICAgICAgIHtyZXNvdXJjZUVtYmVkVHlwZU1hcHBpbmdbcmVzb3VyY2UuaWRdXG4gICAgICAgICAgICA/IHQoYGVtYmVkLnR5cGUuJHtyZXNvdXJjZUVtYmVkVHlwZU1hcHBpbmdbcmVzb3VyY2UuaWRdfWApXG4gICAgICAgICAgICA6IHJlc291cmNlLm5hbWV9XG4gICAgICAgICAge2kgIT09IHJlc291cmNlVHlwZXMubGVuZ3RoIC0gMSAmJiA8U3R5bGVkVG9waWNEaXZpZGVyIGFyaWEtaGlkZGVuPVwidHJ1ZVwiPuKAojwvU3R5bGVkVG9waWNEaXZpZGVyPn1cbiAgICAgICAgPC9TdHlsZWRSZXNvdXJjZUxpc3RFbGVtZW50PlxuICAgICAgKSl9XG4gICAgPC9TdHlsZWRSZXNvdXJjZVR5cGVMaXN0PlxuICApO1xufTtcbiJdfQ== */"));
27
- export var ResourceTitle = /*#__PURE__*/_styled("span", {
28
34
  target: "e1lrrm6s8",
29
- label: "ResourceTitle"
30
- })("margin:0;overflow:hidden;text-overflow:ellipsis;font-weight:", fonts.weight.bold, ";line-height:1;display:-webkit-box;-webkit-line-clamp:1;line-clamp:1;-webkit-box-orient:vertical;grid-area:resourceTitle;", fonts.sizes('16px', '20px'), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInJlc291cmNlQ29tcG9uZW50cy50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBdUN3QyIsImZpbGUiOiJyZXNvdXJjZUNvbXBvbmVudHMudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjItcHJlc2VudCwgTkRMQS5cbiAqXG4gKiBUaGlzIHNvdXJjZSBjb2RlIGlzIGxpY2Vuc2VkIHVuZGVyIHRoZSBHUEx2MyBsaWNlbnNlIGZvdW5kIGluIHRoZVxuICogTElDRU5TRSBmaWxlIGluIHRoZSByb290IGRpcmVjdG9yeSBvZiB0aGlzIHNvdXJjZSB0cmVlLlxuICpcbiAqL1xuXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBjb2xvcnMsIGZvbnRzLCBzcGFjaW5nIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgUmVhY3QsIHsgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgdXNlVHJhbnNsYXRpb24gfSBmcm9tICdyZWFjdC1pMThuZXh0JztcbmltcG9ydCB7IE1lbnVCdXR0b24gfSBmcm9tICdAbmRsYS9idXR0b24nO1xuaW1wb3J0IFNhZmVMaW5rIGZyb20gJ0BuZGxhL3NhZmVsaW5rJztcbmltcG9ydCB7IHVzZU5hdmlnYXRlIH0gZnJvbSAncmVhY3Qtcm91dGVyLWRvbSc7XG5pbXBvcnQgeyBIYXNoVGFnIH0gZnJvbSAnQG5kbGEvaWNvbnMvY29tbW9uJztcbmltcG9ydCByZXNvdXJjZVR5cGVDb2xvciBmcm9tICcuLi91dGlscy9yZXNvdXJjZVR5cGVDb2xvcic7XG5pbXBvcnQgeyByZXNvdXJjZUVtYmVkVHlwZU1hcHBpbmcgfSBmcm9tICcuLi9tb2RlbC9Db250ZW50VHlwZSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgUmVzb3VyY2VJbWFnZVByb3BzIHtcbiAgYWx0OiBzdHJpbmc7XG4gIHNyYzogc3RyaW5nO1xufVxuXG5leHBvcnQgY29uc3QgUmVzb3VyY2VUaXRsZUxpbmsgPSBzdHlsZWQoU2FmZUxpbmspYFxuICBib3gtc2hhZG93OiBub25lO1xuICBjb2xvcjogJHtjb2xvcnMuYnJhbmQucHJpbWFyeX07XG4gIGZsZXg6IDE7XG4gIDphZnRlciB7XG4gICAgY29udGVudDogJyc7XG4gICAgcG9zaXRpb246IGFic29sdXRlO1xuICAgIHotaW5kZXg6IDE7XG4gICAgdG9wOiAwO1xuICAgIHJpZ2h0OiAwO1xuICAgIGJvdHRvbTogMDtcbiAgICBsZWZ0OiAwO1xuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgUmVzb3VyY2VUaXRsZSA9IHN0eWxlZC5zcGFuYFxuICBtYXJnaW46IDA7XG4gIG92ZXJmbG93OiBoaWRkZW47XG4gIHRleHQtb3ZlcmZsb3c6IGVsbGlwc2lzO1xuICBmb250LXdlaWdodDogJHtmb250cy53ZWlnaHQuYm9sZH07XG4gIC8vIFVuZm9ydHVuYXRlIGNzcyBuZWVkZWQgZm9yIG11bHRpLWxpbmUgdGV4dCBvdmVyZmxvdyBlbGxpcHNpcy5cbiAgbGluZS1oZWlnaHQ6IDE7XG4gIGRpc3BsYXk6IC13ZWJraXQtYm94O1xuICAtd2Via2l0LWxpbmUtY2xhbXA6IDE7XG4gIGxpbmUtY2xhbXA6IDE7XG4gIC13ZWJraXQtYm94LW9yaWVudDogdmVydGljYWw7XG4gIGdyaWQtYXJlYTogcmVzb3VyY2VUaXRsZTtcbiAgJHtmb250cy5zaXplcygnMTZweCcsICcyMHB4Jyl9O1xuYDtcblxuY29uc3QgU3R5bGVkVGFnTGlzdCA9IHN0eWxlZC51bGBcbiAgbGlzdC1zdHlsZTogbm9uZTtcbiAgZGlzcGxheTogZmxleDtcbiAgbWFyZ2luOiAwO1xuICBtYXJnaW4tbGVmdDogJHtzcGFjaW5nLnNtYWxsfTtcbiAgcGFkZGluZzogMnB4O1xuICBnYXA6ICR7c3BhY2luZy54c21hbGx9O1xuICBvdmVyZmxvdzogaGlkZGVuO1xuICA6bGFzdC1jaGlsZCB7XG4gICAgbWFyZ2luLXJpZ2h0OiAke3NwYWNpbmcuc21hbGx9O1xuICB9XG5gO1xuXG5jb25zdCBTdHlsZWRUYWdMaXN0RWxlbWVudCA9IHN0eWxlZC5saWBcbiAgbWFyZ2luOiAwO1xuICAke2ZvbnRzLnNpemVzKDE0KX07XG5gO1xuXG5jb25zdCBTdHlsZWRTYWZlTGluayA9IHN0eWxlZChTYWZlTGluaylgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGp1c3RpZnktY29udGVudDogZmxleC1lbmQ7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGJveC1zaGFkb3c6IG5vbmU7XG4gIGNvbG9yOiAke2NvbG9ycy5icmFuZC5ncmV5fTtcbiAgbWluLWhlaWdodDogNDRweDtcbiAgbWluLXdpZHRoOiA0NHB4O1xuICB3aGl0ZS1zcGFjZTogbm93cmFwO1xuICAmOmhvdmVyIHtcbiAgICBjb2xvcjogJHtjb2xvcnMuYnJhbmQucHJpbWFyeX07XG4gIH1cbmA7XG5cbmNvbnN0IFN0eWxlZFJlc291cmNlVHlwZUxpc3QgPSBzdHlsZWQudWxgXG4gIGxpc3Qtc3R5bGU6IG5vbmU7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIG1hcmdpbjogMDtcbiAgcGFkZGluZzogMDtcbiAgb3ZlcmZsb3c6IGhpZGRlbjtcbmA7XG5cbmNvbnN0IFN0eWxlZFRvcGljRGl2aWRlciA9IHN0eWxlZC5zcGFuYFxuICBtYXJnaW46IDA7XG4gIHBhZGRpbmc6IDAgJHtzcGFjaW5nLnh4c21hbGx9O1xuYDtcblxuY29uc3QgU3R5bGVkUmVzb3VyY2VMaXN0RWxlbWVudCA9IHN0eWxlZC5saWBcbiAgd2hpdGUtc3BhY2U6IG5vd3JhcDtcbiAgJHtmb250cy5zaXplcygxMil9O1xuICBtYXJnaW46IDA7XG4gIGxpbmUtaGVpZ2h0OiAxLjU7XG4gIHBhZGRpbmc6IDA7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5gO1xuXG5jb25zdCBUYWdDb3VudGVyV3JhcHBlciA9IHN0eWxlZC5zcGFuYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmb250LXdlaWdodDogJHtmb250cy53ZWlnaHQuc2VtaWJvbGR9O1xuICAke2ZvbnRzLnNpemVzKCcxNHB4JywgJzE0cHgnKX07XG5gO1xuXG5leHBvcnQgaW50ZXJmYWNlIENvbnRlbnRJY29uUHJvcHMge1xuICBjb250ZW50VHlwZTogc3RyaW5nO1xufVxuXG5leHBvcnQgY29uc3QgU3R5bGVkQ29udGVudEljb25XcmFwcGVyID0gc3R5bGVkLnNwYW48Q29udGVudEljb25Qcm9wcz5gXG4gIHdpZHRoOiAxMDAlO1xuICBhc3BlY3QtcmF0aW86IDQvMztcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG4gIGJhY2tncm91bmQtY29sb3I6ICR7KHsgY29udGVudFR5cGUgfSkgPT4gcmVzb3VyY2VUeXBlQ29sb3IoY29udGVudFR5cGUpfTtcbmA7XG5cbmludGVyZmFjZSBUYWdMaXN0UHJvcHMge1xuICB0YWdzPzogc3RyaW5nW107XG4gIHRhZ0xpbmtQcmVmaXg/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTG9hZGVyUHJvcHMge1xuICBsb2FkaW5nPzogYm9vbGVhbjtcbiAgY2hpbGRyZW4/OiBSZWFjdE5vZGU7XG59XG5cbmV4cG9ydCBjb25zdCBUYWdMaXN0ID0gKHsgdGFncywgdGFnTGlua1ByZWZpeCB9OiBUYWdMaXN0UHJvcHMpID0+IHtcbiAgY29uc3QgeyB0IH0gPSB1c2VUcmFuc2xhdGlvbigpO1xuICBpZiAoIXRhZ3MpIHJldHVybiBudWxsO1xuICByZXR1cm4gKFxuICAgIDxTdHlsZWRUYWdMaXN0IGFyaWEtbGFiZWw9e3QoJ215TmRsYS50YWdMaXN0Jyl9PlxuICAgICAge3RhZ3MubWFwKCh0YWcsIGkpID0+IChcbiAgICAgICAgPFN0eWxlZFRhZ0xpc3RFbGVtZW50IGtleT17YHRhZy0ke2l9YH0+XG4gICAgICAgICAgPFN0eWxlZFNhZmVMaW5rIHRvPXtgJHt0YWdMaW5rUHJlZml4ID8gdGFnTGlua1ByZWZpeCA6ICcnfS8ke2VuY29kZVVSSUNvbXBvbmVudCh0YWcpfWB9PlxuICAgICAgICAgICAgPEhhc2hUYWcgLz5cbiAgICAgICAgICAgIHt0YWd9XG4gICAgICAgICAgPC9TdHlsZWRTYWZlTGluaz5cbiAgICAgICAgPC9TdHlsZWRUYWdMaXN0RWxlbWVudD5cbiAgICAgICkpfVxuICAgIDwvU3R5bGVkVGFnTGlzdD5cbiAgKTtcbn07XG5cbmludGVyZmFjZSBDb21wcmVzc2VkVGFnTGlzdFByb3BzIHtcbiAgdGFnczogc3RyaW5nW107XG4gIHRhZ0xpbmtQcmVmaXg/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBjb25zdCBDb21wcmVzc2VkVGFnTGlzdCA9ICh7IHRhZ3MsIHRhZ0xpbmtQcmVmaXggfTogQ29tcHJlc3NlZFRhZ0xpc3RQcm9wcykgPT4ge1xuICBjb25zdCBuYXZpZ2F0ZSA9IHVzZU5hdmlnYXRlKCk7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcbiAgY29uc3QgdmlzaWJsZVRhZ3MgPSB0YWdzLnNsaWNlKDAsIDMpO1xuICBjb25zdCByZW1haW5pbmdUYWdzID0gdGFncy5zbGljZSgzLCB0YWdzLmxlbmd0aCkubWFwKCh0YWcpID0+IHtcbiAgICByZXR1cm4ge1xuICAgICAgaWNvbjogPEhhc2hUYWcgLz4sXG4gICAgICB0ZXh0OiB0YWcsXG4gICAgICBvbkNsaWNrOiAoKSA9PiB7XG4gICAgICAgIG5hdmlnYXRlKGAke3RhZ0xpbmtQcmVmaXggPyB0YWdMaW5rUHJlZml4IDogJyd9LyR7ZW5jb2RlVVJJQ29tcG9uZW50KHRhZyl9YCk7XG4gICAgICB9LFxuICAgIH07XG4gIH0pO1xuICByZXR1cm4gKFxuICAgIDw+XG4gICAgICA8VGFnTGlzdCB0YWdMaW5rUHJlZml4PXt0YWdMaW5rUHJlZml4fSB0YWdzPXt2aXNpYmxlVGFnc30gLz5cbiAgICAgIHtyZW1haW5pbmdUYWdzLmxlbmd0aCA+IDAgJiYgKFxuICAgICAgICA8TWVudUJ1dHRvblxuICAgICAgICAgIHNpemU9XCJzbWFsbFwiXG4gICAgICAgICAgbWVudUljb249ezxUYWdDb3VudGVyV3JhcHBlcj57YCske3JlbWFpbmluZ1RhZ3MubGVuZ3RofWB9PC9UYWdDb3VudGVyV3JhcHBlcj59XG4gICAgICAgICAgbWVudUl0ZW1zPXtyZW1haW5pbmdUYWdzfVxuICAgICAgICAgIGFsaWduPVwiZW5kXCJcbiAgICAgICAgICBhcmlhLWxhYmVsPXt0KCdteU5kbGEubW9yZVRhZ3MnLCB7IGNvdW50OiByZW1haW5pbmdUYWdzLmxlbmd0aCB9KX1cbiAgICAgICAgLz5cbiAgICAgICl9XG4gICAgPC8+XG4gICk7XG59O1xuXG5pbnRlcmZhY2UgUmVzb3VyY2VUeXBlTGlzdFByb3BzIHtcbiAgcmVzb3VyY2VUeXBlcz86IHsgaWQ6IHN0cmluZzsgbmFtZTogc3RyaW5nIH1bXTtcbn1cblxuZXhwb3J0IGNvbnN0IFJlc291cmNlVHlwZUxpc3QgPSAoeyByZXNvdXJjZVR5cGVzIH06IFJlc291cmNlVHlwZUxpc3RQcm9wcykgPT4ge1xuICBjb25zdCB7IHQgfSA9IHVzZVRyYW5zbGF0aW9uKCk7XG4gIGlmICghcmVzb3VyY2VUeXBlcykgcmV0dXJuIG51bGw7XG4gIHJldHVybiAoXG4gICAgPFN0eWxlZFJlc291cmNlVHlwZUxpc3QgYXJpYS1sYWJlbD17dCgnbmF2aWdhdGlvbi50b3BpY3MnKX0+XG4gICAgICB7cmVzb3VyY2VUeXBlcy5tYXAoKHJlc291cmNlLCBpKSA9PiAoXG4gICAgICAgIDxTdHlsZWRSZXNvdXJjZUxpc3RFbGVtZW50IGtleT17cmVzb3VyY2UuaWR9PlxuICAgICAgICAgIHtyZXNvdXJjZUVtYmVkVHlwZU1hcHBpbmdbcmVzb3VyY2UuaWRdXG4gICAgICAgICAgICA/IHQoYGVtYmVkLnR5cGUuJHtyZXNvdXJjZUVtYmVkVHlwZU1hcHBpbmdbcmVzb3VyY2UuaWRdfWApXG4gICAgICAgICAgICA6IHJlc291cmNlLm5hbWV9XG4gICAgICAgICAge2kgIT09IHJlc291cmNlVHlwZXMubGVuZ3RoIC0gMSAmJiA8U3R5bGVkVG9waWNEaXZpZGVyIGFyaWEtaGlkZGVuPVwidHJ1ZVwiPuKAojwvU3R5bGVkVG9waWNEaXZpZGVyPn1cbiAgICAgICAgPC9TdHlsZWRSZXNvdXJjZUxpc3RFbGVtZW50PlxuICAgICAgKSl9XG4gICAgPC9TdHlsZWRSZXNvdXJjZVR5cGVMaXN0PlxuICApO1xufTtcbiJdfQ== */"));
35
+ label: "ResourceTitleLink"
36
+ })("box-shadow:none;color:", colors.brand.primary, ";flex:1;:after{content:'';position:absolute;z-index:1;top:0;right:0;bottom:0;left:0;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["resourceComponents.tsx"],"names":[],"mappings":"AAyBiD","file":"resourceComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2022-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 styled from '@emotion/styled';\nimport { colors, fonts, spacing } from '@ndla/core';\nimport React, { CSSProperties, HTMLAttributes, ReactNode, useMemo } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { MenuButton } from '@ndla/button';\nimport SafeLink from '@ndla/safelink';\nimport { useNavigate } from 'react-router-dom';\nimport { HashTag } from '@ndla/icons/common';\nimport { css } from '@emotion/react';\nimport resourceTypeColor from '../utils/resourceTypeColor';\nimport { resourceEmbedTypeMapping } from '../model/ContentType';\n\nexport interface ResourceImageProps {\n  alt: string;\n  src: string;\n}\n\nexport const ResourceTitleLink = styled(SafeLink)`\n  box-shadow: none;\n  color: ${colors.brand.primary};\n  flex: 1;\n  :after {\n    content: '';\n    position: absolute;\n    z-index: 1;\n    top: 0;\n    right: 0;\n    bottom: 0;\n    left: 0;\n  }\n`;\n\nexport const resourceHeadingStyle = css`\n  margin: 0;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  font-weight: ${fonts.weight.bold};\n  // Unfortunate css needed for multi-line text overflow ellipsis.\n  line-height: 1;\n  display: -webkit-box;\n  -webkit-line-clamp: 1;\n  line-clamp: 1;\n  -webkit-box-orient: vertical;\n  grid-area: resourceTitle;\n  ${fonts.sizes('16px', '20px')};\n`;\n\nconst StyledTagList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  margin-left: ${spacing.small};\n  padding: 2px;\n  gap: ${spacing.xsmall};\n  overflow: hidden;\n  :last-child {\n    margin-right: ${spacing.small};\n  }\n`;\n\nconst StyledTagListElement = styled.li`\n  margin: 0;\n  ${fonts.sizes(14)};\n`;\n\nconst StyledSafeLink = styled(SafeLink)`\n  display: flex;\n  justify-content: flex-end;\n  align-items: center;\n  box-shadow: none;\n  color: ${colors.brand.grey};\n  min-height: 44px;\n  min-width: 44px;\n  white-space: nowrap;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n`;\n\nconst StyledResourceTypeList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  padding: 0;\n  overflow: hidden;\n`;\n\nconst StyledTopicDivider = styled.span`\n  margin: 0;\n  padding: 0 ${spacing.xxsmall};\n`;\n\nconst StyledResourceListElement = styled.li`\n  white-space: nowrap;\n  ${fonts.sizes(12)};\n  margin: 0;\n  line-height: 1.5;\n  padding: 0;\n  display: flex;\n  align-items: center;\n`;\n\nconst TagCounterWrapper = styled.span`\n  display: flex;\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('14px', '14px')};\n`;\n\ninterface ContentIconProps extends HTMLAttributes<HTMLSpanElement> {\n  contentType: string;\n  children?: ReactNode;\n}\n\nconst StyledContentIconWrapper = styled.span`\n  width: 100%;\n  aspect-ratio: 4/3;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  background-color: var(--content-background-color);\n`;\n\nexport const ContentIconWrapper = ({ contentType, children, ...props }: ContentIconProps) => {\n  const contentIconWrapperVars = useMemo(\n    () => ({ '--content-background-color': resourceTypeColor(contentType) } as unknown as CSSProperties),\n    [contentType],\n  );\n  return (\n    <StyledContentIconWrapper {...props} style={contentIconWrapperVars}>\n      {children}\n    </StyledContentIconWrapper>\n  );\n};\n\ninterface TagListProps {\n  tags?: string[];\n  tagLinkPrefix?: string;\n}\n\nexport interface LoaderProps {\n  loading?: boolean;\n  children?: ReactNode;\n}\n\nexport const TagList = ({ tags, tagLinkPrefix }: TagListProps) => {\n  const { t } = useTranslation();\n  if (!tags) return null;\n  return (\n    <StyledTagList aria-label={t('myNdla.tagList')}>\n      {tags.map((tag, i) => (\n        <StyledTagListElement key={`tag-${i}`}>\n          <StyledSafeLink to={`${tagLinkPrefix ? tagLinkPrefix : ''}/${encodeURIComponent(tag)}`}>\n            <HashTag />\n            {tag}\n          </StyledSafeLink>\n        </StyledTagListElement>\n      ))}\n    </StyledTagList>\n  );\n};\n\ninterface CompressedTagListProps {\n  tags: string[];\n  tagLinkPrefix?: string;\n}\n\nexport const CompressedTagList = ({ tags, tagLinkPrefix }: CompressedTagListProps) => {\n  const navigate = useNavigate();\n  const { t } = useTranslation();\n  const visibleTags = useMemo(() => tags.slice(0, 3), [tags]);\n  const remainingTags = useMemo(\n    () =>\n      tags.slice(3, tags.length).map((tag) => {\n        return {\n          icon: <HashTag />,\n          text: tag,\n          onClick: () => {\n            navigate(`${tagLinkPrefix ? tagLinkPrefix : ''}/${encodeURIComponent(tag)}`);\n          },\n        };\n      }),\n    [navigate, tagLinkPrefix, tags],\n  );\n\n  return (\n    <>\n      <TagList tagLinkPrefix={tagLinkPrefix} tags={visibleTags} />\n      {remainingTags.length > 0 && (\n        <MenuButton\n          size=\"small\"\n          menuIcon={<TagCounterWrapper>{`+${remainingTags.length}`}</TagCounterWrapper>}\n          menuItems={remainingTags}\n          align=\"end\"\n          aria-label={t('myNdla.moreTags', { count: remainingTags.length })}\n        />\n      )}\n    </>\n  );\n};\n\ninterface ResourceTypeListProps {\n  resourceTypes?: { id: string; name: string }[];\n}\n\nexport const ResourceTypeList = ({ resourceTypes }: ResourceTypeListProps) => {\n  const { t } = useTranslation();\n  if (!resourceTypes) return null;\n  return (\n    <StyledResourceTypeList aria-label={t('navigation.topics')}>\n      {resourceTypes.map((resource, i) => (\n        <StyledResourceListElement key={resource.id}>\n          {resourceEmbedTypeMapping[resource.id]\n            ? t(`embed.type.${resourceEmbedTypeMapping[resource.id]}`)\n            : resource.name}\n          {i !== resourceTypes.length - 1 && <StyledTopicDivider aria-hidden=\"true\">•</StyledTopicDivider>}\n        </StyledResourceListElement>\n      ))}\n    </StyledResourceTypeList>\n  );\n};\n"]} */"));
37
+ export var resourceHeadingStyle = /*#__PURE__*/css("margin:0;overflow:hidden;text-overflow:ellipsis;font-weight:", fonts.weight.bold, ";line-height:1;display:-webkit-box;-webkit-line-clamp:1;line-clamp:1;-webkit-box-orient:vertical;grid-area:resourceTitle;", fonts.sizes('16px', '20px'), ";;label:resourceHeadingStyle;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["resourceComponents.tsx"],"names":[],"mappings":"AAwCuC","file":"resourceComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2022-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 styled from '@emotion/styled';\nimport { colors, fonts, spacing } from '@ndla/core';\nimport React, { CSSProperties, HTMLAttributes, ReactNode, useMemo } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { MenuButton } from '@ndla/button';\nimport SafeLink from '@ndla/safelink';\nimport { useNavigate } from 'react-router-dom';\nimport { HashTag } from '@ndla/icons/common';\nimport { css } from '@emotion/react';\nimport resourceTypeColor from '../utils/resourceTypeColor';\nimport { resourceEmbedTypeMapping } from '../model/ContentType';\n\nexport interface ResourceImageProps {\n  alt: string;\n  src: string;\n}\n\nexport const ResourceTitleLink = styled(SafeLink)`\n  box-shadow: none;\n  color: ${colors.brand.primary};\n  flex: 1;\n  :after {\n    content: '';\n    position: absolute;\n    z-index: 1;\n    top: 0;\n    right: 0;\n    bottom: 0;\n    left: 0;\n  }\n`;\n\nexport const resourceHeadingStyle = css`\n  margin: 0;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  font-weight: ${fonts.weight.bold};\n  // Unfortunate css needed for multi-line text overflow ellipsis.\n  line-height: 1;\n  display: -webkit-box;\n  -webkit-line-clamp: 1;\n  line-clamp: 1;\n  -webkit-box-orient: vertical;\n  grid-area: resourceTitle;\n  ${fonts.sizes('16px', '20px')};\n`;\n\nconst StyledTagList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  margin-left: ${spacing.small};\n  padding: 2px;\n  gap: ${spacing.xsmall};\n  overflow: hidden;\n  :last-child {\n    margin-right: ${spacing.small};\n  }\n`;\n\nconst StyledTagListElement = styled.li`\n  margin: 0;\n  ${fonts.sizes(14)};\n`;\n\nconst StyledSafeLink = styled(SafeLink)`\n  display: flex;\n  justify-content: flex-end;\n  align-items: center;\n  box-shadow: none;\n  color: ${colors.brand.grey};\n  min-height: 44px;\n  min-width: 44px;\n  white-space: nowrap;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n`;\n\nconst StyledResourceTypeList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  padding: 0;\n  overflow: hidden;\n`;\n\nconst StyledTopicDivider = styled.span`\n  margin: 0;\n  padding: 0 ${spacing.xxsmall};\n`;\n\nconst StyledResourceListElement = styled.li`\n  white-space: nowrap;\n  ${fonts.sizes(12)};\n  margin: 0;\n  line-height: 1.5;\n  padding: 0;\n  display: flex;\n  align-items: center;\n`;\n\nconst TagCounterWrapper = styled.span`\n  display: flex;\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('14px', '14px')};\n`;\n\ninterface ContentIconProps extends HTMLAttributes<HTMLSpanElement> {\n  contentType: string;\n  children?: ReactNode;\n}\n\nconst StyledContentIconWrapper = styled.span`\n  width: 100%;\n  aspect-ratio: 4/3;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  background-color: var(--content-background-color);\n`;\n\nexport const ContentIconWrapper = ({ contentType, children, ...props }: ContentIconProps) => {\n  const contentIconWrapperVars = useMemo(\n    () => ({ '--content-background-color': resourceTypeColor(contentType) } as unknown as CSSProperties),\n    [contentType],\n  );\n  return (\n    <StyledContentIconWrapper {...props} style={contentIconWrapperVars}>\n      {children}\n    </StyledContentIconWrapper>\n  );\n};\n\ninterface TagListProps {\n  tags?: string[];\n  tagLinkPrefix?: string;\n}\n\nexport interface LoaderProps {\n  loading?: boolean;\n  children?: ReactNode;\n}\n\nexport const TagList = ({ tags, tagLinkPrefix }: TagListProps) => {\n  const { t } = useTranslation();\n  if (!tags) return null;\n  return (\n    <StyledTagList aria-label={t('myNdla.tagList')}>\n      {tags.map((tag, i) => (\n        <StyledTagListElement key={`tag-${i}`}>\n          <StyledSafeLink to={`${tagLinkPrefix ? tagLinkPrefix : ''}/${encodeURIComponent(tag)}`}>\n            <HashTag />\n            {tag}\n          </StyledSafeLink>\n        </StyledTagListElement>\n      ))}\n    </StyledTagList>\n  );\n};\n\ninterface CompressedTagListProps {\n  tags: string[];\n  tagLinkPrefix?: string;\n}\n\nexport const CompressedTagList = ({ tags, tagLinkPrefix }: CompressedTagListProps) => {\n  const navigate = useNavigate();\n  const { t } = useTranslation();\n  const visibleTags = useMemo(() => tags.slice(0, 3), [tags]);\n  const remainingTags = useMemo(\n    () =>\n      tags.slice(3, tags.length).map((tag) => {\n        return {\n          icon: <HashTag />,\n          text: tag,\n          onClick: () => {\n            navigate(`${tagLinkPrefix ? tagLinkPrefix : ''}/${encodeURIComponent(tag)}`);\n          },\n        };\n      }),\n    [navigate, tagLinkPrefix, tags],\n  );\n\n  return (\n    <>\n      <TagList tagLinkPrefix={tagLinkPrefix} tags={visibleTags} />\n      {remainingTags.length > 0 && (\n        <MenuButton\n          size=\"small\"\n          menuIcon={<TagCounterWrapper>{`+${remainingTags.length}`}</TagCounterWrapper>}\n          menuItems={remainingTags}\n          align=\"end\"\n          aria-label={t('myNdla.moreTags', { count: remainingTags.length })}\n        />\n      )}\n    </>\n  );\n};\n\ninterface ResourceTypeListProps {\n  resourceTypes?: { id: string; name: string }[];\n}\n\nexport const ResourceTypeList = ({ resourceTypes }: ResourceTypeListProps) => {\n  const { t } = useTranslation();\n  if (!resourceTypes) return null;\n  return (\n    <StyledResourceTypeList aria-label={t('navigation.topics')}>\n      {resourceTypes.map((resource, i) => (\n        <StyledResourceListElement key={resource.id}>\n          {resourceEmbedTypeMapping[resource.id]\n            ? t(`embed.type.${resourceEmbedTypeMapping[resource.id]}`)\n            : resource.name}\n          {i !== resourceTypes.length - 1 && <StyledTopicDivider aria-hidden=\"true\">•</StyledTopicDivider>}\n        </StyledResourceListElement>\n      ))}\n    </StyledResourceTypeList>\n  );\n};\n"]} */"));
31
38
  var StyledTagList = /*#__PURE__*/_styled("ul", {
32
39
  target: "e1lrrm6s7",
33
40
  label: "StyledTagList"
34
- })("list-style:none;display:flex;margin:0;margin-left:", spacing.small, ";padding:2px;gap:", spacing.xsmall, ";overflow:hidden;:last-child{margin-right:", spacing.small, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInJlc291cmNlQ29tcG9uZW50cy50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBc0QrQiIsImZpbGUiOiJyZXNvdXJjZUNvbXBvbmVudHMudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjItcHJlc2VudCwgTkRMQS5cbiAqXG4gKiBUaGlzIHNvdXJjZSBjb2RlIGlzIGxpY2Vuc2VkIHVuZGVyIHRoZSBHUEx2MyBsaWNlbnNlIGZvdW5kIGluIHRoZVxuICogTElDRU5TRSBmaWxlIGluIHRoZSByb290IGRpcmVjdG9yeSBvZiB0aGlzIHNvdXJjZSB0cmVlLlxuICpcbiAqL1xuXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBjb2xvcnMsIGZvbnRzLCBzcGFjaW5nIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgUmVhY3QsIHsgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgdXNlVHJhbnNsYXRpb24gfSBmcm9tICdyZWFjdC1pMThuZXh0JztcbmltcG9ydCB7IE1lbnVCdXR0b24gfSBmcm9tICdAbmRsYS9idXR0b24nO1xuaW1wb3J0IFNhZmVMaW5rIGZyb20gJ0BuZGxhL3NhZmVsaW5rJztcbmltcG9ydCB7IHVzZU5hdmlnYXRlIH0gZnJvbSAncmVhY3Qtcm91dGVyLWRvbSc7XG5pbXBvcnQgeyBIYXNoVGFnIH0gZnJvbSAnQG5kbGEvaWNvbnMvY29tbW9uJztcbmltcG9ydCByZXNvdXJjZVR5cGVDb2xvciBmcm9tICcuLi91dGlscy9yZXNvdXJjZVR5cGVDb2xvcic7XG5pbXBvcnQgeyByZXNvdXJjZUVtYmVkVHlwZU1hcHBpbmcgfSBmcm9tICcuLi9tb2RlbC9Db250ZW50VHlwZSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgUmVzb3VyY2VJbWFnZVByb3BzIHtcbiAgYWx0OiBzdHJpbmc7XG4gIHNyYzogc3RyaW5nO1xufVxuXG5leHBvcnQgY29uc3QgUmVzb3VyY2VUaXRsZUxpbmsgPSBzdHlsZWQoU2FmZUxpbmspYFxuICBib3gtc2hhZG93OiBub25lO1xuICBjb2xvcjogJHtjb2xvcnMuYnJhbmQucHJpbWFyeX07XG4gIGZsZXg6IDE7XG4gIDphZnRlciB7XG4gICAgY29udGVudDogJyc7XG4gICAgcG9zaXRpb246IGFic29sdXRlO1xuICAgIHotaW5kZXg6IDE7XG4gICAgdG9wOiAwO1xuICAgIHJpZ2h0OiAwO1xuICAgIGJvdHRvbTogMDtcbiAgICBsZWZ0OiAwO1xuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgUmVzb3VyY2VUaXRsZSA9IHN0eWxlZC5zcGFuYFxuICBtYXJnaW46IDA7XG4gIG92ZXJmbG93OiBoaWRkZW47XG4gIHRleHQtb3ZlcmZsb3c6IGVsbGlwc2lzO1xuICBmb250LXdlaWdodDogJHtmb250cy53ZWlnaHQuYm9sZH07XG4gIC8vIFVuZm9ydHVuYXRlIGNzcyBuZWVkZWQgZm9yIG11bHRpLWxpbmUgdGV4dCBvdmVyZmxvdyBlbGxpcHNpcy5cbiAgbGluZS1oZWlnaHQ6IDE7XG4gIGRpc3BsYXk6IC13ZWJraXQtYm94O1xuICAtd2Via2l0LWxpbmUtY2xhbXA6IDE7XG4gIGxpbmUtY2xhbXA6IDE7XG4gIC13ZWJraXQtYm94LW9yaWVudDogdmVydGljYWw7XG4gIGdyaWQtYXJlYTogcmVzb3VyY2VUaXRsZTtcbiAgJHtmb250cy5zaXplcygnMTZweCcsICcyMHB4Jyl9O1xuYDtcblxuY29uc3QgU3R5bGVkVGFnTGlzdCA9IHN0eWxlZC51bGBcbiAgbGlzdC1zdHlsZTogbm9uZTtcbiAgZGlzcGxheTogZmxleDtcbiAgbWFyZ2luOiAwO1xuICBtYXJnaW4tbGVmdDogJHtzcGFjaW5nLnNtYWxsfTtcbiAgcGFkZGluZzogMnB4O1xuICBnYXA6ICR7c3BhY2luZy54c21hbGx9O1xuICBvdmVyZmxvdzogaGlkZGVuO1xuICA6bGFzdC1jaGlsZCB7XG4gICAgbWFyZ2luLXJpZ2h0OiAke3NwYWNpbmcuc21hbGx9O1xuICB9XG5gO1xuXG5jb25zdCBTdHlsZWRUYWdMaXN0RWxlbWVudCA9IHN0eWxlZC5saWBcbiAgbWFyZ2luOiAwO1xuICAke2ZvbnRzLnNpemVzKDE0KX07XG5gO1xuXG5jb25zdCBTdHlsZWRTYWZlTGluayA9IHN0eWxlZChTYWZlTGluaylgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGp1c3RpZnktY29udGVudDogZmxleC1lbmQ7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGJveC1zaGFkb3c6IG5vbmU7XG4gIGNvbG9yOiAke2NvbG9ycy5icmFuZC5ncmV5fTtcbiAgbWluLWhlaWdodDogNDRweDtcbiAgbWluLXdpZHRoOiA0NHB4O1xuICB3aGl0ZS1zcGFjZTogbm93cmFwO1xuICAmOmhvdmVyIHtcbiAgICBjb2xvcjogJHtjb2xvcnMuYnJhbmQucHJpbWFyeX07XG4gIH1cbmA7XG5cbmNvbnN0IFN0eWxlZFJlc291cmNlVHlwZUxpc3QgPSBzdHlsZWQudWxgXG4gIGxpc3Qtc3R5bGU6IG5vbmU7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIG1hcmdpbjogMDtcbiAgcGFkZGluZzogMDtcbiAgb3ZlcmZsb3c6IGhpZGRlbjtcbmA7XG5cbmNvbnN0IFN0eWxlZFRvcGljRGl2aWRlciA9IHN0eWxlZC5zcGFuYFxuICBtYXJnaW46IDA7XG4gIHBhZGRpbmc6IDAgJHtzcGFjaW5nLnh4c21hbGx9O1xuYDtcblxuY29uc3QgU3R5bGVkUmVzb3VyY2VMaXN0RWxlbWVudCA9IHN0eWxlZC5saWBcbiAgd2hpdGUtc3BhY2U6IG5vd3JhcDtcbiAgJHtmb250cy5zaXplcygxMil9O1xuICBtYXJnaW46IDA7XG4gIGxpbmUtaGVpZ2h0OiAxLjU7XG4gIHBhZGRpbmc6IDA7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5gO1xuXG5jb25zdCBUYWdDb3VudGVyV3JhcHBlciA9IHN0eWxlZC5zcGFuYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmb250LXdlaWdodDogJHtmb250cy53ZWlnaHQuc2VtaWJvbGR9O1xuICAke2ZvbnRzLnNpemVzKCcxNHB4JywgJzE0cHgnKX07XG5gO1xuXG5leHBvcnQgaW50ZXJmYWNlIENvbnRlbnRJY29uUHJvcHMge1xuICBjb250ZW50VHlwZTogc3RyaW5nO1xufVxuXG5leHBvcnQgY29uc3QgU3R5bGVkQ29udGVudEljb25XcmFwcGVyID0gc3R5bGVkLnNwYW48Q29udGVudEljb25Qcm9wcz5gXG4gIHdpZHRoOiAxMDAlO1xuICBhc3BlY3QtcmF0aW86IDQvMztcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG4gIGJhY2tncm91bmQtY29sb3I6ICR7KHsgY29udGVudFR5cGUgfSkgPT4gcmVzb3VyY2VUeXBlQ29sb3IoY29udGVudFR5cGUpfTtcbmA7XG5cbmludGVyZmFjZSBUYWdMaXN0UHJvcHMge1xuICB0YWdzPzogc3RyaW5nW107XG4gIHRhZ0xpbmtQcmVmaXg/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTG9hZGVyUHJvcHMge1xuICBsb2FkaW5nPzogYm9vbGVhbjtcbiAgY2hpbGRyZW4/OiBSZWFjdE5vZGU7XG59XG5cbmV4cG9ydCBjb25zdCBUYWdMaXN0ID0gKHsgdGFncywgdGFnTGlua1ByZWZpeCB9OiBUYWdMaXN0UHJvcHMpID0+IHtcbiAgY29uc3QgeyB0IH0gPSB1c2VUcmFuc2xhdGlvbigpO1xuICBpZiAoIXRhZ3MpIHJldHVybiBudWxsO1xuICByZXR1cm4gKFxuICAgIDxTdHlsZWRUYWdMaXN0IGFyaWEtbGFiZWw9e3QoJ215TmRsYS50YWdMaXN0Jyl9PlxuICAgICAge3RhZ3MubWFwKCh0YWcsIGkpID0+IChcbiAgICAgICAgPFN0eWxlZFRhZ0xpc3RFbGVtZW50IGtleT17YHRhZy0ke2l9YH0+XG4gICAgICAgICAgPFN0eWxlZFNhZmVMaW5rIHRvPXtgJHt0YWdMaW5rUHJlZml4ID8gdGFnTGlua1ByZWZpeCA6ICcnfS8ke2VuY29kZVVSSUNvbXBvbmVudCh0YWcpfWB9PlxuICAgICAgICAgICAgPEhhc2hUYWcgLz5cbiAgICAgICAgICAgIHt0YWd9XG4gICAgICAgICAgPC9TdHlsZWRTYWZlTGluaz5cbiAgICAgICAgPC9TdHlsZWRUYWdMaXN0RWxlbWVudD5cbiAgICAgICkpfVxuICAgIDwvU3R5bGVkVGFnTGlzdD5cbiAgKTtcbn07XG5cbmludGVyZmFjZSBDb21wcmVzc2VkVGFnTGlzdFByb3BzIHtcbiAgdGFnczogc3RyaW5nW107XG4gIHRhZ0xpbmtQcmVmaXg/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBjb25zdCBDb21wcmVzc2VkVGFnTGlzdCA9ICh7IHRhZ3MsIHRhZ0xpbmtQcmVmaXggfTogQ29tcHJlc3NlZFRhZ0xpc3RQcm9wcykgPT4ge1xuICBjb25zdCBuYXZpZ2F0ZSA9IHVzZU5hdmlnYXRlKCk7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcbiAgY29uc3QgdmlzaWJsZVRhZ3MgPSB0YWdzLnNsaWNlKDAsIDMpO1xuICBjb25zdCByZW1haW5pbmdUYWdzID0gdGFncy5zbGljZSgzLCB0YWdzLmxlbmd0aCkubWFwKCh0YWcpID0+IHtcbiAgICByZXR1cm4ge1xuICAgICAgaWNvbjogPEhhc2hUYWcgLz4sXG4gICAgICB0ZXh0OiB0YWcsXG4gICAgICBvbkNsaWNrOiAoKSA9PiB7XG4gICAgICAgIG5hdmlnYXRlKGAke3RhZ0xpbmtQcmVmaXggPyB0YWdMaW5rUHJlZml4IDogJyd9LyR7ZW5jb2RlVVJJQ29tcG9uZW50KHRhZyl9YCk7XG4gICAgICB9LFxuICAgIH07XG4gIH0pO1xuICByZXR1cm4gKFxuICAgIDw+XG4gICAgICA8VGFnTGlzdCB0YWdMaW5rUHJlZml4PXt0YWdMaW5rUHJlZml4fSB0YWdzPXt2aXNpYmxlVGFnc30gLz5cbiAgICAgIHtyZW1haW5pbmdUYWdzLmxlbmd0aCA+IDAgJiYgKFxuICAgICAgICA8TWVudUJ1dHRvblxuICAgICAgICAgIHNpemU9XCJzbWFsbFwiXG4gICAgICAgICAgbWVudUljb249ezxUYWdDb3VudGVyV3JhcHBlcj57YCske3JlbWFpbmluZ1RhZ3MubGVuZ3RofWB9PC9UYWdDb3VudGVyV3JhcHBlcj59XG4gICAgICAgICAgbWVudUl0ZW1zPXtyZW1haW5pbmdUYWdzfVxuICAgICAgICAgIGFsaWduPVwiZW5kXCJcbiAgICAgICAgICBhcmlhLWxhYmVsPXt0KCdteU5kbGEubW9yZVRhZ3MnLCB7IGNvdW50OiByZW1haW5pbmdUYWdzLmxlbmd0aCB9KX1cbiAgICAgICAgLz5cbiAgICAgICl9XG4gICAgPC8+XG4gICk7XG59O1xuXG5pbnRlcmZhY2UgUmVzb3VyY2VUeXBlTGlzdFByb3BzIHtcbiAgcmVzb3VyY2VUeXBlcz86IHsgaWQ6IHN0cmluZzsgbmFtZTogc3RyaW5nIH1bXTtcbn1cblxuZXhwb3J0IGNvbnN0IFJlc291cmNlVHlwZUxpc3QgPSAoeyByZXNvdXJjZVR5cGVzIH06IFJlc291cmNlVHlwZUxpc3RQcm9wcykgPT4ge1xuICBjb25zdCB7IHQgfSA9IHVzZVRyYW5zbGF0aW9uKCk7XG4gIGlmICghcmVzb3VyY2VUeXBlcykgcmV0dXJuIG51bGw7XG4gIHJldHVybiAoXG4gICAgPFN0eWxlZFJlc291cmNlVHlwZUxpc3QgYXJpYS1sYWJlbD17dCgnbmF2aWdhdGlvbi50b3BpY3MnKX0+XG4gICAgICB7cmVzb3VyY2VUeXBlcy5tYXAoKHJlc291cmNlLCBpKSA9PiAoXG4gICAgICAgIDxTdHlsZWRSZXNvdXJjZUxpc3RFbGVtZW50IGtleT17cmVzb3VyY2UuaWR9PlxuICAgICAgICAgIHtyZXNvdXJjZUVtYmVkVHlwZU1hcHBpbmdbcmVzb3VyY2UuaWRdXG4gICAgICAgICAgICA/IHQoYGVtYmVkLnR5cGUuJHtyZXNvdXJjZUVtYmVkVHlwZU1hcHBpbmdbcmVzb3VyY2UuaWRdfWApXG4gICAgICAgICAgICA6IHJlc291cmNlLm5hbWV9XG4gICAgICAgICAge2kgIT09IHJlc291cmNlVHlwZXMubGVuZ3RoIC0gMSAmJiA8U3R5bGVkVG9waWNEaXZpZGVyIGFyaWEtaGlkZGVuPVwidHJ1ZVwiPuKAojwvU3R5bGVkVG9waWNEaXZpZGVyPn1cbiAgICAgICAgPC9TdHlsZWRSZXNvdXJjZUxpc3RFbGVtZW50PlxuICAgICAgKSl9XG4gICAgPC9TdHlsZWRSZXNvdXJjZVR5cGVMaXN0PlxuICApO1xufTtcbiJdfQ== */"));
41
+ })("list-style:none;display:flex;margin:0;margin-left:", spacing.small, ";padding:2px;gap:", spacing.xsmall, ";overflow:hidden;:last-child{margin-right:", spacing.small, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["resourceComponents.tsx"],"names":[],"mappings":"AAuD+B","file":"resourceComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2022-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 styled from '@emotion/styled';\nimport { colors, fonts, spacing } from '@ndla/core';\nimport React, { CSSProperties, HTMLAttributes, ReactNode, useMemo } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { MenuButton } from '@ndla/button';\nimport SafeLink from '@ndla/safelink';\nimport { useNavigate } from 'react-router-dom';\nimport { HashTag } from '@ndla/icons/common';\nimport { css } from '@emotion/react';\nimport resourceTypeColor from '../utils/resourceTypeColor';\nimport { resourceEmbedTypeMapping } from '../model/ContentType';\n\nexport interface ResourceImageProps {\n  alt: string;\n  src: string;\n}\n\nexport const ResourceTitleLink = styled(SafeLink)`\n  box-shadow: none;\n  color: ${colors.brand.primary};\n  flex: 1;\n  :after {\n    content: '';\n    position: absolute;\n    z-index: 1;\n    top: 0;\n    right: 0;\n    bottom: 0;\n    left: 0;\n  }\n`;\n\nexport const resourceHeadingStyle = css`\n  margin: 0;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  font-weight: ${fonts.weight.bold};\n  // Unfortunate css needed for multi-line text overflow ellipsis.\n  line-height: 1;\n  display: -webkit-box;\n  -webkit-line-clamp: 1;\n  line-clamp: 1;\n  -webkit-box-orient: vertical;\n  grid-area: resourceTitle;\n  ${fonts.sizes('16px', '20px')};\n`;\n\nconst StyledTagList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  margin-left: ${spacing.small};\n  padding: 2px;\n  gap: ${spacing.xsmall};\n  overflow: hidden;\n  :last-child {\n    margin-right: ${spacing.small};\n  }\n`;\n\nconst StyledTagListElement = styled.li`\n  margin: 0;\n  ${fonts.sizes(14)};\n`;\n\nconst StyledSafeLink = styled(SafeLink)`\n  display: flex;\n  justify-content: flex-end;\n  align-items: center;\n  box-shadow: none;\n  color: ${colors.brand.grey};\n  min-height: 44px;\n  min-width: 44px;\n  white-space: nowrap;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n`;\n\nconst StyledResourceTypeList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  padding: 0;\n  overflow: hidden;\n`;\n\nconst StyledTopicDivider = styled.span`\n  margin: 0;\n  padding: 0 ${spacing.xxsmall};\n`;\n\nconst StyledResourceListElement = styled.li`\n  white-space: nowrap;\n  ${fonts.sizes(12)};\n  margin: 0;\n  line-height: 1.5;\n  padding: 0;\n  display: flex;\n  align-items: center;\n`;\n\nconst TagCounterWrapper = styled.span`\n  display: flex;\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('14px', '14px')};\n`;\n\ninterface ContentIconProps extends HTMLAttributes<HTMLSpanElement> {\n  contentType: string;\n  children?: ReactNode;\n}\n\nconst StyledContentIconWrapper = styled.span`\n  width: 100%;\n  aspect-ratio: 4/3;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  background-color: var(--content-background-color);\n`;\n\nexport const ContentIconWrapper = ({ contentType, children, ...props }: ContentIconProps) => {\n  const contentIconWrapperVars = useMemo(\n    () => ({ '--content-background-color': resourceTypeColor(contentType) } as unknown as CSSProperties),\n    [contentType],\n  );\n  return (\n    <StyledContentIconWrapper {...props} style={contentIconWrapperVars}>\n      {children}\n    </StyledContentIconWrapper>\n  );\n};\n\ninterface TagListProps {\n  tags?: string[];\n  tagLinkPrefix?: string;\n}\n\nexport interface LoaderProps {\n  loading?: boolean;\n  children?: ReactNode;\n}\n\nexport const TagList = ({ tags, tagLinkPrefix }: TagListProps) => {\n  const { t } = useTranslation();\n  if (!tags) return null;\n  return (\n    <StyledTagList aria-label={t('myNdla.tagList')}>\n      {tags.map((tag, i) => (\n        <StyledTagListElement key={`tag-${i}`}>\n          <StyledSafeLink to={`${tagLinkPrefix ? tagLinkPrefix : ''}/${encodeURIComponent(tag)}`}>\n            <HashTag />\n            {tag}\n          </StyledSafeLink>\n        </StyledTagListElement>\n      ))}\n    </StyledTagList>\n  );\n};\n\ninterface CompressedTagListProps {\n  tags: string[];\n  tagLinkPrefix?: string;\n}\n\nexport const CompressedTagList = ({ tags, tagLinkPrefix }: CompressedTagListProps) => {\n  const navigate = useNavigate();\n  const { t } = useTranslation();\n  const visibleTags = useMemo(() => tags.slice(0, 3), [tags]);\n  const remainingTags = useMemo(\n    () =>\n      tags.slice(3, tags.length).map((tag) => {\n        return {\n          icon: <HashTag />,\n          text: tag,\n          onClick: () => {\n            navigate(`${tagLinkPrefix ? tagLinkPrefix : ''}/${encodeURIComponent(tag)}`);\n          },\n        };\n      }),\n    [navigate, tagLinkPrefix, tags],\n  );\n\n  return (\n    <>\n      <TagList tagLinkPrefix={tagLinkPrefix} tags={visibleTags} />\n      {remainingTags.length > 0 && (\n        <MenuButton\n          size=\"small\"\n          menuIcon={<TagCounterWrapper>{`+${remainingTags.length}`}</TagCounterWrapper>}\n          menuItems={remainingTags}\n          align=\"end\"\n          aria-label={t('myNdla.moreTags', { count: remainingTags.length })}\n        />\n      )}\n    </>\n  );\n};\n\ninterface ResourceTypeListProps {\n  resourceTypes?: { id: string; name: string }[];\n}\n\nexport const ResourceTypeList = ({ resourceTypes }: ResourceTypeListProps) => {\n  const { t } = useTranslation();\n  if (!resourceTypes) return null;\n  return (\n    <StyledResourceTypeList aria-label={t('navigation.topics')}>\n      {resourceTypes.map((resource, i) => (\n        <StyledResourceListElement key={resource.id}>\n          {resourceEmbedTypeMapping[resource.id]\n            ? t(`embed.type.${resourceEmbedTypeMapping[resource.id]}`)\n            : resource.name}\n          {i !== resourceTypes.length - 1 && <StyledTopicDivider aria-hidden=\"true\">•</StyledTopicDivider>}\n        </StyledResourceListElement>\n      ))}\n    </StyledResourceTypeList>\n  );\n};\n"]} */"));
35
42
  var StyledTagListElement = /*#__PURE__*/_styled("li", {
36
43
  target: "e1lrrm6s6",
37
44
  label: "StyledTagListElement"
38
- })("margin:0;", fonts.sizes(14), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInJlc291cmNlQ29tcG9uZW50cy50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBbUVzQyIsImZpbGUiOiJyZXNvdXJjZUNvbXBvbmVudHMudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjItcHJlc2VudCwgTkRMQS5cbiAqXG4gKiBUaGlzIHNvdXJjZSBjb2RlIGlzIGxpY2Vuc2VkIHVuZGVyIHRoZSBHUEx2MyBsaWNlbnNlIGZvdW5kIGluIHRoZVxuICogTElDRU5TRSBmaWxlIGluIHRoZSByb290IGRpcmVjdG9yeSBvZiB0aGlzIHNvdXJjZSB0cmVlLlxuICpcbiAqL1xuXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBjb2xvcnMsIGZvbnRzLCBzcGFjaW5nIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgUmVhY3QsIHsgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgdXNlVHJhbnNsYXRpb24gfSBmcm9tICdyZWFjdC1pMThuZXh0JztcbmltcG9ydCB7IE1lbnVCdXR0b24gfSBmcm9tICdAbmRsYS9idXR0b24nO1xuaW1wb3J0IFNhZmVMaW5rIGZyb20gJ0BuZGxhL3NhZmVsaW5rJztcbmltcG9ydCB7IHVzZU5hdmlnYXRlIH0gZnJvbSAncmVhY3Qtcm91dGVyLWRvbSc7XG5pbXBvcnQgeyBIYXNoVGFnIH0gZnJvbSAnQG5kbGEvaWNvbnMvY29tbW9uJztcbmltcG9ydCByZXNvdXJjZVR5cGVDb2xvciBmcm9tICcuLi91dGlscy9yZXNvdXJjZVR5cGVDb2xvcic7XG5pbXBvcnQgeyByZXNvdXJjZUVtYmVkVHlwZU1hcHBpbmcgfSBmcm9tICcuLi9tb2RlbC9Db250ZW50VHlwZSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgUmVzb3VyY2VJbWFnZVByb3BzIHtcbiAgYWx0OiBzdHJpbmc7XG4gIHNyYzogc3RyaW5nO1xufVxuXG5leHBvcnQgY29uc3QgUmVzb3VyY2VUaXRsZUxpbmsgPSBzdHlsZWQoU2FmZUxpbmspYFxuICBib3gtc2hhZG93OiBub25lO1xuICBjb2xvcjogJHtjb2xvcnMuYnJhbmQucHJpbWFyeX07XG4gIGZsZXg6IDE7XG4gIDphZnRlciB7XG4gICAgY29udGVudDogJyc7XG4gICAgcG9zaXRpb246IGFic29sdXRlO1xuICAgIHotaW5kZXg6IDE7XG4gICAgdG9wOiAwO1xuICAgIHJpZ2h0OiAwO1xuICAgIGJvdHRvbTogMDtcbiAgICBsZWZ0OiAwO1xuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgUmVzb3VyY2VUaXRsZSA9IHN0eWxlZC5zcGFuYFxuICBtYXJnaW46IDA7XG4gIG92ZXJmbG93OiBoaWRkZW47XG4gIHRleHQtb3ZlcmZsb3c6IGVsbGlwc2lzO1xuICBmb250LXdlaWdodDogJHtmb250cy53ZWlnaHQuYm9sZH07XG4gIC8vIFVuZm9ydHVuYXRlIGNzcyBuZWVkZWQgZm9yIG11bHRpLWxpbmUgdGV4dCBvdmVyZmxvdyBlbGxpcHNpcy5cbiAgbGluZS1oZWlnaHQ6IDE7XG4gIGRpc3BsYXk6IC13ZWJraXQtYm94O1xuICAtd2Via2l0LWxpbmUtY2xhbXA6IDE7XG4gIGxpbmUtY2xhbXA6IDE7XG4gIC13ZWJraXQtYm94LW9yaWVudDogdmVydGljYWw7XG4gIGdyaWQtYXJlYTogcmVzb3VyY2VUaXRsZTtcbiAgJHtmb250cy5zaXplcygnMTZweCcsICcyMHB4Jyl9O1xuYDtcblxuY29uc3QgU3R5bGVkVGFnTGlzdCA9IHN0eWxlZC51bGBcbiAgbGlzdC1zdHlsZTogbm9uZTtcbiAgZGlzcGxheTogZmxleDtcbiAgbWFyZ2luOiAwO1xuICBtYXJnaW4tbGVmdDogJHtzcGFjaW5nLnNtYWxsfTtcbiAgcGFkZGluZzogMnB4O1xuICBnYXA6ICR7c3BhY2luZy54c21hbGx9O1xuICBvdmVyZmxvdzogaGlkZGVuO1xuICA6bGFzdC1jaGlsZCB7XG4gICAgbWFyZ2luLXJpZ2h0OiAke3NwYWNpbmcuc21hbGx9O1xuICB9XG5gO1xuXG5jb25zdCBTdHlsZWRUYWdMaXN0RWxlbWVudCA9IHN0eWxlZC5saWBcbiAgbWFyZ2luOiAwO1xuICAke2ZvbnRzLnNpemVzKDE0KX07XG5gO1xuXG5jb25zdCBTdHlsZWRTYWZlTGluayA9IHN0eWxlZChTYWZlTGluaylgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGp1c3RpZnktY29udGVudDogZmxleC1lbmQ7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGJveC1zaGFkb3c6IG5vbmU7XG4gIGNvbG9yOiAke2NvbG9ycy5icmFuZC5ncmV5fTtcbiAgbWluLWhlaWdodDogNDRweDtcbiAgbWluLXdpZHRoOiA0NHB4O1xuICB3aGl0ZS1zcGFjZTogbm93cmFwO1xuICAmOmhvdmVyIHtcbiAgICBjb2xvcjogJHtjb2xvcnMuYnJhbmQucHJpbWFyeX07XG4gIH1cbmA7XG5cbmNvbnN0IFN0eWxlZFJlc291cmNlVHlwZUxpc3QgPSBzdHlsZWQudWxgXG4gIGxpc3Qtc3R5bGU6IG5vbmU7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIG1hcmdpbjogMDtcbiAgcGFkZGluZzogMDtcbiAgb3ZlcmZsb3c6IGhpZGRlbjtcbmA7XG5cbmNvbnN0IFN0eWxlZFRvcGljRGl2aWRlciA9IHN0eWxlZC5zcGFuYFxuICBtYXJnaW46IDA7XG4gIHBhZGRpbmc6IDAgJHtzcGFjaW5nLnh4c21hbGx9O1xuYDtcblxuY29uc3QgU3R5bGVkUmVzb3VyY2VMaXN0RWxlbWVudCA9IHN0eWxlZC5saWBcbiAgd2hpdGUtc3BhY2U6IG5vd3JhcDtcbiAgJHtmb250cy5zaXplcygxMil9O1xuICBtYXJnaW46IDA7XG4gIGxpbmUtaGVpZ2h0OiAxLjU7XG4gIHBhZGRpbmc6IDA7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5gO1xuXG5jb25zdCBUYWdDb3VudGVyV3JhcHBlciA9IHN0eWxlZC5zcGFuYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmb250LXdlaWdodDogJHtmb250cy53ZWlnaHQuc2VtaWJvbGR9O1xuICAke2ZvbnRzLnNpemVzKCcxNHB4JywgJzE0cHgnKX07XG5gO1xuXG5leHBvcnQgaW50ZXJmYWNlIENvbnRlbnRJY29uUHJvcHMge1xuICBjb250ZW50VHlwZTogc3RyaW5nO1xufVxuXG5leHBvcnQgY29uc3QgU3R5bGVkQ29udGVudEljb25XcmFwcGVyID0gc3R5bGVkLnNwYW48Q29udGVudEljb25Qcm9wcz5gXG4gIHdpZHRoOiAxMDAlO1xuICBhc3BlY3QtcmF0aW86IDQvMztcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG4gIGJhY2tncm91bmQtY29sb3I6ICR7KHsgY29udGVudFR5cGUgfSkgPT4gcmVzb3VyY2VUeXBlQ29sb3IoY29udGVudFR5cGUpfTtcbmA7XG5cbmludGVyZmFjZSBUYWdMaXN0UHJvcHMge1xuICB0YWdzPzogc3RyaW5nW107XG4gIHRhZ0xpbmtQcmVmaXg/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTG9hZGVyUHJvcHMge1xuICBsb2FkaW5nPzogYm9vbGVhbjtcbiAgY2hpbGRyZW4/OiBSZWFjdE5vZGU7XG59XG5cbmV4cG9ydCBjb25zdCBUYWdMaXN0ID0gKHsgdGFncywgdGFnTGlua1ByZWZpeCB9OiBUYWdMaXN0UHJvcHMpID0+IHtcbiAgY29uc3QgeyB0IH0gPSB1c2VUcmFuc2xhdGlvbigpO1xuICBpZiAoIXRhZ3MpIHJldHVybiBudWxsO1xuICByZXR1cm4gKFxuICAgIDxTdHlsZWRUYWdMaXN0IGFyaWEtbGFiZWw9e3QoJ215TmRsYS50YWdMaXN0Jyl9PlxuICAgICAge3RhZ3MubWFwKCh0YWcsIGkpID0+IChcbiAgICAgICAgPFN0eWxlZFRhZ0xpc3RFbGVtZW50IGtleT17YHRhZy0ke2l9YH0+XG4gICAgICAgICAgPFN0eWxlZFNhZmVMaW5rIHRvPXtgJHt0YWdMaW5rUHJlZml4ID8gdGFnTGlua1ByZWZpeCA6ICcnfS8ke2VuY29kZVVSSUNvbXBvbmVudCh0YWcpfWB9PlxuICAgICAgICAgICAgPEhhc2hUYWcgLz5cbiAgICAgICAgICAgIHt0YWd9XG4gICAgICAgICAgPC9TdHlsZWRTYWZlTGluaz5cbiAgICAgICAgPC9TdHlsZWRUYWdMaXN0RWxlbWVudD5cbiAgICAgICkpfVxuICAgIDwvU3R5bGVkVGFnTGlzdD5cbiAgKTtcbn07XG5cbmludGVyZmFjZSBDb21wcmVzc2VkVGFnTGlzdFByb3BzIHtcbiAgdGFnczogc3RyaW5nW107XG4gIHRhZ0xpbmtQcmVmaXg/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBjb25zdCBDb21wcmVzc2VkVGFnTGlzdCA9ICh7IHRhZ3MsIHRhZ0xpbmtQcmVmaXggfTogQ29tcHJlc3NlZFRhZ0xpc3RQcm9wcykgPT4ge1xuICBjb25zdCBuYXZpZ2F0ZSA9IHVzZU5hdmlnYXRlKCk7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcbiAgY29uc3QgdmlzaWJsZVRhZ3MgPSB0YWdzLnNsaWNlKDAsIDMpO1xuICBjb25zdCByZW1haW5pbmdUYWdzID0gdGFncy5zbGljZSgzLCB0YWdzLmxlbmd0aCkubWFwKCh0YWcpID0+IHtcbiAgICByZXR1cm4ge1xuICAgICAgaWNvbjogPEhhc2hUYWcgLz4sXG4gICAgICB0ZXh0OiB0YWcsXG4gICAgICBvbkNsaWNrOiAoKSA9PiB7XG4gICAgICAgIG5hdmlnYXRlKGAke3RhZ0xpbmtQcmVmaXggPyB0YWdMaW5rUHJlZml4IDogJyd9LyR7ZW5jb2RlVVJJQ29tcG9uZW50KHRhZyl9YCk7XG4gICAgICB9LFxuICAgIH07XG4gIH0pO1xuICByZXR1cm4gKFxuICAgIDw+XG4gICAgICA8VGFnTGlzdCB0YWdMaW5rUHJlZml4PXt0YWdMaW5rUHJlZml4fSB0YWdzPXt2aXNpYmxlVGFnc30gLz5cbiAgICAgIHtyZW1haW5pbmdUYWdzLmxlbmd0aCA+IDAgJiYgKFxuICAgICAgICA8TWVudUJ1dHRvblxuICAgICAgICAgIHNpemU9XCJzbWFsbFwiXG4gICAgICAgICAgbWVudUljb249ezxUYWdDb3VudGVyV3JhcHBlcj57YCske3JlbWFpbmluZ1RhZ3MubGVuZ3RofWB9PC9UYWdDb3VudGVyV3JhcHBlcj59XG4gICAgICAgICAgbWVudUl0ZW1zPXtyZW1haW5pbmdUYWdzfVxuICAgICAgICAgIGFsaWduPVwiZW5kXCJcbiAgICAgICAgICBhcmlhLWxhYmVsPXt0KCdteU5kbGEubW9yZVRhZ3MnLCB7IGNvdW50OiByZW1haW5pbmdUYWdzLmxlbmd0aCB9KX1cbiAgICAgICAgLz5cbiAgICAgICl9XG4gICAgPC8+XG4gICk7XG59O1xuXG5pbnRlcmZhY2UgUmVzb3VyY2VUeXBlTGlzdFByb3BzIHtcbiAgcmVzb3VyY2VUeXBlcz86IHsgaWQ6IHN0cmluZzsgbmFtZTogc3RyaW5nIH1bXTtcbn1cblxuZXhwb3J0IGNvbnN0IFJlc291cmNlVHlwZUxpc3QgPSAoeyByZXNvdXJjZVR5cGVzIH06IFJlc291cmNlVHlwZUxpc3RQcm9wcykgPT4ge1xuICBjb25zdCB7IHQgfSA9IHVzZVRyYW5zbGF0aW9uKCk7XG4gIGlmICghcmVzb3VyY2VUeXBlcykgcmV0dXJuIG51bGw7XG4gIHJldHVybiAoXG4gICAgPFN0eWxlZFJlc291cmNlVHlwZUxpc3QgYXJpYS1sYWJlbD17dCgnbmF2aWdhdGlvbi50b3BpY3MnKX0+XG4gICAgICB7cmVzb3VyY2VUeXBlcy5tYXAoKHJlc291cmNlLCBpKSA9PiAoXG4gICAgICAgIDxTdHlsZWRSZXNvdXJjZUxpc3RFbGVtZW50IGtleT17cmVzb3VyY2UuaWR9PlxuICAgICAgICAgIHtyZXNvdXJjZUVtYmVkVHlwZU1hcHBpbmdbcmVzb3VyY2UuaWRdXG4gICAgICAgICAgICA/IHQoYGVtYmVkLnR5cGUuJHtyZXNvdXJjZUVtYmVkVHlwZU1hcHBpbmdbcmVzb3VyY2UuaWRdfWApXG4gICAgICAgICAgICA6IHJlc291cmNlLm5hbWV9XG4gICAgICAgICAge2kgIT09IHJlc291cmNlVHlwZXMubGVuZ3RoIC0gMSAmJiA8U3R5bGVkVG9waWNEaXZpZGVyIGFyaWEtaGlkZGVuPVwidHJ1ZVwiPuKAojwvU3R5bGVkVG9waWNEaXZpZGVyPn1cbiAgICAgICAgPC9TdHlsZWRSZXNvdXJjZUxpc3RFbGVtZW50PlxuICAgICAgKSl9XG4gICAgPC9TdHlsZWRSZXNvdXJjZVR5cGVMaXN0PlxuICApO1xufTtcbiJdfQ== */"));
45
+ })("margin:0;", fonts.sizes(14), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["resourceComponents.tsx"],"names":[],"mappings":"AAoEsC","file":"resourceComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2022-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 styled from '@emotion/styled';\nimport { colors, fonts, spacing } from '@ndla/core';\nimport React, { CSSProperties, HTMLAttributes, ReactNode, useMemo } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { MenuButton } from '@ndla/button';\nimport SafeLink from '@ndla/safelink';\nimport { useNavigate } from 'react-router-dom';\nimport { HashTag } from '@ndla/icons/common';\nimport { css } from '@emotion/react';\nimport resourceTypeColor from '../utils/resourceTypeColor';\nimport { resourceEmbedTypeMapping } from '../model/ContentType';\n\nexport interface ResourceImageProps {\n  alt: string;\n  src: string;\n}\n\nexport const ResourceTitleLink = styled(SafeLink)`\n  box-shadow: none;\n  color: ${colors.brand.primary};\n  flex: 1;\n  :after {\n    content: '';\n    position: absolute;\n    z-index: 1;\n    top: 0;\n    right: 0;\n    bottom: 0;\n    left: 0;\n  }\n`;\n\nexport const resourceHeadingStyle = css`\n  margin: 0;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  font-weight: ${fonts.weight.bold};\n  // Unfortunate css needed for multi-line text overflow ellipsis.\n  line-height: 1;\n  display: -webkit-box;\n  -webkit-line-clamp: 1;\n  line-clamp: 1;\n  -webkit-box-orient: vertical;\n  grid-area: resourceTitle;\n  ${fonts.sizes('16px', '20px')};\n`;\n\nconst StyledTagList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  margin-left: ${spacing.small};\n  padding: 2px;\n  gap: ${spacing.xsmall};\n  overflow: hidden;\n  :last-child {\n    margin-right: ${spacing.small};\n  }\n`;\n\nconst StyledTagListElement = styled.li`\n  margin: 0;\n  ${fonts.sizes(14)};\n`;\n\nconst StyledSafeLink = styled(SafeLink)`\n  display: flex;\n  justify-content: flex-end;\n  align-items: center;\n  box-shadow: none;\n  color: ${colors.brand.grey};\n  min-height: 44px;\n  min-width: 44px;\n  white-space: nowrap;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n`;\n\nconst StyledResourceTypeList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  padding: 0;\n  overflow: hidden;\n`;\n\nconst StyledTopicDivider = styled.span`\n  margin: 0;\n  padding: 0 ${spacing.xxsmall};\n`;\n\nconst StyledResourceListElement = styled.li`\n  white-space: nowrap;\n  ${fonts.sizes(12)};\n  margin: 0;\n  line-height: 1.5;\n  padding: 0;\n  display: flex;\n  align-items: center;\n`;\n\nconst TagCounterWrapper = styled.span`\n  display: flex;\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('14px', '14px')};\n`;\n\ninterface ContentIconProps extends HTMLAttributes<HTMLSpanElement> {\n  contentType: string;\n  children?: ReactNode;\n}\n\nconst StyledContentIconWrapper = styled.span`\n  width: 100%;\n  aspect-ratio: 4/3;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  background-color: var(--content-background-color);\n`;\n\nexport const ContentIconWrapper = ({ contentType, children, ...props }: ContentIconProps) => {\n  const contentIconWrapperVars = useMemo(\n    () => ({ '--content-background-color': resourceTypeColor(contentType) } as unknown as CSSProperties),\n    [contentType],\n  );\n  return (\n    <StyledContentIconWrapper {...props} style={contentIconWrapperVars}>\n      {children}\n    </StyledContentIconWrapper>\n  );\n};\n\ninterface TagListProps {\n  tags?: string[];\n  tagLinkPrefix?: string;\n}\n\nexport interface LoaderProps {\n  loading?: boolean;\n  children?: ReactNode;\n}\n\nexport const TagList = ({ tags, tagLinkPrefix }: TagListProps) => {\n  const { t } = useTranslation();\n  if (!tags) return null;\n  return (\n    <StyledTagList aria-label={t('myNdla.tagList')}>\n      {tags.map((tag, i) => (\n        <StyledTagListElement key={`tag-${i}`}>\n          <StyledSafeLink to={`${tagLinkPrefix ? tagLinkPrefix : ''}/${encodeURIComponent(tag)}`}>\n            <HashTag />\n            {tag}\n          </StyledSafeLink>\n        </StyledTagListElement>\n      ))}\n    </StyledTagList>\n  );\n};\n\ninterface CompressedTagListProps {\n  tags: string[];\n  tagLinkPrefix?: string;\n}\n\nexport const CompressedTagList = ({ tags, tagLinkPrefix }: CompressedTagListProps) => {\n  const navigate = useNavigate();\n  const { t } = useTranslation();\n  const visibleTags = useMemo(() => tags.slice(0, 3), [tags]);\n  const remainingTags = useMemo(\n    () =>\n      tags.slice(3, tags.length).map((tag) => {\n        return {\n          icon: <HashTag />,\n          text: tag,\n          onClick: () => {\n            navigate(`${tagLinkPrefix ? tagLinkPrefix : ''}/${encodeURIComponent(tag)}`);\n          },\n        };\n      }),\n    [navigate, tagLinkPrefix, tags],\n  );\n\n  return (\n    <>\n      <TagList tagLinkPrefix={tagLinkPrefix} tags={visibleTags} />\n      {remainingTags.length > 0 && (\n        <MenuButton\n          size=\"small\"\n          menuIcon={<TagCounterWrapper>{`+${remainingTags.length}`}</TagCounterWrapper>}\n          menuItems={remainingTags}\n          align=\"end\"\n          aria-label={t('myNdla.moreTags', { count: remainingTags.length })}\n        />\n      )}\n    </>\n  );\n};\n\ninterface ResourceTypeListProps {\n  resourceTypes?: { id: string; name: string }[];\n}\n\nexport const ResourceTypeList = ({ resourceTypes }: ResourceTypeListProps) => {\n  const { t } = useTranslation();\n  if (!resourceTypes) return null;\n  return (\n    <StyledResourceTypeList aria-label={t('navigation.topics')}>\n      {resourceTypes.map((resource, i) => (\n        <StyledResourceListElement key={resource.id}>\n          {resourceEmbedTypeMapping[resource.id]\n            ? t(`embed.type.${resourceEmbedTypeMapping[resource.id]}`)\n            : resource.name}\n          {i !== resourceTypes.length - 1 && <StyledTopicDivider aria-hidden=\"true\">•</StyledTopicDivider>}\n        </StyledResourceListElement>\n      ))}\n    </StyledResourceTypeList>\n  );\n};\n"]} */"));
39
46
  var StyledSafeLink = /*#__PURE__*/_styled(SafeLink, {
40
47
  target: "e1lrrm6s5",
41
48
  label: "StyledSafeLink"
42
- })("display:flex;justify-content:flex-end;align-items:center;box-shadow:none;color:", colors.brand.grey, ";min-height:44px;min-width:44px;white-space:nowrap;&:hover{color:", colors.brand.primary, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInJlc291cmNlQ29tcG9uZW50cy50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBd0V1QyIsImZpbGUiOiJyZXNvdXJjZUNvbXBvbmVudHMudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjItcHJlc2VudCwgTkRMQS5cbiAqXG4gKiBUaGlzIHNvdXJjZSBjb2RlIGlzIGxpY2Vuc2VkIHVuZGVyIHRoZSBHUEx2MyBsaWNlbnNlIGZvdW5kIGluIHRoZVxuICogTElDRU5TRSBmaWxlIGluIHRoZSByb290IGRpcmVjdG9yeSBvZiB0aGlzIHNvdXJjZSB0cmVlLlxuICpcbiAqL1xuXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBjb2xvcnMsIGZvbnRzLCBzcGFjaW5nIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgUmVhY3QsIHsgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgdXNlVHJhbnNsYXRpb24gfSBmcm9tICdyZWFjdC1pMThuZXh0JztcbmltcG9ydCB7IE1lbnVCdXR0b24gfSBmcm9tICdAbmRsYS9idXR0b24nO1xuaW1wb3J0IFNhZmVMaW5rIGZyb20gJ0BuZGxhL3NhZmVsaW5rJztcbmltcG9ydCB7IHVzZU5hdmlnYXRlIH0gZnJvbSAncmVhY3Qtcm91dGVyLWRvbSc7XG5pbXBvcnQgeyBIYXNoVGFnIH0gZnJvbSAnQG5kbGEvaWNvbnMvY29tbW9uJztcbmltcG9ydCByZXNvdXJjZVR5cGVDb2xvciBmcm9tICcuLi91dGlscy9yZXNvdXJjZVR5cGVDb2xvcic7XG5pbXBvcnQgeyByZXNvdXJjZUVtYmVkVHlwZU1hcHBpbmcgfSBmcm9tICcuLi9tb2RlbC9Db250ZW50VHlwZSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgUmVzb3VyY2VJbWFnZVByb3BzIHtcbiAgYWx0OiBzdHJpbmc7XG4gIHNyYzogc3RyaW5nO1xufVxuXG5leHBvcnQgY29uc3QgUmVzb3VyY2VUaXRsZUxpbmsgPSBzdHlsZWQoU2FmZUxpbmspYFxuICBib3gtc2hhZG93OiBub25lO1xuICBjb2xvcjogJHtjb2xvcnMuYnJhbmQucHJpbWFyeX07XG4gIGZsZXg6IDE7XG4gIDphZnRlciB7XG4gICAgY29udGVudDogJyc7XG4gICAgcG9zaXRpb246IGFic29sdXRlO1xuICAgIHotaW5kZXg6IDE7XG4gICAgdG9wOiAwO1xuICAgIHJpZ2h0OiAwO1xuICAgIGJvdHRvbTogMDtcbiAgICBsZWZ0OiAwO1xuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgUmVzb3VyY2VUaXRsZSA9IHN0eWxlZC5zcGFuYFxuICBtYXJnaW46IDA7XG4gIG92ZXJmbG93OiBoaWRkZW47XG4gIHRleHQtb3ZlcmZsb3c6IGVsbGlwc2lzO1xuICBmb250LXdlaWdodDogJHtmb250cy53ZWlnaHQuYm9sZH07XG4gIC8vIFVuZm9ydHVuYXRlIGNzcyBuZWVkZWQgZm9yIG11bHRpLWxpbmUgdGV4dCBvdmVyZmxvdyBlbGxpcHNpcy5cbiAgbGluZS1oZWlnaHQ6IDE7XG4gIGRpc3BsYXk6IC13ZWJraXQtYm94O1xuICAtd2Via2l0LWxpbmUtY2xhbXA6IDE7XG4gIGxpbmUtY2xhbXA6IDE7XG4gIC13ZWJraXQtYm94LW9yaWVudDogdmVydGljYWw7XG4gIGdyaWQtYXJlYTogcmVzb3VyY2VUaXRsZTtcbiAgJHtmb250cy5zaXplcygnMTZweCcsICcyMHB4Jyl9O1xuYDtcblxuY29uc3QgU3R5bGVkVGFnTGlzdCA9IHN0eWxlZC51bGBcbiAgbGlzdC1zdHlsZTogbm9uZTtcbiAgZGlzcGxheTogZmxleDtcbiAgbWFyZ2luOiAwO1xuICBtYXJnaW4tbGVmdDogJHtzcGFjaW5nLnNtYWxsfTtcbiAgcGFkZGluZzogMnB4O1xuICBnYXA6ICR7c3BhY2luZy54c21hbGx9O1xuICBvdmVyZmxvdzogaGlkZGVuO1xuICA6bGFzdC1jaGlsZCB7XG4gICAgbWFyZ2luLXJpZ2h0OiAke3NwYWNpbmcuc21hbGx9O1xuICB9XG5gO1xuXG5jb25zdCBTdHlsZWRUYWdMaXN0RWxlbWVudCA9IHN0eWxlZC5saWBcbiAgbWFyZ2luOiAwO1xuICAke2ZvbnRzLnNpemVzKDE0KX07XG5gO1xuXG5jb25zdCBTdHlsZWRTYWZlTGluayA9IHN0eWxlZChTYWZlTGluaylgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGp1c3RpZnktY29udGVudDogZmxleC1lbmQ7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGJveC1zaGFkb3c6IG5vbmU7XG4gIGNvbG9yOiAke2NvbG9ycy5icmFuZC5ncmV5fTtcbiAgbWluLWhlaWdodDogNDRweDtcbiAgbWluLXdpZHRoOiA0NHB4O1xuICB3aGl0ZS1zcGFjZTogbm93cmFwO1xuICAmOmhvdmVyIHtcbiAgICBjb2xvcjogJHtjb2xvcnMuYnJhbmQucHJpbWFyeX07XG4gIH1cbmA7XG5cbmNvbnN0IFN0eWxlZFJlc291cmNlVHlwZUxpc3QgPSBzdHlsZWQudWxgXG4gIGxpc3Qtc3R5bGU6IG5vbmU7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIG1hcmdpbjogMDtcbiAgcGFkZGluZzogMDtcbiAgb3ZlcmZsb3c6IGhpZGRlbjtcbmA7XG5cbmNvbnN0IFN0eWxlZFRvcGljRGl2aWRlciA9IHN0eWxlZC5zcGFuYFxuICBtYXJnaW46IDA7XG4gIHBhZGRpbmc6IDAgJHtzcGFjaW5nLnh4c21hbGx9O1xuYDtcblxuY29uc3QgU3R5bGVkUmVzb3VyY2VMaXN0RWxlbWVudCA9IHN0eWxlZC5saWBcbiAgd2hpdGUtc3BhY2U6IG5vd3JhcDtcbiAgJHtmb250cy5zaXplcygxMil9O1xuICBtYXJnaW46IDA7XG4gIGxpbmUtaGVpZ2h0OiAxLjU7XG4gIHBhZGRpbmc6IDA7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5gO1xuXG5jb25zdCBUYWdDb3VudGVyV3JhcHBlciA9IHN0eWxlZC5zcGFuYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmb250LXdlaWdodDogJHtmb250cy53ZWlnaHQuc2VtaWJvbGR9O1xuICAke2ZvbnRzLnNpemVzKCcxNHB4JywgJzE0cHgnKX07XG5gO1xuXG5leHBvcnQgaW50ZXJmYWNlIENvbnRlbnRJY29uUHJvcHMge1xuICBjb250ZW50VHlwZTogc3RyaW5nO1xufVxuXG5leHBvcnQgY29uc3QgU3R5bGVkQ29udGVudEljb25XcmFwcGVyID0gc3R5bGVkLnNwYW48Q29udGVudEljb25Qcm9wcz5gXG4gIHdpZHRoOiAxMDAlO1xuICBhc3BlY3QtcmF0aW86IDQvMztcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG4gIGJhY2tncm91bmQtY29sb3I6ICR7KHsgY29udGVudFR5cGUgfSkgPT4gcmVzb3VyY2VUeXBlQ29sb3IoY29udGVudFR5cGUpfTtcbmA7XG5cbmludGVyZmFjZSBUYWdMaXN0UHJvcHMge1xuICB0YWdzPzogc3RyaW5nW107XG4gIHRhZ0xpbmtQcmVmaXg/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTG9hZGVyUHJvcHMge1xuICBsb2FkaW5nPzogYm9vbGVhbjtcbiAgY2hpbGRyZW4/OiBSZWFjdE5vZGU7XG59XG5cbmV4cG9ydCBjb25zdCBUYWdMaXN0ID0gKHsgdGFncywgdGFnTGlua1ByZWZpeCB9OiBUYWdMaXN0UHJvcHMpID0+IHtcbiAgY29uc3QgeyB0IH0gPSB1c2VUcmFuc2xhdGlvbigpO1xuICBpZiAoIXRhZ3MpIHJldHVybiBudWxsO1xuICByZXR1cm4gKFxuICAgIDxTdHlsZWRUYWdMaXN0IGFyaWEtbGFiZWw9e3QoJ215TmRsYS50YWdMaXN0Jyl9PlxuICAgICAge3RhZ3MubWFwKCh0YWcsIGkpID0+IChcbiAgICAgICAgPFN0eWxlZFRhZ0xpc3RFbGVtZW50IGtleT17YHRhZy0ke2l9YH0+XG4gICAgICAgICAgPFN0eWxlZFNhZmVMaW5rIHRvPXtgJHt0YWdMaW5rUHJlZml4ID8gdGFnTGlua1ByZWZpeCA6ICcnfS8ke2VuY29kZVVSSUNvbXBvbmVudCh0YWcpfWB9PlxuICAgICAgICAgICAgPEhhc2hUYWcgLz5cbiAgICAgICAgICAgIHt0YWd9XG4gICAgICAgICAgPC9TdHlsZWRTYWZlTGluaz5cbiAgICAgICAgPC9TdHlsZWRUYWdMaXN0RWxlbWVudD5cbiAgICAgICkpfVxuICAgIDwvU3R5bGVkVGFnTGlzdD5cbiAgKTtcbn07XG5cbmludGVyZmFjZSBDb21wcmVzc2VkVGFnTGlzdFByb3BzIHtcbiAgdGFnczogc3RyaW5nW107XG4gIHRhZ0xpbmtQcmVmaXg/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBjb25zdCBDb21wcmVzc2VkVGFnTGlzdCA9ICh7IHRhZ3MsIHRhZ0xpbmtQcmVmaXggfTogQ29tcHJlc3NlZFRhZ0xpc3RQcm9wcykgPT4ge1xuICBjb25zdCBuYXZpZ2F0ZSA9IHVzZU5hdmlnYXRlKCk7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcbiAgY29uc3QgdmlzaWJsZVRhZ3MgPSB0YWdzLnNsaWNlKDAsIDMpO1xuICBjb25zdCByZW1haW5pbmdUYWdzID0gdGFncy5zbGljZSgzLCB0YWdzLmxlbmd0aCkubWFwKCh0YWcpID0+IHtcbiAgICByZXR1cm4ge1xuICAgICAgaWNvbjogPEhhc2hUYWcgLz4sXG4gICAgICB0ZXh0OiB0YWcsXG4gICAgICBvbkNsaWNrOiAoKSA9PiB7XG4gICAgICAgIG5hdmlnYXRlKGAke3RhZ0xpbmtQcmVmaXggPyB0YWdMaW5rUHJlZml4IDogJyd9LyR7ZW5jb2RlVVJJQ29tcG9uZW50KHRhZyl9YCk7XG4gICAgICB9LFxuICAgIH07XG4gIH0pO1xuICByZXR1cm4gKFxuICAgIDw+XG4gICAgICA8VGFnTGlzdCB0YWdMaW5rUHJlZml4PXt0YWdMaW5rUHJlZml4fSB0YWdzPXt2aXNpYmxlVGFnc30gLz5cbiAgICAgIHtyZW1haW5pbmdUYWdzLmxlbmd0aCA+IDAgJiYgKFxuICAgICAgICA8TWVudUJ1dHRvblxuICAgICAgICAgIHNpemU9XCJzbWFsbFwiXG4gICAgICAgICAgbWVudUljb249ezxUYWdDb3VudGVyV3JhcHBlcj57YCske3JlbWFpbmluZ1RhZ3MubGVuZ3RofWB9PC9UYWdDb3VudGVyV3JhcHBlcj59XG4gICAgICAgICAgbWVudUl0ZW1zPXtyZW1haW5pbmdUYWdzfVxuICAgICAgICAgIGFsaWduPVwiZW5kXCJcbiAgICAgICAgICBhcmlhLWxhYmVsPXt0KCdteU5kbGEubW9yZVRhZ3MnLCB7IGNvdW50OiByZW1haW5pbmdUYWdzLmxlbmd0aCB9KX1cbiAgICAgICAgLz5cbiAgICAgICl9XG4gICAgPC8+XG4gICk7XG59O1xuXG5pbnRlcmZhY2UgUmVzb3VyY2VUeXBlTGlzdFByb3BzIHtcbiAgcmVzb3VyY2VUeXBlcz86IHsgaWQ6IHN0cmluZzsgbmFtZTogc3RyaW5nIH1bXTtcbn1cblxuZXhwb3J0IGNvbnN0IFJlc291cmNlVHlwZUxpc3QgPSAoeyByZXNvdXJjZVR5cGVzIH06IFJlc291cmNlVHlwZUxpc3RQcm9wcykgPT4ge1xuICBjb25zdCB7IHQgfSA9IHVzZVRyYW5zbGF0aW9uKCk7XG4gIGlmICghcmVzb3VyY2VUeXBlcykgcmV0dXJuIG51bGw7XG4gIHJldHVybiAoXG4gICAgPFN0eWxlZFJlc291cmNlVHlwZUxpc3QgYXJpYS1sYWJlbD17dCgnbmF2aWdhdGlvbi50b3BpY3MnKX0+XG4gICAgICB7cmVzb3VyY2VUeXBlcy5tYXAoKHJlc291cmNlLCBpKSA9PiAoXG4gICAgICAgIDxTdHlsZWRSZXNvdXJjZUxpc3RFbGVtZW50IGtleT17cmVzb3VyY2UuaWR9PlxuICAgICAgICAgIHtyZXNvdXJjZUVtYmVkVHlwZU1hcHBpbmdbcmVzb3VyY2UuaWRdXG4gICAgICAgICAgICA/IHQoYGVtYmVkLnR5cGUuJHtyZXNvdXJjZUVtYmVkVHlwZU1hcHBpbmdbcmVzb3VyY2UuaWRdfWApXG4gICAgICAgICAgICA6IHJlc291cmNlLm5hbWV9XG4gICAgICAgICAge2kgIT09IHJlc291cmNlVHlwZXMubGVuZ3RoIC0gMSAmJiA8U3R5bGVkVG9waWNEaXZpZGVyIGFyaWEtaGlkZGVuPVwidHJ1ZVwiPuKAojwvU3R5bGVkVG9waWNEaXZpZGVyPn1cbiAgICAgICAgPC9TdHlsZWRSZXNvdXJjZUxpc3RFbGVtZW50PlxuICAgICAgKSl9XG4gICAgPC9TdHlsZWRSZXNvdXJjZVR5cGVMaXN0PlxuICApO1xufTtcbiJdfQ== */"));
49
+ })("display:flex;justify-content:flex-end;align-items:center;box-shadow:none;color:", colors.brand.grey, ";min-height:44px;min-width:44px;white-space:nowrap;&:hover{color:", colors.brand.primary, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["resourceComponents.tsx"],"names":[],"mappings":"AAyEuC","file":"resourceComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2022-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 styled from '@emotion/styled';\nimport { colors, fonts, spacing } from '@ndla/core';\nimport React, { CSSProperties, HTMLAttributes, ReactNode, useMemo } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { MenuButton } from '@ndla/button';\nimport SafeLink from '@ndla/safelink';\nimport { useNavigate } from 'react-router-dom';\nimport { HashTag } from '@ndla/icons/common';\nimport { css } from '@emotion/react';\nimport resourceTypeColor from '../utils/resourceTypeColor';\nimport { resourceEmbedTypeMapping } from '../model/ContentType';\n\nexport interface ResourceImageProps {\n  alt: string;\n  src: string;\n}\n\nexport const ResourceTitleLink = styled(SafeLink)`\n  box-shadow: none;\n  color: ${colors.brand.primary};\n  flex: 1;\n  :after {\n    content: '';\n    position: absolute;\n    z-index: 1;\n    top: 0;\n    right: 0;\n    bottom: 0;\n    left: 0;\n  }\n`;\n\nexport const resourceHeadingStyle = css`\n  margin: 0;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  font-weight: ${fonts.weight.bold};\n  // Unfortunate css needed for multi-line text overflow ellipsis.\n  line-height: 1;\n  display: -webkit-box;\n  -webkit-line-clamp: 1;\n  line-clamp: 1;\n  -webkit-box-orient: vertical;\n  grid-area: resourceTitle;\n  ${fonts.sizes('16px', '20px')};\n`;\n\nconst StyledTagList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  margin-left: ${spacing.small};\n  padding: 2px;\n  gap: ${spacing.xsmall};\n  overflow: hidden;\n  :last-child {\n    margin-right: ${spacing.small};\n  }\n`;\n\nconst StyledTagListElement = styled.li`\n  margin: 0;\n  ${fonts.sizes(14)};\n`;\n\nconst StyledSafeLink = styled(SafeLink)`\n  display: flex;\n  justify-content: flex-end;\n  align-items: center;\n  box-shadow: none;\n  color: ${colors.brand.grey};\n  min-height: 44px;\n  min-width: 44px;\n  white-space: nowrap;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n`;\n\nconst StyledResourceTypeList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  padding: 0;\n  overflow: hidden;\n`;\n\nconst StyledTopicDivider = styled.span`\n  margin: 0;\n  padding: 0 ${spacing.xxsmall};\n`;\n\nconst StyledResourceListElement = styled.li`\n  white-space: nowrap;\n  ${fonts.sizes(12)};\n  margin: 0;\n  line-height: 1.5;\n  padding: 0;\n  display: flex;\n  align-items: center;\n`;\n\nconst TagCounterWrapper = styled.span`\n  display: flex;\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('14px', '14px')};\n`;\n\ninterface ContentIconProps extends HTMLAttributes<HTMLSpanElement> {\n  contentType: string;\n  children?: ReactNode;\n}\n\nconst StyledContentIconWrapper = styled.span`\n  width: 100%;\n  aspect-ratio: 4/3;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  background-color: var(--content-background-color);\n`;\n\nexport const ContentIconWrapper = ({ contentType, children, ...props }: ContentIconProps) => {\n  const contentIconWrapperVars = useMemo(\n    () => ({ '--content-background-color': resourceTypeColor(contentType) } as unknown as CSSProperties),\n    [contentType],\n  );\n  return (\n    <StyledContentIconWrapper {...props} style={contentIconWrapperVars}>\n      {children}\n    </StyledContentIconWrapper>\n  );\n};\n\ninterface TagListProps {\n  tags?: string[];\n  tagLinkPrefix?: string;\n}\n\nexport interface LoaderProps {\n  loading?: boolean;\n  children?: ReactNode;\n}\n\nexport const TagList = ({ tags, tagLinkPrefix }: TagListProps) => {\n  const { t } = useTranslation();\n  if (!tags) return null;\n  return (\n    <StyledTagList aria-label={t('myNdla.tagList')}>\n      {tags.map((tag, i) => (\n        <StyledTagListElement key={`tag-${i}`}>\n          <StyledSafeLink to={`${tagLinkPrefix ? tagLinkPrefix : ''}/${encodeURIComponent(tag)}`}>\n            <HashTag />\n            {tag}\n          </StyledSafeLink>\n        </StyledTagListElement>\n      ))}\n    </StyledTagList>\n  );\n};\n\ninterface CompressedTagListProps {\n  tags: string[];\n  tagLinkPrefix?: string;\n}\n\nexport const CompressedTagList = ({ tags, tagLinkPrefix }: CompressedTagListProps) => {\n  const navigate = useNavigate();\n  const { t } = useTranslation();\n  const visibleTags = useMemo(() => tags.slice(0, 3), [tags]);\n  const remainingTags = useMemo(\n    () =>\n      tags.slice(3, tags.length).map((tag) => {\n        return {\n          icon: <HashTag />,\n          text: tag,\n          onClick: () => {\n            navigate(`${tagLinkPrefix ? tagLinkPrefix : ''}/${encodeURIComponent(tag)}`);\n          },\n        };\n      }),\n    [navigate, tagLinkPrefix, tags],\n  );\n\n  return (\n    <>\n      <TagList tagLinkPrefix={tagLinkPrefix} tags={visibleTags} />\n      {remainingTags.length > 0 && (\n        <MenuButton\n          size=\"small\"\n          menuIcon={<TagCounterWrapper>{`+${remainingTags.length}`}</TagCounterWrapper>}\n          menuItems={remainingTags}\n          align=\"end\"\n          aria-label={t('myNdla.moreTags', { count: remainingTags.length })}\n        />\n      )}\n    </>\n  );\n};\n\ninterface ResourceTypeListProps {\n  resourceTypes?: { id: string; name: string }[];\n}\n\nexport const ResourceTypeList = ({ resourceTypes }: ResourceTypeListProps) => {\n  const { t } = useTranslation();\n  if (!resourceTypes) return null;\n  return (\n    <StyledResourceTypeList aria-label={t('navigation.topics')}>\n      {resourceTypes.map((resource, i) => (\n        <StyledResourceListElement key={resource.id}>\n          {resourceEmbedTypeMapping[resource.id]\n            ? t(`embed.type.${resourceEmbedTypeMapping[resource.id]}`)\n            : resource.name}\n          {i !== resourceTypes.length - 1 && <StyledTopicDivider aria-hidden=\"true\">•</StyledTopicDivider>}\n        </StyledResourceListElement>\n      ))}\n    </StyledResourceTypeList>\n  );\n};\n"]} */"));
43
50
  var StyledResourceTypeList = /*#__PURE__*/_styled("ul", {
44
51
  target: "e1lrrm6s4",
45
52
  label: "StyledResourceTypeList"
@@ -49,28 +56,47 @@ var StyledResourceTypeList = /*#__PURE__*/_styled("ul", {
49
56
  } : {
50
57
  name: "vspsww",
51
58
  styles: "list-style:none;display:flex;margin:0;padding:0;overflow:hidden",
52
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInJlc291cmNlQ29tcG9uZW50cy50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBc0Z3QyIsImZpbGUiOiJyZXNvdXJjZUNvbXBvbmVudHMudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjItcHJlc2VudCwgTkRMQS5cbiAqXG4gKiBUaGlzIHNvdXJjZSBjb2RlIGlzIGxpY2Vuc2VkIHVuZGVyIHRoZSBHUEx2MyBsaWNlbnNlIGZvdW5kIGluIHRoZVxuICogTElDRU5TRSBmaWxlIGluIHRoZSByb290IGRpcmVjdG9yeSBvZiB0aGlzIHNvdXJjZSB0cmVlLlxuICpcbiAqL1xuXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBjb2xvcnMsIGZvbnRzLCBzcGFjaW5nIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgUmVhY3QsIHsgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgdXNlVHJhbnNsYXRpb24gfSBmcm9tICdyZWFjdC1pMThuZXh0JztcbmltcG9ydCB7IE1lbnVCdXR0b24gfSBmcm9tICdAbmRsYS9idXR0b24nO1xuaW1wb3J0IFNhZmVMaW5rIGZyb20gJ0BuZGxhL3NhZmVsaW5rJztcbmltcG9ydCB7IHVzZU5hdmlnYXRlIH0gZnJvbSAncmVhY3Qtcm91dGVyLWRvbSc7XG5pbXBvcnQgeyBIYXNoVGFnIH0gZnJvbSAnQG5kbGEvaWNvbnMvY29tbW9uJztcbmltcG9ydCByZXNvdXJjZVR5cGVDb2xvciBmcm9tICcuLi91dGlscy9yZXNvdXJjZVR5cGVDb2xvcic7XG5pbXBvcnQgeyByZXNvdXJjZUVtYmVkVHlwZU1hcHBpbmcgfSBmcm9tICcuLi9tb2RlbC9Db250ZW50VHlwZSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgUmVzb3VyY2VJbWFnZVByb3BzIHtcbiAgYWx0OiBzdHJpbmc7XG4gIHNyYzogc3RyaW5nO1xufVxuXG5leHBvcnQgY29uc3QgUmVzb3VyY2VUaXRsZUxpbmsgPSBzdHlsZWQoU2FmZUxpbmspYFxuICBib3gtc2hhZG93OiBub25lO1xuICBjb2xvcjogJHtjb2xvcnMuYnJhbmQucHJpbWFyeX07XG4gIGZsZXg6IDE7XG4gIDphZnRlciB7XG4gICAgY29udGVudDogJyc7XG4gICAgcG9zaXRpb246IGFic29sdXRlO1xuICAgIHotaW5kZXg6IDE7XG4gICAgdG9wOiAwO1xuICAgIHJpZ2h0OiAwO1xuICAgIGJvdHRvbTogMDtcbiAgICBsZWZ0OiAwO1xuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgUmVzb3VyY2VUaXRsZSA9IHN0eWxlZC5zcGFuYFxuICBtYXJnaW46IDA7XG4gIG92ZXJmbG93OiBoaWRkZW47XG4gIHRleHQtb3ZlcmZsb3c6IGVsbGlwc2lzO1xuICBmb250LXdlaWdodDogJHtmb250cy53ZWlnaHQuYm9sZH07XG4gIC8vIFVuZm9ydHVuYXRlIGNzcyBuZWVkZWQgZm9yIG11bHRpLWxpbmUgdGV4dCBvdmVyZmxvdyBlbGxpcHNpcy5cbiAgbGluZS1oZWlnaHQ6IDE7XG4gIGRpc3BsYXk6IC13ZWJraXQtYm94O1xuICAtd2Via2l0LWxpbmUtY2xhbXA6IDE7XG4gIGxpbmUtY2xhbXA6IDE7XG4gIC13ZWJraXQtYm94LW9yaWVudDogdmVydGljYWw7XG4gIGdyaWQtYXJlYTogcmVzb3VyY2VUaXRsZTtcbiAgJHtmb250cy5zaXplcygnMTZweCcsICcyMHB4Jyl9O1xuYDtcblxuY29uc3QgU3R5bGVkVGFnTGlzdCA9IHN0eWxlZC51bGBcbiAgbGlzdC1zdHlsZTogbm9uZTtcbiAgZGlzcGxheTogZmxleDtcbiAgbWFyZ2luOiAwO1xuICBtYXJnaW4tbGVmdDogJHtzcGFjaW5nLnNtYWxsfTtcbiAgcGFkZGluZzogMnB4O1xuICBnYXA6ICR7c3BhY2luZy54c21hbGx9O1xuICBvdmVyZmxvdzogaGlkZGVuO1xuICA6bGFzdC1jaGlsZCB7XG4gICAgbWFyZ2luLXJpZ2h0OiAke3NwYWNpbmcuc21hbGx9O1xuICB9XG5gO1xuXG5jb25zdCBTdHlsZWRUYWdMaXN0RWxlbWVudCA9IHN0eWxlZC5saWBcbiAgbWFyZ2luOiAwO1xuICAke2ZvbnRzLnNpemVzKDE0KX07XG5gO1xuXG5jb25zdCBTdHlsZWRTYWZlTGluayA9IHN0eWxlZChTYWZlTGluaylgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGp1c3RpZnktY29udGVudDogZmxleC1lbmQ7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGJveC1zaGFkb3c6IG5vbmU7XG4gIGNvbG9yOiAke2NvbG9ycy5icmFuZC5ncmV5fTtcbiAgbWluLWhlaWdodDogNDRweDtcbiAgbWluLXdpZHRoOiA0NHB4O1xuICB3aGl0ZS1zcGFjZTogbm93cmFwO1xuICAmOmhvdmVyIHtcbiAgICBjb2xvcjogJHtjb2xvcnMuYnJhbmQucHJpbWFyeX07XG4gIH1cbmA7XG5cbmNvbnN0IFN0eWxlZFJlc291cmNlVHlwZUxpc3QgPSBzdHlsZWQudWxgXG4gIGxpc3Qtc3R5bGU6IG5vbmU7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIG1hcmdpbjogMDtcbiAgcGFkZGluZzogMDtcbiAgb3ZlcmZsb3c6IGhpZGRlbjtcbmA7XG5cbmNvbnN0IFN0eWxlZFRvcGljRGl2aWRlciA9IHN0eWxlZC5zcGFuYFxuICBtYXJnaW46IDA7XG4gIHBhZGRpbmc6IDAgJHtzcGFjaW5nLnh4c21hbGx9O1xuYDtcblxuY29uc3QgU3R5bGVkUmVzb3VyY2VMaXN0RWxlbWVudCA9IHN0eWxlZC5saWBcbiAgd2hpdGUtc3BhY2U6IG5vd3JhcDtcbiAgJHtmb250cy5zaXplcygxMil9O1xuICBtYXJnaW46IDA7XG4gIGxpbmUtaGVpZ2h0OiAxLjU7XG4gIHBhZGRpbmc6IDA7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5gO1xuXG5jb25zdCBUYWdDb3VudGVyV3JhcHBlciA9IHN0eWxlZC5zcGFuYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmb250LXdlaWdodDogJHtmb250cy53ZWlnaHQuc2VtaWJvbGR9O1xuICAke2ZvbnRzLnNpemVzKCcxNHB4JywgJzE0cHgnKX07XG5gO1xuXG5leHBvcnQgaW50ZXJmYWNlIENvbnRlbnRJY29uUHJvcHMge1xuICBjb250ZW50VHlwZTogc3RyaW5nO1xufVxuXG5leHBvcnQgY29uc3QgU3R5bGVkQ29udGVudEljb25XcmFwcGVyID0gc3R5bGVkLnNwYW48Q29udGVudEljb25Qcm9wcz5gXG4gIHdpZHRoOiAxMDAlO1xuICBhc3BlY3QtcmF0aW86IDQvMztcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG4gIGJhY2tncm91bmQtY29sb3I6ICR7KHsgY29udGVudFR5cGUgfSkgPT4gcmVzb3VyY2VUeXBlQ29sb3IoY29udGVudFR5cGUpfTtcbmA7XG5cbmludGVyZmFjZSBUYWdMaXN0UHJvcHMge1xuICB0YWdzPzogc3RyaW5nW107XG4gIHRhZ0xpbmtQcmVmaXg/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTG9hZGVyUHJvcHMge1xuICBsb2FkaW5nPzogYm9vbGVhbjtcbiAgY2hpbGRyZW4/OiBSZWFjdE5vZGU7XG59XG5cbmV4cG9ydCBjb25zdCBUYWdMaXN0ID0gKHsgdGFncywgdGFnTGlua1ByZWZpeCB9OiBUYWdMaXN0UHJvcHMpID0+IHtcbiAgY29uc3QgeyB0IH0gPSB1c2VUcmFuc2xhdGlvbigpO1xuICBpZiAoIXRhZ3MpIHJldHVybiBudWxsO1xuICByZXR1cm4gKFxuICAgIDxTdHlsZWRUYWdMaXN0IGFyaWEtbGFiZWw9e3QoJ215TmRsYS50YWdMaXN0Jyl9PlxuICAgICAge3RhZ3MubWFwKCh0YWcsIGkpID0+IChcbiAgICAgICAgPFN0eWxlZFRhZ0xpc3RFbGVtZW50IGtleT17YHRhZy0ke2l9YH0+XG4gICAgICAgICAgPFN0eWxlZFNhZmVMaW5rIHRvPXtgJHt0YWdMaW5rUHJlZml4ID8gdGFnTGlua1ByZWZpeCA6ICcnfS8ke2VuY29kZVVSSUNvbXBvbmVudCh0YWcpfWB9PlxuICAgICAgICAgICAgPEhhc2hUYWcgLz5cbiAgICAgICAgICAgIHt0YWd9XG4gICAgICAgICAgPC9TdHlsZWRTYWZlTGluaz5cbiAgICAgICAgPC9TdHlsZWRUYWdMaXN0RWxlbWVudD5cbiAgICAgICkpfVxuICAgIDwvU3R5bGVkVGFnTGlzdD5cbiAgKTtcbn07XG5cbmludGVyZmFjZSBDb21wcmVzc2VkVGFnTGlzdFByb3BzIHtcbiAgdGFnczogc3RyaW5nW107XG4gIHRhZ0xpbmtQcmVmaXg/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBjb25zdCBDb21wcmVzc2VkVGFnTGlzdCA9ICh7IHRhZ3MsIHRhZ0xpbmtQcmVmaXggfTogQ29tcHJlc3NlZFRhZ0xpc3RQcm9wcykgPT4ge1xuICBjb25zdCBuYXZpZ2F0ZSA9IHVzZU5hdmlnYXRlKCk7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcbiAgY29uc3QgdmlzaWJsZVRhZ3MgPSB0YWdzLnNsaWNlKDAsIDMpO1xuICBjb25zdCByZW1haW5pbmdUYWdzID0gdGFncy5zbGljZSgzLCB0YWdzLmxlbmd0aCkubWFwKCh0YWcpID0+IHtcbiAgICByZXR1cm4ge1xuICAgICAgaWNvbjogPEhhc2hUYWcgLz4sXG4gICAgICB0ZXh0OiB0YWcsXG4gICAgICBvbkNsaWNrOiAoKSA9PiB7XG4gICAgICAgIG5hdmlnYXRlKGAke3RhZ0xpbmtQcmVmaXggPyB0YWdMaW5rUHJlZml4IDogJyd9LyR7ZW5jb2RlVVJJQ29tcG9uZW50KHRhZyl9YCk7XG4gICAgICB9LFxuICAgIH07XG4gIH0pO1xuICByZXR1cm4gKFxuICAgIDw+XG4gICAgICA8VGFnTGlzdCB0YWdMaW5rUHJlZml4PXt0YWdMaW5rUHJlZml4fSB0YWdzPXt2aXNpYmxlVGFnc30gLz5cbiAgICAgIHtyZW1haW5pbmdUYWdzLmxlbmd0aCA+IDAgJiYgKFxuICAgICAgICA8TWVudUJ1dHRvblxuICAgICAgICAgIHNpemU9XCJzbWFsbFwiXG4gICAgICAgICAgbWVudUljb249ezxUYWdDb3VudGVyV3JhcHBlcj57YCske3JlbWFpbmluZ1RhZ3MubGVuZ3RofWB9PC9UYWdDb3VudGVyV3JhcHBlcj59XG4gICAgICAgICAgbWVudUl0ZW1zPXtyZW1haW5pbmdUYWdzfVxuICAgICAgICAgIGFsaWduPVwiZW5kXCJcbiAgICAgICAgICBhcmlhLWxhYmVsPXt0KCdteU5kbGEubW9yZVRhZ3MnLCB7IGNvdW50OiByZW1haW5pbmdUYWdzLmxlbmd0aCB9KX1cbiAgICAgICAgLz5cbiAgICAgICl9XG4gICAgPC8+XG4gICk7XG59O1xuXG5pbnRlcmZhY2UgUmVzb3VyY2VUeXBlTGlzdFByb3BzIHtcbiAgcmVzb3VyY2VUeXBlcz86IHsgaWQ6IHN0cmluZzsgbmFtZTogc3RyaW5nIH1bXTtcbn1cblxuZXhwb3J0IGNvbnN0IFJlc291cmNlVHlwZUxpc3QgPSAoeyByZXNvdXJjZVR5cGVzIH06IFJlc291cmNlVHlwZUxpc3RQcm9wcykgPT4ge1xuICBjb25zdCB7IHQgfSA9IHVzZVRyYW5zbGF0aW9uKCk7XG4gIGlmICghcmVzb3VyY2VUeXBlcykgcmV0dXJuIG51bGw7XG4gIHJldHVybiAoXG4gICAgPFN0eWxlZFJlc291cmNlVHlwZUxpc3QgYXJpYS1sYWJlbD17dCgnbmF2aWdhdGlvbi50b3BpY3MnKX0+XG4gICAgICB7cmVzb3VyY2VUeXBlcy5tYXAoKHJlc291cmNlLCBpKSA9PiAoXG4gICAgICAgIDxTdHlsZWRSZXNvdXJjZUxpc3RFbGVtZW50IGtleT17cmVzb3VyY2UuaWR9PlxuICAgICAgICAgIHtyZXNvdXJjZUVtYmVkVHlwZU1hcHBpbmdbcmVzb3VyY2UuaWRdXG4gICAgICAgICAgICA/IHQoYGVtYmVkLnR5cGUuJHtyZXNvdXJjZUVtYmVkVHlwZU1hcHBpbmdbcmVzb3VyY2UuaWRdfWApXG4gICAgICAgICAgICA6IHJlc291cmNlLm5hbWV9XG4gICAgICAgICAge2kgIT09IHJlc291cmNlVHlwZXMubGVuZ3RoIC0gMSAmJiA8U3R5bGVkVG9waWNEaXZpZGVyIGFyaWEtaGlkZGVuPVwidHJ1ZVwiPuKAojwvU3R5bGVkVG9waWNEaXZpZGVyPn1cbiAgICAgICAgPC9TdHlsZWRSZXNvdXJjZUxpc3RFbGVtZW50PlxuICAgICAgKSl9XG4gICAgPC9TdHlsZWRSZXNvdXJjZVR5cGVMaXN0PlxuICApO1xufTtcbiJdfQ== */",
59
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["resourceComponents.tsx"],"names":[],"mappings":"AAuFwC","file":"resourceComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2022-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 styled from '@emotion/styled';\nimport { colors, fonts, spacing } from '@ndla/core';\nimport React, { CSSProperties, HTMLAttributes, ReactNode, useMemo } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { MenuButton } from '@ndla/button';\nimport SafeLink from '@ndla/safelink';\nimport { useNavigate } from 'react-router-dom';\nimport { HashTag } from '@ndla/icons/common';\nimport { css } from '@emotion/react';\nimport resourceTypeColor from '../utils/resourceTypeColor';\nimport { resourceEmbedTypeMapping } from '../model/ContentType';\n\nexport interface ResourceImageProps {\n  alt: string;\n  src: string;\n}\n\nexport const ResourceTitleLink = styled(SafeLink)`\n  box-shadow: none;\n  color: ${colors.brand.primary};\n  flex: 1;\n  :after {\n    content: '';\n    position: absolute;\n    z-index: 1;\n    top: 0;\n    right: 0;\n    bottom: 0;\n    left: 0;\n  }\n`;\n\nexport const resourceHeadingStyle = css`\n  margin: 0;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  font-weight: ${fonts.weight.bold};\n  // Unfortunate css needed for multi-line text overflow ellipsis.\n  line-height: 1;\n  display: -webkit-box;\n  -webkit-line-clamp: 1;\n  line-clamp: 1;\n  -webkit-box-orient: vertical;\n  grid-area: resourceTitle;\n  ${fonts.sizes('16px', '20px')};\n`;\n\nconst StyledTagList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  margin-left: ${spacing.small};\n  padding: 2px;\n  gap: ${spacing.xsmall};\n  overflow: hidden;\n  :last-child {\n    margin-right: ${spacing.small};\n  }\n`;\n\nconst StyledTagListElement = styled.li`\n  margin: 0;\n  ${fonts.sizes(14)};\n`;\n\nconst StyledSafeLink = styled(SafeLink)`\n  display: flex;\n  justify-content: flex-end;\n  align-items: center;\n  box-shadow: none;\n  color: ${colors.brand.grey};\n  min-height: 44px;\n  min-width: 44px;\n  white-space: nowrap;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n`;\n\nconst StyledResourceTypeList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  padding: 0;\n  overflow: hidden;\n`;\n\nconst StyledTopicDivider = styled.span`\n  margin: 0;\n  padding: 0 ${spacing.xxsmall};\n`;\n\nconst StyledResourceListElement = styled.li`\n  white-space: nowrap;\n  ${fonts.sizes(12)};\n  margin: 0;\n  line-height: 1.5;\n  padding: 0;\n  display: flex;\n  align-items: center;\n`;\n\nconst TagCounterWrapper = styled.span`\n  display: flex;\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('14px', '14px')};\n`;\n\ninterface ContentIconProps extends HTMLAttributes<HTMLSpanElement> {\n  contentType: string;\n  children?: ReactNode;\n}\n\nconst StyledContentIconWrapper = styled.span`\n  width: 100%;\n  aspect-ratio: 4/3;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  background-color: var(--content-background-color);\n`;\n\nexport const ContentIconWrapper = ({ contentType, children, ...props }: ContentIconProps) => {\n  const contentIconWrapperVars = useMemo(\n    () => ({ '--content-background-color': resourceTypeColor(contentType) } as unknown as CSSProperties),\n    [contentType],\n  );\n  return (\n    <StyledContentIconWrapper {...props} style={contentIconWrapperVars}>\n      {children}\n    </StyledContentIconWrapper>\n  );\n};\n\ninterface TagListProps {\n  tags?: string[];\n  tagLinkPrefix?: string;\n}\n\nexport interface LoaderProps {\n  loading?: boolean;\n  children?: ReactNode;\n}\n\nexport const TagList = ({ tags, tagLinkPrefix }: TagListProps) => {\n  const { t } = useTranslation();\n  if (!tags) return null;\n  return (\n    <StyledTagList aria-label={t('myNdla.tagList')}>\n      {tags.map((tag, i) => (\n        <StyledTagListElement key={`tag-${i}`}>\n          <StyledSafeLink to={`${tagLinkPrefix ? tagLinkPrefix : ''}/${encodeURIComponent(tag)}`}>\n            <HashTag />\n            {tag}\n          </StyledSafeLink>\n        </StyledTagListElement>\n      ))}\n    </StyledTagList>\n  );\n};\n\ninterface CompressedTagListProps {\n  tags: string[];\n  tagLinkPrefix?: string;\n}\n\nexport const CompressedTagList = ({ tags, tagLinkPrefix }: CompressedTagListProps) => {\n  const navigate = useNavigate();\n  const { t } = useTranslation();\n  const visibleTags = useMemo(() => tags.slice(0, 3), [tags]);\n  const remainingTags = useMemo(\n    () =>\n      tags.slice(3, tags.length).map((tag) => {\n        return {\n          icon: <HashTag />,\n          text: tag,\n          onClick: () => {\n            navigate(`${tagLinkPrefix ? tagLinkPrefix : ''}/${encodeURIComponent(tag)}`);\n          },\n        };\n      }),\n    [navigate, tagLinkPrefix, tags],\n  );\n\n  return (\n    <>\n      <TagList tagLinkPrefix={tagLinkPrefix} tags={visibleTags} />\n      {remainingTags.length > 0 && (\n        <MenuButton\n          size=\"small\"\n          menuIcon={<TagCounterWrapper>{`+${remainingTags.length}`}</TagCounterWrapper>}\n          menuItems={remainingTags}\n          align=\"end\"\n          aria-label={t('myNdla.moreTags', { count: remainingTags.length })}\n        />\n      )}\n    </>\n  );\n};\n\ninterface ResourceTypeListProps {\n  resourceTypes?: { id: string; name: string }[];\n}\n\nexport const ResourceTypeList = ({ resourceTypes }: ResourceTypeListProps) => {\n  const { t } = useTranslation();\n  if (!resourceTypes) return null;\n  return (\n    <StyledResourceTypeList aria-label={t('navigation.topics')}>\n      {resourceTypes.map((resource, i) => (\n        <StyledResourceListElement key={resource.id}>\n          {resourceEmbedTypeMapping[resource.id]\n            ? t(`embed.type.${resourceEmbedTypeMapping[resource.id]}`)\n            : resource.name}\n          {i !== resourceTypes.length - 1 && <StyledTopicDivider aria-hidden=\"true\">•</StyledTopicDivider>}\n        </StyledResourceListElement>\n      ))}\n    </StyledResourceTypeList>\n  );\n};\n"]} */",
53
60
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
54
61
  });
55
62
  var StyledTopicDivider = /*#__PURE__*/_styled("span", {
56
63
  target: "e1lrrm6s3",
57
64
  label: "StyledTopicDivider"
58
- })("margin:0;padding:0 ", spacing.xxsmall, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInJlc291cmNlQ29tcG9uZW50cy50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBOEZzQyIsImZpbGUiOiJyZXNvdXJjZUNvbXBvbmVudHMudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjItcHJlc2VudCwgTkRMQS5cbiAqXG4gKiBUaGlzIHNvdXJjZSBjb2RlIGlzIGxpY2Vuc2VkIHVuZGVyIHRoZSBHUEx2MyBsaWNlbnNlIGZvdW5kIGluIHRoZVxuICogTElDRU5TRSBmaWxlIGluIHRoZSByb290IGRpcmVjdG9yeSBvZiB0aGlzIHNvdXJjZSB0cmVlLlxuICpcbiAqL1xuXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBjb2xvcnMsIGZvbnRzLCBzcGFjaW5nIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgUmVhY3QsIHsgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgdXNlVHJhbnNsYXRpb24gfSBmcm9tICdyZWFjdC1pMThuZXh0JztcbmltcG9ydCB7IE1lbnVCdXR0b24gfSBmcm9tICdAbmRsYS9idXR0b24nO1xuaW1wb3J0IFNhZmVMaW5rIGZyb20gJ0BuZGxhL3NhZmVsaW5rJztcbmltcG9ydCB7IHVzZU5hdmlnYXRlIH0gZnJvbSAncmVhY3Qtcm91dGVyLWRvbSc7XG5pbXBvcnQgeyBIYXNoVGFnIH0gZnJvbSAnQG5kbGEvaWNvbnMvY29tbW9uJztcbmltcG9ydCByZXNvdXJjZVR5cGVDb2xvciBmcm9tICcuLi91dGlscy9yZXNvdXJjZVR5cGVDb2xvcic7XG5pbXBvcnQgeyByZXNvdXJjZUVtYmVkVHlwZU1hcHBpbmcgfSBmcm9tICcuLi9tb2RlbC9Db250ZW50VHlwZSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgUmVzb3VyY2VJbWFnZVByb3BzIHtcbiAgYWx0OiBzdHJpbmc7XG4gIHNyYzogc3RyaW5nO1xufVxuXG5leHBvcnQgY29uc3QgUmVzb3VyY2VUaXRsZUxpbmsgPSBzdHlsZWQoU2FmZUxpbmspYFxuICBib3gtc2hhZG93OiBub25lO1xuICBjb2xvcjogJHtjb2xvcnMuYnJhbmQucHJpbWFyeX07XG4gIGZsZXg6IDE7XG4gIDphZnRlciB7XG4gICAgY29udGVudDogJyc7XG4gICAgcG9zaXRpb246IGFic29sdXRlO1xuICAgIHotaW5kZXg6IDE7XG4gICAgdG9wOiAwO1xuICAgIHJpZ2h0OiAwO1xuICAgIGJvdHRvbTogMDtcbiAgICBsZWZ0OiAwO1xuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgUmVzb3VyY2VUaXRsZSA9IHN0eWxlZC5zcGFuYFxuICBtYXJnaW46IDA7XG4gIG92ZXJmbG93OiBoaWRkZW47XG4gIHRleHQtb3ZlcmZsb3c6IGVsbGlwc2lzO1xuICBmb250LXdlaWdodDogJHtmb250cy53ZWlnaHQuYm9sZH07XG4gIC8vIFVuZm9ydHVuYXRlIGNzcyBuZWVkZWQgZm9yIG11bHRpLWxpbmUgdGV4dCBvdmVyZmxvdyBlbGxpcHNpcy5cbiAgbGluZS1oZWlnaHQ6IDE7XG4gIGRpc3BsYXk6IC13ZWJraXQtYm94O1xuICAtd2Via2l0LWxpbmUtY2xhbXA6IDE7XG4gIGxpbmUtY2xhbXA6IDE7XG4gIC13ZWJraXQtYm94LW9yaWVudDogdmVydGljYWw7XG4gIGdyaWQtYXJlYTogcmVzb3VyY2VUaXRsZTtcbiAgJHtmb250cy5zaXplcygnMTZweCcsICcyMHB4Jyl9O1xuYDtcblxuY29uc3QgU3R5bGVkVGFnTGlzdCA9IHN0eWxlZC51bGBcbiAgbGlzdC1zdHlsZTogbm9uZTtcbiAgZGlzcGxheTogZmxleDtcbiAgbWFyZ2luOiAwO1xuICBtYXJnaW4tbGVmdDogJHtzcGFjaW5nLnNtYWxsfTtcbiAgcGFkZGluZzogMnB4O1xuICBnYXA6ICR7c3BhY2luZy54c21hbGx9O1xuICBvdmVyZmxvdzogaGlkZGVuO1xuICA6bGFzdC1jaGlsZCB7XG4gICAgbWFyZ2luLXJpZ2h0OiAke3NwYWNpbmcuc21hbGx9O1xuICB9XG5gO1xuXG5jb25zdCBTdHlsZWRUYWdMaXN0RWxlbWVudCA9IHN0eWxlZC5saWBcbiAgbWFyZ2luOiAwO1xuICAke2ZvbnRzLnNpemVzKDE0KX07XG5gO1xuXG5jb25zdCBTdHlsZWRTYWZlTGluayA9IHN0eWxlZChTYWZlTGluaylgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGp1c3RpZnktY29udGVudDogZmxleC1lbmQ7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGJveC1zaGFkb3c6IG5vbmU7XG4gIGNvbG9yOiAke2NvbG9ycy5icmFuZC5ncmV5fTtcbiAgbWluLWhlaWdodDogNDRweDtcbiAgbWluLXdpZHRoOiA0NHB4O1xuICB3aGl0ZS1zcGFjZTogbm93cmFwO1xuICAmOmhvdmVyIHtcbiAgICBjb2xvcjogJHtjb2xvcnMuYnJhbmQucHJpbWFyeX07XG4gIH1cbmA7XG5cbmNvbnN0IFN0eWxlZFJlc291cmNlVHlwZUxpc3QgPSBzdHlsZWQudWxgXG4gIGxpc3Qtc3R5bGU6IG5vbmU7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIG1hcmdpbjogMDtcbiAgcGFkZGluZzogMDtcbiAgb3ZlcmZsb3c6IGhpZGRlbjtcbmA7XG5cbmNvbnN0IFN0eWxlZFRvcGljRGl2aWRlciA9IHN0eWxlZC5zcGFuYFxuICBtYXJnaW46IDA7XG4gIHBhZGRpbmc6IDAgJHtzcGFjaW5nLnh4c21hbGx9O1xuYDtcblxuY29uc3QgU3R5bGVkUmVzb3VyY2VMaXN0RWxlbWVudCA9IHN0eWxlZC5saWBcbiAgd2hpdGUtc3BhY2U6IG5vd3JhcDtcbiAgJHtmb250cy5zaXplcygxMil9O1xuICBtYXJnaW46IDA7XG4gIGxpbmUtaGVpZ2h0OiAxLjU7XG4gIHBhZGRpbmc6IDA7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5gO1xuXG5jb25zdCBUYWdDb3VudGVyV3JhcHBlciA9IHN0eWxlZC5zcGFuYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmb250LXdlaWdodDogJHtmb250cy53ZWlnaHQuc2VtaWJvbGR9O1xuICAke2ZvbnRzLnNpemVzKCcxNHB4JywgJzE0cHgnKX07XG5gO1xuXG5leHBvcnQgaW50ZXJmYWNlIENvbnRlbnRJY29uUHJvcHMge1xuICBjb250ZW50VHlwZTogc3RyaW5nO1xufVxuXG5leHBvcnQgY29uc3QgU3R5bGVkQ29udGVudEljb25XcmFwcGVyID0gc3R5bGVkLnNwYW48Q29udGVudEljb25Qcm9wcz5gXG4gIHdpZHRoOiAxMDAlO1xuICBhc3BlY3QtcmF0aW86IDQvMztcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG4gIGJhY2tncm91bmQtY29sb3I6ICR7KHsgY29udGVudFR5cGUgfSkgPT4gcmVzb3VyY2VUeXBlQ29sb3IoY29udGVudFR5cGUpfTtcbmA7XG5cbmludGVyZmFjZSBUYWdMaXN0UHJvcHMge1xuICB0YWdzPzogc3RyaW5nW107XG4gIHRhZ0xpbmtQcmVmaXg/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTG9hZGVyUHJvcHMge1xuICBsb2FkaW5nPzogYm9vbGVhbjtcbiAgY2hpbGRyZW4/OiBSZWFjdE5vZGU7XG59XG5cbmV4cG9ydCBjb25zdCBUYWdMaXN0ID0gKHsgdGFncywgdGFnTGlua1ByZWZpeCB9OiBUYWdMaXN0UHJvcHMpID0+IHtcbiAgY29uc3QgeyB0IH0gPSB1c2VUcmFuc2xhdGlvbigpO1xuICBpZiAoIXRhZ3MpIHJldHVybiBudWxsO1xuICByZXR1cm4gKFxuICAgIDxTdHlsZWRUYWdMaXN0IGFyaWEtbGFiZWw9e3QoJ215TmRsYS50YWdMaXN0Jyl9PlxuICAgICAge3RhZ3MubWFwKCh0YWcsIGkpID0+IChcbiAgICAgICAgPFN0eWxlZFRhZ0xpc3RFbGVtZW50IGtleT17YHRhZy0ke2l9YH0+XG4gICAgICAgICAgPFN0eWxlZFNhZmVMaW5rIHRvPXtgJHt0YWdMaW5rUHJlZml4ID8gdGFnTGlua1ByZWZpeCA6ICcnfS8ke2VuY29kZVVSSUNvbXBvbmVudCh0YWcpfWB9PlxuICAgICAgICAgICAgPEhhc2hUYWcgLz5cbiAgICAgICAgICAgIHt0YWd9XG4gICAgICAgICAgPC9TdHlsZWRTYWZlTGluaz5cbiAgICAgICAgPC9TdHlsZWRUYWdMaXN0RWxlbWVudD5cbiAgICAgICkpfVxuICAgIDwvU3R5bGVkVGFnTGlzdD5cbiAgKTtcbn07XG5cbmludGVyZmFjZSBDb21wcmVzc2VkVGFnTGlzdFByb3BzIHtcbiAgdGFnczogc3RyaW5nW107XG4gIHRhZ0xpbmtQcmVmaXg/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBjb25zdCBDb21wcmVzc2VkVGFnTGlzdCA9ICh7IHRhZ3MsIHRhZ0xpbmtQcmVmaXggfTogQ29tcHJlc3NlZFRhZ0xpc3RQcm9wcykgPT4ge1xuICBjb25zdCBuYXZpZ2F0ZSA9IHVzZU5hdmlnYXRlKCk7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcbiAgY29uc3QgdmlzaWJsZVRhZ3MgPSB0YWdzLnNsaWNlKDAsIDMpO1xuICBjb25zdCByZW1haW5pbmdUYWdzID0gdGFncy5zbGljZSgzLCB0YWdzLmxlbmd0aCkubWFwKCh0YWcpID0+IHtcbiAgICByZXR1cm4ge1xuICAgICAgaWNvbjogPEhhc2hUYWcgLz4sXG4gICAgICB0ZXh0OiB0YWcsXG4gICAgICBvbkNsaWNrOiAoKSA9PiB7XG4gICAgICAgIG5hdmlnYXRlKGAke3RhZ0xpbmtQcmVmaXggPyB0YWdMaW5rUHJlZml4IDogJyd9LyR7ZW5jb2RlVVJJQ29tcG9uZW50KHRhZyl9YCk7XG4gICAgICB9LFxuICAgIH07XG4gIH0pO1xuICByZXR1cm4gKFxuICAgIDw+XG4gICAgICA8VGFnTGlzdCB0YWdMaW5rUHJlZml4PXt0YWdMaW5rUHJlZml4fSB0YWdzPXt2aXNpYmxlVGFnc30gLz5cbiAgICAgIHtyZW1haW5pbmdUYWdzLmxlbmd0aCA+IDAgJiYgKFxuICAgICAgICA8TWVudUJ1dHRvblxuICAgICAgICAgIHNpemU9XCJzbWFsbFwiXG4gICAgICAgICAgbWVudUljb249ezxUYWdDb3VudGVyV3JhcHBlcj57YCske3JlbWFpbmluZ1RhZ3MubGVuZ3RofWB9PC9UYWdDb3VudGVyV3JhcHBlcj59XG4gICAgICAgICAgbWVudUl0ZW1zPXtyZW1haW5pbmdUYWdzfVxuICAgICAgICAgIGFsaWduPVwiZW5kXCJcbiAgICAgICAgICBhcmlhLWxhYmVsPXt0KCdteU5kbGEubW9yZVRhZ3MnLCB7IGNvdW50OiByZW1haW5pbmdUYWdzLmxlbmd0aCB9KX1cbiAgICAgICAgLz5cbiAgICAgICl9XG4gICAgPC8+XG4gICk7XG59O1xuXG5pbnRlcmZhY2UgUmVzb3VyY2VUeXBlTGlzdFByb3BzIHtcbiAgcmVzb3VyY2VUeXBlcz86IHsgaWQ6IHN0cmluZzsgbmFtZTogc3RyaW5nIH1bXTtcbn1cblxuZXhwb3J0IGNvbnN0IFJlc291cmNlVHlwZUxpc3QgPSAoeyByZXNvdXJjZVR5cGVzIH06IFJlc291cmNlVHlwZUxpc3RQcm9wcykgPT4ge1xuICBjb25zdCB7IHQgfSA9IHVzZVRyYW5zbGF0aW9uKCk7XG4gIGlmICghcmVzb3VyY2VUeXBlcykgcmV0dXJuIG51bGw7XG4gIHJldHVybiAoXG4gICAgPFN0eWxlZFJlc291cmNlVHlwZUxpc3QgYXJpYS1sYWJlbD17dCgnbmF2aWdhdGlvbi50b3BpY3MnKX0+XG4gICAgICB7cmVzb3VyY2VUeXBlcy5tYXAoKHJlc291cmNlLCBpKSA9PiAoXG4gICAgICAgIDxTdHlsZWRSZXNvdXJjZUxpc3RFbGVtZW50IGtleT17cmVzb3VyY2UuaWR9PlxuICAgICAgICAgIHtyZXNvdXJjZUVtYmVkVHlwZU1hcHBpbmdbcmVzb3VyY2UuaWRdXG4gICAgICAgICAgICA/IHQoYGVtYmVkLnR5cGUuJHtyZXNvdXJjZUVtYmVkVHlwZU1hcHBpbmdbcmVzb3VyY2UuaWRdfWApXG4gICAgICAgICAgICA6IHJlc291cmNlLm5hbWV9XG4gICAgICAgICAge2kgIT09IHJlc291cmNlVHlwZXMubGVuZ3RoIC0gMSAmJiA8U3R5bGVkVG9waWNEaXZpZGVyIGFyaWEtaGlkZGVuPVwidHJ1ZVwiPuKAojwvU3R5bGVkVG9waWNEaXZpZGVyPn1cbiAgICAgICAgPC9TdHlsZWRSZXNvdXJjZUxpc3RFbGVtZW50PlxuICAgICAgKSl9XG4gICAgPC9TdHlsZWRSZXNvdXJjZVR5cGVMaXN0PlxuICApO1xufTtcbiJdfQ== */"));
65
+ })("margin:0;padding:0 ", spacing.xxsmall, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["resourceComponents.tsx"],"names":[],"mappings":"AA+FsC","file":"resourceComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2022-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 styled from '@emotion/styled';\nimport { colors, fonts, spacing } from '@ndla/core';\nimport React, { CSSProperties, HTMLAttributes, ReactNode, useMemo } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { MenuButton } from '@ndla/button';\nimport SafeLink from '@ndla/safelink';\nimport { useNavigate } from 'react-router-dom';\nimport { HashTag } from '@ndla/icons/common';\nimport { css } from '@emotion/react';\nimport resourceTypeColor from '../utils/resourceTypeColor';\nimport { resourceEmbedTypeMapping } from '../model/ContentType';\n\nexport interface ResourceImageProps {\n  alt: string;\n  src: string;\n}\n\nexport const ResourceTitleLink = styled(SafeLink)`\n  box-shadow: none;\n  color: ${colors.brand.primary};\n  flex: 1;\n  :after {\n    content: '';\n    position: absolute;\n    z-index: 1;\n    top: 0;\n    right: 0;\n    bottom: 0;\n    left: 0;\n  }\n`;\n\nexport const resourceHeadingStyle = css`\n  margin: 0;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  font-weight: ${fonts.weight.bold};\n  // Unfortunate css needed for multi-line text overflow ellipsis.\n  line-height: 1;\n  display: -webkit-box;\n  -webkit-line-clamp: 1;\n  line-clamp: 1;\n  -webkit-box-orient: vertical;\n  grid-area: resourceTitle;\n  ${fonts.sizes('16px', '20px')};\n`;\n\nconst StyledTagList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  margin-left: ${spacing.small};\n  padding: 2px;\n  gap: ${spacing.xsmall};\n  overflow: hidden;\n  :last-child {\n    margin-right: ${spacing.small};\n  }\n`;\n\nconst StyledTagListElement = styled.li`\n  margin: 0;\n  ${fonts.sizes(14)};\n`;\n\nconst StyledSafeLink = styled(SafeLink)`\n  display: flex;\n  justify-content: flex-end;\n  align-items: center;\n  box-shadow: none;\n  color: ${colors.brand.grey};\n  min-height: 44px;\n  min-width: 44px;\n  white-space: nowrap;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n`;\n\nconst StyledResourceTypeList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  padding: 0;\n  overflow: hidden;\n`;\n\nconst StyledTopicDivider = styled.span`\n  margin: 0;\n  padding: 0 ${spacing.xxsmall};\n`;\n\nconst StyledResourceListElement = styled.li`\n  white-space: nowrap;\n  ${fonts.sizes(12)};\n  margin: 0;\n  line-height: 1.5;\n  padding: 0;\n  display: flex;\n  align-items: center;\n`;\n\nconst TagCounterWrapper = styled.span`\n  display: flex;\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('14px', '14px')};\n`;\n\ninterface ContentIconProps extends HTMLAttributes<HTMLSpanElement> {\n  contentType: string;\n  children?: ReactNode;\n}\n\nconst StyledContentIconWrapper = styled.span`\n  width: 100%;\n  aspect-ratio: 4/3;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  background-color: var(--content-background-color);\n`;\n\nexport const ContentIconWrapper = ({ contentType, children, ...props }: ContentIconProps) => {\n  const contentIconWrapperVars = useMemo(\n    () => ({ '--content-background-color': resourceTypeColor(contentType) } as unknown as CSSProperties),\n    [contentType],\n  );\n  return (\n    <StyledContentIconWrapper {...props} style={contentIconWrapperVars}>\n      {children}\n    </StyledContentIconWrapper>\n  );\n};\n\ninterface TagListProps {\n  tags?: string[];\n  tagLinkPrefix?: string;\n}\n\nexport interface LoaderProps {\n  loading?: boolean;\n  children?: ReactNode;\n}\n\nexport const TagList = ({ tags, tagLinkPrefix }: TagListProps) => {\n  const { t } = useTranslation();\n  if (!tags) return null;\n  return (\n    <StyledTagList aria-label={t('myNdla.tagList')}>\n      {tags.map((tag, i) => (\n        <StyledTagListElement key={`tag-${i}`}>\n          <StyledSafeLink to={`${tagLinkPrefix ? tagLinkPrefix : ''}/${encodeURIComponent(tag)}`}>\n            <HashTag />\n            {tag}\n          </StyledSafeLink>\n        </StyledTagListElement>\n      ))}\n    </StyledTagList>\n  );\n};\n\ninterface CompressedTagListProps {\n  tags: string[];\n  tagLinkPrefix?: string;\n}\n\nexport const CompressedTagList = ({ tags, tagLinkPrefix }: CompressedTagListProps) => {\n  const navigate = useNavigate();\n  const { t } = useTranslation();\n  const visibleTags = useMemo(() => tags.slice(0, 3), [tags]);\n  const remainingTags = useMemo(\n    () =>\n      tags.slice(3, tags.length).map((tag) => {\n        return {\n          icon: <HashTag />,\n          text: tag,\n          onClick: () => {\n            navigate(`${tagLinkPrefix ? tagLinkPrefix : ''}/${encodeURIComponent(tag)}`);\n          },\n        };\n      }),\n    [navigate, tagLinkPrefix, tags],\n  );\n\n  return (\n    <>\n      <TagList tagLinkPrefix={tagLinkPrefix} tags={visibleTags} />\n      {remainingTags.length > 0 && (\n        <MenuButton\n          size=\"small\"\n          menuIcon={<TagCounterWrapper>{`+${remainingTags.length}`}</TagCounterWrapper>}\n          menuItems={remainingTags}\n          align=\"end\"\n          aria-label={t('myNdla.moreTags', { count: remainingTags.length })}\n        />\n      )}\n    </>\n  );\n};\n\ninterface ResourceTypeListProps {\n  resourceTypes?: { id: string; name: string }[];\n}\n\nexport const ResourceTypeList = ({ resourceTypes }: ResourceTypeListProps) => {\n  const { t } = useTranslation();\n  if (!resourceTypes) return null;\n  return (\n    <StyledResourceTypeList aria-label={t('navigation.topics')}>\n      {resourceTypes.map((resource, i) => (\n        <StyledResourceListElement key={resource.id}>\n          {resourceEmbedTypeMapping[resource.id]\n            ? t(`embed.type.${resourceEmbedTypeMapping[resource.id]}`)\n            : resource.name}\n          {i !== resourceTypes.length - 1 && <StyledTopicDivider aria-hidden=\"true\">•</StyledTopicDivider>}\n        </StyledResourceListElement>\n      ))}\n    </StyledResourceTypeList>\n  );\n};\n"]} */"));
59
66
  var StyledResourceListElement = /*#__PURE__*/_styled("li", {
60
67
  target: "e1lrrm6s2",
61
68
  label: "StyledResourceListElement"
62
- })("white-space:nowrap;", fonts.sizes(12), ";margin:0;line-height:1.5;padding:0;display:flex;align-items:center;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInJlc291cmNlQ29tcG9uZW50cy50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBbUcyQyIsImZpbGUiOiJyZXNvdXJjZUNvbXBvbmVudHMudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjItcHJlc2VudCwgTkRMQS5cbiAqXG4gKiBUaGlzIHNvdXJjZSBjb2RlIGlzIGxpY2Vuc2VkIHVuZGVyIHRoZSBHUEx2MyBsaWNlbnNlIGZvdW5kIGluIHRoZVxuICogTElDRU5TRSBmaWxlIGluIHRoZSByb290IGRpcmVjdG9yeSBvZiB0aGlzIHNvdXJjZSB0cmVlLlxuICpcbiAqL1xuXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBjb2xvcnMsIGZvbnRzLCBzcGFjaW5nIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgUmVhY3QsIHsgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgdXNlVHJhbnNsYXRpb24gfSBmcm9tICdyZWFjdC1pMThuZXh0JztcbmltcG9ydCB7IE1lbnVCdXR0b24gfSBmcm9tICdAbmRsYS9idXR0b24nO1xuaW1wb3J0IFNhZmVMaW5rIGZyb20gJ0BuZGxhL3NhZmVsaW5rJztcbmltcG9ydCB7IHVzZU5hdmlnYXRlIH0gZnJvbSAncmVhY3Qtcm91dGVyLWRvbSc7XG5pbXBvcnQgeyBIYXNoVGFnIH0gZnJvbSAnQG5kbGEvaWNvbnMvY29tbW9uJztcbmltcG9ydCByZXNvdXJjZVR5cGVDb2xvciBmcm9tICcuLi91dGlscy9yZXNvdXJjZVR5cGVDb2xvcic7XG5pbXBvcnQgeyByZXNvdXJjZUVtYmVkVHlwZU1hcHBpbmcgfSBmcm9tICcuLi9tb2RlbC9Db250ZW50VHlwZSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgUmVzb3VyY2VJbWFnZVByb3BzIHtcbiAgYWx0OiBzdHJpbmc7XG4gIHNyYzogc3RyaW5nO1xufVxuXG5leHBvcnQgY29uc3QgUmVzb3VyY2VUaXRsZUxpbmsgPSBzdHlsZWQoU2FmZUxpbmspYFxuICBib3gtc2hhZG93OiBub25lO1xuICBjb2xvcjogJHtjb2xvcnMuYnJhbmQucHJpbWFyeX07XG4gIGZsZXg6IDE7XG4gIDphZnRlciB7XG4gICAgY29udGVudDogJyc7XG4gICAgcG9zaXRpb246IGFic29sdXRlO1xuICAgIHotaW5kZXg6IDE7XG4gICAgdG9wOiAwO1xuICAgIHJpZ2h0OiAwO1xuICAgIGJvdHRvbTogMDtcbiAgICBsZWZ0OiAwO1xuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgUmVzb3VyY2VUaXRsZSA9IHN0eWxlZC5zcGFuYFxuICBtYXJnaW46IDA7XG4gIG92ZXJmbG93OiBoaWRkZW47XG4gIHRleHQtb3ZlcmZsb3c6IGVsbGlwc2lzO1xuICBmb250LXdlaWdodDogJHtmb250cy53ZWlnaHQuYm9sZH07XG4gIC8vIFVuZm9ydHVuYXRlIGNzcyBuZWVkZWQgZm9yIG11bHRpLWxpbmUgdGV4dCBvdmVyZmxvdyBlbGxpcHNpcy5cbiAgbGluZS1oZWlnaHQ6IDE7XG4gIGRpc3BsYXk6IC13ZWJraXQtYm94O1xuICAtd2Via2l0LWxpbmUtY2xhbXA6IDE7XG4gIGxpbmUtY2xhbXA6IDE7XG4gIC13ZWJraXQtYm94LW9yaWVudDogdmVydGljYWw7XG4gIGdyaWQtYXJlYTogcmVzb3VyY2VUaXRsZTtcbiAgJHtmb250cy5zaXplcygnMTZweCcsICcyMHB4Jyl9O1xuYDtcblxuY29uc3QgU3R5bGVkVGFnTGlzdCA9IHN0eWxlZC51bGBcbiAgbGlzdC1zdHlsZTogbm9uZTtcbiAgZGlzcGxheTogZmxleDtcbiAgbWFyZ2luOiAwO1xuICBtYXJnaW4tbGVmdDogJHtzcGFjaW5nLnNtYWxsfTtcbiAgcGFkZGluZzogMnB4O1xuICBnYXA6ICR7c3BhY2luZy54c21hbGx9O1xuICBvdmVyZmxvdzogaGlkZGVuO1xuICA6bGFzdC1jaGlsZCB7XG4gICAgbWFyZ2luLXJpZ2h0OiAke3NwYWNpbmcuc21hbGx9O1xuICB9XG5gO1xuXG5jb25zdCBTdHlsZWRUYWdMaXN0RWxlbWVudCA9IHN0eWxlZC5saWBcbiAgbWFyZ2luOiAwO1xuICAke2ZvbnRzLnNpemVzKDE0KX07XG5gO1xuXG5jb25zdCBTdHlsZWRTYWZlTGluayA9IHN0eWxlZChTYWZlTGluaylgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGp1c3RpZnktY29udGVudDogZmxleC1lbmQ7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGJveC1zaGFkb3c6IG5vbmU7XG4gIGNvbG9yOiAke2NvbG9ycy5icmFuZC5ncmV5fTtcbiAgbWluLWhlaWdodDogNDRweDtcbiAgbWluLXdpZHRoOiA0NHB4O1xuICB3aGl0ZS1zcGFjZTogbm93cmFwO1xuICAmOmhvdmVyIHtcbiAgICBjb2xvcjogJHtjb2xvcnMuYnJhbmQucHJpbWFyeX07XG4gIH1cbmA7XG5cbmNvbnN0IFN0eWxlZFJlc291cmNlVHlwZUxpc3QgPSBzdHlsZWQudWxgXG4gIGxpc3Qtc3R5bGU6IG5vbmU7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIG1hcmdpbjogMDtcbiAgcGFkZGluZzogMDtcbiAgb3ZlcmZsb3c6IGhpZGRlbjtcbmA7XG5cbmNvbnN0IFN0eWxlZFRvcGljRGl2aWRlciA9IHN0eWxlZC5zcGFuYFxuICBtYXJnaW46IDA7XG4gIHBhZGRpbmc6IDAgJHtzcGFjaW5nLnh4c21hbGx9O1xuYDtcblxuY29uc3QgU3R5bGVkUmVzb3VyY2VMaXN0RWxlbWVudCA9IHN0eWxlZC5saWBcbiAgd2hpdGUtc3BhY2U6IG5vd3JhcDtcbiAgJHtmb250cy5zaXplcygxMil9O1xuICBtYXJnaW46IDA7XG4gIGxpbmUtaGVpZ2h0OiAxLjU7XG4gIHBhZGRpbmc6IDA7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5gO1xuXG5jb25zdCBUYWdDb3VudGVyV3JhcHBlciA9IHN0eWxlZC5zcGFuYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmb250LXdlaWdodDogJHtmb250cy53ZWlnaHQuc2VtaWJvbGR9O1xuICAke2ZvbnRzLnNpemVzKCcxNHB4JywgJzE0cHgnKX07XG5gO1xuXG5leHBvcnQgaW50ZXJmYWNlIENvbnRlbnRJY29uUHJvcHMge1xuICBjb250ZW50VHlwZTogc3RyaW5nO1xufVxuXG5leHBvcnQgY29uc3QgU3R5bGVkQ29udGVudEljb25XcmFwcGVyID0gc3R5bGVkLnNwYW48Q29udGVudEljb25Qcm9wcz5gXG4gIHdpZHRoOiAxMDAlO1xuICBhc3BlY3QtcmF0aW86IDQvMztcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG4gIGJhY2tncm91bmQtY29sb3I6ICR7KHsgY29udGVudFR5cGUgfSkgPT4gcmVzb3VyY2VUeXBlQ29sb3IoY29udGVudFR5cGUpfTtcbmA7XG5cbmludGVyZmFjZSBUYWdMaXN0UHJvcHMge1xuICB0YWdzPzogc3RyaW5nW107XG4gIHRhZ0xpbmtQcmVmaXg/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTG9hZGVyUHJvcHMge1xuICBsb2FkaW5nPzogYm9vbGVhbjtcbiAgY2hpbGRyZW4/OiBSZWFjdE5vZGU7XG59XG5cbmV4cG9ydCBjb25zdCBUYWdMaXN0ID0gKHsgdGFncywgdGFnTGlua1ByZWZpeCB9OiBUYWdMaXN0UHJvcHMpID0+IHtcbiAgY29uc3QgeyB0IH0gPSB1c2VUcmFuc2xhdGlvbigpO1xuICBpZiAoIXRhZ3MpIHJldHVybiBudWxsO1xuICByZXR1cm4gKFxuICAgIDxTdHlsZWRUYWdMaXN0IGFyaWEtbGFiZWw9e3QoJ215TmRsYS50YWdMaXN0Jyl9PlxuICAgICAge3RhZ3MubWFwKCh0YWcsIGkpID0+IChcbiAgICAgICAgPFN0eWxlZFRhZ0xpc3RFbGVtZW50IGtleT17YHRhZy0ke2l9YH0+XG4gICAgICAgICAgPFN0eWxlZFNhZmVMaW5rIHRvPXtgJHt0YWdMaW5rUHJlZml4ID8gdGFnTGlua1ByZWZpeCA6ICcnfS8ke2VuY29kZVVSSUNvbXBvbmVudCh0YWcpfWB9PlxuICAgICAgICAgICAgPEhhc2hUYWcgLz5cbiAgICAgICAgICAgIHt0YWd9XG4gICAgICAgICAgPC9TdHlsZWRTYWZlTGluaz5cbiAgICAgICAgPC9TdHlsZWRUYWdMaXN0RWxlbWVudD5cbiAgICAgICkpfVxuICAgIDwvU3R5bGVkVGFnTGlzdD5cbiAgKTtcbn07XG5cbmludGVyZmFjZSBDb21wcmVzc2VkVGFnTGlzdFByb3BzIHtcbiAgdGFnczogc3RyaW5nW107XG4gIHRhZ0xpbmtQcmVmaXg/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBjb25zdCBDb21wcmVzc2VkVGFnTGlzdCA9ICh7IHRhZ3MsIHRhZ0xpbmtQcmVmaXggfTogQ29tcHJlc3NlZFRhZ0xpc3RQcm9wcykgPT4ge1xuICBjb25zdCBuYXZpZ2F0ZSA9IHVzZU5hdmlnYXRlKCk7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcbiAgY29uc3QgdmlzaWJsZVRhZ3MgPSB0YWdzLnNsaWNlKDAsIDMpO1xuICBjb25zdCByZW1haW5pbmdUYWdzID0gdGFncy5zbGljZSgzLCB0YWdzLmxlbmd0aCkubWFwKCh0YWcpID0+IHtcbiAgICByZXR1cm4ge1xuICAgICAgaWNvbjogPEhhc2hUYWcgLz4sXG4gICAgICB0ZXh0OiB0YWcsXG4gICAgICBvbkNsaWNrOiAoKSA9PiB7XG4gICAgICAgIG5hdmlnYXRlKGAke3RhZ0xpbmtQcmVmaXggPyB0YWdMaW5rUHJlZml4IDogJyd9LyR7ZW5jb2RlVVJJQ29tcG9uZW50KHRhZyl9YCk7XG4gICAgICB9LFxuICAgIH07XG4gIH0pO1xuICByZXR1cm4gKFxuICAgIDw+XG4gICAgICA8VGFnTGlzdCB0YWdMaW5rUHJlZml4PXt0YWdMaW5rUHJlZml4fSB0YWdzPXt2aXNpYmxlVGFnc30gLz5cbiAgICAgIHtyZW1haW5pbmdUYWdzLmxlbmd0aCA+IDAgJiYgKFxuICAgICAgICA8TWVudUJ1dHRvblxuICAgICAgICAgIHNpemU9XCJzbWFsbFwiXG4gICAgICAgICAgbWVudUljb249ezxUYWdDb3VudGVyV3JhcHBlcj57YCske3JlbWFpbmluZ1RhZ3MubGVuZ3RofWB9PC9UYWdDb3VudGVyV3JhcHBlcj59XG4gICAgICAgICAgbWVudUl0ZW1zPXtyZW1haW5pbmdUYWdzfVxuICAgICAgICAgIGFsaWduPVwiZW5kXCJcbiAgICAgICAgICBhcmlhLWxhYmVsPXt0KCdteU5kbGEubW9yZVRhZ3MnLCB7IGNvdW50OiByZW1haW5pbmdUYWdzLmxlbmd0aCB9KX1cbiAgICAgICAgLz5cbiAgICAgICl9XG4gICAgPC8+XG4gICk7XG59O1xuXG5pbnRlcmZhY2UgUmVzb3VyY2VUeXBlTGlzdFByb3BzIHtcbiAgcmVzb3VyY2VUeXBlcz86IHsgaWQ6IHN0cmluZzsgbmFtZTogc3RyaW5nIH1bXTtcbn1cblxuZXhwb3J0IGNvbnN0IFJlc291cmNlVHlwZUxpc3QgPSAoeyByZXNvdXJjZVR5cGVzIH06IFJlc291cmNlVHlwZUxpc3RQcm9wcykgPT4ge1xuICBjb25zdCB7IHQgfSA9IHVzZVRyYW5zbGF0aW9uKCk7XG4gIGlmICghcmVzb3VyY2VUeXBlcykgcmV0dXJuIG51bGw7XG4gIHJldHVybiAoXG4gICAgPFN0eWxlZFJlc291cmNlVHlwZUxpc3QgYXJpYS1sYWJlbD17dCgnbmF2aWdhdGlvbi50b3BpY3MnKX0+XG4gICAgICB7cmVzb3VyY2VUeXBlcy5tYXAoKHJlc291cmNlLCBpKSA9PiAoXG4gICAgICAgIDxTdHlsZWRSZXNvdXJjZUxpc3RFbGVtZW50IGtleT17cmVzb3VyY2UuaWR9PlxuICAgICAgICAgIHtyZXNvdXJjZUVtYmVkVHlwZU1hcHBpbmdbcmVzb3VyY2UuaWRdXG4gICAgICAgICAgICA/IHQoYGVtYmVkLnR5cGUuJHtyZXNvdXJjZUVtYmVkVHlwZU1hcHBpbmdbcmVzb3VyY2UuaWRdfWApXG4gICAgICAgICAgICA6IHJlc291cmNlLm5hbWV9XG4gICAgICAgICAge2kgIT09IHJlc291cmNlVHlwZXMubGVuZ3RoIC0gMSAmJiA8U3R5bGVkVG9waWNEaXZpZGVyIGFyaWEtaGlkZGVuPVwidHJ1ZVwiPuKAojwvU3R5bGVkVG9waWNEaXZpZGVyPn1cbiAgICAgICAgPC9TdHlsZWRSZXNvdXJjZUxpc3RFbGVtZW50PlxuICAgICAgKSl9XG4gICAgPC9TdHlsZWRSZXNvdXJjZVR5cGVMaXN0PlxuICApO1xufTtcbiJdfQ== */"));
69
+ })("white-space:nowrap;", fonts.sizes(12), ";margin:0;line-height:1.5;padding:0;display:flex;align-items:center;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["resourceComponents.tsx"],"names":[],"mappings":"AAoG2C","file":"resourceComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2022-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 styled from '@emotion/styled';\nimport { colors, fonts, spacing } from '@ndla/core';\nimport React, { CSSProperties, HTMLAttributes, ReactNode, useMemo } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { MenuButton } from '@ndla/button';\nimport SafeLink from '@ndla/safelink';\nimport { useNavigate } from 'react-router-dom';\nimport { HashTag } from '@ndla/icons/common';\nimport { css } from '@emotion/react';\nimport resourceTypeColor from '../utils/resourceTypeColor';\nimport { resourceEmbedTypeMapping } from '../model/ContentType';\n\nexport interface ResourceImageProps {\n  alt: string;\n  src: string;\n}\n\nexport const ResourceTitleLink = styled(SafeLink)`\n  box-shadow: none;\n  color: ${colors.brand.primary};\n  flex: 1;\n  :after {\n    content: '';\n    position: absolute;\n    z-index: 1;\n    top: 0;\n    right: 0;\n    bottom: 0;\n    left: 0;\n  }\n`;\n\nexport const resourceHeadingStyle = css`\n  margin: 0;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  font-weight: ${fonts.weight.bold};\n  // Unfortunate css needed for multi-line text overflow ellipsis.\n  line-height: 1;\n  display: -webkit-box;\n  -webkit-line-clamp: 1;\n  line-clamp: 1;\n  -webkit-box-orient: vertical;\n  grid-area: resourceTitle;\n  ${fonts.sizes('16px', '20px')};\n`;\n\nconst StyledTagList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  margin-left: ${spacing.small};\n  padding: 2px;\n  gap: ${spacing.xsmall};\n  overflow: hidden;\n  :last-child {\n    margin-right: ${spacing.small};\n  }\n`;\n\nconst StyledTagListElement = styled.li`\n  margin: 0;\n  ${fonts.sizes(14)};\n`;\n\nconst StyledSafeLink = styled(SafeLink)`\n  display: flex;\n  justify-content: flex-end;\n  align-items: center;\n  box-shadow: none;\n  color: ${colors.brand.grey};\n  min-height: 44px;\n  min-width: 44px;\n  white-space: nowrap;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n`;\n\nconst StyledResourceTypeList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  padding: 0;\n  overflow: hidden;\n`;\n\nconst StyledTopicDivider = styled.span`\n  margin: 0;\n  padding: 0 ${spacing.xxsmall};\n`;\n\nconst StyledResourceListElement = styled.li`\n  white-space: nowrap;\n  ${fonts.sizes(12)};\n  margin: 0;\n  line-height: 1.5;\n  padding: 0;\n  display: flex;\n  align-items: center;\n`;\n\nconst TagCounterWrapper = styled.span`\n  display: flex;\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('14px', '14px')};\n`;\n\ninterface ContentIconProps extends HTMLAttributes<HTMLSpanElement> {\n  contentType: string;\n  children?: ReactNode;\n}\n\nconst StyledContentIconWrapper = styled.span`\n  width: 100%;\n  aspect-ratio: 4/3;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  background-color: var(--content-background-color);\n`;\n\nexport const ContentIconWrapper = ({ contentType, children, ...props }: ContentIconProps) => {\n  const contentIconWrapperVars = useMemo(\n    () => ({ '--content-background-color': resourceTypeColor(contentType) } as unknown as CSSProperties),\n    [contentType],\n  );\n  return (\n    <StyledContentIconWrapper {...props} style={contentIconWrapperVars}>\n      {children}\n    </StyledContentIconWrapper>\n  );\n};\n\ninterface TagListProps {\n  tags?: string[];\n  tagLinkPrefix?: string;\n}\n\nexport interface LoaderProps {\n  loading?: boolean;\n  children?: ReactNode;\n}\n\nexport const TagList = ({ tags, tagLinkPrefix }: TagListProps) => {\n  const { t } = useTranslation();\n  if (!tags) return null;\n  return (\n    <StyledTagList aria-label={t('myNdla.tagList')}>\n      {tags.map((tag, i) => (\n        <StyledTagListElement key={`tag-${i}`}>\n          <StyledSafeLink to={`${tagLinkPrefix ? tagLinkPrefix : ''}/${encodeURIComponent(tag)}`}>\n            <HashTag />\n            {tag}\n          </StyledSafeLink>\n        </StyledTagListElement>\n      ))}\n    </StyledTagList>\n  );\n};\n\ninterface CompressedTagListProps {\n  tags: string[];\n  tagLinkPrefix?: string;\n}\n\nexport const CompressedTagList = ({ tags, tagLinkPrefix }: CompressedTagListProps) => {\n  const navigate = useNavigate();\n  const { t } = useTranslation();\n  const visibleTags = useMemo(() => tags.slice(0, 3), [tags]);\n  const remainingTags = useMemo(\n    () =>\n      tags.slice(3, tags.length).map((tag) => {\n        return {\n          icon: <HashTag />,\n          text: tag,\n          onClick: () => {\n            navigate(`${tagLinkPrefix ? tagLinkPrefix : ''}/${encodeURIComponent(tag)}`);\n          },\n        };\n      }),\n    [navigate, tagLinkPrefix, tags],\n  );\n\n  return (\n    <>\n      <TagList tagLinkPrefix={tagLinkPrefix} tags={visibleTags} />\n      {remainingTags.length > 0 && (\n        <MenuButton\n          size=\"small\"\n          menuIcon={<TagCounterWrapper>{`+${remainingTags.length}`}</TagCounterWrapper>}\n          menuItems={remainingTags}\n          align=\"end\"\n          aria-label={t('myNdla.moreTags', { count: remainingTags.length })}\n        />\n      )}\n    </>\n  );\n};\n\ninterface ResourceTypeListProps {\n  resourceTypes?: { id: string; name: string }[];\n}\n\nexport const ResourceTypeList = ({ resourceTypes }: ResourceTypeListProps) => {\n  const { t } = useTranslation();\n  if (!resourceTypes) return null;\n  return (\n    <StyledResourceTypeList aria-label={t('navigation.topics')}>\n      {resourceTypes.map((resource, i) => (\n        <StyledResourceListElement key={resource.id}>\n          {resourceEmbedTypeMapping[resource.id]\n            ? t(`embed.type.${resourceEmbedTypeMapping[resource.id]}`)\n            : resource.name}\n          {i !== resourceTypes.length - 1 && <StyledTopicDivider aria-hidden=\"true\">•</StyledTopicDivider>}\n        </StyledResourceListElement>\n      ))}\n    </StyledResourceTypeList>\n  );\n};\n"]} */"));
63
70
  var TagCounterWrapper = /*#__PURE__*/_styled("span", {
64
71
  target: "e1lrrm6s1",
65
72
  label: "TagCounterWrapper"
66
- })("display:flex;font-weight:", fonts.weight.semibold, ";", fonts.sizes('14px', '14px'), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInJlc291cmNlQ29tcG9uZW50cy50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNkdxQyIsImZpbGUiOiJyZXNvdXJjZUNvbXBvbmVudHMudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjItcHJlc2VudCwgTkRMQS5cbiAqXG4gKiBUaGlzIHNvdXJjZSBjb2RlIGlzIGxpY2Vuc2VkIHVuZGVyIHRoZSBHUEx2MyBsaWNlbnNlIGZvdW5kIGluIHRoZVxuICogTElDRU5TRSBmaWxlIGluIHRoZSByb290IGRpcmVjdG9yeSBvZiB0aGlzIHNvdXJjZSB0cmVlLlxuICpcbiAqL1xuXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBjb2xvcnMsIGZvbnRzLCBzcGFjaW5nIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgUmVhY3QsIHsgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgdXNlVHJhbnNsYXRpb24gfSBmcm9tICdyZWFjdC1pMThuZXh0JztcbmltcG9ydCB7IE1lbnVCdXR0b24gfSBmcm9tICdAbmRsYS9idXR0b24nO1xuaW1wb3J0IFNhZmVMaW5rIGZyb20gJ0BuZGxhL3NhZmVsaW5rJztcbmltcG9ydCB7IHVzZU5hdmlnYXRlIH0gZnJvbSAncmVhY3Qtcm91dGVyLWRvbSc7XG5pbXBvcnQgeyBIYXNoVGFnIH0gZnJvbSAnQG5kbGEvaWNvbnMvY29tbW9uJztcbmltcG9ydCByZXNvdXJjZVR5cGVDb2xvciBmcm9tICcuLi91dGlscy9yZXNvdXJjZVR5cGVDb2xvcic7XG5pbXBvcnQgeyByZXNvdXJjZUVtYmVkVHlwZU1hcHBpbmcgfSBmcm9tICcuLi9tb2RlbC9Db250ZW50VHlwZSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgUmVzb3VyY2VJbWFnZVByb3BzIHtcbiAgYWx0OiBzdHJpbmc7XG4gIHNyYzogc3RyaW5nO1xufVxuXG5leHBvcnQgY29uc3QgUmVzb3VyY2VUaXRsZUxpbmsgPSBzdHlsZWQoU2FmZUxpbmspYFxuICBib3gtc2hhZG93OiBub25lO1xuICBjb2xvcjogJHtjb2xvcnMuYnJhbmQucHJpbWFyeX07XG4gIGZsZXg6IDE7XG4gIDphZnRlciB7XG4gICAgY29udGVudDogJyc7XG4gICAgcG9zaXRpb246IGFic29sdXRlO1xuICAgIHotaW5kZXg6IDE7XG4gICAgdG9wOiAwO1xuICAgIHJpZ2h0OiAwO1xuICAgIGJvdHRvbTogMDtcbiAgICBsZWZ0OiAwO1xuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgUmVzb3VyY2VUaXRsZSA9IHN0eWxlZC5zcGFuYFxuICBtYXJnaW46IDA7XG4gIG92ZXJmbG93OiBoaWRkZW47XG4gIHRleHQtb3ZlcmZsb3c6IGVsbGlwc2lzO1xuICBmb250LXdlaWdodDogJHtmb250cy53ZWlnaHQuYm9sZH07XG4gIC8vIFVuZm9ydHVuYXRlIGNzcyBuZWVkZWQgZm9yIG11bHRpLWxpbmUgdGV4dCBvdmVyZmxvdyBlbGxpcHNpcy5cbiAgbGluZS1oZWlnaHQ6IDE7XG4gIGRpc3BsYXk6IC13ZWJraXQtYm94O1xuICAtd2Via2l0LWxpbmUtY2xhbXA6IDE7XG4gIGxpbmUtY2xhbXA6IDE7XG4gIC13ZWJraXQtYm94LW9yaWVudDogdmVydGljYWw7XG4gIGdyaWQtYXJlYTogcmVzb3VyY2VUaXRsZTtcbiAgJHtmb250cy5zaXplcygnMTZweCcsICcyMHB4Jyl9O1xuYDtcblxuY29uc3QgU3R5bGVkVGFnTGlzdCA9IHN0eWxlZC51bGBcbiAgbGlzdC1zdHlsZTogbm9uZTtcbiAgZGlzcGxheTogZmxleDtcbiAgbWFyZ2luOiAwO1xuICBtYXJnaW4tbGVmdDogJHtzcGFjaW5nLnNtYWxsfTtcbiAgcGFkZGluZzogMnB4O1xuICBnYXA6ICR7c3BhY2luZy54c21hbGx9O1xuICBvdmVyZmxvdzogaGlkZGVuO1xuICA6bGFzdC1jaGlsZCB7XG4gICAgbWFyZ2luLXJpZ2h0OiAke3NwYWNpbmcuc21hbGx9O1xuICB9XG5gO1xuXG5jb25zdCBTdHlsZWRUYWdMaXN0RWxlbWVudCA9IHN0eWxlZC5saWBcbiAgbWFyZ2luOiAwO1xuICAke2ZvbnRzLnNpemVzKDE0KX07XG5gO1xuXG5jb25zdCBTdHlsZWRTYWZlTGluayA9IHN0eWxlZChTYWZlTGluaylgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGp1c3RpZnktY29udGVudDogZmxleC1lbmQ7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGJveC1zaGFkb3c6IG5vbmU7XG4gIGNvbG9yOiAke2NvbG9ycy5icmFuZC5ncmV5fTtcbiAgbWluLWhlaWdodDogNDRweDtcbiAgbWluLXdpZHRoOiA0NHB4O1xuICB3aGl0ZS1zcGFjZTogbm93cmFwO1xuICAmOmhvdmVyIHtcbiAgICBjb2xvcjogJHtjb2xvcnMuYnJhbmQucHJpbWFyeX07XG4gIH1cbmA7XG5cbmNvbnN0IFN0eWxlZFJlc291cmNlVHlwZUxpc3QgPSBzdHlsZWQudWxgXG4gIGxpc3Qtc3R5bGU6IG5vbmU7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIG1hcmdpbjogMDtcbiAgcGFkZGluZzogMDtcbiAgb3ZlcmZsb3c6IGhpZGRlbjtcbmA7XG5cbmNvbnN0IFN0eWxlZFRvcGljRGl2aWRlciA9IHN0eWxlZC5zcGFuYFxuICBtYXJnaW46IDA7XG4gIHBhZGRpbmc6IDAgJHtzcGFjaW5nLnh4c21hbGx9O1xuYDtcblxuY29uc3QgU3R5bGVkUmVzb3VyY2VMaXN0RWxlbWVudCA9IHN0eWxlZC5saWBcbiAgd2hpdGUtc3BhY2U6IG5vd3JhcDtcbiAgJHtmb250cy5zaXplcygxMil9O1xuICBtYXJnaW46IDA7XG4gIGxpbmUtaGVpZ2h0OiAxLjU7XG4gIHBhZGRpbmc6IDA7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5gO1xuXG5jb25zdCBUYWdDb3VudGVyV3JhcHBlciA9IHN0eWxlZC5zcGFuYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmb250LXdlaWdodDogJHtmb250cy53ZWlnaHQuc2VtaWJvbGR9O1xuICAke2ZvbnRzLnNpemVzKCcxNHB4JywgJzE0cHgnKX07XG5gO1xuXG5leHBvcnQgaW50ZXJmYWNlIENvbnRlbnRJY29uUHJvcHMge1xuICBjb250ZW50VHlwZTogc3RyaW5nO1xufVxuXG5leHBvcnQgY29uc3QgU3R5bGVkQ29udGVudEljb25XcmFwcGVyID0gc3R5bGVkLnNwYW48Q29udGVudEljb25Qcm9wcz5gXG4gIHdpZHRoOiAxMDAlO1xuICBhc3BlY3QtcmF0aW86IDQvMztcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG4gIGJhY2tncm91bmQtY29sb3I6ICR7KHsgY29udGVudFR5cGUgfSkgPT4gcmVzb3VyY2VUeXBlQ29sb3IoY29udGVudFR5cGUpfTtcbmA7XG5cbmludGVyZmFjZSBUYWdMaXN0UHJvcHMge1xuICB0YWdzPzogc3RyaW5nW107XG4gIHRhZ0xpbmtQcmVmaXg/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTG9hZGVyUHJvcHMge1xuICBsb2FkaW5nPzogYm9vbGVhbjtcbiAgY2hpbGRyZW4/OiBSZWFjdE5vZGU7XG59XG5cbmV4cG9ydCBjb25zdCBUYWdMaXN0ID0gKHsgdGFncywgdGFnTGlua1ByZWZpeCB9OiBUYWdMaXN0UHJvcHMpID0+IHtcbiAgY29uc3QgeyB0IH0gPSB1c2VUcmFuc2xhdGlvbigpO1xuICBpZiAoIXRhZ3MpIHJldHVybiBudWxsO1xuICByZXR1cm4gKFxuICAgIDxTdHlsZWRUYWdMaXN0IGFyaWEtbGFiZWw9e3QoJ215TmRsYS50YWdMaXN0Jyl9PlxuICAgICAge3RhZ3MubWFwKCh0YWcsIGkpID0+IChcbiAgICAgICAgPFN0eWxlZFRhZ0xpc3RFbGVtZW50IGtleT17YHRhZy0ke2l9YH0+XG4gICAgICAgICAgPFN0eWxlZFNhZmVMaW5rIHRvPXtgJHt0YWdMaW5rUHJlZml4ID8gdGFnTGlua1ByZWZpeCA6ICcnfS8ke2VuY29kZVVSSUNvbXBvbmVudCh0YWcpfWB9PlxuICAgICAgICAgICAgPEhhc2hUYWcgLz5cbiAgICAgICAgICAgIHt0YWd9XG4gICAgICAgICAgPC9TdHlsZWRTYWZlTGluaz5cbiAgICAgICAgPC9TdHlsZWRUYWdMaXN0RWxlbWVudD5cbiAgICAgICkpfVxuICAgIDwvU3R5bGVkVGFnTGlzdD5cbiAgKTtcbn07XG5cbmludGVyZmFjZSBDb21wcmVzc2VkVGFnTGlzdFByb3BzIHtcbiAgdGFnczogc3RyaW5nW107XG4gIHRhZ0xpbmtQcmVmaXg/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBjb25zdCBDb21wcmVzc2VkVGFnTGlzdCA9ICh7IHRhZ3MsIHRhZ0xpbmtQcmVmaXggfTogQ29tcHJlc3NlZFRhZ0xpc3RQcm9wcykgPT4ge1xuICBjb25zdCBuYXZpZ2F0ZSA9IHVzZU5hdmlnYXRlKCk7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcbiAgY29uc3QgdmlzaWJsZVRhZ3MgPSB0YWdzLnNsaWNlKDAsIDMpO1xuICBjb25zdCByZW1haW5pbmdUYWdzID0gdGFncy5zbGljZSgzLCB0YWdzLmxlbmd0aCkubWFwKCh0YWcpID0+IHtcbiAgICByZXR1cm4ge1xuICAgICAgaWNvbjogPEhhc2hUYWcgLz4sXG4gICAgICB0ZXh0OiB0YWcsXG4gICAgICBvbkNsaWNrOiAoKSA9PiB7XG4gICAgICAgIG5hdmlnYXRlKGAke3RhZ0xpbmtQcmVmaXggPyB0YWdMaW5rUHJlZml4IDogJyd9LyR7ZW5jb2RlVVJJQ29tcG9uZW50KHRhZyl9YCk7XG4gICAgICB9LFxuICAgIH07XG4gIH0pO1xuICByZXR1cm4gKFxuICAgIDw+XG4gICAgICA8VGFnTGlzdCB0YWdMaW5rUHJlZml4PXt0YWdMaW5rUHJlZml4fSB0YWdzPXt2aXNpYmxlVGFnc30gLz5cbiAgICAgIHtyZW1haW5pbmdUYWdzLmxlbmd0aCA+IDAgJiYgKFxuICAgICAgICA8TWVudUJ1dHRvblxuICAgICAgICAgIHNpemU9XCJzbWFsbFwiXG4gICAgICAgICAgbWVudUljb249ezxUYWdDb3VudGVyV3JhcHBlcj57YCske3JlbWFpbmluZ1RhZ3MubGVuZ3RofWB9PC9UYWdDb3VudGVyV3JhcHBlcj59XG4gICAgICAgICAgbWVudUl0ZW1zPXtyZW1haW5pbmdUYWdzfVxuICAgICAgICAgIGFsaWduPVwiZW5kXCJcbiAgICAgICAgICBhcmlhLWxhYmVsPXt0KCdteU5kbGEubW9yZVRhZ3MnLCB7IGNvdW50OiByZW1haW5pbmdUYWdzLmxlbmd0aCB9KX1cbiAgICAgICAgLz5cbiAgICAgICl9XG4gICAgPC8+XG4gICk7XG59O1xuXG5pbnRlcmZhY2UgUmVzb3VyY2VUeXBlTGlzdFByb3BzIHtcbiAgcmVzb3VyY2VUeXBlcz86IHsgaWQ6IHN0cmluZzsgbmFtZTogc3RyaW5nIH1bXTtcbn1cblxuZXhwb3J0IGNvbnN0IFJlc291cmNlVHlwZUxpc3QgPSAoeyByZXNvdXJjZVR5cGVzIH06IFJlc291cmNlVHlwZUxpc3RQcm9wcykgPT4ge1xuICBjb25zdCB7IHQgfSA9IHVzZVRyYW5zbGF0aW9uKCk7XG4gIGlmICghcmVzb3VyY2VUeXBlcykgcmV0dXJuIG51bGw7XG4gIHJldHVybiAoXG4gICAgPFN0eWxlZFJlc291cmNlVHlwZUxpc3QgYXJpYS1sYWJlbD17dCgnbmF2aWdhdGlvbi50b3BpY3MnKX0+XG4gICAgICB7cmVzb3VyY2VUeXBlcy5tYXAoKHJlc291cmNlLCBpKSA9PiAoXG4gICAgICAgIDxTdHlsZWRSZXNvdXJjZUxpc3RFbGVtZW50IGtleT17cmVzb3VyY2UuaWR9PlxuICAgICAgICAgIHtyZXNvdXJjZUVtYmVkVHlwZU1hcHBpbmdbcmVzb3VyY2UuaWRdXG4gICAgICAgICAgICA/IHQoYGVtYmVkLnR5cGUuJHtyZXNvdXJjZUVtYmVkVHlwZU1hcHBpbmdbcmVzb3VyY2UuaWRdfWApXG4gICAgICAgICAgICA6IHJlc291cmNlLm5hbWV9XG4gICAgICAgICAge2kgIT09IHJlc291cmNlVHlwZXMubGVuZ3RoIC0gMSAmJiA8U3R5bGVkVG9waWNEaXZpZGVyIGFyaWEtaGlkZGVuPVwidHJ1ZVwiPuKAojwvU3R5bGVkVG9waWNEaXZpZGVyPn1cbiAgICAgICAgPC9TdHlsZWRSZXNvdXJjZUxpc3RFbGVtZW50PlxuICAgICAgKSl9XG4gICAgPC9TdHlsZWRSZXNvdXJjZVR5cGVMaXN0PlxuICApO1xufTtcbiJdfQ== */"));
67
- export var StyledContentIconWrapper = /*#__PURE__*/_styled("span", {
73
+ })("display:flex;font-weight:", fonts.weight.semibold, ";", fonts.sizes('14px', '14px'), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["resourceComponents.tsx"],"names":[],"mappings":"AA8GqC","file":"resourceComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2022-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 styled from '@emotion/styled';\nimport { colors, fonts, spacing } from '@ndla/core';\nimport React, { CSSProperties, HTMLAttributes, ReactNode, useMemo } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { MenuButton } from '@ndla/button';\nimport SafeLink from '@ndla/safelink';\nimport { useNavigate } from 'react-router-dom';\nimport { HashTag } from '@ndla/icons/common';\nimport { css } from '@emotion/react';\nimport resourceTypeColor from '../utils/resourceTypeColor';\nimport { resourceEmbedTypeMapping } from '../model/ContentType';\n\nexport interface ResourceImageProps {\n  alt: string;\n  src: string;\n}\n\nexport const ResourceTitleLink = styled(SafeLink)`\n  box-shadow: none;\n  color: ${colors.brand.primary};\n  flex: 1;\n  :after {\n    content: '';\n    position: absolute;\n    z-index: 1;\n    top: 0;\n    right: 0;\n    bottom: 0;\n    left: 0;\n  }\n`;\n\nexport const resourceHeadingStyle = css`\n  margin: 0;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  font-weight: ${fonts.weight.bold};\n  // Unfortunate css needed for multi-line text overflow ellipsis.\n  line-height: 1;\n  display: -webkit-box;\n  -webkit-line-clamp: 1;\n  line-clamp: 1;\n  -webkit-box-orient: vertical;\n  grid-area: resourceTitle;\n  ${fonts.sizes('16px', '20px')};\n`;\n\nconst StyledTagList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  margin-left: ${spacing.small};\n  padding: 2px;\n  gap: ${spacing.xsmall};\n  overflow: hidden;\n  :last-child {\n    margin-right: ${spacing.small};\n  }\n`;\n\nconst StyledTagListElement = styled.li`\n  margin: 0;\n  ${fonts.sizes(14)};\n`;\n\nconst StyledSafeLink = styled(SafeLink)`\n  display: flex;\n  justify-content: flex-end;\n  align-items: center;\n  box-shadow: none;\n  color: ${colors.brand.grey};\n  min-height: 44px;\n  min-width: 44px;\n  white-space: nowrap;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n`;\n\nconst StyledResourceTypeList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  padding: 0;\n  overflow: hidden;\n`;\n\nconst StyledTopicDivider = styled.span`\n  margin: 0;\n  padding: 0 ${spacing.xxsmall};\n`;\n\nconst StyledResourceListElement = styled.li`\n  white-space: nowrap;\n  ${fonts.sizes(12)};\n  margin: 0;\n  line-height: 1.5;\n  padding: 0;\n  display: flex;\n  align-items: center;\n`;\n\nconst TagCounterWrapper = styled.span`\n  display: flex;\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('14px', '14px')};\n`;\n\ninterface ContentIconProps extends HTMLAttributes<HTMLSpanElement> {\n  contentType: string;\n  children?: ReactNode;\n}\n\nconst StyledContentIconWrapper = styled.span`\n  width: 100%;\n  aspect-ratio: 4/3;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  background-color: var(--content-background-color);\n`;\n\nexport const ContentIconWrapper = ({ contentType, children, ...props }: ContentIconProps) => {\n  const contentIconWrapperVars = useMemo(\n    () => ({ '--content-background-color': resourceTypeColor(contentType) } as unknown as CSSProperties),\n    [contentType],\n  );\n  return (\n    <StyledContentIconWrapper {...props} style={contentIconWrapperVars}>\n      {children}\n    </StyledContentIconWrapper>\n  );\n};\n\ninterface TagListProps {\n  tags?: string[];\n  tagLinkPrefix?: string;\n}\n\nexport interface LoaderProps {\n  loading?: boolean;\n  children?: ReactNode;\n}\n\nexport const TagList = ({ tags, tagLinkPrefix }: TagListProps) => {\n  const { t } = useTranslation();\n  if (!tags) return null;\n  return (\n    <StyledTagList aria-label={t('myNdla.tagList')}>\n      {tags.map((tag, i) => (\n        <StyledTagListElement key={`tag-${i}`}>\n          <StyledSafeLink to={`${tagLinkPrefix ? tagLinkPrefix : ''}/${encodeURIComponent(tag)}`}>\n            <HashTag />\n            {tag}\n          </StyledSafeLink>\n        </StyledTagListElement>\n      ))}\n    </StyledTagList>\n  );\n};\n\ninterface CompressedTagListProps {\n  tags: string[];\n  tagLinkPrefix?: string;\n}\n\nexport const CompressedTagList = ({ tags, tagLinkPrefix }: CompressedTagListProps) => {\n  const navigate = useNavigate();\n  const { t } = useTranslation();\n  const visibleTags = useMemo(() => tags.slice(0, 3), [tags]);\n  const remainingTags = useMemo(\n    () =>\n      tags.slice(3, tags.length).map((tag) => {\n        return {\n          icon: <HashTag />,\n          text: tag,\n          onClick: () => {\n            navigate(`${tagLinkPrefix ? tagLinkPrefix : ''}/${encodeURIComponent(tag)}`);\n          },\n        };\n      }),\n    [navigate, tagLinkPrefix, tags],\n  );\n\n  return (\n    <>\n      <TagList tagLinkPrefix={tagLinkPrefix} tags={visibleTags} />\n      {remainingTags.length > 0 && (\n        <MenuButton\n          size=\"small\"\n          menuIcon={<TagCounterWrapper>{`+${remainingTags.length}`}</TagCounterWrapper>}\n          menuItems={remainingTags}\n          align=\"end\"\n          aria-label={t('myNdla.moreTags', { count: remainingTags.length })}\n        />\n      )}\n    </>\n  );\n};\n\ninterface ResourceTypeListProps {\n  resourceTypes?: { id: string; name: string }[];\n}\n\nexport const ResourceTypeList = ({ resourceTypes }: ResourceTypeListProps) => {\n  const { t } = useTranslation();\n  if (!resourceTypes) return null;\n  return (\n    <StyledResourceTypeList aria-label={t('navigation.topics')}>\n      {resourceTypes.map((resource, i) => (\n        <StyledResourceListElement key={resource.id}>\n          {resourceEmbedTypeMapping[resource.id]\n            ? t(`embed.type.${resourceEmbedTypeMapping[resource.id]}`)\n            : resource.name}\n          {i !== resourceTypes.length - 1 && <StyledTopicDivider aria-hidden=\"true\">•</StyledTopicDivider>}\n        </StyledResourceListElement>\n      ))}\n    </StyledResourceTypeList>\n  );\n};\n"]} */"));
74
+ var StyledContentIconWrapper = /*#__PURE__*/_styled("span", {
68
75
  target: "e1lrrm6s0",
69
76
  label: "StyledContentIconWrapper"
70
- })("width:100%;aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;background-color:", function (_ref) {
71
- var contentType = _ref.contentType;
72
- return resourceTypeColor(contentType);
73
- }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInJlc291cmNlQ29tcG9uZW50cy50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBdUhxRSIsImZpbGUiOiJyZXNvdXJjZUNvbXBvbmVudHMudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjItcHJlc2VudCwgTkRMQS5cbiAqXG4gKiBUaGlzIHNvdXJjZSBjb2RlIGlzIGxpY2Vuc2VkIHVuZGVyIHRoZSBHUEx2MyBsaWNlbnNlIGZvdW5kIGluIHRoZVxuICogTElDRU5TRSBmaWxlIGluIHRoZSByb290IGRpcmVjdG9yeSBvZiB0aGlzIHNvdXJjZSB0cmVlLlxuICpcbiAqL1xuXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBjb2xvcnMsIGZvbnRzLCBzcGFjaW5nIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgUmVhY3QsIHsgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgdXNlVHJhbnNsYXRpb24gfSBmcm9tICdyZWFjdC1pMThuZXh0JztcbmltcG9ydCB7IE1lbnVCdXR0b24gfSBmcm9tICdAbmRsYS9idXR0b24nO1xuaW1wb3J0IFNhZmVMaW5rIGZyb20gJ0BuZGxhL3NhZmVsaW5rJztcbmltcG9ydCB7IHVzZU5hdmlnYXRlIH0gZnJvbSAncmVhY3Qtcm91dGVyLWRvbSc7XG5pbXBvcnQgeyBIYXNoVGFnIH0gZnJvbSAnQG5kbGEvaWNvbnMvY29tbW9uJztcbmltcG9ydCByZXNvdXJjZVR5cGVDb2xvciBmcm9tICcuLi91dGlscy9yZXNvdXJjZVR5cGVDb2xvcic7XG5pbXBvcnQgeyByZXNvdXJjZUVtYmVkVHlwZU1hcHBpbmcgfSBmcm9tICcuLi9tb2RlbC9Db250ZW50VHlwZSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgUmVzb3VyY2VJbWFnZVByb3BzIHtcbiAgYWx0OiBzdHJpbmc7XG4gIHNyYzogc3RyaW5nO1xufVxuXG5leHBvcnQgY29uc3QgUmVzb3VyY2VUaXRsZUxpbmsgPSBzdHlsZWQoU2FmZUxpbmspYFxuICBib3gtc2hhZG93OiBub25lO1xuICBjb2xvcjogJHtjb2xvcnMuYnJhbmQucHJpbWFyeX07XG4gIGZsZXg6IDE7XG4gIDphZnRlciB7XG4gICAgY29udGVudDogJyc7XG4gICAgcG9zaXRpb246IGFic29sdXRlO1xuICAgIHotaW5kZXg6IDE7XG4gICAgdG9wOiAwO1xuICAgIHJpZ2h0OiAwO1xuICAgIGJvdHRvbTogMDtcbiAgICBsZWZ0OiAwO1xuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgUmVzb3VyY2VUaXRsZSA9IHN0eWxlZC5zcGFuYFxuICBtYXJnaW46IDA7XG4gIG92ZXJmbG93OiBoaWRkZW47XG4gIHRleHQtb3ZlcmZsb3c6IGVsbGlwc2lzO1xuICBmb250LXdlaWdodDogJHtmb250cy53ZWlnaHQuYm9sZH07XG4gIC8vIFVuZm9ydHVuYXRlIGNzcyBuZWVkZWQgZm9yIG11bHRpLWxpbmUgdGV4dCBvdmVyZmxvdyBlbGxpcHNpcy5cbiAgbGluZS1oZWlnaHQ6IDE7XG4gIGRpc3BsYXk6IC13ZWJraXQtYm94O1xuICAtd2Via2l0LWxpbmUtY2xhbXA6IDE7XG4gIGxpbmUtY2xhbXA6IDE7XG4gIC13ZWJraXQtYm94LW9yaWVudDogdmVydGljYWw7XG4gIGdyaWQtYXJlYTogcmVzb3VyY2VUaXRsZTtcbiAgJHtmb250cy5zaXplcygnMTZweCcsICcyMHB4Jyl9O1xuYDtcblxuY29uc3QgU3R5bGVkVGFnTGlzdCA9IHN0eWxlZC51bGBcbiAgbGlzdC1zdHlsZTogbm9uZTtcbiAgZGlzcGxheTogZmxleDtcbiAgbWFyZ2luOiAwO1xuICBtYXJnaW4tbGVmdDogJHtzcGFjaW5nLnNtYWxsfTtcbiAgcGFkZGluZzogMnB4O1xuICBnYXA6ICR7c3BhY2luZy54c21hbGx9O1xuICBvdmVyZmxvdzogaGlkZGVuO1xuICA6bGFzdC1jaGlsZCB7XG4gICAgbWFyZ2luLXJpZ2h0OiAke3NwYWNpbmcuc21hbGx9O1xuICB9XG5gO1xuXG5jb25zdCBTdHlsZWRUYWdMaXN0RWxlbWVudCA9IHN0eWxlZC5saWBcbiAgbWFyZ2luOiAwO1xuICAke2ZvbnRzLnNpemVzKDE0KX07XG5gO1xuXG5jb25zdCBTdHlsZWRTYWZlTGluayA9IHN0eWxlZChTYWZlTGluaylgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGp1c3RpZnktY29udGVudDogZmxleC1lbmQ7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGJveC1zaGFkb3c6IG5vbmU7XG4gIGNvbG9yOiAke2NvbG9ycy5icmFuZC5ncmV5fTtcbiAgbWluLWhlaWdodDogNDRweDtcbiAgbWluLXdpZHRoOiA0NHB4O1xuICB3aGl0ZS1zcGFjZTogbm93cmFwO1xuICAmOmhvdmVyIHtcbiAgICBjb2xvcjogJHtjb2xvcnMuYnJhbmQucHJpbWFyeX07XG4gIH1cbmA7XG5cbmNvbnN0IFN0eWxlZFJlc291cmNlVHlwZUxpc3QgPSBzdHlsZWQudWxgXG4gIGxpc3Qtc3R5bGU6IG5vbmU7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIG1hcmdpbjogMDtcbiAgcGFkZGluZzogMDtcbiAgb3ZlcmZsb3c6IGhpZGRlbjtcbmA7XG5cbmNvbnN0IFN0eWxlZFRvcGljRGl2aWRlciA9IHN0eWxlZC5zcGFuYFxuICBtYXJnaW46IDA7XG4gIHBhZGRpbmc6IDAgJHtzcGFjaW5nLnh4c21hbGx9O1xuYDtcblxuY29uc3QgU3R5bGVkUmVzb3VyY2VMaXN0RWxlbWVudCA9IHN0eWxlZC5saWBcbiAgd2hpdGUtc3BhY2U6IG5vd3JhcDtcbiAgJHtmb250cy5zaXplcygxMil9O1xuICBtYXJnaW46IDA7XG4gIGxpbmUtaGVpZ2h0OiAxLjU7XG4gIHBhZGRpbmc6IDA7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5gO1xuXG5jb25zdCBUYWdDb3VudGVyV3JhcHBlciA9IHN0eWxlZC5zcGFuYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmb250LXdlaWdodDogJHtmb250cy53ZWlnaHQuc2VtaWJvbGR9O1xuICAke2ZvbnRzLnNpemVzKCcxNHB4JywgJzE0cHgnKX07XG5gO1xuXG5leHBvcnQgaW50ZXJmYWNlIENvbnRlbnRJY29uUHJvcHMge1xuICBjb250ZW50VHlwZTogc3RyaW5nO1xufVxuXG5leHBvcnQgY29uc3QgU3R5bGVkQ29udGVudEljb25XcmFwcGVyID0gc3R5bGVkLnNwYW48Q29udGVudEljb25Qcm9wcz5gXG4gIHdpZHRoOiAxMDAlO1xuICBhc3BlY3QtcmF0aW86IDQvMztcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG4gIGJhY2tncm91bmQtY29sb3I6ICR7KHsgY29udGVudFR5cGUgfSkgPT4gcmVzb3VyY2VUeXBlQ29sb3IoY29udGVudFR5cGUpfTtcbmA7XG5cbmludGVyZmFjZSBUYWdMaXN0UHJvcHMge1xuICB0YWdzPzogc3RyaW5nW107XG4gIHRhZ0xpbmtQcmVmaXg/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTG9hZGVyUHJvcHMge1xuICBsb2FkaW5nPzogYm9vbGVhbjtcbiAgY2hpbGRyZW4/OiBSZWFjdE5vZGU7XG59XG5cbmV4cG9ydCBjb25zdCBUYWdMaXN0ID0gKHsgdGFncywgdGFnTGlua1ByZWZpeCB9OiBUYWdMaXN0UHJvcHMpID0+IHtcbiAgY29uc3QgeyB0IH0gPSB1c2VUcmFuc2xhdGlvbigpO1xuICBpZiAoIXRhZ3MpIHJldHVybiBudWxsO1xuICByZXR1cm4gKFxuICAgIDxTdHlsZWRUYWdMaXN0IGFyaWEtbGFiZWw9e3QoJ215TmRsYS50YWdMaXN0Jyl9PlxuICAgICAge3RhZ3MubWFwKCh0YWcsIGkpID0+IChcbiAgICAgICAgPFN0eWxlZFRhZ0xpc3RFbGVtZW50IGtleT17YHRhZy0ke2l9YH0+XG4gICAgICAgICAgPFN0eWxlZFNhZmVMaW5rIHRvPXtgJHt0YWdMaW5rUHJlZml4ID8gdGFnTGlua1ByZWZpeCA6ICcnfS8ke2VuY29kZVVSSUNvbXBvbmVudCh0YWcpfWB9PlxuICAgICAgICAgICAgPEhhc2hUYWcgLz5cbiAgICAgICAgICAgIHt0YWd9XG4gICAgICAgICAgPC9TdHlsZWRTYWZlTGluaz5cbiAgICAgICAgPC9TdHlsZWRUYWdMaXN0RWxlbWVudD5cbiAgICAgICkpfVxuICAgIDwvU3R5bGVkVGFnTGlzdD5cbiAgKTtcbn07XG5cbmludGVyZmFjZSBDb21wcmVzc2VkVGFnTGlzdFByb3BzIHtcbiAgdGFnczogc3RyaW5nW107XG4gIHRhZ0xpbmtQcmVmaXg/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBjb25zdCBDb21wcmVzc2VkVGFnTGlzdCA9ICh7IHRhZ3MsIHRhZ0xpbmtQcmVmaXggfTogQ29tcHJlc3NlZFRhZ0xpc3RQcm9wcykgPT4ge1xuICBjb25zdCBuYXZpZ2F0ZSA9IHVzZU5hdmlnYXRlKCk7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcbiAgY29uc3QgdmlzaWJsZVRhZ3MgPSB0YWdzLnNsaWNlKDAsIDMpO1xuICBjb25zdCByZW1haW5pbmdUYWdzID0gdGFncy5zbGljZSgzLCB0YWdzLmxlbmd0aCkubWFwKCh0YWcpID0+IHtcbiAgICByZXR1cm4ge1xuICAgICAgaWNvbjogPEhhc2hUYWcgLz4sXG4gICAgICB0ZXh0OiB0YWcsXG4gICAgICBvbkNsaWNrOiAoKSA9PiB7XG4gICAgICAgIG5hdmlnYXRlKGAke3RhZ0xpbmtQcmVmaXggPyB0YWdMaW5rUHJlZml4IDogJyd9LyR7ZW5jb2RlVVJJQ29tcG9uZW50KHRhZyl9YCk7XG4gICAgICB9LFxuICAgIH07XG4gIH0pO1xuICByZXR1cm4gKFxuICAgIDw+XG4gICAgICA8VGFnTGlzdCB0YWdMaW5rUHJlZml4PXt0YWdMaW5rUHJlZml4fSB0YWdzPXt2aXNpYmxlVGFnc30gLz5cbiAgICAgIHtyZW1haW5pbmdUYWdzLmxlbmd0aCA+IDAgJiYgKFxuICAgICAgICA8TWVudUJ1dHRvblxuICAgICAgICAgIHNpemU9XCJzbWFsbFwiXG4gICAgICAgICAgbWVudUljb249ezxUYWdDb3VudGVyV3JhcHBlcj57YCske3JlbWFpbmluZ1RhZ3MubGVuZ3RofWB9PC9UYWdDb3VudGVyV3JhcHBlcj59XG4gICAgICAgICAgbWVudUl0ZW1zPXtyZW1haW5pbmdUYWdzfVxuICAgICAgICAgIGFsaWduPVwiZW5kXCJcbiAgICAgICAgICBhcmlhLWxhYmVsPXt0KCdteU5kbGEubW9yZVRhZ3MnLCB7IGNvdW50OiByZW1haW5pbmdUYWdzLmxlbmd0aCB9KX1cbiAgICAgICAgLz5cbiAgICAgICl9XG4gICAgPC8+XG4gICk7XG59O1xuXG5pbnRlcmZhY2UgUmVzb3VyY2VUeXBlTGlzdFByb3BzIHtcbiAgcmVzb3VyY2VUeXBlcz86IHsgaWQ6IHN0cmluZzsgbmFtZTogc3RyaW5nIH1bXTtcbn1cblxuZXhwb3J0IGNvbnN0IFJlc291cmNlVHlwZUxpc3QgPSAoeyByZXNvdXJjZVR5cGVzIH06IFJlc291cmNlVHlwZUxpc3RQcm9wcykgPT4ge1xuICBjb25zdCB7IHQgfSA9IHVzZVRyYW5zbGF0aW9uKCk7XG4gIGlmICghcmVzb3VyY2VUeXBlcykgcmV0dXJuIG51bGw7XG4gIHJldHVybiAoXG4gICAgPFN0eWxlZFJlc291cmNlVHlwZUxpc3QgYXJpYS1sYWJlbD17dCgnbmF2aWdhdGlvbi50b3BpY3MnKX0+XG4gICAgICB7cmVzb3VyY2VUeXBlcy5tYXAoKHJlc291cmNlLCBpKSA9PiAoXG4gICAgICAgIDxTdHlsZWRSZXNvdXJjZUxpc3RFbGVtZW50IGtleT17cmVzb3VyY2UuaWR9PlxuICAgICAgICAgIHtyZXNvdXJjZUVtYmVkVHlwZU1hcHBpbmdbcmVzb3VyY2UuaWRdXG4gICAgICAgICAgICA/IHQoYGVtYmVkLnR5cGUuJHtyZXNvdXJjZUVtYmVkVHlwZU1hcHBpbmdbcmVzb3VyY2UuaWRdfWApXG4gICAgICAgICAgICA6IHJlc291cmNlLm5hbWV9XG4gICAgICAgICAge2kgIT09IHJlc291cmNlVHlwZXMubGVuZ3RoIC0gMSAmJiA8U3R5bGVkVG9waWNEaXZpZGVyIGFyaWEtaGlkZGVuPVwidHJ1ZVwiPuKAojwvU3R5bGVkVG9waWNEaXZpZGVyPn1cbiAgICAgICAgPC9TdHlsZWRSZXNvdXJjZUxpc3RFbGVtZW50PlxuICAgICAgKSl9XG4gICAgPC9TdHlsZWRSZXNvdXJjZVR5cGVMaXN0PlxuICApO1xufTtcbiJdfQ== */"));
77
+ })(process.env.NODE_ENV === "production" ? {
78
+ name: "758j4h",
79
+ styles: "width:100%;aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;background-color:var(--content-background-color)"
80
+ } : {
81
+ name: "758j4h",
82
+ styles: "width:100%;aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;background-color:var(--content-background-color)",
83
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["resourceComponents.tsx"],"names":[],"mappings":"AAyH4C","file":"resourceComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2022-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 styled from '@emotion/styled';\nimport { colors, fonts, spacing } from '@ndla/core';\nimport React, { CSSProperties, HTMLAttributes, ReactNode, useMemo } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { MenuButton } from '@ndla/button';\nimport SafeLink from '@ndla/safelink';\nimport { useNavigate } from 'react-router-dom';\nimport { HashTag } from '@ndla/icons/common';\nimport { css } from '@emotion/react';\nimport resourceTypeColor from '../utils/resourceTypeColor';\nimport { resourceEmbedTypeMapping } from '../model/ContentType';\n\nexport interface ResourceImageProps {\n  alt: string;\n  src: string;\n}\n\nexport const ResourceTitleLink = styled(SafeLink)`\n  box-shadow: none;\n  color: ${colors.brand.primary};\n  flex: 1;\n  :after {\n    content: '';\n    position: absolute;\n    z-index: 1;\n    top: 0;\n    right: 0;\n    bottom: 0;\n    left: 0;\n  }\n`;\n\nexport const resourceHeadingStyle = css`\n  margin: 0;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  font-weight: ${fonts.weight.bold};\n  // Unfortunate css needed for multi-line text overflow ellipsis.\n  line-height: 1;\n  display: -webkit-box;\n  -webkit-line-clamp: 1;\n  line-clamp: 1;\n  -webkit-box-orient: vertical;\n  grid-area: resourceTitle;\n  ${fonts.sizes('16px', '20px')};\n`;\n\nconst StyledTagList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  margin-left: ${spacing.small};\n  padding: 2px;\n  gap: ${spacing.xsmall};\n  overflow: hidden;\n  :last-child {\n    margin-right: ${spacing.small};\n  }\n`;\n\nconst StyledTagListElement = styled.li`\n  margin: 0;\n  ${fonts.sizes(14)};\n`;\n\nconst StyledSafeLink = styled(SafeLink)`\n  display: flex;\n  justify-content: flex-end;\n  align-items: center;\n  box-shadow: none;\n  color: ${colors.brand.grey};\n  min-height: 44px;\n  min-width: 44px;\n  white-space: nowrap;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n`;\n\nconst StyledResourceTypeList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  padding: 0;\n  overflow: hidden;\n`;\n\nconst StyledTopicDivider = styled.span`\n  margin: 0;\n  padding: 0 ${spacing.xxsmall};\n`;\n\nconst StyledResourceListElement = styled.li`\n  white-space: nowrap;\n  ${fonts.sizes(12)};\n  margin: 0;\n  line-height: 1.5;\n  padding: 0;\n  display: flex;\n  align-items: center;\n`;\n\nconst TagCounterWrapper = styled.span`\n  display: flex;\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('14px', '14px')};\n`;\n\ninterface ContentIconProps extends HTMLAttributes<HTMLSpanElement> {\n  contentType: string;\n  children?: ReactNode;\n}\n\nconst StyledContentIconWrapper = styled.span`\n  width: 100%;\n  aspect-ratio: 4/3;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  background-color: var(--content-background-color);\n`;\n\nexport const ContentIconWrapper = ({ contentType, children, ...props }: ContentIconProps) => {\n  const contentIconWrapperVars = useMemo(\n    () => ({ '--content-background-color': resourceTypeColor(contentType) } as unknown as CSSProperties),\n    [contentType],\n  );\n  return (\n    <StyledContentIconWrapper {...props} style={contentIconWrapperVars}>\n      {children}\n    </StyledContentIconWrapper>\n  );\n};\n\ninterface TagListProps {\n  tags?: string[];\n  tagLinkPrefix?: string;\n}\n\nexport interface LoaderProps {\n  loading?: boolean;\n  children?: ReactNode;\n}\n\nexport const TagList = ({ tags, tagLinkPrefix }: TagListProps) => {\n  const { t } = useTranslation();\n  if (!tags) return null;\n  return (\n    <StyledTagList aria-label={t('myNdla.tagList')}>\n      {tags.map((tag, i) => (\n        <StyledTagListElement key={`tag-${i}`}>\n          <StyledSafeLink to={`${tagLinkPrefix ? tagLinkPrefix : ''}/${encodeURIComponent(tag)}`}>\n            <HashTag />\n            {tag}\n          </StyledSafeLink>\n        </StyledTagListElement>\n      ))}\n    </StyledTagList>\n  );\n};\n\ninterface CompressedTagListProps {\n  tags: string[];\n  tagLinkPrefix?: string;\n}\n\nexport const CompressedTagList = ({ tags, tagLinkPrefix }: CompressedTagListProps) => {\n  const navigate = useNavigate();\n  const { t } = useTranslation();\n  const visibleTags = useMemo(() => tags.slice(0, 3), [tags]);\n  const remainingTags = useMemo(\n    () =>\n      tags.slice(3, tags.length).map((tag) => {\n        return {\n          icon: <HashTag />,\n          text: tag,\n          onClick: () => {\n            navigate(`${tagLinkPrefix ? tagLinkPrefix : ''}/${encodeURIComponent(tag)}`);\n          },\n        };\n      }),\n    [navigate, tagLinkPrefix, tags],\n  );\n\n  return (\n    <>\n      <TagList tagLinkPrefix={tagLinkPrefix} tags={visibleTags} />\n      {remainingTags.length > 0 && (\n        <MenuButton\n          size=\"small\"\n          menuIcon={<TagCounterWrapper>{`+${remainingTags.length}`}</TagCounterWrapper>}\n          menuItems={remainingTags}\n          align=\"end\"\n          aria-label={t('myNdla.moreTags', { count: remainingTags.length })}\n        />\n      )}\n    </>\n  );\n};\n\ninterface ResourceTypeListProps {\n  resourceTypes?: { id: string; name: string }[];\n}\n\nexport const ResourceTypeList = ({ resourceTypes }: ResourceTypeListProps) => {\n  const { t } = useTranslation();\n  if (!resourceTypes) return null;\n  return (\n    <StyledResourceTypeList aria-label={t('navigation.topics')}>\n      {resourceTypes.map((resource, i) => (\n        <StyledResourceListElement key={resource.id}>\n          {resourceEmbedTypeMapping[resource.id]\n            ? t(`embed.type.${resourceEmbedTypeMapping[resource.id]}`)\n            : resource.name}\n          {i !== resourceTypes.length - 1 && <StyledTopicDivider aria-hidden=\"true\">•</StyledTopicDivider>}\n        </StyledResourceListElement>\n      ))}\n    </StyledResourceTypeList>\n  );\n};\n"]} */",
84
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
85
+ });
86
+ export var ContentIconWrapper = function ContentIconWrapper(_ref) {
87
+ var contentType = _ref.contentType,
88
+ children = _ref.children,
89
+ props = _objectWithoutProperties(_ref, _excluded);
90
+ var contentIconWrapperVars = useMemo(function () {
91
+ return {
92
+ '--content-background-color': resourceTypeColor(contentType)
93
+ };
94
+ }, [contentType]);
95
+ return _jsx(StyledContentIconWrapper, _objectSpread(_objectSpread({}, props), {}, {
96
+ style: contentIconWrapperVars,
97
+ children: children
98
+ }));
99
+ };
74
100
  export var TagList = function TagList(_ref2) {
75
101
  var tags = _ref2.tags,
76
102
  tagLinkPrefix = _ref2.tagLinkPrefix;
@@ -95,16 +121,20 @@ export var CompressedTagList = function CompressedTagList(_ref3) {
95
121
  var navigate = useNavigate();
96
122
  var _useTranslation2 = useTranslation(),
97
123
  t = _useTranslation2.t;
98
- var visibleTags = tags.slice(0, 3);
99
- var remainingTags = tags.slice(3, tags.length).map(function (tag) {
100
- return {
101
- icon: _jsx(HashTag, {}),
102
- text: tag,
103
- onClick: function onClick() {
104
- navigate("".concat(tagLinkPrefix ? tagLinkPrefix : '', "/").concat(encodeURIComponent(tag)));
105
- }
106
- };
107
- });
124
+ var visibleTags = useMemo(function () {
125
+ return tags.slice(0, 3);
126
+ }, [tags]);
127
+ var remainingTags = useMemo(function () {
128
+ return tags.slice(3, tags.length).map(function (tag) {
129
+ return {
130
+ icon: _jsx(HashTag, {}),
131
+ text: tag,
132
+ onClick: function onClick() {
133
+ navigate("".concat(tagLinkPrefix ? tagLinkPrefix : '', "/").concat(encodeURIComponent(tag)));
134
+ }
135
+ };
136
+ });
137
+ }, [navigate, tagLinkPrefix, tags]);
108
138
  return _jsxs(_Fragment, {
109
139
  children: [_jsx(TagList, {
110
140
  tagLinkPrefix: tagLinkPrefix,