@ndla/ui 42.1.1 → 43.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (71) hide show
  1. package/es/AudioPlayer/AudioPlayer.js +27 -33
  2. package/es/AudioPlayer/Controls.js +41 -39
  3. package/es/Breadcrumb/index.js +0 -1
  4. package/es/CampaignBlock/CampaignBlock.js +32 -18
  5. package/es/LanguageSelector/LanguageSelector.js +31 -36
  6. package/es/LicenseByline/EmbedByline.js +5 -5
  7. package/es/MyNdla/Resource/Folder.js +27 -72
  8. package/es/MyNdla/index.js +1 -3
  9. package/es/Resource/BlockResource.js +15 -27
  10. package/es/Resource/ListResource.js +14 -19
  11. package/es/Resource/resourceComponents.js +82 -41
  12. package/es/TreeStructure/ComboboxButton.js +17 -20
  13. package/es/TreeStructure/FolderItem.js +42 -69
  14. package/es/TreeStructure/FolderItems.js +25 -19
  15. package/es/TreeStructure/TreeStructure.js +19 -26
  16. package/es/index.js +2 -2
  17. package/lib/AudioPlayer/AudioPlayer.js +27 -33
  18. package/lib/AudioPlayer/Controls.js +40 -38
  19. package/lib/Breadcrumb/index.d.ts +0 -1
  20. package/lib/Breadcrumb/index.js +0 -7
  21. package/lib/CampaignBlock/CampaignBlock.js +32 -18
  22. package/lib/LanguageSelector/LanguageSelector.js +31 -36
  23. package/lib/LicenseByline/EmbedByline.js +5 -5
  24. package/lib/MyNdla/Resource/Folder.d.ts +3 -4
  25. package/lib/MyNdla/Resource/Folder.js +27 -72
  26. package/lib/MyNdla/index.d.ts +1 -3
  27. package/lib/MyNdla/index.js +0 -14
  28. package/lib/Resource/BlockResource.d.ts +3 -3
  29. package/lib/Resource/BlockResource.js +14 -26
  30. package/lib/Resource/ListResource.d.ts +3 -3
  31. package/lib/Resource/ListResource.js +13 -18
  32. package/lib/Resource/resourceComponents.d.ts +5 -10
  33. package/lib/Resource/resourceComponents.js +85 -42
  34. package/lib/TreeStructure/ComboboxButton.js +17 -20
  35. package/lib/TreeStructure/FolderItem.js +40 -67
  36. package/lib/TreeStructure/FolderItems.js +31 -26
  37. package/lib/TreeStructure/TreeStructure.js +19 -26
  38. package/lib/index.d.ts +2 -2
  39. package/lib/index.js +0 -12
  40. package/package.json +16 -17
  41. package/src/AudioPlayer/AudioPlayer.tsx +24 -34
  42. package/src/AudioPlayer/Controls.tsx +22 -26
  43. package/src/Breadcrumb/index.ts +0 -2
  44. package/src/CampaignBlock/CampaignBlock.tsx +10 -10
  45. package/src/LanguageSelector/LanguageSelector.tsx +26 -32
  46. package/src/LicenseByline/EmbedByline.tsx +1 -1
  47. package/src/MyNdla/Resource/Folder.stories.tsx +27 -5
  48. package/src/MyNdla/Resource/Folder.tsx +32 -54
  49. package/src/MyNdla/index.ts +1 -3
  50. package/src/Resource/BlockResource.stories.tsx +1 -1
  51. package/src/Resource/BlockResource.tsx +25 -24
  52. package/src/Resource/ListResource.tsx +21 -18
  53. package/src/Resource/Resource.stories.tsx +32 -2
  54. package/src/Resource/resourceComponents.tsx +55 -26
  55. package/src/TreeStructure/ComboboxButton.tsx +5 -7
  56. package/src/TreeStructure/FolderItem.tsx +50 -35
  57. package/src/TreeStructure/FolderItems.tsx +6 -8
  58. package/src/TreeStructure/TreeStructure.tsx +16 -25
  59. package/src/index.ts +2 -2
  60. package/es/Breadcrumb/ActionBreadcrumb.js +0 -74
  61. package/es/MyNdla/Resource/FolderMenu.js +0 -74
  62. package/es/MyNdla/SettingsMenu.js +0 -98
  63. package/lib/Breadcrumb/ActionBreadcrumb.d.ts +0 -15
  64. package/lib/Breadcrumb/ActionBreadcrumb.js +0 -82
  65. package/lib/MyNdla/Resource/FolderMenu.d.ts +0 -16
  66. package/lib/MyNdla/Resource/FolderMenu.js +0 -81
  67. package/lib/MyNdla/SettingsMenu.d.ts +0 -15
  68. package/lib/MyNdla/SettingsMenu.js +0 -102
  69. package/src/Breadcrumb/ActionBreadcrumb.tsx +0 -87
  70. package/src/MyNdla/Resource/FolderMenu.tsx +0 -102
  71. package/src/MyNdla/SettingsMenu.tsx +0 -96
@@ -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,12 +18,13 @@ 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
- import { MenuButton } from '@ndla/button';
15
- import SafeLink from '@ndla/safelink';
16
- import { useNavigate } from 'react-router-dom';
23
+ import { IconButtonV2 } from '@ndla/button';
24
+ import SafeLink, { SafeLinkButton } from '@ndla/safelink';
17
25
  import { HashTag } from '@ndla/icons/common';
26
+ import { css } from '@emotion/react';
27
+ import { DropdownMenu, DropdownContent, DropdownTrigger, DropdownItem } from '@ndla/dropdown-menu';
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";
@@ -23,23 +33,24 @@ import { Fragment as _Fragment } from "@emotion/react/jsx-runtime";
23
33
  export var ResourceTitleLink = /*#__PURE__*/_styled(SafeLink, {
24
34
  target: "e1lrrm6s9",
25
35
  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", {
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 { IconButtonV2 } from '@ndla/button';\nimport SafeLink, { SafeLinkButton } from '@ndla/safelink';\nimport { HashTag } from '@ndla/icons/common';\nimport { css } from '@emotion/react';\nimport { DropdownMenu, DropdownContent, DropdownTrigger, DropdownItem } from '@ndla/dropdown-menu';\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\nconst StyledTrigger = styled(IconButtonV2)`\n  margin: 0px ${spacing.xsmall};\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 { t } = useTranslation();\n  const visibleTags = useMemo(() => tags.slice(0, 3), [tags]);\n  const remainingTags = useMemo(() => tags.slice(3, tags.length), [tags]);\n\n  return (\n    <>\n      <TagList tagLinkPrefix={tagLinkPrefix} tags={visibleTags} />\n      {remainingTags.length > 0 && (\n        <DropdownMenu>\n          <DropdownTrigger>\n            <StyledTrigger\n              size=\"xsmall\"\n              variant=\"ghost\"\n              colorTheme=\"light\"\n              aria-label={t('myNdla.moreTags', { count: remainingTags.length })}\n            >\n              {<TagCounterWrapper>{`+${remainingTags.length}`}</TagCounterWrapper>}\n            </StyledTrigger>\n          </DropdownTrigger>\n          <DropdownContent showArrow>\n            {remainingTags.map((tag, i) => (\n              <DropdownItem key={`tag-${i}`}>\n                <SafeLinkButton\n                  to={`${tagLinkPrefix ?? ''}/${encodeURIComponent(tag)}`}\n                  variant=\"ghost\"\n                  colorTheme=\"light\"\n                >\n                  <HashTag />\n                  {tag}\n                </SafeLinkButton>\n              </DropdownItem>\n            ))}\n          </DropdownContent>\n        </DropdownMenu>\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
+ var StyledTrigger = /*#__PURE__*/_styled(IconButtonV2, {
28
38
  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== */"));
39
+ label: "StyledTrigger"
40
+ })("margin:0px ", spacing.xsmall, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["resourceComponents.tsx"],"names":[],"mappings":"AAwC0C","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 { IconButtonV2 } from '@ndla/button';\nimport SafeLink, { SafeLinkButton } from '@ndla/safelink';\nimport { HashTag } from '@ndla/icons/common';\nimport { css } from '@emotion/react';\nimport { DropdownMenu, DropdownContent, DropdownTrigger, DropdownItem } from '@ndla/dropdown-menu';\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\nconst StyledTrigger = styled(IconButtonV2)`\n  margin: 0px ${spacing.xsmall};\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 { t } = useTranslation();\n  const visibleTags = useMemo(() => tags.slice(0, 3), [tags]);\n  const remainingTags = useMemo(() => tags.slice(3, tags.length), [tags]);\n\n  return (\n    <>\n      <TagList tagLinkPrefix={tagLinkPrefix} tags={visibleTags} />\n      {remainingTags.length > 0 && (\n        <DropdownMenu>\n          <DropdownTrigger>\n            <StyledTrigger\n              size=\"xsmall\"\n              variant=\"ghost\"\n              colorTheme=\"light\"\n              aria-label={t('myNdla.moreTags', { count: remainingTags.length })}\n            >\n              {<TagCounterWrapper>{`+${remainingTags.length}`}</TagCounterWrapper>}\n            </StyledTrigger>\n          </DropdownTrigger>\n          <DropdownContent showArrow>\n            {remainingTags.map((tag, i) => (\n              <DropdownItem key={`tag-${i}`}>\n                <SafeLinkButton\n                  to={`${tagLinkPrefix ?? ''}/${encodeURIComponent(tag)}`}\n                  variant=\"ghost\"\n                  colorTheme=\"light\"\n                >\n                  <HashTag />\n                  {tag}\n                </SafeLinkButton>\n              </DropdownItem>\n            ))}\n          </DropdownContent>\n        </DropdownMenu>\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"]} */"));
41
+ 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":"AA4CuC","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 { IconButtonV2 } from '@ndla/button';\nimport SafeLink, { SafeLinkButton } from '@ndla/safelink';\nimport { HashTag } from '@ndla/icons/common';\nimport { css } from '@emotion/react';\nimport { DropdownMenu, DropdownContent, DropdownTrigger, DropdownItem } from '@ndla/dropdown-menu';\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\nconst StyledTrigger = styled(IconButtonV2)`\n  margin: 0px ${spacing.xsmall};\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 { t } = useTranslation();\n  const visibleTags = useMemo(() => tags.slice(0, 3), [tags]);\n  const remainingTags = useMemo(() => tags.slice(3, tags.length), [tags]);\n\n  return (\n    <>\n      <TagList tagLinkPrefix={tagLinkPrefix} tags={visibleTags} />\n      {remainingTags.length > 0 && (\n        <DropdownMenu>\n          <DropdownTrigger>\n            <StyledTrigger\n              size=\"xsmall\"\n              variant=\"ghost\"\n              colorTheme=\"light\"\n              aria-label={t('myNdla.moreTags', { count: remainingTags.length })}\n            >\n              {<TagCounterWrapper>{`+${remainingTags.length}`}</TagCounterWrapper>}\n            </StyledTrigger>\n          </DropdownTrigger>\n          <DropdownContent showArrow>\n            {remainingTags.map((tag, i) => (\n              <DropdownItem key={`tag-${i}`}>\n                <SafeLinkButton\n                  to={`${tagLinkPrefix ?? ''}/${encodeURIComponent(tag)}`}\n                  variant=\"ghost\"\n                  colorTheme=\"light\"\n                >\n                  <HashTag />\n                  {tag}\n                </SafeLinkButton>\n              </DropdownItem>\n            ))}\n          </DropdownContent>\n        </DropdownMenu>\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
42
  var StyledTagList = /*#__PURE__*/_styled("ul", {
32
43
  target: "e1lrrm6s7",
33
44
  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== */"));
45
+ })("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":"AA2D+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 { IconButtonV2 } from '@ndla/button';\nimport SafeLink, { SafeLinkButton } from '@ndla/safelink';\nimport { HashTag } from '@ndla/icons/common';\nimport { css } from '@emotion/react';\nimport { DropdownMenu, DropdownContent, DropdownTrigger, DropdownItem } from '@ndla/dropdown-menu';\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\nconst StyledTrigger = styled(IconButtonV2)`\n  margin: 0px ${spacing.xsmall};\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 { t } = useTranslation();\n  const visibleTags = useMemo(() => tags.slice(0, 3), [tags]);\n  const remainingTags = useMemo(() => tags.slice(3, tags.length), [tags]);\n\n  return (\n    <>\n      <TagList tagLinkPrefix={tagLinkPrefix} tags={visibleTags} />\n      {remainingTags.length > 0 && (\n        <DropdownMenu>\n          <DropdownTrigger>\n            <StyledTrigger\n              size=\"xsmall\"\n              variant=\"ghost\"\n              colorTheme=\"light\"\n              aria-label={t('myNdla.moreTags', { count: remainingTags.length })}\n            >\n              {<TagCounterWrapper>{`+${remainingTags.length}`}</TagCounterWrapper>}\n            </StyledTrigger>\n          </DropdownTrigger>\n          <DropdownContent showArrow>\n            {remainingTags.map((tag, i) => (\n              <DropdownItem key={`tag-${i}`}>\n                <SafeLinkButton\n                  to={`${tagLinkPrefix ?? ''}/${encodeURIComponent(tag)}`}\n                  variant=\"ghost\"\n                  colorTheme=\"light\"\n                >\n                  <HashTag />\n                  {tag}\n                </SafeLinkButton>\n              </DropdownItem>\n            ))}\n          </DropdownContent>\n        </DropdownMenu>\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
46
  var StyledTagListElement = /*#__PURE__*/_styled("li", {
36
47
  target: "e1lrrm6s6",
37
48
  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== */"));
49
+ })("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":"AAwEsC","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 { IconButtonV2 } from '@ndla/button';\nimport SafeLink, { SafeLinkButton } from '@ndla/safelink';\nimport { HashTag } from '@ndla/icons/common';\nimport { css } from '@emotion/react';\nimport { DropdownMenu, DropdownContent, DropdownTrigger, DropdownItem } from '@ndla/dropdown-menu';\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\nconst StyledTrigger = styled(IconButtonV2)`\n  margin: 0px ${spacing.xsmall};\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 { t } = useTranslation();\n  const visibleTags = useMemo(() => tags.slice(0, 3), [tags]);\n  const remainingTags = useMemo(() => tags.slice(3, tags.length), [tags]);\n\n  return (\n    <>\n      <TagList tagLinkPrefix={tagLinkPrefix} tags={visibleTags} />\n      {remainingTags.length > 0 && (\n        <DropdownMenu>\n          <DropdownTrigger>\n            <StyledTrigger\n              size=\"xsmall\"\n              variant=\"ghost\"\n              colorTheme=\"light\"\n              aria-label={t('myNdla.moreTags', { count: remainingTags.length })}\n            >\n              {<TagCounterWrapper>{`+${remainingTags.length}`}</TagCounterWrapper>}\n            </StyledTrigger>\n          </DropdownTrigger>\n          <DropdownContent showArrow>\n            {remainingTags.map((tag, i) => (\n              <DropdownItem key={`tag-${i}`}>\n                <SafeLinkButton\n                  to={`${tagLinkPrefix ?? ''}/${encodeURIComponent(tag)}`}\n                  variant=\"ghost\"\n                  colorTheme=\"light\"\n                >\n                  <HashTag />\n                  {tag}\n                </SafeLinkButton>\n              </DropdownItem>\n            ))}\n          </DropdownContent>\n        </DropdownMenu>\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
50
  var StyledSafeLink = /*#__PURE__*/_styled(SafeLink, {
40
51
  target: "e1lrrm6s5",
41
52
  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== */"));
53
+ })("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":"AA6EuC","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 { IconButtonV2 } from '@ndla/button';\nimport SafeLink, { SafeLinkButton } from '@ndla/safelink';\nimport { HashTag } from '@ndla/icons/common';\nimport { css } from '@emotion/react';\nimport { DropdownMenu, DropdownContent, DropdownTrigger, DropdownItem } from '@ndla/dropdown-menu';\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\nconst StyledTrigger = styled(IconButtonV2)`\n  margin: 0px ${spacing.xsmall};\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 { t } = useTranslation();\n  const visibleTags = useMemo(() => tags.slice(0, 3), [tags]);\n  const remainingTags = useMemo(() => tags.slice(3, tags.length), [tags]);\n\n  return (\n    <>\n      <TagList tagLinkPrefix={tagLinkPrefix} tags={visibleTags} />\n      {remainingTags.length > 0 && (\n        <DropdownMenu>\n          <DropdownTrigger>\n            <StyledTrigger\n              size=\"xsmall\"\n              variant=\"ghost\"\n              colorTheme=\"light\"\n              aria-label={t('myNdla.moreTags', { count: remainingTags.length })}\n            >\n              {<TagCounterWrapper>{`+${remainingTags.length}`}</TagCounterWrapper>}\n            </StyledTrigger>\n          </DropdownTrigger>\n          <DropdownContent showArrow>\n            {remainingTags.map((tag, i) => (\n              <DropdownItem key={`tag-${i}`}>\n                <SafeLinkButton\n                  to={`${tagLinkPrefix ?? ''}/${encodeURIComponent(tag)}`}\n                  variant=\"ghost\"\n                  colorTheme=\"light\"\n                >\n                  <HashTag />\n                  {tag}\n                </SafeLinkButton>\n              </DropdownItem>\n            ))}\n          </DropdownContent>\n        </DropdownMenu>\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
54
  var StyledResourceTypeList = /*#__PURE__*/_styled("ul", {
44
55
  target: "e1lrrm6s4",
45
56
  label: "StyledResourceTypeList"
@@ -49,28 +60,47 @@ var StyledResourceTypeList = /*#__PURE__*/_styled("ul", {
49
60
  } : {
50
61
  name: "vspsww",
51
62
  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== */",
63
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["resourceComponents.tsx"],"names":[],"mappings":"AA2FwC","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 { IconButtonV2 } from '@ndla/button';\nimport SafeLink, { SafeLinkButton } from '@ndla/safelink';\nimport { HashTag } from '@ndla/icons/common';\nimport { css } from '@emotion/react';\nimport { DropdownMenu, DropdownContent, DropdownTrigger, DropdownItem } from '@ndla/dropdown-menu';\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\nconst StyledTrigger = styled(IconButtonV2)`\n  margin: 0px ${spacing.xsmall};\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 { t } = useTranslation();\n  const visibleTags = useMemo(() => tags.slice(0, 3), [tags]);\n  const remainingTags = useMemo(() => tags.slice(3, tags.length), [tags]);\n\n  return (\n    <>\n      <TagList tagLinkPrefix={tagLinkPrefix} tags={visibleTags} />\n      {remainingTags.length > 0 && (\n        <DropdownMenu>\n          <DropdownTrigger>\n            <StyledTrigger\n              size=\"xsmall\"\n              variant=\"ghost\"\n              colorTheme=\"light\"\n              aria-label={t('myNdla.moreTags', { count: remainingTags.length })}\n            >\n              {<TagCounterWrapper>{`+${remainingTags.length}`}</TagCounterWrapper>}\n            </StyledTrigger>\n          </DropdownTrigger>\n          <DropdownContent showArrow>\n            {remainingTags.map((tag, i) => (\n              <DropdownItem key={`tag-${i}`}>\n                <SafeLinkButton\n                  to={`${tagLinkPrefix ?? ''}/${encodeURIComponent(tag)}`}\n                  variant=\"ghost\"\n                  colorTheme=\"light\"\n                >\n                  <HashTag />\n                  {tag}\n                </SafeLinkButton>\n              </DropdownItem>\n            ))}\n          </DropdownContent>\n        </DropdownMenu>\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
64
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
54
65
  });
55
66
  var StyledTopicDivider = /*#__PURE__*/_styled("span", {
56
67
  target: "e1lrrm6s3",
57
68
  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== */"));
69
+ })("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":"AAmGsC","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 { IconButtonV2 } from '@ndla/button';\nimport SafeLink, { SafeLinkButton } from '@ndla/safelink';\nimport { HashTag } from '@ndla/icons/common';\nimport { css } from '@emotion/react';\nimport { DropdownMenu, DropdownContent, DropdownTrigger, DropdownItem } from '@ndla/dropdown-menu';\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\nconst StyledTrigger = styled(IconButtonV2)`\n  margin: 0px ${spacing.xsmall};\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 { t } = useTranslation();\n  const visibleTags = useMemo(() => tags.slice(0, 3), [tags]);\n  const remainingTags = useMemo(() => tags.slice(3, tags.length), [tags]);\n\n  return (\n    <>\n      <TagList tagLinkPrefix={tagLinkPrefix} tags={visibleTags} />\n      {remainingTags.length > 0 && (\n        <DropdownMenu>\n          <DropdownTrigger>\n            <StyledTrigger\n              size=\"xsmall\"\n              variant=\"ghost\"\n              colorTheme=\"light\"\n              aria-label={t('myNdla.moreTags', { count: remainingTags.length })}\n            >\n              {<TagCounterWrapper>{`+${remainingTags.length}`}</TagCounterWrapper>}\n            </StyledTrigger>\n          </DropdownTrigger>\n          <DropdownContent showArrow>\n            {remainingTags.map((tag, i) => (\n              <DropdownItem key={`tag-${i}`}>\n                <SafeLinkButton\n                  to={`${tagLinkPrefix ?? ''}/${encodeURIComponent(tag)}`}\n                  variant=\"ghost\"\n                  colorTheme=\"light\"\n                >\n                  <HashTag />\n                  {tag}\n                </SafeLinkButton>\n              </DropdownItem>\n            ))}\n          </DropdownContent>\n        </DropdownMenu>\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
70
  var StyledResourceListElement = /*#__PURE__*/_styled("li", {
60
71
  target: "e1lrrm6s2",
61
72
  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== */"));
73
+ })("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":"AAwG2C","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 { IconButtonV2 } from '@ndla/button';\nimport SafeLink, { SafeLinkButton } from '@ndla/safelink';\nimport { HashTag } from '@ndla/icons/common';\nimport { css } from '@emotion/react';\nimport { DropdownMenu, DropdownContent, DropdownTrigger, DropdownItem } from '@ndla/dropdown-menu';\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\nconst StyledTrigger = styled(IconButtonV2)`\n  margin: 0px ${spacing.xsmall};\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 { t } = useTranslation();\n  const visibleTags = useMemo(() => tags.slice(0, 3), [tags]);\n  const remainingTags = useMemo(() => tags.slice(3, tags.length), [tags]);\n\n  return (\n    <>\n      <TagList tagLinkPrefix={tagLinkPrefix} tags={visibleTags} />\n      {remainingTags.length > 0 && (\n        <DropdownMenu>\n          <DropdownTrigger>\n            <StyledTrigger\n              size=\"xsmall\"\n              variant=\"ghost\"\n              colorTheme=\"light\"\n              aria-label={t('myNdla.moreTags', { count: remainingTags.length })}\n            >\n              {<TagCounterWrapper>{`+${remainingTags.length}`}</TagCounterWrapper>}\n            </StyledTrigger>\n          </DropdownTrigger>\n          <DropdownContent showArrow>\n            {remainingTags.map((tag, i) => (\n              <DropdownItem key={`tag-${i}`}>\n                <SafeLinkButton\n                  to={`${tagLinkPrefix ?? ''}/${encodeURIComponent(tag)}`}\n                  variant=\"ghost\"\n                  colorTheme=\"light\"\n                >\n                  <HashTag />\n                  {tag}\n                </SafeLinkButton>\n              </DropdownItem>\n            ))}\n          </DropdownContent>\n        </DropdownMenu>\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
74
  var TagCounterWrapper = /*#__PURE__*/_styled("span", {
64
75
  target: "e1lrrm6s1",
65
76
  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", {
77
+ })("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":"AAkHqC","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 { IconButtonV2 } from '@ndla/button';\nimport SafeLink, { SafeLinkButton } from '@ndla/safelink';\nimport { HashTag } from '@ndla/icons/common';\nimport { css } from '@emotion/react';\nimport { DropdownMenu, DropdownContent, DropdownTrigger, DropdownItem } from '@ndla/dropdown-menu';\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\nconst StyledTrigger = styled(IconButtonV2)`\n  margin: 0px ${spacing.xsmall};\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 { t } = useTranslation();\n  const visibleTags = useMemo(() => tags.slice(0, 3), [tags]);\n  const remainingTags = useMemo(() => tags.slice(3, tags.length), [tags]);\n\n  return (\n    <>\n      <TagList tagLinkPrefix={tagLinkPrefix} tags={visibleTags} />\n      {remainingTags.length > 0 && (\n        <DropdownMenu>\n          <DropdownTrigger>\n            <StyledTrigger\n              size=\"xsmall\"\n              variant=\"ghost\"\n              colorTheme=\"light\"\n              aria-label={t('myNdla.moreTags', { count: remainingTags.length })}\n            >\n              {<TagCounterWrapper>{`+${remainingTags.length}`}</TagCounterWrapper>}\n            </StyledTrigger>\n          </DropdownTrigger>\n          <DropdownContent showArrow>\n            {remainingTags.map((tag, i) => (\n              <DropdownItem key={`tag-${i}`}>\n                <SafeLinkButton\n                  to={`${tagLinkPrefix ?? ''}/${encodeURIComponent(tag)}`}\n                  variant=\"ghost\"\n                  colorTheme=\"light\"\n                >\n                  <HashTag />\n                  {tag}\n                </SafeLinkButton>\n              </DropdownItem>\n            ))}\n          </DropdownContent>\n        </DropdownMenu>\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"]} */"));
78
+ var StyledContentIconWrapper = /*#__PURE__*/_styled("span", {
68
79
  target: "e1lrrm6s0",
69
80
  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== */"));
81
+ })(process.env.NODE_ENV === "production" ? {
82
+ name: "758j4h",
83
+ styles: "width:100%;aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;background-color:var(--content-background-color)"
84
+ } : {
85
+ name: "758j4h",
86
+ styles: "width:100%;aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;background-color:var(--content-background-color)",
87
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["resourceComponents.tsx"],"names":[],"mappings":"AA6H4C","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 { IconButtonV2 } from '@ndla/button';\nimport SafeLink, { SafeLinkButton } from '@ndla/safelink';\nimport { HashTag } from '@ndla/icons/common';\nimport { css } from '@emotion/react';\nimport { DropdownMenu, DropdownContent, DropdownTrigger, DropdownItem } from '@ndla/dropdown-menu';\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\nconst StyledTrigger = styled(IconButtonV2)`\n  margin: 0px ${spacing.xsmall};\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 { t } = useTranslation();\n  const visibleTags = useMemo(() => tags.slice(0, 3), [tags]);\n  const remainingTags = useMemo(() => tags.slice(3, tags.length), [tags]);\n\n  return (\n    <>\n      <TagList tagLinkPrefix={tagLinkPrefix} tags={visibleTags} />\n      {remainingTags.length > 0 && (\n        <DropdownMenu>\n          <DropdownTrigger>\n            <StyledTrigger\n              size=\"xsmall\"\n              variant=\"ghost\"\n              colorTheme=\"light\"\n              aria-label={t('myNdla.moreTags', { count: remainingTags.length })}\n            >\n              {<TagCounterWrapper>{`+${remainingTags.length}`}</TagCounterWrapper>}\n            </StyledTrigger>\n          </DropdownTrigger>\n          <DropdownContent showArrow>\n            {remainingTags.map((tag, i) => (\n              <DropdownItem key={`tag-${i}`}>\n                <SafeLinkButton\n                  to={`${tagLinkPrefix ?? ''}/${encodeURIComponent(tag)}`}\n                  variant=\"ghost\"\n                  colorTheme=\"light\"\n                >\n                  <HashTag />\n                  {tag}\n                </SafeLinkButton>\n              </DropdownItem>\n            ))}\n          </DropdownContent>\n        </DropdownMenu>\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"]} */",
88
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
89
+ });
90
+ export var ContentIconWrapper = function ContentIconWrapper(_ref) {
91
+ var contentType = _ref.contentType,
92
+ children = _ref.children,
93
+ props = _objectWithoutProperties(_ref, _excluded);
94
+ var contentIconWrapperVars = useMemo(function () {
95
+ return {
96
+ '--content-background-color': resourceTypeColor(contentType)
97
+ };
98
+ }, [contentType]);
99
+ return _jsx(StyledContentIconWrapper, _objectSpread(_objectSpread({}, props), {}, {
100
+ style: contentIconWrapperVars,
101
+ children: children
102
+ }));
103
+ };
74
104
  export var TagList = function TagList(_ref2) {
75
105
  var tags = _ref2.tags,
76
106
  tagLinkPrefix = _ref2.tagLinkPrefix;
@@ -92,33 +122,44 @@ export var TagList = function TagList(_ref2) {
92
122
  export var CompressedTagList = function CompressedTagList(_ref3) {
93
123
  var tags = _ref3.tags,
94
124
  tagLinkPrefix = _ref3.tagLinkPrefix;
95
- var navigate = useNavigate();
96
125
  var _useTranslation2 = useTranslation(),
97
126
  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
- });
127
+ var visibleTags = useMemo(function () {
128
+ return tags.slice(0, 3);
129
+ }, [tags]);
130
+ var remainingTags = useMemo(function () {
131
+ return tags.slice(3, tags.length);
132
+ }, [tags]);
108
133
  return _jsxs(_Fragment, {
109
134
  children: [_jsx(TagList, {
110
135
  tagLinkPrefix: tagLinkPrefix,
111
136
  tags: visibleTags
112
- }), remainingTags.length > 0 && _jsx(MenuButton, {
113
- size: "small",
114
- menuIcon: _jsx(TagCounterWrapper, {
115
- children: "+".concat(remainingTags.length)
116
- }),
117
- menuItems: remainingTags,
118
- align: "end",
119
- "aria-label": t('myNdla.moreTags', {
120
- count: remainingTags.length
121
- })
137
+ }), remainingTags.length > 0 && _jsxs(DropdownMenu, {
138
+ children: [_jsx(DropdownTrigger, {
139
+ children: _jsx(StyledTrigger, {
140
+ size: "xsmall",
141
+ variant: "ghost",
142
+ colorTheme: "light",
143
+ "aria-label": t('myNdla.moreTags', {
144
+ count: remainingTags.length
145
+ }),
146
+ children: _jsx(TagCounterWrapper, {
147
+ children: "+".concat(remainingTags.length)
148
+ })
149
+ })
150
+ }), _jsx(DropdownContent, {
151
+ showArrow: true,
152
+ children: remainingTags.map(function (tag, i) {
153
+ return _jsx(DropdownItem, {
154
+ children: _jsxs(SafeLinkButton, {
155
+ to: "".concat(tagLinkPrefix !== null && tagLinkPrefix !== void 0 ? tagLinkPrefix : '', "/").concat(encodeURIComponent(tag)),
156
+ variant: "ghost",
157
+ colorTheme: "light",
158
+ children: [_jsx(HashTag, {}), tag]
159
+ })
160
+ }, "tag-".concat(i));
161
+ })
162
+ })]
122
163
  })]
123
164
  });
124
165
  };