@ndla/ui 44.0.13 → 44.0.15

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.
@@ -16,7 +16,7 @@ var StyledCardContainer = /*#__PURE__*/_styled(SafeLink, {
16
16
  label: "StyledCardContainer"
17
17
  })("display:flex;flex-direction:column;background-color:", colors.background.default, ";border-radius:", misc.borderRadius, ";box-shadow:none;&:hover,&:focus-visible{text-decoration:underline ", colors.text.primary, ";text-underline-offset:3px;}", mq.range({
18
18
  from: breakpoints.tablet
19
- }), "{min-height:350px;min-width:250px;max-height:350px;width:250px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlByb2dyYW1tZUNhcmQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTJCNEMiLCJmaWxlIjoiUHJvZ3JhbW1lQ2FyZC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMy1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCBTYWZlTGluayBmcm9tICdAbmRsYS9zYWZlbGluayc7XG5pbXBvcnQgeyBzcGFjaW5nLCBjb2xvcnMsIG1pc2MsIGJyZWFrcG9pbnRzLCBtcSwgZm9udHMgfSBmcm9tICdAbmRsYS9jb3JlJztcblxuaW50ZXJmYWNlIEltYWdlIHtcbiAgc3JjOiBzdHJpbmc7XG4gIGFsdDogc3RyaW5nO1xufVxuZXhwb3J0IGludGVyZmFjZSBQcm9ncmFtbWUge1xuICBpZDogc3RyaW5nO1xuICB0aXRsZToge1xuICAgIHRpdGxlOiBzdHJpbmc7XG4gICAgbGFuZ3VhZ2U6IHN0cmluZztcbiAgfTtcbiAgbmFycm93SW1hZ2U/OiBJbWFnZTtcbiAgd2lkZUltYWdlPzogSW1hZ2U7XG4gIHVybDogc3RyaW5nO1xufVxuXG5jb25zdCBTdHlsZWRDYXJkQ29udGFpbmVyID0gc3R5bGVkKFNhZmVMaW5rKWBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgYmFja2dyb3VuZC1jb2xvcjogJHtjb2xvcnMuYmFja2dyb3VuZC5kZWZhdWx0fTtcbiAgYm9yZGVyLXJhZGl1czogJHttaXNjLmJvcmRlclJhZGl1c307XG4gIGJveC1zaGFkb3c6IG5vbmU7XG5cbiAgJjpob3ZlcixcbiAgJjpmb2N1cy12aXNpYmxlIHtcbiAgICB0ZXh0LWRlY29yYXRpb246IHVuZGVybGluZSAke2NvbG9ycy50ZXh0LnByaW1hcnl9O1xuICAgIHRleHQtdW5kZXJsaW5lLW9mZnNldDogM3B4O1xuICB9XG5cbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLnRhYmxldCB9KX0ge1xuICAgIG1pbi1oZWlnaHQ6IDM1MHB4O1xuICAgIG1pbi13aWR0aDogMjUwcHg7XG4gICAgbWF4LWhlaWdodDogMzUwcHg7XG4gICAgd2lkdGg6IDI1MHB4O1xuICB9XG5gO1xuXG5jb25zdCBTdHlsZWRJbWcgPSBzdHlsZWQuaW1nYFxuICBkaXNwbGF5OiBub25lO1xuICBmbGV4OiAxO1xuICBib3JkZXItcmFkaXVzOiAke21pc2MuYm9yZGVyUmFkaXVzfSAke21pc2MuYm9yZGVyUmFkaXVzfSAwIDA7XG4gIHdpZHRoOiAxMDAlO1xuXG4gICZbZGF0YS1pcy1tb2JpbGU9J3RydWUnXSB7XG4gICAgJHttcS5yYW5nZSh7IHVudGlsOiBicmVha3BvaW50cy50YWJsZXQgfSl9IHtcbiAgICAgIGRpc3BsYXk6IGJsb2NrO1xuICAgIH1cbiAgfVxuICAmW2RhdGEtaXMtbW9iaWxlPSdmYWxzZSddIHtcbiAgICAke21xLnJhbmdlKHsgZnJvbTogYnJlYWtwb2ludHMudGFibGV0IH0pfSB7XG4gICAgICBkaXNwbGF5OiBibG9jaztcbiAgICB9XG4gIH1cbmA7XG5cbmNvbnN0IFN0eWxlZFRpdGxlID0gc3R5bGVkLnNwYW5gXG4gIGRpc3BsYXk6IGZsZXg7XG4gIG1pbi1oZWlnaHQ6IDcwcHg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIHBhZGRpbmctbGVmdDogJHtzcGFjaW5nLm5zbWFsbH07XG4gIG1hcmdpbi10b3A6IGF1dG87XG5cbiAgYm9yZGVyOiAxcHggc29saWQgJHtjb2xvcnMuYnJhbmQubGlnaHRlcn07XG4gIGJvcmRlci1yYWRpdXM6IDAgMCAke21pc2MuYm9yZGVyUmFkaXVzfSAke21pc2MuYm9yZGVyUmFkaXVzfTtcblxuICBmb250LXdlaWdodDogJHtmb250cy53ZWlnaHQuc2VtaWJvbGR9O1xuICBjb2xvcjogJHtjb2xvcnMudGV4dC5wcmltYXJ5fTtcbiAgJHtmb250cy5zaXplcygnMTZweCcsICcyNHB4Jyl9O1xuXG4gICR7bXEucmFuZ2UoeyBmcm9tOiBicmVha3BvaW50cy50YWJsZXQgfSl9IHtcbiAgICAke2ZvbnRzLnNpemVzKCcxNnB4JywgJzE4cHgnKX07XG4gIH1cbmA7XG5cbmNvbnN0IFByb2dyYW1tZUNhcmQgPSAoeyB0aXRsZSwgbmFycm93SW1hZ2UsIHdpZGVJbWFnZSwgdXJsIH06IFByb2dyYW1tZSkgPT4ge1xuICByZXR1cm4gKFxuICAgIDxTdHlsZWRDYXJkQ29udGFpbmVyIHRvPXt1cmx9PlxuICAgICAge25hcnJvd0ltYWdlICYmIDxTdHlsZWRJbWcgZGF0YS1pcy1tb2JpbGU9XCJmYWxzZVwiIHNyYz17bmFycm93SW1hZ2Uuc3JjfSBsb2FkaW5nPVwibGF6eVwiIGFsdD17bmFycm93SW1hZ2UuYWx0fSAvPn1cbiAgICAgIHt3aWRlSW1hZ2UgJiYgPFN0eWxlZEltZyBkYXRhLWlzLW1vYmlsZT1cInRydWVcIiBzcmM9e3dpZGVJbWFnZS5zcmN9IGxvYWRpbmc9XCJsYXp5XCIgYWx0PXt3aWRlSW1hZ2UuYWx0fSAvPn1cbiAgICAgIDxTdHlsZWRUaXRsZT57dGl0bGUudGl0bGV9PC9TdHlsZWRUaXRsZT5cbiAgICA8L1N0eWxlZENhcmRDb250YWluZXI+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBQcm9ncmFtbWVDYXJkO1xuIl19 */"));
19
+ }), "{min-height:350px;min-width:250px;max-height:350px;width:250px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlByb2dyYW1tZUNhcmQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTJCNEMiLCJmaWxlIjoiUHJvZ3JhbW1lQ2FyZC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMy1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCBTYWZlTGluayBmcm9tICdAbmRsYS9zYWZlbGluayc7XG5pbXBvcnQgeyBzcGFjaW5nLCBjb2xvcnMsIG1pc2MsIGJyZWFrcG9pbnRzLCBtcSwgZm9udHMgfSBmcm9tICdAbmRsYS9jb3JlJztcblxuaW50ZXJmYWNlIEltYWdlIHtcbiAgc3JjOiBzdHJpbmc7XG4gIGFsdDogc3RyaW5nO1xufVxuZXhwb3J0IGludGVyZmFjZSBQcm9ncmFtbWUge1xuICBpZDogc3RyaW5nO1xuICB0aXRsZToge1xuICAgIHRpdGxlOiBzdHJpbmc7XG4gICAgbGFuZ3VhZ2U6IHN0cmluZztcbiAgfTtcbiAgbmFycm93SW1hZ2U/OiBJbWFnZTtcbiAgd2lkZUltYWdlPzogSW1hZ2U7XG4gIHVybDogc3RyaW5nO1xufVxuXG5jb25zdCBTdHlsZWRDYXJkQ29udGFpbmVyID0gc3R5bGVkKFNhZmVMaW5rKWBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgYmFja2dyb3VuZC1jb2xvcjogJHtjb2xvcnMuYmFja2dyb3VuZC5kZWZhdWx0fTtcbiAgYm9yZGVyLXJhZGl1czogJHttaXNjLmJvcmRlclJhZGl1c307XG4gIGJveC1zaGFkb3c6IG5vbmU7XG5cbiAgJjpob3ZlcixcbiAgJjpmb2N1cy12aXNpYmxlIHtcbiAgICB0ZXh0LWRlY29yYXRpb246IHVuZGVybGluZSAke2NvbG9ycy50ZXh0LnByaW1hcnl9O1xuICAgIHRleHQtdW5kZXJsaW5lLW9mZnNldDogM3B4O1xuICB9XG5cbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLnRhYmxldCB9KX0ge1xuICAgIG1pbi1oZWlnaHQ6IDM1MHB4O1xuICAgIG1pbi13aWR0aDogMjUwcHg7XG4gICAgbWF4LWhlaWdodDogMzUwcHg7XG4gICAgd2lkdGg6IDI1MHB4O1xuICB9XG5gO1xuXG5jb25zdCBTdHlsZWRJbWcgPSBzdHlsZWQuaW1nYFxuICBkaXNwbGF5OiBub25lO1xuICBmbGV4OiAxO1xuICBib3JkZXItcmFkaXVzOiAke21pc2MuYm9yZGVyUmFkaXVzfSAke21pc2MuYm9yZGVyUmFkaXVzfSAwIDA7XG4gIHdpZHRoOiAxMDAlO1xuXG4gICZbZGF0YS1pcy1tb2JpbGU9J3RydWUnXSB7XG4gICAgJHttcS5yYW5nZSh7IHVudGlsOiBicmVha3BvaW50cy50YWJsZXQgfSl9IHtcbiAgICAgIGRpc3BsYXk6IGJsb2NrO1xuICAgIH1cbiAgfVxuICAmW2RhdGEtaXMtbW9iaWxlPSdmYWxzZSddIHtcbiAgICAke21xLnJhbmdlKHsgZnJvbTogYnJlYWtwb2ludHMudGFibGV0IH0pfSB7XG4gICAgICBkaXNwbGF5OiBibG9jaztcbiAgICB9XG4gIH1cbmA7XG5cbmNvbnN0IFN0eWxlZFRpdGxlID0gc3R5bGVkLnNwYW5gXG4gIGRpc3BsYXk6IGZsZXg7XG4gIG1pbi1oZWlnaHQ6IDcwcHg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIHBhZGRpbmctbGVmdDogJHtzcGFjaW5nLm5zbWFsbH07XG4gIG1hcmdpbi10b3A6IGF1dG87XG5cbiAgYm9yZGVyOiAxcHggc29saWQgJHtjb2xvcnMuYnJhbmQubGlnaHRlcn07XG4gIGJvcmRlci1yYWRpdXM6IDAgMCAke21pc2MuYm9yZGVyUmFkaXVzfSAke21pc2MuYm9yZGVyUmFkaXVzfTtcblxuICBmb250LXdlaWdodDogJHtmb250cy53ZWlnaHQuc2VtaWJvbGR9O1xuICBjb2xvcjogJHtjb2xvcnMudGV4dC5wcmltYXJ5fTtcbiAgJHtmb250cy5zaXplcygnMTZweCcsICcyNHB4Jyl9O1xuXG4gICR7bXEucmFuZ2UoeyBmcm9tOiBicmVha3BvaW50cy50YWJsZXQgfSl9IHtcbiAgICAke2ZvbnRzLnNpemVzKCcxNnB4JywgJzE4cHgnKX07XG4gIH1cbmA7XG5cbmNvbnN0IFByb2dyYW1tZUNhcmQgPSAoeyB0aXRsZSwgbmFycm93SW1hZ2UsIHdpZGVJbWFnZSwgdXJsIH06IFByb2dyYW1tZSkgPT4ge1xuICByZXR1cm4gKFxuICAgIDxTdHlsZWRDYXJkQ29udGFpbmVyIHRvPXt1cmx9PlxuICAgICAge25hcnJvd0ltYWdlICYmIChcbiAgICAgICAgPFN0eWxlZEltZyBkYXRhLWlzLW1vYmlsZT1cImZhbHNlXCIgaGVpZ2h0PXsyODB9IHdpZHRoPXsyNTB9IHNyYz17bmFycm93SW1hZ2Uuc3JjfSBhbHQ9e25hcnJvd0ltYWdlLmFsdH0gLz5cbiAgICAgICl9XG4gICAgICB7d2lkZUltYWdlICYmIChcbiAgICAgICAgPFN0eWxlZEltZyBkYXRhLWlzLW1vYmlsZT1cInRydWVcIiBoZWlnaHQ9ezI4MH0gd2lkdGg9ezI1MH0gc3JjPXt3aWRlSW1hZ2Uuc3JjfSBhbHQ9e3dpZGVJbWFnZS5hbHR9IC8+XG4gICAgICApfVxuICAgICAgPFN0eWxlZFRpdGxlPnt0aXRsZS50aXRsZX08L1N0eWxlZFRpdGxlPlxuICAgIDwvU3R5bGVkQ2FyZENvbnRhaW5lcj5cbiAgKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IFByb2dyYW1tZUNhcmQ7XG4iXX0= */"));
20
20
  var StyledImg = /*#__PURE__*/_styled("img", {
21
21
  target: "eo9d6lc1",
22
22
  label: "StyledImg"
@@ -24,13 +24,13 @@ var StyledImg = /*#__PURE__*/_styled("img", {
24
24
  until: breakpoints.tablet
25
25
  }), "{display:block;}}&[data-is-mobile='false']{", mq.range({
26
26
  from: breakpoints.tablet
27
- }), "{display:block;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlByb2dyYW1tZUNhcmQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWdENEIiLCJmaWxlIjoiUHJvZ3JhbW1lQ2FyZC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMy1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCBTYWZlTGluayBmcm9tICdAbmRsYS9zYWZlbGluayc7XG5pbXBvcnQgeyBzcGFjaW5nLCBjb2xvcnMsIG1pc2MsIGJyZWFrcG9pbnRzLCBtcSwgZm9udHMgfSBmcm9tICdAbmRsYS9jb3JlJztcblxuaW50ZXJmYWNlIEltYWdlIHtcbiAgc3JjOiBzdHJpbmc7XG4gIGFsdDogc3RyaW5nO1xufVxuZXhwb3J0IGludGVyZmFjZSBQcm9ncmFtbWUge1xuICBpZDogc3RyaW5nO1xuICB0aXRsZToge1xuICAgIHRpdGxlOiBzdHJpbmc7XG4gICAgbGFuZ3VhZ2U6IHN0cmluZztcbiAgfTtcbiAgbmFycm93SW1hZ2U/OiBJbWFnZTtcbiAgd2lkZUltYWdlPzogSW1hZ2U7XG4gIHVybDogc3RyaW5nO1xufVxuXG5jb25zdCBTdHlsZWRDYXJkQ29udGFpbmVyID0gc3R5bGVkKFNhZmVMaW5rKWBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgYmFja2dyb3VuZC1jb2xvcjogJHtjb2xvcnMuYmFja2dyb3VuZC5kZWZhdWx0fTtcbiAgYm9yZGVyLXJhZGl1czogJHttaXNjLmJvcmRlclJhZGl1c307XG4gIGJveC1zaGFkb3c6IG5vbmU7XG5cbiAgJjpob3ZlcixcbiAgJjpmb2N1cy12aXNpYmxlIHtcbiAgICB0ZXh0LWRlY29yYXRpb246IHVuZGVybGluZSAke2NvbG9ycy50ZXh0LnByaW1hcnl9O1xuICAgIHRleHQtdW5kZXJsaW5lLW9mZnNldDogM3B4O1xuICB9XG5cbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLnRhYmxldCB9KX0ge1xuICAgIG1pbi1oZWlnaHQ6IDM1MHB4O1xuICAgIG1pbi13aWR0aDogMjUwcHg7XG4gICAgbWF4LWhlaWdodDogMzUwcHg7XG4gICAgd2lkdGg6IDI1MHB4O1xuICB9XG5gO1xuXG5jb25zdCBTdHlsZWRJbWcgPSBzdHlsZWQuaW1nYFxuICBkaXNwbGF5OiBub25lO1xuICBmbGV4OiAxO1xuICBib3JkZXItcmFkaXVzOiAke21pc2MuYm9yZGVyUmFkaXVzfSAke21pc2MuYm9yZGVyUmFkaXVzfSAwIDA7XG4gIHdpZHRoOiAxMDAlO1xuXG4gICZbZGF0YS1pcy1tb2JpbGU9J3RydWUnXSB7XG4gICAgJHttcS5yYW5nZSh7IHVudGlsOiBicmVha3BvaW50cy50YWJsZXQgfSl9IHtcbiAgICAgIGRpc3BsYXk6IGJsb2NrO1xuICAgIH1cbiAgfVxuICAmW2RhdGEtaXMtbW9iaWxlPSdmYWxzZSddIHtcbiAgICAke21xLnJhbmdlKHsgZnJvbTogYnJlYWtwb2ludHMudGFibGV0IH0pfSB7XG4gICAgICBkaXNwbGF5OiBibG9jaztcbiAgICB9XG4gIH1cbmA7XG5cbmNvbnN0IFN0eWxlZFRpdGxlID0gc3R5bGVkLnNwYW5gXG4gIGRpc3BsYXk6IGZsZXg7XG4gIG1pbi1oZWlnaHQ6IDcwcHg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIHBhZGRpbmctbGVmdDogJHtzcGFjaW5nLm5zbWFsbH07XG4gIG1hcmdpbi10b3A6IGF1dG87XG5cbiAgYm9yZGVyOiAxcHggc29saWQgJHtjb2xvcnMuYnJhbmQubGlnaHRlcn07XG4gIGJvcmRlci1yYWRpdXM6IDAgMCAke21pc2MuYm9yZGVyUmFkaXVzfSAke21pc2MuYm9yZGVyUmFkaXVzfTtcblxuICBmb250LXdlaWdodDogJHtmb250cy53ZWlnaHQuc2VtaWJvbGR9O1xuICBjb2xvcjogJHtjb2xvcnMudGV4dC5wcmltYXJ5fTtcbiAgJHtmb250cy5zaXplcygnMTZweCcsICcyNHB4Jyl9O1xuXG4gICR7bXEucmFuZ2UoeyBmcm9tOiBicmVha3BvaW50cy50YWJsZXQgfSl9IHtcbiAgICAke2ZvbnRzLnNpemVzKCcxNnB4JywgJzE4cHgnKX07XG4gIH1cbmA7XG5cbmNvbnN0IFByb2dyYW1tZUNhcmQgPSAoeyB0aXRsZSwgbmFycm93SW1hZ2UsIHdpZGVJbWFnZSwgdXJsIH06IFByb2dyYW1tZSkgPT4ge1xuICByZXR1cm4gKFxuICAgIDxTdHlsZWRDYXJkQ29udGFpbmVyIHRvPXt1cmx9PlxuICAgICAge25hcnJvd0ltYWdlICYmIDxTdHlsZWRJbWcgZGF0YS1pcy1tb2JpbGU9XCJmYWxzZVwiIHNyYz17bmFycm93SW1hZ2Uuc3JjfSBsb2FkaW5nPVwibGF6eVwiIGFsdD17bmFycm93SW1hZ2UuYWx0fSAvPn1cbiAgICAgIHt3aWRlSW1hZ2UgJiYgPFN0eWxlZEltZyBkYXRhLWlzLW1vYmlsZT1cInRydWVcIiBzcmM9e3dpZGVJbWFnZS5zcmN9IGxvYWRpbmc9XCJsYXp5XCIgYWx0PXt3aWRlSW1hZ2UuYWx0fSAvPn1cbiAgICAgIDxTdHlsZWRUaXRsZT57dGl0bGUudGl0bGV9PC9TdHlsZWRUaXRsZT5cbiAgICA8L1N0eWxlZENhcmRDb250YWluZXI+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBQcm9ncmFtbWVDYXJkO1xuIl19 */"));
27
+ }), "{display:block;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlByb2dyYW1tZUNhcmQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWdENEIiLCJmaWxlIjoiUHJvZ3JhbW1lQ2FyZC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMy1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCBTYWZlTGluayBmcm9tICdAbmRsYS9zYWZlbGluayc7XG5pbXBvcnQgeyBzcGFjaW5nLCBjb2xvcnMsIG1pc2MsIGJyZWFrcG9pbnRzLCBtcSwgZm9udHMgfSBmcm9tICdAbmRsYS9jb3JlJztcblxuaW50ZXJmYWNlIEltYWdlIHtcbiAgc3JjOiBzdHJpbmc7XG4gIGFsdDogc3RyaW5nO1xufVxuZXhwb3J0IGludGVyZmFjZSBQcm9ncmFtbWUge1xuICBpZDogc3RyaW5nO1xuICB0aXRsZToge1xuICAgIHRpdGxlOiBzdHJpbmc7XG4gICAgbGFuZ3VhZ2U6IHN0cmluZztcbiAgfTtcbiAgbmFycm93SW1hZ2U/OiBJbWFnZTtcbiAgd2lkZUltYWdlPzogSW1hZ2U7XG4gIHVybDogc3RyaW5nO1xufVxuXG5jb25zdCBTdHlsZWRDYXJkQ29udGFpbmVyID0gc3R5bGVkKFNhZmVMaW5rKWBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgYmFja2dyb3VuZC1jb2xvcjogJHtjb2xvcnMuYmFja2dyb3VuZC5kZWZhdWx0fTtcbiAgYm9yZGVyLXJhZGl1czogJHttaXNjLmJvcmRlclJhZGl1c307XG4gIGJveC1zaGFkb3c6IG5vbmU7XG5cbiAgJjpob3ZlcixcbiAgJjpmb2N1cy12aXNpYmxlIHtcbiAgICB0ZXh0LWRlY29yYXRpb246IHVuZGVybGluZSAke2NvbG9ycy50ZXh0LnByaW1hcnl9O1xuICAgIHRleHQtdW5kZXJsaW5lLW9mZnNldDogM3B4O1xuICB9XG5cbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLnRhYmxldCB9KX0ge1xuICAgIG1pbi1oZWlnaHQ6IDM1MHB4O1xuICAgIG1pbi13aWR0aDogMjUwcHg7XG4gICAgbWF4LWhlaWdodDogMzUwcHg7XG4gICAgd2lkdGg6IDI1MHB4O1xuICB9XG5gO1xuXG5jb25zdCBTdHlsZWRJbWcgPSBzdHlsZWQuaW1nYFxuICBkaXNwbGF5OiBub25lO1xuICBmbGV4OiAxO1xuICBib3JkZXItcmFkaXVzOiAke21pc2MuYm9yZGVyUmFkaXVzfSAke21pc2MuYm9yZGVyUmFkaXVzfSAwIDA7XG4gIHdpZHRoOiAxMDAlO1xuXG4gICZbZGF0YS1pcy1tb2JpbGU9J3RydWUnXSB7XG4gICAgJHttcS5yYW5nZSh7IHVudGlsOiBicmVha3BvaW50cy50YWJsZXQgfSl9IHtcbiAgICAgIGRpc3BsYXk6IGJsb2NrO1xuICAgIH1cbiAgfVxuICAmW2RhdGEtaXMtbW9iaWxlPSdmYWxzZSddIHtcbiAgICAke21xLnJhbmdlKHsgZnJvbTogYnJlYWtwb2ludHMudGFibGV0IH0pfSB7XG4gICAgICBkaXNwbGF5OiBibG9jaztcbiAgICB9XG4gIH1cbmA7XG5cbmNvbnN0IFN0eWxlZFRpdGxlID0gc3R5bGVkLnNwYW5gXG4gIGRpc3BsYXk6IGZsZXg7XG4gIG1pbi1oZWlnaHQ6IDcwcHg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIHBhZGRpbmctbGVmdDogJHtzcGFjaW5nLm5zbWFsbH07XG4gIG1hcmdpbi10b3A6IGF1dG87XG5cbiAgYm9yZGVyOiAxcHggc29saWQgJHtjb2xvcnMuYnJhbmQubGlnaHRlcn07XG4gIGJvcmRlci1yYWRpdXM6IDAgMCAke21pc2MuYm9yZGVyUmFkaXVzfSAke21pc2MuYm9yZGVyUmFkaXVzfTtcblxuICBmb250LXdlaWdodDogJHtmb250cy53ZWlnaHQuc2VtaWJvbGR9O1xuICBjb2xvcjogJHtjb2xvcnMudGV4dC5wcmltYXJ5fTtcbiAgJHtmb250cy5zaXplcygnMTZweCcsICcyNHB4Jyl9O1xuXG4gICR7bXEucmFuZ2UoeyBmcm9tOiBicmVha3BvaW50cy50YWJsZXQgfSl9IHtcbiAgICAke2ZvbnRzLnNpemVzKCcxNnB4JywgJzE4cHgnKX07XG4gIH1cbmA7XG5cbmNvbnN0IFByb2dyYW1tZUNhcmQgPSAoeyB0aXRsZSwgbmFycm93SW1hZ2UsIHdpZGVJbWFnZSwgdXJsIH06IFByb2dyYW1tZSkgPT4ge1xuICByZXR1cm4gKFxuICAgIDxTdHlsZWRDYXJkQ29udGFpbmVyIHRvPXt1cmx9PlxuICAgICAge25hcnJvd0ltYWdlICYmIChcbiAgICAgICAgPFN0eWxlZEltZyBkYXRhLWlzLW1vYmlsZT1cImZhbHNlXCIgaGVpZ2h0PXsyODB9IHdpZHRoPXsyNTB9IHNyYz17bmFycm93SW1hZ2Uuc3JjfSBhbHQ9e25hcnJvd0ltYWdlLmFsdH0gLz5cbiAgICAgICl9XG4gICAgICB7d2lkZUltYWdlICYmIChcbiAgICAgICAgPFN0eWxlZEltZyBkYXRhLWlzLW1vYmlsZT1cInRydWVcIiBoZWlnaHQ9ezI4MH0gd2lkdGg9ezI1MH0gc3JjPXt3aWRlSW1hZ2Uuc3JjfSBhbHQ9e3dpZGVJbWFnZS5hbHR9IC8+XG4gICAgICApfVxuICAgICAgPFN0eWxlZFRpdGxlPnt0aXRsZS50aXRsZX08L1N0eWxlZFRpdGxlPlxuICAgIDwvU3R5bGVkQ2FyZENvbnRhaW5lcj5cbiAgKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IFByb2dyYW1tZUNhcmQ7XG4iXX0= */"));
28
28
  var StyledTitle = /*#__PURE__*/_styled("span", {
29
29
  target: "eo9d6lc0",
30
30
  label: "StyledTitle"
31
31
  })("display:flex;min-height:70px;align-items:center;padding-left:", spacing.nsmall, ";margin-top:auto;border:1px solid ", colors.brand.lighter, ";border-radius:0 0 ", misc.borderRadius, " ", misc.borderRadius, ";font-weight:", fonts.weight.semibold, ";color:", colors.text.primary, ";", fonts.sizes('16px', '24px'), ";", mq.range({
32
32
  from: breakpoints.tablet
33
- }), "{", fonts.sizes('16px', '18px'), ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlByb2dyYW1tZUNhcmQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWtFK0IiLCJmaWxlIjoiUHJvZ3JhbW1lQ2FyZC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMy1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCBTYWZlTGluayBmcm9tICdAbmRsYS9zYWZlbGluayc7XG5pbXBvcnQgeyBzcGFjaW5nLCBjb2xvcnMsIG1pc2MsIGJyZWFrcG9pbnRzLCBtcSwgZm9udHMgfSBmcm9tICdAbmRsYS9jb3JlJztcblxuaW50ZXJmYWNlIEltYWdlIHtcbiAgc3JjOiBzdHJpbmc7XG4gIGFsdDogc3RyaW5nO1xufVxuZXhwb3J0IGludGVyZmFjZSBQcm9ncmFtbWUge1xuICBpZDogc3RyaW5nO1xuICB0aXRsZToge1xuICAgIHRpdGxlOiBzdHJpbmc7XG4gICAgbGFuZ3VhZ2U6IHN0cmluZztcbiAgfTtcbiAgbmFycm93SW1hZ2U/OiBJbWFnZTtcbiAgd2lkZUltYWdlPzogSW1hZ2U7XG4gIHVybDogc3RyaW5nO1xufVxuXG5jb25zdCBTdHlsZWRDYXJkQ29udGFpbmVyID0gc3R5bGVkKFNhZmVMaW5rKWBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgYmFja2dyb3VuZC1jb2xvcjogJHtjb2xvcnMuYmFja2dyb3VuZC5kZWZhdWx0fTtcbiAgYm9yZGVyLXJhZGl1czogJHttaXNjLmJvcmRlclJhZGl1c307XG4gIGJveC1zaGFkb3c6IG5vbmU7XG5cbiAgJjpob3ZlcixcbiAgJjpmb2N1cy12aXNpYmxlIHtcbiAgICB0ZXh0LWRlY29yYXRpb246IHVuZGVybGluZSAke2NvbG9ycy50ZXh0LnByaW1hcnl9O1xuICAgIHRleHQtdW5kZXJsaW5lLW9mZnNldDogM3B4O1xuICB9XG5cbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLnRhYmxldCB9KX0ge1xuICAgIG1pbi1oZWlnaHQ6IDM1MHB4O1xuICAgIG1pbi13aWR0aDogMjUwcHg7XG4gICAgbWF4LWhlaWdodDogMzUwcHg7XG4gICAgd2lkdGg6IDI1MHB4O1xuICB9XG5gO1xuXG5jb25zdCBTdHlsZWRJbWcgPSBzdHlsZWQuaW1nYFxuICBkaXNwbGF5OiBub25lO1xuICBmbGV4OiAxO1xuICBib3JkZXItcmFkaXVzOiAke21pc2MuYm9yZGVyUmFkaXVzfSAke21pc2MuYm9yZGVyUmFkaXVzfSAwIDA7XG4gIHdpZHRoOiAxMDAlO1xuXG4gICZbZGF0YS1pcy1tb2JpbGU9J3RydWUnXSB7XG4gICAgJHttcS5yYW5nZSh7IHVudGlsOiBicmVha3BvaW50cy50YWJsZXQgfSl9IHtcbiAgICAgIGRpc3BsYXk6IGJsb2NrO1xuICAgIH1cbiAgfVxuICAmW2RhdGEtaXMtbW9iaWxlPSdmYWxzZSddIHtcbiAgICAke21xLnJhbmdlKHsgZnJvbTogYnJlYWtwb2ludHMudGFibGV0IH0pfSB7XG4gICAgICBkaXNwbGF5OiBibG9jaztcbiAgICB9XG4gIH1cbmA7XG5cbmNvbnN0IFN0eWxlZFRpdGxlID0gc3R5bGVkLnNwYW5gXG4gIGRpc3BsYXk6IGZsZXg7XG4gIG1pbi1oZWlnaHQ6IDcwcHg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIHBhZGRpbmctbGVmdDogJHtzcGFjaW5nLm5zbWFsbH07XG4gIG1hcmdpbi10b3A6IGF1dG87XG5cbiAgYm9yZGVyOiAxcHggc29saWQgJHtjb2xvcnMuYnJhbmQubGlnaHRlcn07XG4gIGJvcmRlci1yYWRpdXM6IDAgMCAke21pc2MuYm9yZGVyUmFkaXVzfSAke21pc2MuYm9yZGVyUmFkaXVzfTtcblxuICBmb250LXdlaWdodDogJHtmb250cy53ZWlnaHQuc2VtaWJvbGR9O1xuICBjb2xvcjogJHtjb2xvcnMudGV4dC5wcmltYXJ5fTtcbiAgJHtmb250cy5zaXplcygnMTZweCcsICcyNHB4Jyl9O1xuXG4gICR7bXEucmFuZ2UoeyBmcm9tOiBicmVha3BvaW50cy50YWJsZXQgfSl9IHtcbiAgICAke2ZvbnRzLnNpemVzKCcxNnB4JywgJzE4cHgnKX07XG4gIH1cbmA7XG5cbmNvbnN0IFByb2dyYW1tZUNhcmQgPSAoeyB0aXRsZSwgbmFycm93SW1hZ2UsIHdpZGVJbWFnZSwgdXJsIH06IFByb2dyYW1tZSkgPT4ge1xuICByZXR1cm4gKFxuICAgIDxTdHlsZWRDYXJkQ29udGFpbmVyIHRvPXt1cmx9PlxuICAgICAge25hcnJvd0ltYWdlICYmIDxTdHlsZWRJbWcgZGF0YS1pcy1tb2JpbGU9XCJmYWxzZVwiIHNyYz17bmFycm93SW1hZ2Uuc3JjfSBsb2FkaW5nPVwibGF6eVwiIGFsdD17bmFycm93SW1hZ2UuYWx0fSAvPn1cbiAgICAgIHt3aWRlSW1hZ2UgJiYgPFN0eWxlZEltZyBkYXRhLWlzLW1vYmlsZT1cInRydWVcIiBzcmM9e3dpZGVJbWFnZS5zcmN9IGxvYWRpbmc9XCJsYXp5XCIgYWx0PXt3aWRlSW1hZ2UuYWx0fSAvPn1cbiAgICAgIDxTdHlsZWRUaXRsZT57dGl0bGUudGl0bGV9PC9TdHlsZWRUaXRsZT5cbiAgICA8L1N0eWxlZENhcmRDb250YWluZXI+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBQcm9ncmFtbWVDYXJkO1xuIl19 */"));
33
+ }), "{", fonts.sizes('16px', '18px'), ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlByb2dyYW1tZUNhcmQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWtFK0IiLCJmaWxlIjoiUHJvZ3JhbW1lQ2FyZC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMy1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCBTYWZlTGluayBmcm9tICdAbmRsYS9zYWZlbGluayc7XG5pbXBvcnQgeyBzcGFjaW5nLCBjb2xvcnMsIG1pc2MsIGJyZWFrcG9pbnRzLCBtcSwgZm9udHMgfSBmcm9tICdAbmRsYS9jb3JlJztcblxuaW50ZXJmYWNlIEltYWdlIHtcbiAgc3JjOiBzdHJpbmc7XG4gIGFsdDogc3RyaW5nO1xufVxuZXhwb3J0IGludGVyZmFjZSBQcm9ncmFtbWUge1xuICBpZDogc3RyaW5nO1xuICB0aXRsZToge1xuICAgIHRpdGxlOiBzdHJpbmc7XG4gICAgbGFuZ3VhZ2U6IHN0cmluZztcbiAgfTtcbiAgbmFycm93SW1hZ2U/OiBJbWFnZTtcbiAgd2lkZUltYWdlPzogSW1hZ2U7XG4gIHVybDogc3RyaW5nO1xufVxuXG5jb25zdCBTdHlsZWRDYXJkQ29udGFpbmVyID0gc3R5bGVkKFNhZmVMaW5rKWBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgYmFja2dyb3VuZC1jb2xvcjogJHtjb2xvcnMuYmFja2dyb3VuZC5kZWZhdWx0fTtcbiAgYm9yZGVyLXJhZGl1czogJHttaXNjLmJvcmRlclJhZGl1c307XG4gIGJveC1zaGFkb3c6IG5vbmU7XG5cbiAgJjpob3ZlcixcbiAgJjpmb2N1cy12aXNpYmxlIHtcbiAgICB0ZXh0LWRlY29yYXRpb246IHVuZGVybGluZSAke2NvbG9ycy50ZXh0LnByaW1hcnl9O1xuICAgIHRleHQtdW5kZXJsaW5lLW9mZnNldDogM3B4O1xuICB9XG5cbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLnRhYmxldCB9KX0ge1xuICAgIG1pbi1oZWlnaHQ6IDM1MHB4O1xuICAgIG1pbi13aWR0aDogMjUwcHg7XG4gICAgbWF4LWhlaWdodDogMzUwcHg7XG4gICAgd2lkdGg6IDI1MHB4O1xuICB9XG5gO1xuXG5jb25zdCBTdHlsZWRJbWcgPSBzdHlsZWQuaW1nYFxuICBkaXNwbGF5OiBub25lO1xuICBmbGV4OiAxO1xuICBib3JkZXItcmFkaXVzOiAke21pc2MuYm9yZGVyUmFkaXVzfSAke21pc2MuYm9yZGVyUmFkaXVzfSAwIDA7XG4gIHdpZHRoOiAxMDAlO1xuXG4gICZbZGF0YS1pcy1tb2JpbGU9J3RydWUnXSB7XG4gICAgJHttcS5yYW5nZSh7IHVudGlsOiBicmVha3BvaW50cy50YWJsZXQgfSl9IHtcbiAgICAgIGRpc3BsYXk6IGJsb2NrO1xuICAgIH1cbiAgfVxuICAmW2RhdGEtaXMtbW9iaWxlPSdmYWxzZSddIHtcbiAgICAke21xLnJhbmdlKHsgZnJvbTogYnJlYWtwb2ludHMudGFibGV0IH0pfSB7XG4gICAgICBkaXNwbGF5OiBibG9jaztcbiAgICB9XG4gIH1cbmA7XG5cbmNvbnN0IFN0eWxlZFRpdGxlID0gc3R5bGVkLnNwYW5gXG4gIGRpc3BsYXk6IGZsZXg7XG4gIG1pbi1oZWlnaHQ6IDcwcHg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIHBhZGRpbmctbGVmdDogJHtzcGFjaW5nLm5zbWFsbH07XG4gIG1hcmdpbi10b3A6IGF1dG87XG5cbiAgYm9yZGVyOiAxcHggc29saWQgJHtjb2xvcnMuYnJhbmQubGlnaHRlcn07XG4gIGJvcmRlci1yYWRpdXM6IDAgMCAke21pc2MuYm9yZGVyUmFkaXVzfSAke21pc2MuYm9yZGVyUmFkaXVzfTtcblxuICBmb250LXdlaWdodDogJHtmb250cy53ZWlnaHQuc2VtaWJvbGR9O1xuICBjb2xvcjogJHtjb2xvcnMudGV4dC5wcmltYXJ5fTtcbiAgJHtmb250cy5zaXplcygnMTZweCcsICcyNHB4Jyl9O1xuXG4gICR7bXEucmFuZ2UoeyBmcm9tOiBicmVha3BvaW50cy50YWJsZXQgfSl9IHtcbiAgICAke2ZvbnRzLnNpemVzKCcxNnB4JywgJzE4cHgnKX07XG4gIH1cbmA7XG5cbmNvbnN0IFByb2dyYW1tZUNhcmQgPSAoeyB0aXRsZSwgbmFycm93SW1hZ2UsIHdpZGVJbWFnZSwgdXJsIH06IFByb2dyYW1tZSkgPT4ge1xuICByZXR1cm4gKFxuICAgIDxTdHlsZWRDYXJkQ29udGFpbmVyIHRvPXt1cmx9PlxuICAgICAge25hcnJvd0ltYWdlICYmIChcbiAgICAgICAgPFN0eWxlZEltZyBkYXRhLWlzLW1vYmlsZT1cImZhbHNlXCIgaGVpZ2h0PXsyODB9IHdpZHRoPXsyNTB9IHNyYz17bmFycm93SW1hZ2Uuc3JjfSBhbHQ9e25hcnJvd0ltYWdlLmFsdH0gLz5cbiAgICAgICl9XG4gICAgICB7d2lkZUltYWdlICYmIChcbiAgICAgICAgPFN0eWxlZEltZyBkYXRhLWlzLW1vYmlsZT1cInRydWVcIiBoZWlnaHQ9ezI4MH0gd2lkdGg9ezI1MH0gc3JjPXt3aWRlSW1hZ2Uuc3JjfSBhbHQ9e3dpZGVJbWFnZS5hbHR9IC8+XG4gICAgICApfVxuICAgICAgPFN0eWxlZFRpdGxlPnt0aXRsZS50aXRsZX08L1N0eWxlZFRpdGxlPlxuICAgIDwvU3R5bGVkQ2FyZENvbnRhaW5lcj5cbiAgKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IFByb2dyYW1tZUNhcmQ7XG4iXX0= */"));
34
34
  var ProgrammeCard = function ProgrammeCard(_ref) {
35
35
  var title = _ref.title,
36
36
  narrowImage = _ref.narrowImage,
@@ -40,13 +40,15 @@ var ProgrammeCard = function ProgrammeCard(_ref) {
40
40
  to: url,
41
41
  children: [narrowImage && _jsx(StyledImg, {
42
42
  "data-is-mobile": "false",
43
+ height: 280,
44
+ width: 250,
43
45
  src: narrowImage.src,
44
- loading: "lazy",
45
46
  alt: narrowImage.alt
46
47
  }), wideImage && _jsx(StyledImg, {
47
48
  "data-is-mobile": "true",
49
+ height: 280,
50
+ width: 250,
48
51
  src: wideImage.src,
49
- loading: "lazy",
50
52
  alt: wideImage.alt
51
53
  }), _jsx(StyledTitle, {
52
54
  children: title.title
@@ -23,7 +23,7 @@ import { jsxs as _jsxs } from "@emotion/react/jsx-runtime";
23
23
  var OpenButton = /*#__PURE__*/_styled("span", {
24
24
  target: "e11ok6h86",
25
25
  label: "OpenButton"
26
- })("display:flex;align-items:center;justify-content:center;align-self:stretch;color:", colors.brand.tertiary, ";", misc.transition.default, ";cursor:pointer;&:hover{color:", colors.brand.primary, ";}svg{width:24px;height:24px;transform:rotate(-90deg);}&[data-open='true']{svg{transform:rotate(0deg);}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FolderItem.tsx"],"names":[],"mappings":"AAsB8B","file":"FolderItem.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 { CSSProperties, KeyboardEvent, useEffect, useMemo, useRef } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { ArrowDropDownRounded } from '@ndla/icons/common';\nimport { FolderOutlined, FolderShared } from '@ndla/icons/contentType';\nimport { Done } from '@ndla/icons/editor';\nimport { ButtonV2 as Button } from '@ndla/button';\nimport { colors, spacing, animations, misc, fonts } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\nimport { IFolder } from '@ndla/types-backend/learningpath-api';\nimport { CommonFolderItemsProps } from './types';\nimport { arrowNavigation } from './arrowNavigation';\nimport { treestructureId } from './helperFunctions';\n\nconst OpenButton = styled.span`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  align-self: stretch;\n  color: ${colors.brand.tertiary};\n  ${misc.transition.default};\n  cursor: pointer;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n  svg {\n    width: 24px;\n    height: 24px;\n    transform: rotate(-90deg);\n  }\n  &[data-open='true'] {\n    svg {\n      transform: rotate(0deg);\n    }\n  }\n`;\n\nconst StyledName = styled.span`\n  white-space: nowrap;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  grid-column-start: 2;\n  text-align: left;\n`;\n\nconst IconWrapper = styled.div`\n  display: flex;\n`;\n\nconst FolderIconWrapper = styled.div`\n  svg {\n    height: 24px;\n    width: 24px;\n  }\n`;\n\nconst FolderName = styled(Button)`\n  display: grid;\n  grid-template-columns: auto 1fr auto;\n  padding-left: calc(0.75 * ${spacing.normal} * var(--level));\n  gap: ${spacing.xxsmall};\n  border: none;\n  outline: none;\n  color: ${colors.text.primary};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\n\n  &:hover {\n    box-shadow: none;\n    outline: none;\n    background: ${colors.brand.lightest};\n    color: ${colors.text.primary};\n  }\n\n  &[data-focused='true'] {\n    background: ${colors.brand.lightest};\n  }\n\n  &[data-selected='true'] {\n    background: ${colors.brand.lighter};\n    &:hover {\n      background: ${colors.brand.light};\n    }\n  }\n\n  &[data-creating='true'][data-focused='true'] {\n    color: ${colors.brand.primary};\n  }\n\n  &[data-creating='true'] {\n    background: none;\n  }\n`;\n\nconst StyledDone = styled(Done)`\n  color: ${colors.support.green};\n`;\n\nconst FolderNameLink = styled(SafeLink)`\n  display: grid;\n  align-items: center;\n  grid-template-columns: ${spacing.medium} 1fr auto;\n  padding: ${spacing.small} ${spacing.xxsmall};\n  padding-left: calc(0.75 * ${spacing.normal} * var(--level));\n  gap: ${spacing.xxsmall};\n  cursor: pointer;\n\n  border: none;\n  box-shadow: none;\n  color: ${colors.text.primary};\n  font-size: ${fonts.sizes('16px')};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\n  &[data-selected='true'] {\n    color: ${colors.brand.primary};\n    font-weight: ${fonts.weight.semibold};\n  }\n  &:hover,\n  &:focus {\n    color: ${colors.brand.primary};\n  }\n`;\n\ninterface Props extends CommonFolderItemsProps {\n  isOpen: boolean;\n  folder: IFolder;\n  isCreatingFolder?: boolean;\n  index: number;\n}\n\nconst FolderItem = ({\n  focusedFolder,\n  folder,\n  isOpen,\n  level,\n  loading,\n  selectedFolder,\n  onCloseFolder,\n  onOpenFolder,\n  setFocusedFolder,\n  setSelectedFolder,\n  targetResource,\n  visibleFolders,\n  maxLevel,\n  isCreatingFolder,\n  type,\n  closeTree,\n  index,\n}: Props) => {\n  const { t } = useTranslation();\n  const { id, name } = folder;\n  const ref = useRef<HTMLButtonElement & HTMLAnchorElement>(null);\n  const selected = selectedFolder ? selectedFolder.id === id : false;\n\n  const levelVariable = useMemo(() => ({ '--level': level } as unknown as CSSProperties), [level]);\n\n  const focused = focusedFolder?.id === id;\n\n  const handleClickFolder = () => {\n    if (!selected) {\n      setSelectedFolder(folder);\n    }\n    setFocusedFolder(folder);\n    if (type === 'picker') {\n      if (selected) {\n        closeTree();\n      }\n    }\n  };\n\n  useEffect(() => {\n    if (focusedFolder?.id === id && !isCreatingFolder) {\n      if (type === 'navigation') {\n        ref.current?.focus();\n      }\n      if (type === 'picker') {\n        ref.current?.focus();\n        ref.current?.scrollIntoView({\n          behavior: 'smooth',\n          block: 'start',\n        });\n      }\n    }\n  }, [focusedFolder, ref, id, isCreatingFolder, type]);\n\n  const linkPath = `/minndla/folders/${id}`;\n\n  const containsResource =\n    targetResource && folder.resources.some((resource) => resource.resourceId === targetResource.resourceId);\n\n  const emptyFolder = folder.subfolders.length === 0;\n  const isMaxDepth = level > maxLevel;\n  const hideArrow = isMaxDepth || emptyFolder;\n\n  const FolderIcon = folder.status === 'shared' ? FolderShared : FolderOutlined;\n\n  const tabable = selected || focused || (!focusedFolder && !folder.parentId && index === 0);\n\n  return type === 'navigation' ? (\n    <FolderNameLink\n      role=\"treeitem\"\n      aria-owns={folder.subfolders.length ? treestructureId(type, `subfolders-${folder.id}`) : undefined}\n      aria-expanded={isMaxDepth || emptyFolder ? undefined : isOpen}\n      aria-current={selected ? 'page' : undefined}\n      aria-describedby={containsResource ? `alreadyAdded-${folder.id}` : undefined}\n      ref={ref}\n      style={levelVariable}\n      onKeyDown={(e: KeyboardEvent<HTMLElement>) => {\n        if (e.key === 'Enter') {\n          setSelectedFolder(folder);\n          return;\n        }\n        arrowNavigation(e, id, visibleFolders, setFocusedFolder, onOpenFolder, onCloseFolder);\n      }}\n      to={loading ? '' : linkPath}\n      tabIndex={tabable ? 0 : -1}\n      data-selected={selected}\n      onFocus={() => setFocusedFolder(folder)}\n      onClick={handleClickFolder}\n    >\n      {!hideArrow && (\n        <OpenButton\n          aria-hidden\n          tabIndex={-1}\n          data-open={isOpen}\n          onClick={(e) => {\n            e.stopPropagation();\n            e.preventDefault();\n            ref.current?.focus();\n            if (isOpen) {\n              onCloseFolder(id);\n            } else {\n              onOpenFolder(id);\n            }\n          }}\n        >\n          <ArrowDropDownRounded />\n        </OpenButton>\n      )}\n      <StyledName>{name}</StyledName>\n    </FolderNameLink>\n  ) : (\n    <FolderName\n      tabIndex={-1}\n      role=\"treeitem\"\n      id={treestructureId(type, folder.id)}\n      aria-expanded={isMaxDepth || emptyFolder ? undefined : isOpen}\n      aria-selected={selected}\n      data-focused={focusedFolder?.id === folder.id}\n      aria-describedby={containsResource ? `alreadyAdded-${folder.id}` : undefined}\n      aria-label={`${name}${folder.status === 'shared' ? `, ${t('myNdla.folder.sharing.shared')}` : ''}`}\n      variant=\"ghost\"\n      shape=\"sharp\"\n      fontWeight=\"normal\"\n      colorTheme=\"light\"\n      ref={ref}\n      style={levelVariable}\n      data-selected={selected}\n      disabled={loading}\n      onFocus={() => setFocusedFolder(focusedFolder || folder)}\n      onClick={handleClickFolder}\n      data-creating={isCreatingFolder}\n    >\n      <IconWrapper>\n        {!hideArrow && (\n          <OpenButton\n            aria-hidden\n            tabIndex={-1}\n            data-open={isOpen}\n            onClick={(e) => {\n              e.stopPropagation();\n              setFocusedFolder(folder);\n              if (isOpen) {\n                onCloseFolder(id);\n              } else {\n                onOpenFolder(id);\n              }\n            }}\n          >\n            <ArrowDropDownRounded />\n          </OpenButton>\n        )}\n        <FolderIconWrapper>\n          <FolderIcon />\n        </FolderIconWrapper>\n      </IconWrapper>\n      <StyledName>{name}</StyledName>\n      {containsResource && (\n        <StyledDone\n          aria-label={t('myNdla.alreadyInFolder')}\n          id={`alreadyAdded-${folder.id}`}\n          title={t('myNdla.alreadyInFolder')}\n        />\n      )}\n    </FolderName>\n  );\n};\n\nexport default FolderItem;\n"]} */"));
26
+ })("display:flex;align-items:center;justify-content:center;align-self:stretch;color:", colors.brand.tertiary, ";", misc.transition.default, ";cursor:pointer;&:hover{color:", colors.brand.primary, ";}svg{width:24px;height:24px;transform:rotate(-90deg);}&[data-open='true']{svg{transform:rotate(0deg);}}&[data-hide-arrow='true']{visibility:hidden;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FolderItem.tsx"],"names":[],"mappings":"AAsB8B","file":"FolderItem.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 { CSSProperties, KeyboardEvent, useEffect, useMemo, useRef } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { ArrowDropDownRounded } from '@ndla/icons/common';\nimport { FolderOutlined, FolderShared } from '@ndla/icons/contentType';\nimport { Done } from '@ndla/icons/editor';\nimport { ButtonV2 as Button } from '@ndla/button';\nimport { colors, spacing, animations, misc, fonts } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\nimport { IFolder } from '@ndla/types-backend/learningpath-api';\nimport { CommonFolderItemsProps } from './types';\nimport { arrowNavigation } from './arrowNavigation';\nimport { treestructureId } from './helperFunctions';\n\nconst OpenButton = styled.span`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  align-self: stretch;\n  color: ${colors.brand.tertiary};\n  ${misc.transition.default};\n  cursor: pointer;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n  svg {\n    width: 24px;\n    height: 24px;\n    transform: rotate(-90deg);\n  }\n  &[data-open='true'] {\n    svg {\n      transform: rotate(0deg);\n    }\n  }\n  &[data-hide-arrow='true'] {\n    visibility: hidden;\n  }\n`;\n\nconst StyledName = styled.span`\n  white-space: nowrap;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  grid-column-start: 2;\n  text-align: left;\n`;\n\nconst IconWrapper = styled.div`\n  display: flex;\n`;\n\nconst FolderIconWrapper = styled.div`\n  svg {\n    height: 24px;\n    width: 24px;\n  }\n`;\n\nconst FolderName = styled(Button)`\n  display: grid;\n  grid-template-columns: auto 1fr auto;\n  padding-left: calc(0.75 * ${spacing.normal} * var(--level));\n  gap: ${spacing.xxsmall};\n  border: none;\n  outline: none;\n  color: ${colors.text.primary};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\n\n  &:hover {\n    box-shadow: none;\n    outline: none;\n    background: ${colors.brand.lightest};\n    color: ${colors.text.primary};\n  }\n\n  &[data-focused='true'] {\n    background: ${colors.brand.lightest};\n  }\n\n  &[data-selected='true'] {\n    background: ${colors.brand.lighter};\n    &:hover {\n      background: ${colors.brand.light};\n    }\n  }\n\n  &[data-creating='true'][data-focused='true'] {\n    color: ${colors.brand.primary};\n  }\n\n  &[data-creating='true'] {\n    background: none;\n  }\n`;\n\nconst StyledDone = styled(Done)`\n  color: ${colors.support.green};\n`;\n\nconst FolderNameLink = styled(SafeLink)`\n  display: grid;\n  align-items: center;\n  grid-template-columns: ${spacing.medium} 1fr auto;\n  padding: ${spacing.small} ${spacing.xxsmall};\n  padding-left: calc(0.75 * ${spacing.normal} * var(--level));\n  gap: ${spacing.xxsmall};\n  cursor: pointer;\n\n  border: none;\n  box-shadow: none;\n  color: ${colors.text.primary};\n  font-size: ${fonts.sizes('16px')};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\n  &[data-selected='true'] {\n    color: ${colors.brand.primary};\n    font-weight: ${fonts.weight.semibold};\n  }\n  &:hover,\n  &:focus {\n    color: ${colors.brand.primary};\n  }\n`;\n\ninterface Props extends CommonFolderItemsProps {\n  isOpen: boolean;\n  folder: IFolder;\n  isCreatingFolder?: boolean;\n  index: number;\n}\n\nconst FolderItem = ({\n  focusedFolder,\n  folder,\n  isOpen,\n  level,\n  loading,\n  selectedFolder,\n  onCloseFolder,\n  onOpenFolder,\n  setFocusedFolder,\n  setSelectedFolder,\n  targetResource,\n  visibleFolders,\n  maxLevel,\n  isCreatingFolder,\n  type,\n  closeTree,\n  index,\n}: Props) => {\n  const { t } = useTranslation();\n  const { id, name } = folder;\n  const ref = useRef<HTMLButtonElement & HTMLAnchorElement>(null);\n  const selected = selectedFolder ? selectedFolder.id === id : false;\n\n  const levelVariable = useMemo(() => ({ '--level': level } as unknown as CSSProperties), [level]);\n\n  const focused = focusedFolder?.id === id;\n\n  const handleClickFolder = () => {\n    if (!selected) {\n      setSelectedFolder(folder);\n    }\n    setFocusedFolder(folder);\n    if (type === 'picker') {\n      if (selected) {\n        closeTree();\n      }\n    }\n  };\n\n  useEffect(() => {\n    if (focusedFolder?.id === id && !isCreatingFolder) {\n      if (type === 'navigation') {\n        ref.current?.focus();\n      }\n      if (type === 'picker') {\n        ref.current?.focus();\n        ref.current?.scrollIntoView({\n          behavior: 'smooth',\n          block: 'start',\n        });\n      }\n    }\n  }, [focusedFolder, ref, id, isCreatingFolder, type]);\n\n  const linkPath = `/minndla/folders/${id}`;\n\n  const containsResource =\n    targetResource && folder.resources.some((resource) => resource.resourceId === targetResource.resourceId);\n\n  const emptyFolder = folder.subfolders.length === 0;\n  const isMaxDepth = level > maxLevel;\n  const hideArrow = isMaxDepth || emptyFolder;\n\n  const FolderIcon = folder.status === 'shared' ? FolderShared : FolderOutlined;\n\n  const tabable = selected || focused || (!focusedFolder && !folder.parentId && index === 0);\n\n  return type === 'navigation' ? (\n    <FolderNameLink\n      role=\"treeitem\"\n      aria-owns={folder.subfolders.length ? treestructureId(type, `subfolders-${folder.id}`) : undefined}\n      aria-expanded={isMaxDepth || emptyFolder ? undefined : isOpen}\n      aria-current={selected ? 'page' : undefined}\n      aria-describedby={containsResource ? `alreadyAdded-${folder.id}` : undefined}\n      ref={ref}\n      style={levelVariable}\n      onKeyDown={(e: KeyboardEvent<HTMLElement>) => {\n        if (e.key === 'Enter') {\n          setSelectedFolder(folder);\n          return;\n        }\n        arrowNavigation(e, id, visibleFolders, setFocusedFolder, onOpenFolder, onCloseFolder);\n      }}\n      to={loading ? '' : linkPath}\n      tabIndex={tabable ? 0 : -1}\n      data-selected={selected}\n      onFocus={() => setFocusedFolder(folder)}\n      onClick={handleClickFolder}\n    >\n      <OpenButton\n        aria-hidden\n        tabIndex={-1}\n        data-open={isOpen}\n        data-hide-arrow={hideArrow}\n        onClick={(e) => {\n          e.stopPropagation();\n          e.preventDefault();\n          ref.current?.focus();\n          if (isOpen) {\n            onCloseFolder(id);\n          } else {\n            onOpenFolder(id);\n          }\n        }}\n      >\n        <ArrowDropDownRounded />\n      </OpenButton>\n      <StyledName>{name}</StyledName>\n    </FolderNameLink>\n  ) : (\n    <FolderName\n      tabIndex={-1}\n      role=\"treeitem\"\n      id={treestructureId(type, folder.id)}\n      aria-expanded={isMaxDepth || emptyFolder ? undefined : isOpen}\n      aria-selected={selected}\n      data-focused={focusedFolder?.id === folder.id}\n      aria-describedby={containsResource ? `alreadyAdded-${folder.id}` : undefined}\n      aria-label={`${name}${folder.status === 'shared' ? `, ${t('myNdla.folder.sharing.shared')}` : ''}`}\n      variant=\"ghost\"\n      shape=\"sharp\"\n      fontWeight=\"normal\"\n      colorTheme=\"light\"\n      ref={ref}\n      style={levelVariable}\n      data-selected={selected}\n      disabled={loading}\n      onFocus={() => setFocusedFolder(focusedFolder || folder)}\n      onClick={handleClickFolder}\n      data-creating={isCreatingFolder}\n    >\n      <IconWrapper>\n        <OpenButton\n          aria-hidden\n          tabIndex={-1}\n          data-open={isOpen}\n          data-hide-arrow={hideArrow}\n          onClick={(e) => {\n            e.stopPropagation();\n            setFocusedFolder(folder);\n            if (isOpen) {\n              onCloseFolder(id);\n            } else {\n              onOpenFolder(id);\n            }\n          }}\n        >\n          <ArrowDropDownRounded />\n        </OpenButton>\n        <FolderIconWrapper>\n          <FolderIcon />\n        </FolderIconWrapper>\n      </IconWrapper>\n      <StyledName>{name}</StyledName>\n      {containsResource && (\n        <StyledDone\n          aria-label={t('myNdla.alreadyInFolder')}\n          id={`alreadyAdded-${folder.id}`}\n          title={t('myNdla.alreadyInFolder')}\n        />\n      )}\n    </FolderName>\n  );\n};\n\nexport default FolderItem;\n"]} */"));
27
27
  var StyledName = /*#__PURE__*/_styled("span", {
28
28
  target: "e11ok6h85",
29
29
  label: "StyledName"
@@ -33,7 +33,7 @@ var StyledName = /*#__PURE__*/_styled("span", {
33
33
  } : {
34
34
  name: "woa3z4",
35
35
  styles: "white-space:nowrap;overflow:hidden;text-overflow:ellipsis;grid-column-start:2;text-align:left",
36
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FolderItem.tsx"],"names":[],"mappings":"AA6C8B","file":"FolderItem.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 { CSSProperties, KeyboardEvent, useEffect, useMemo, useRef } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { ArrowDropDownRounded } from '@ndla/icons/common';\nimport { FolderOutlined, FolderShared } from '@ndla/icons/contentType';\nimport { Done } from '@ndla/icons/editor';\nimport { ButtonV2 as Button } from '@ndla/button';\nimport { colors, spacing, animations, misc, fonts } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\nimport { IFolder } from '@ndla/types-backend/learningpath-api';\nimport { CommonFolderItemsProps } from './types';\nimport { arrowNavigation } from './arrowNavigation';\nimport { treestructureId } from './helperFunctions';\n\nconst OpenButton = styled.span`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  align-self: stretch;\n  color: ${colors.brand.tertiary};\n  ${misc.transition.default};\n  cursor: pointer;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n  svg {\n    width: 24px;\n    height: 24px;\n    transform: rotate(-90deg);\n  }\n  &[data-open='true'] {\n    svg {\n      transform: rotate(0deg);\n    }\n  }\n`;\n\nconst StyledName = styled.span`\n  white-space: nowrap;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  grid-column-start: 2;\n  text-align: left;\n`;\n\nconst IconWrapper = styled.div`\n  display: flex;\n`;\n\nconst FolderIconWrapper = styled.div`\n  svg {\n    height: 24px;\n    width: 24px;\n  }\n`;\n\nconst FolderName = styled(Button)`\n  display: grid;\n  grid-template-columns: auto 1fr auto;\n  padding-left: calc(0.75 * ${spacing.normal} * var(--level));\n  gap: ${spacing.xxsmall};\n  border: none;\n  outline: none;\n  color: ${colors.text.primary};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\n\n  &:hover {\n    box-shadow: none;\n    outline: none;\n    background: ${colors.brand.lightest};\n    color: ${colors.text.primary};\n  }\n\n  &[data-focused='true'] {\n    background: ${colors.brand.lightest};\n  }\n\n  &[data-selected='true'] {\n    background: ${colors.brand.lighter};\n    &:hover {\n      background: ${colors.brand.light};\n    }\n  }\n\n  &[data-creating='true'][data-focused='true'] {\n    color: ${colors.brand.primary};\n  }\n\n  &[data-creating='true'] {\n    background: none;\n  }\n`;\n\nconst StyledDone = styled(Done)`\n  color: ${colors.support.green};\n`;\n\nconst FolderNameLink = styled(SafeLink)`\n  display: grid;\n  align-items: center;\n  grid-template-columns: ${spacing.medium} 1fr auto;\n  padding: ${spacing.small} ${spacing.xxsmall};\n  padding-left: calc(0.75 * ${spacing.normal} * var(--level));\n  gap: ${spacing.xxsmall};\n  cursor: pointer;\n\n  border: none;\n  box-shadow: none;\n  color: ${colors.text.primary};\n  font-size: ${fonts.sizes('16px')};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\n  &[data-selected='true'] {\n    color: ${colors.brand.primary};\n    font-weight: ${fonts.weight.semibold};\n  }\n  &:hover,\n  &:focus {\n    color: ${colors.brand.primary};\n  }\n`;\n\ninterface Props extends CommonFolderItemsProps {\n  isOpen: boolean;\n  folder: IFolder;\n  isCreatingFolder?: boolean;\n  index: number;\n}\n\nconst FolderItem = ({\n  focusedFolder,\n  folder,\n  isOpen,\n  level,\n  loading,\n  selectedFolder,\n  onCloseFolder,\n  onOpenFolder,\n  setFocusedFolder,\n  setSelectedFolder,\n  targetResource,\n  visibleFolders,\n  maxLevel,\n  isCreatingFolder,\n  type,\n  closeTree,\n  index,\n}: Props) => {\n  const { t } = useTranslation();\n  const { id, name } = folder;\n  const ref = useRef<HTMLButtonElement & HTMLAnchorElement>(null);\n  const selected = selectedFolder ? selectedFolder.id === id : false;\n\n  const levelVariable = useMemo(() => ({ '--level': level } as unknown as CSSProperties), [level]);\n\n  const focused = focusedFolder?.id === id;\n\n  const handleClickFolder = () => {\n    if (!selected) {\n      setSelectedFolder(folder);\n    }\n    setFocusedFolder(folder);\n    if (type === 'picker') {\n      if (selected) {\n        closeTree();\n      }\n    }\n  };\n\n  useEffect(() => {\n    if (focusedFolder?.id === id && !isCreatingFolder) {\n      if (type === 'navigation') {\n        ref.current?.focus();\n      }\n      if (type === 'picker') {\n        ref.current?.focus();\n        ref.current?.scrollIntoView({\n          behavior: 'smooth',\n          block: 'start',\n        });\n      }\n    }\n  }, [focusedFolder, ref, id, isCreatingFolder, type]);\n\n  const linkPath = `/minndla/folders/${id}`;\n\n  const containsResource =\n    targetResource && folder.resources.some((resource) => resource.resourceId === targetResource.resourceId);\n\n  const emptyFolder = folder.subfolders.length === 0;\n  const isMaxDepth = level > maxLevel;\n  const hideArrow = isMaxDepth || emptyFolder;\n\n  const FolderIcon = folder.status === 'shared' ? FolderShared : FolderOutlined;\n\n  const tabable = selected || focused || (!focusedFolder && !folder.parentId && index === 0);\n\n  return type === 'navigation' ? (\n    <FolderNameLink\n      role=\"treeitem\"\n      aria-owns={folder.subfolders.length ? treestructureId(type, `subfolders-${folder.id}`) : undefined}\n      aria-expanded={isMaxDepth || emptyFolder ? undefined : isOpen}\n      aria-current={selected ? 'page' : undefined}\n      aria-describedby={containsResource ? `alreadyAdded-${folder.id}` : undefined}\n      ref={ref}\n      style={levelVariable}\n      onKeyDown={(e: KeyboardEvent<HTMLElement>) => {\n        if (e.key === 'Enter') {\n          setSelectedFolder(folder);\n          return;\n        }\n        arrowNavigation(e, id, visibleFolders, setFocusedFolder, onOpenFolder, onCloseFolder);\n      }}\n      to={loading ? '' : linkPath}\n      tabIndex={tabable ? 0 : -1}\n      data-selected={selected}\n      onFocus={() => setFocusedFolder(folder)}\n      onClick={handleClickFolder}\n    >\n      {!hideArrow && (\n        <OpenButton\n          aria-hidden\n          tabIndex={-1}\n          data-open={isOpen}\n          onClick={(e) => {\n            e.stopPropagation();\n            e.preventDefault();\n            ref.current?.focus();\n            if (isOpen) {\n              onCloseFolder(id);\n            } else {\n              onOpenFolder(id);\n            }\n          }}\n        >\n          <ArrowDropDownRounded />\n        </OpenButton>\n      )}\n      <StyledName>{name}</StyledName>\n    </FolderNameLink>\n  ) : (\n    <FolderName\n      tabIndex={-1}\n      role=\"treeitem\"\n      id={treestructureId(type, folder.id)}\n      aria-expanded={isMaxDepth || emptyFolder ? undefined : isOpen}\n      aria-selected={selected}\n      data-focused={focusedFolder?.id === folder.id}\n      aria-describedby={containsResource ? `alreadyAdded-${folder.id}` : undefined}\n      aria-label={`${name}${folder.status === 'shared' ? `, ${t('myNdla.folder.sharing.shared')}` : ''}`}\n      variant=\"ghost\"\n      shape=\"sharp\"\n      fontWeight=\"normal\"\n      colorTheme=\"light\"\n      ref={ref}\n      style={levelVariable}\n      data-selected={selected}\n      disabled={loading}\n      onFocus={() => setFocusedFolder(focusedFolder || folder)}\n      onClick={handleClickFolder}\n      data-creating={isCreatingFolder}\n    >\n      <IconWrapper>\n        {!hideArrow && (\n          <OpenButton\n            aria-hidden\n            tabIndex={-1}\n            data-open={isOpen}\n            onClick={(e) => {\n              e.stopPropagation();\n              setFocusedFolder(folder);\n              if (isOpen) {\n                onCloseFolder(id);\n              } else {\n                onOpenFolder(id);\n              }\n            }}\n          >\n            <ArrowDropDownRounded />\n          </OpenButton>\n        )}\n        <FolderIconWrapper>\n          <FolderIcon />\n        </FolderIconWrapper>\n      </IconWrapper>\n      <StyledName>{name}</StyledName>\n      {containsResource && (\n        <StyledDone\n          aria-label={t('myNdla.alreadyInFolder')}\n          id={`alreadyAdded-${folder.id}`}\n          title={t('myNdla.alreadyInFolder')}\n        />\n      )}\n    </FolderName>\n  );\n};\n\nexport default FolderItem;\n"]} */",
36
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FolderItem.tsx"],"names":[],"mappings":"AAgD8B","file":"FolderItem.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 { CSSProperties, KeyboardEvent, useEffect, useMemo, useRef } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { ArrowDropDownRounded } from '@ndla/icons/common';\nimport { FolderOutlined, FolderShared } from '@ndla/icons/contentType';\nimport { Done } from '@ndla/icons/editor';\nimport { ButtonV2 as Button } from '@ndla/button';\nimport { colors, spacing, animations, misc, fonts } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\nimport { IFolder } from '@ndla/types-backend/learningpath-api';\nimport { CommonFolderItemsProps } from './types';\nimport { arrowNavigation } from './arrowNavigation';\nimport { treestructureId } from './helperFunctions';\n\nconst OpenButton = styled.span`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  align-self: stretch;\n  color: ${colors.brand.tertiary};\n  ${misc.transition.default};\n  cursor: pointer;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n  svg {\n    width: 24px;\n    height: 24px;\n    transform: rotate(-90deg);\n  }\n  &[data-open='true'] {\n    svg {\n      transform: rotate(0deg);\n    }\n  }\n  &[data-hide-arrow='true'] {\n    visibility: hidden;\n  }\n`;\n\nconst StyledName = styled.span`\n  white-space: nowrap;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  grid-column-start: 2;\n  text-align: left;\n`;\n\nconst IconWrapper = styled.div`\n  display: flex;\n`;\n\nconst FolderIconWrapper = styled.div`\n  svg {\n    height: 24px;\n    width: 24px;\n  }\n`;\n\nconst FolderName = styled(Button)`\n  display: grid;\n  grid-template-columns: auto 1fr auto;\n  padding-left: calc(0.75 * ${spacing.normal} * var(--level));\n  gap: ${spacing.xxsmall};\n  border: none;\n  outline: none;\n  color: ${colors.text.primary};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\n\n  &:hover {\n    box-shadow: none;\n    outline: none;\n    background: ${colors.brand.lightest};\n    color: ${colors.text.primary};\n  }\n\n  &[data-focused='true'] {\n    background: ${colors.brand.lightest};\n  }\n\n  &[data-selected='true'] {\n    background: ${colors.brand.lighter};\n    &:hover {\n      background: ${colors.brand.light};\n    }\n  }\n\n  &[data-creating='true'][data-focused='true'] {\n    color: ${colors.brand.primary};\n  }\n\n  &[data-creating='true'] {\n    background: none;\n  }\n`;\n\nconst StyledDone = styled(Done)`\n  color: ${colors.support.green};\n`;\n\nconst FolderNameLink = styled(SafeLink)`\n  display: grid;\n  align-items: center;\n  grid-template-columns: ${spacing.medium} 1fr auto;\n  padding: ${spacing.small} ${spacing.xxsmall};\n  padding-left: calc(0.75 * ${spacing.normal} * var(--level));\n  gap: ${spacing.xxsmall};\n  cursor: pointer;\n\n  border: none;\n  box-shadow: none;\n  color: ${colors.text.primary};\n  font-size: ${fonts.sizes('16px')};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\n  &[data-selected='true'] {\n    color: ${colors.brand.primary};\n    font-weight: ${fonts.weight.semibold};\n  }\n  &:hover,\n  &:focus {\n    color: ${colors.brand.primary};\n  }\n`;\n\ninterface Props extends CommonFolderItemsProps {\n  isOpen: boolean;\n  folder: IFolder;\n  isCreatingFolder?: boolean;\n  index: number;\n}\n\nconst FolderItem = ({\n  focusedFolder,\n  folder,\n  isOpen,\n  level,\n  loading,\n  selectedFolder,\n  onCloseFolder,\n  onOpenFolder,\n  setFocusedFolder,\n  setSelectedFolder,\n  targetResource,\n  visibleFolders,\n  maxLevel,\n  isCreatingFolder,\n  type,\n  closeTree,\n  index,\n}: Props) => {\n  const { t } = useTranslation();\n  const { id, name } = folder;\n  const ref = useRef<HTMLButtonElement & HTMLAnchorElement>(null);\n  const selected = selectedFolder ? selectedFolder.id === id : false;\n\n  const levelVariable = useMemo(() => ({ '--level': level } as unknown as CSSProperties), [level]);\n\n  const focused = focusedFolder?.id === id;\n\n  const handleClickFolder = () => {\n    if (!selected) {\n      setSelectedFolder(folder);\n    }\n    setFocusedFolder(folder);\n    if (type === 'picker') {\n      if (selected) {\n        closeTree();\n      }\n    }\n  };\n\n  useEffect(() => {\n    if (focusedFolder?.id === id && !isCreatingFolder) {\n      if (type === 'navigation') {\n        ref.current?.focus();\n      }\n      if (type === 'picker') {\n        ref.current?.focus();\n        ref.current?.scrollIntoView({\n          behavior: 'smooth',\n          block: 'start',\n        });\n      }\n    }\n  }, [focusedFolder, ref, id, isCreatingFolder, type]);\n\n  const linkPath = `/minndla/folders/${id}`;\n\n  const containsResource =\n    targetResource && folder.resources.some((resource) => resource.resourceId === targetResource.resourceId);\n\n  const emptyFolder = folder.subfolders.length === 0;\n  const isMaxDepth = level > maxLevel;\n  const hideArrow = isMaxDepth || emptyFolder;\n\n  const FolderIcon = folder.status === 'shared' ? FolderShared : FolderOutlined;\n\n  const tabable = selected || focused || (!focusedFolder && !folder.parentId && index === 0);\n\n  return type === 'navigation' ? (\n    <FolderNameLink\n      role=\"treeitem\"\n      aria-owns={folder.subfolders.length ? treestructureId(type, `subfolders-${folder.id}`) : undefined}\n      aria-expanded={isMaxDepth || emptyFolder ? undefined : isOpen}\n      aria-current={selected ? 'page' : undefined}\n      aria-describedby={containsResource ? `alreadyAdded-${folder.id}` : undefined}\n      ref={ref}\n      style={levelVariable}\n      onKeyDown={(e: KeyboardEvent<HTMLElement>) => {\n        if (e.key === 'Enter') {\n          setSelectedFolder(folder);\n          return;\n        }\n        arrowNavigation(e, id, visibleFolders, setFocusedFolder, onOpenFolder, onCloseFolder);\n      }}\n      to={loading ? '' : linkPath}\n      tabIndex={tabable ? 0 : -1}\n      data-selected={selected}\n      onFocus={() => setFocusedFolder(folder)}\n      onClick={handleClickFolder}\n    >\n      <OpenButton\n        aria-hidden\n        tabIndex={-1}\n        data-open={isOpen}\n        data-hide-arrow={hideArrow}\n        onClick={(e) => {\n          e.stopPropagation();\n          e.preventDefault();\n          ref.current?.focus();\n          if (isOpen) {\n            onCloseFolder(id);\n          } else {\n            onOpenFolder(id);\n          }\n        }}\n      >\n        <ArrowDropDownRounded />\n      </OpenButton>\n      <StyledName>{name}</StyledName>\n    </FolderNameLink>\n  ) : (\n    <FolderName\n      tabIndex={-1}\n      role=\"treeitem\"\n      id={treestructureId(type, folder.id)}\n      aria-expanded={isMaxDepth || emptyFolder ? undefined : isOpen}\n      aria-selected={selected}\n      data-focused={focusedFolder?.id === folder.id}\n      aria-describedby={containsResource ? `alreadyAdded-${folder.id}` : undefined}\n      aria-label={`${name}${folder.status === 'shared' ? `, ${t('myNdla.folder.sharing.shared')}` : ''}`}\n      variant=\"ghost\"\n      shape=\"sharp\"\n      fontWeight=\"normal\"\n      colorTheme=\"light\"\n      ref={ref}\n      style={levelVariable}\n      data-selected={selected}\n      disabled={loading}\n      onFocus={() => setFocusedFolder(focusedFolder || folder)}\n      onClick={handleClickFolder}\n      data-creating={isCreatingFolder}\n    >\n      <IconWrapper>\n        <OpenButton\n          aria-hidden\n          tabIndex={-1}\n          data-open={isOpen}\n          data-hide-arrow={hideArrow}\n          onClick={(e) => {\n            e.stopPropagation();\n            setFocusedFolder(folder);\n            if (isOpen) {\n              onCloseFolder(id);\n            } else {\n              onOpenFolder(id);\n            }\n          }}\n        >\n          <ArrowDropDownRounded />\n        </OpenButton>\n        <FolderIconWrapper>\n          <FolderIcon />\n        </FolderIconWrapper>\n      </IconWrapper>\n      <StyledName>{name}</StyledName>\n      {containsResource && (\n        <StyledDone\n          aria-label={t('myNdla.alreadyInFolder')}\n          id={`alreadyAdded-${folder.id}`}\n          title={t('myNdla.alreadyInFolder')}\n        />\n      )}\n    </FolderName>\n  );\n};\n\nexport default FolderItem;\n"]} */",
37
37
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
38
38
  });
39
39
  var IconWrapper = /*#__PURE__*/_styled("div", {
@@ -45,7 +45,7 @@ var IconWrapper = /*#__PURE__*/_styled("div", {
45
45
  } : {
46
46
  name: "zjik7",
47
47
  styles: "display:flex",
48
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FolderItem.tsx"],"names":[],"mappings":"AAqD8B","file":"FolderItem.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 { CSSProperties, KeyboardEvent, useEffect, useMemo, useRef } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { ArrowDropDownRounded } from '@ndla/icons/common';\nimport { FolderOutlined, FolderShared } from '@ndla/icons/contentType';\nimport { Done } from '@ndla/icons/editor';\nimport { ButtonV2 as Button } from '@ndla/button';\nimport { colors, spacing, animations, misc, fonts } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\nimport { IFolder } from '@ndla/types-backend/learningpath-api';\nimport { CommonFolderItemsProps } from './types';\nimport { arrowNavigation } from './arrowNavigation';\nimport { treestructureId } from './helperFunctions';\n\nconst OpenButton = styled.span`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  align-self: stretch;\n  color: ${colors.brand.tertiary};\n  ${misc.transition.default};\n  cursor: pointer;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n  svg {\n    width: 24px;\n    height: 24px;\n    transform: rotate(-90deg);\n  }\n  &[data-open='true'] {\n    svg {\n      transform: rotate(0deg);\n    }\n  }\n`;\n\nconst StyledName = styled.span`\n  white-space: nowrap;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  grid-column-start: 2;\n  text-align: left;\n`;\n\nconst IconWrapper = styled.div`\n  display: flex;\n`;\n\nconst FolderIconWrapper = styled.div`\n  svg {\n    height: 24px;\n    width: 24px;\n  }\n`;\n\nconst FolderName = styled(Button)`\n  display: grid;\n  grid-template-columns: auto 1fr auto;\n  padding-left: calc(0.75 * ${spacing.normal} * var(--level));\n  gap: ${spacing.xxsmall};\n  border: none;\n  outline: none;\n  color: ${colors.text.primary};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\n\n  &:hover {\n    box-shadow: none;\n    outline: none;\n    background: ${colors.brand.lightest};\n    color: ${colors.text.primary};\n  }\n\n  &[data-focused='true'] {\n    background: ${colors.brand.lightest};\n  }\n\n  &[data-selected='true'] {\n    background: ${colors.brand.lighter};\n    &:hover {\n      background: ${colors.brand.light};\n    }\n  }\n\n  &[data-creating='true'][data-focused='true'] {\n    color: ${colors.brand.primary};\n  }\n\n  &[data-creating='true'] {\n    background: none;\n  }\n`;\n\nconst StyledDone = styled(Done)`\n  color: ${colors.support.green};\n`;\n\nconst FolderNameLink = styled(SafeLink)`\n  display: grid;\n  align-items: center;\n  grid-template-columns: ${spacing.medium} 1fr auto;\n  padding: ${spacing.small} ${spacing.xxsmall};\n  padding-left: calc(0.75 * ${spacing.normal} * var(--level));\n  gap: ${spacing.xxsmall};\n  cursor: pointer;\n\n  border: none;\n  box-shadow: none;\n  color: ${colors.text.primary};\n  font-size: ${fonts.sizes('16px')};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\n  &[data-selected='true'] {\n    color: ${colors.brand.primary};\n    font-weight: ${fonts.weight.semibold};\n  }\n  &:hover,\n  &:focus {\n    color: ${colors.brand.primary};\n  }\n`;\n\ninterface Props extends CommonFolderItemsProps {\n  isOpen: boolean;\n  folder: IFolder;\n  isCreatingFolder?: boolean;\n  index: number;\n}\n\nconst FolderItem = ({\n  focusedFolder,\n  folder,\n  isOpen,\n  level,\n  loading,\n  selectedFolder,\n  onCloseFolder,\n  onOpenFolder,\n  setFocusedFolder,\n  setSelectedFolder,\n  targetResource,\n  visibleFolders,\n  maxLevel,\n  isCreatingFolder,\n  type,\n  closeTree,\n  index,\n}: Props) => {\n  const { t } = useTranslation();\n  const { id, name } = folder;\n  const ref = useRef<HTMLButtonElement & HTMLAnchorElement>(null);\n  const selected = selectedFolder ? selectedFolder.id === id : false;\n\n  const levelVariable = useMemo(() => ({ '--level': level } as unknown as CSSProperties), [level]);\n\n  const focused = focusedFolder?.id === id;\n\n  const handleClickFolder = () => {\n    if (!selected) {\n      setSelectedFolder(folder);\n    }\n    setFocusedFolder(folder);\n    if (type === 'picker') {\n      if (selected) {\n        closeTree();\n      }\n    }\n  };\n\n  useEffect(() => {\n    if (focusedFolder?.id === id && !isCreatingFolder) {\n      if (type === 'navigation') {\n        ref.current?.focus();\n      }\n      if (type === 'picker') {\n        ref.current?.focus();\n        ref.current?.scrollIntoView({\n          behavior: 'smooth',\n          block: 'start',\n        });\n      }\n    }\n  }, [focusedFolder, ref, id, isCreatingFolder, type]);\n\n  const linkPath = `/minndla/folders/${id}`;\n\n  const containsResource =\n    targetResource && folder.resources.some((resource) => resource.resourceId === targetResource.resourceId);\n\n  const emptyFolder = folder.subfolders.length === 0;\n  const isMaxDepth = level > maxLevel;\n  const hideArrow = isMaxDepth || emptyFolder;\n\n  const FolderIcon = folder.status === 'shared' ? FolderShared : FolderOutlined;\n\n  const tabable = selected || focused || (!focusedFolder && !folder.parentId && index === 0);\n\n  return type === 'navigation' ? (\n    <FolderNameLink\n      role=\"treeitem\"\n      aria-owns={folder.subfolders.length ? treestructureId(type, `subfolders-${folder.id}`) : undefined}\n      aria-expanded={isMaxDepth || emptyFolder ? undefined : isOpen}\n      aria-current={selected ? 'page' : undefined}\n      aria-describedby={containsResource ? `alreadyAdded-${folder.id}` : undefined}\n      ref={ref}\n      style={levelVariable}\n      onKeyDown={(e: KeyboardEvent<HTMLElement>) => {\n        if (e.key === 'Enter') {\n          setSelectedFolder(folder);\n          return;\n        }\n        arrowNavigation(e, id, visibleFolders, setFocusedFolder, onOpenFolder, onCloseFolder);\n      }}\n      to={loading ? '' : linkPath}\n      tabIndex={tabable ? 0 : -1}\n      data-selected={selected}\n      onFocus={() => setFocusedFolder(folder)}\n      onClick={handleClickFolder}\n    >\n      {!hideArrow && (\n        <OpenButton\n          aria-hidden\n          tabIndex={-1}\n          data-open={isOpen}\n          onClick={(e) => {\n            e.stopPropagation();\n            e.preventDefault();\n            ref.current?.focus();\n            if (isOpen) {\n              onCloseFolder(id);\n            } else {\n              onOpenFolder(id);\n            }\n          }}\n        >\n          <ArrowDropDownRounded />\n        </OpenButton>\n      )}\n      <StyledName>{name}</StyledName>\n    </FolderNameLink>\n  ) : (\n    <FolderName\n      tabIndex={-1}\n      role=\"treeitem\"\n      id={treestructureId(type, folder.id)}\n      aria-expanded={isMaxDepth || emptyFolder ? undefined : isOpen}\n      aria-selected={selected}\n      data-focused={focusedFolder?.id === folder.id}\n      aria-describedby={containsResource ? `alreadyAdded-${folder.id}` : undefined}\n      aria-label={`${name}${folder.status === 'shared' ? `, ${t('myNdla.folder.sharing.shared')}` : ''}`}\n      variant=\"ghost\"\n      shape=\"sharp\"\n      fontWeight=\"normal\"\n      colorTheme=\"light\"\n      ref={ref}\n      style={levelVariable}\n      data-selected={selected}\n      disabled={loading}\n      onFocus={() => setFocusedFolder(focusedFolder || folder)}\n      onClick={handleClickFolder}\n      data-creating={isCreatingFolder}\n    >\n      <IconWrapper>\n        {!hideArrow && (\n          <OpenButton\n            aria-hidden\n            tabIndex={-1}\n            data-open={isOpen}\n            onClick={(e) => {\n              e.stopPropagation();\n              setFocusedFolder(folder);\n              if (isOpen) {\n                onCloseFolder(id);\n              } else {\n                onOpenFolder(id);\n              }\n            }}\n          >\n            <ArrowDropDownRounded />\n          </OpenButton>\n        )}\n        <FolderIconWrapper>\n          <FolderIcon />\n        </FolderIconWrapper>\n      </IconWrapper>\n      <StyledName>{name}</StyledName>\n      {containsResource && (\n        <StyledDone\n          aria-label={t('myNdla.alreadyInFolder')}\n          id={`alreadyAdded-${folder.id}`}\n          title={t('myNdla.alreadyInFolder')}\n        />\n      )}\n    </FolderName>\n  );\n};\n\nexport default FolderItem;\n"]} */",
48
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FolderItem.tsx"],"names":[],"mappings":"AAwD8B","file":"FolderItem.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 { CSSProperties, KeyboardEvent, useEffect, useMemo, useRef } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { ArrowDropDownRounded } from '@ndla/icons/common';\nimport { FolderOutlined, FolderShared } from '@ndla/icons/contentType';\nimport { Done } from '@ndla/icons/editor';\nimport { ButtonV2 as Button } from '@ndla/button';\nimport { colors, spacing, animations, misc, fonts } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\nimport { IFolder } from '@ndla/types-backend/learningpath-api';\nimport { CommonFolderItemsProps } from './types';\nimport { arrowNavigation } from './arrowNavigation';\nimport { treestructureId } from './helperFunctions';\n\nconst OpenButton = styled.span`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  align-self: stretch;\n  color: ${colors.brand.tertiary};\n  ${misc.transition.default};\n  cursor: pointer;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n  svg {\n    width: 24px;\n    height: 24px;\n    transform: rotate(-90deg);\n  }\n  &[data-open='true'] {\n    svg {\n      transform: rotate(0deg);\n    }\n  }\n  &[data-hide-arrow='true'] {\n    visibility: hidden;\n  }\n`;\n\nconst StyledName = styled.span`\n  white-space: nowrap;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  grid-column-start: 2;\n  text-align: left;\n`;\n\nconst IconWrapper = styled.div`\n  display: flex;\n`;\n\nconst FolderIconWrapper = styled.div`\n  svg {\n    height: 24px;\n    width: 24px;\n  }\n`;\n\nconst FolderName = styled(Button)`\n  display: grid;\n  grid-template-columns: auto 1fr auto;\n  padding-left: calc(0.75 * ${spacing.normal} * var(--level));\n  gap: ${spacing.xxsmall};\n  border: none;\n  outline: none;\n  color: ${colors.text.primary};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\n\n  &:hover {\n    box-shadow: none;\n    outline: none;\n    background: ${colors.brand.lightest};\n    color: ${colors.text.primary};\n  }\n\n  &[data-focused='true'] {\n    background: ${colors.brand.lightest};\n  }\n\n  &[data-selected='true'] {\n    background: ${colors.brand.lighter};\n    &:hover {\n      background: ${colors.brand.light};\n    }\n  }\n\n  &[data-creating='true'][data-focused='true'] {\n    color: ${colors.brand.primary};\n  }\n\n  &[data-creating='true'] {\n    background: none;\n  }\n`;\n\nconst StyledDone = styled(Done)`\n  color: ${colors.support.green};\n`;\n\nconst FolderNameLink = styled(SafeLink)`\n  display: grid;\n  align-items: center;\n  grid-template-columns: ${spacing.medium} 1fr auto;\n  padding: ${spacing.small} ${spacing.xxsmall};\n  padding-left: calc(0.75 * ${spacing.normal} * var(--level));\n  gap: ${spacing.xxsmall};\n  cursor: pointer;\n\n  border: none;\n  box-shadow: none;\n  color: ${colors.text.primary};\n  font-size: ${fonts.sizes('16px')};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\n  &[data-selected='true'] {\n    color: ${colors.brand.primary};\n    font-weight: ${fonts.weight.semibold};\n  }\n  &:hover,\n  &:focus {\n    color: ${colors.brand.primary};\n  }\n`;\n\ninterface Props extends CommonFolderItemsProps {\n  isOpen: boolean;\n  folder: IFolder;\n  isCreatingFolder?: boolean;\n  index: number;\n}\n\nconst FolderItem = ({\n  focusedFolder,\n  folder,\n  isOpen,\n  level,\n  loading,\n  selectedFolder,\n  onCloseFolder,\n  onOpenFolder,\n  setFocusedFolder,\n  setSelectedFolder,\n  targetResource,\n  visibleFolders,\n  maxLevel,\n  isCreatingFolder,\n  type,\n  closeTree,\n  index,\n}: Props) => {\n  const { t } = useTranslation();\n  const { id, name } = folder;\n  const ref = useRef<HTMLButtonElement & HTMLAnchorElement>(null);\n  const selected = selectedFolder ? selectedFolder.id === id : false;\n\n  const levelVariable = useMemo(() => ({ '--level': level } as unknown as CSSProperties), [level]);\n\n  const focused = focusedFolder?.id === id;\n\n  const handleClickFolder = () => {\n    if (!selected) {\n      setSelectedFolder(folder);\n    }\n    setFocusedFolder(folder);\n    if (type === 'picker') {\n      if (selected) {\n        closeTree();\n      }\n    }\n  };\n\n  useEffect(() => {\n    if (focusedFolder?.id === id && !isCreatingFolder) {\n      if (type === 'navigation') {\n        ref.current?.focus();\n      }\n      if (type === 'picker') {\n        ref.current?.focus();\n        ref.current?.scrollIntoView({\n          behavior: 'smooth',\n          block: 'start',\n        });\n      }\n    }\n  }, [focusedFolder, ref, id, isCreatingFolder, type]);\n\n  const linkPath = `/minndla/folders/${id}`;\n\n  const containsResource =\n    targetResource && folder.resources.some((resource) => resource.resourceId === targetResource.resourceId);\n\n  const emptyFolder = folder.subfolders.length === 0;\n  const isMaxDepth = level > maxLevel;\n  const hideArrow = isMaxDepth || emptyFolder;\n\n  const FolderIcon = folder.status === 'shared' ? FolderShared : FolderOutlined;\n\n  const tabable = selected || focused || (!focusedFolder && !folder.parentId && index === 0);\n\n  return type === 'navigation' ? (\n    <FolderNameLink\n      role=\"treeitem\"\n      aria-owns={folder.subfolders.length ? treestructureId(type, `subfolders-${folder.id}`) : undefined}\n      aria-expanded={isMaxDepth || emptyFolder ? undefined : isOpen}\n      aria-current={selected ? 'page' : undefined}\n      aria-describedby={containsResource ? `alreadyAdded-${folder.id}` : undefined}\n      ref={ref}\n      style={levelVariable}\n      onKeyDown={(e: KeyboardEvent<HTMLElement>) => {\n        if (e.key === 'Enter') {\n          setSelectedFolder(folder);\n          return;\n        }\n        arrowNavigation(e, id, visibleFolders, setFocusedFolder, onOpenFolder, onCloseFolder);\n      }}\n      to={loading ? '' : linkPath}\n      tabIndex={tabable ? 0 : -1}\n      data-selected={selected}\n      onFocus={() => setFocusedFolder(folder)}\n      onClick={handleClickFolder}\n    >\n      <OpenButton\n        aria-hidden\n        tabIndex={-1}\n        data-open={isOpen}\n        data-hide-arrow={hideArrow}\n        onClick={(e) => {\n          e.stopPropagation();\n          e.preventDefault();\n          ref.current?.focus();\n          if (isOpen) {\n            onCloseFolder(id);\n          } else {\n            onOpenFolder(id);\n          }\n        }}\n      >\n        <ArrowDropDownRounded />\n      </OpenButton>\n      <StyledName>{name}</StyledName>\n    </FolderNameLink>\n  ) : (\n    <FolderName\n      tabIndex={-1}\n      role=\"treeitem\"\n      id={treestructureId(type, folder.id)}\n      aria-expanded={isMaxDepth || emptyFolder ? undefined : isOpen}\n      aria-selected={selected}\n      data-focused={focusedFolder?.id === folder.id}\n      aria-describedby={containsResource ? `alreadyAdded-${folder.id}` : undefined}\n      aria-label={`${name}${folder.status === 'shared' ? `, ${t('myNdla.folder.sharing.shared')}` : ''}`}\n      variant=\"ghost\"\n      shape=\"sharp\"\n      fontWeight=\"normal\"\n      colorTheme=\"light\"\n      ref={ref}\n      style={levelVariable}\n      data-selected={selected}\n      disabled={loading}\n      onFocus={() => setFocusedFolder(focusedFolder || folder)}\n      onClick={handleClickFolder}\n      data-creating={isCreatingFolder}\n    >\n      <IconWrapper>\n        <OpenButton\n          aria-hidden\n          tabIndex={-1}\n          data-open={isOpen}\n          data-hide-arrow={hideArrow}\n          onClick={(e) => {\n            e.stopPropagation();\n            setFocusedFolder(folder);\n            if (isOpen) {\n              onCloseFolder(id);\n            } else {\n              onOpenFolder(id);\n            }\n          }}\n        >\n          <ArrowDropDownRounded />\n        </OpenButton>\n        <FolderIconWrapper>\n          <FolderIcon />\n        </FolderIconWrapper>\n      </IconWrapper>\n      <StyledName>{name}</StyledName>\n      {containsResource && (\n        <StyledDone\n          aria-label={t('myNdla.alreadyInFolder')}\n          id={`alreadyAdded-${folder.id}`}\n          title={t('myNdla.alreadyInFolder')}\n        />\n      )}\n    </FolderName>\n  );\n};\n\nexport default FolderItem;\n"]} */",
49
49
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
50
50
  });
51
51
  var FolderIconWrapper = /*#__PURE__*/_styled("div", {
@@ -57,21 +57,21 @@ var FolderIconWrapper = /*#__PURE__*/_styled("div", {
57
57
  } : {
58
58
  name: "h1kfx5",
59
59
  styles: "svg{height:24px;width:24px;}",
60
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FolderItem.tsx"],"names":[],"mappings":"AAyDoC","file":"FolderItem.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 { CSSProperties, KeyboardEvent, useEffect, useMemo, useRef } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { ArrowDropDownRounded } from '@ndla/icons/common';\nimport { FolderOutlined, FolderShared } from '@ndla/icons/contentType';\nimport { Done } from '@ndla/icons/editor';\nimport { ButtonV2 as Button } from '@ndla/button';\nimport { colors, spacing, animations, misc, fonts } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\nimport { IFolder } from '@ndla/types-backend/learningpath-api';\nimport { CommonFolderItemsProps } from './types';\nimport { arrowNavigation } from './arrowNavigation';\nimport { treestructureId } from './helperFunctions';\n\nconst OpenButton = styled.span`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  align-self: stretch;\n  color: ${colors.brand.tertiary};\n  ${misc.transition.default};\n  cursor: pointer;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n  svg {\n    width: 24px;\n    height: 24px;\n    transform: rotate(-90deg);\n  }\n  &[data-open='true'] {\n    svg {\n      transform: rotate(0deg);\n    }\n  }\n`;\n\nconst StyledName = styled.span`\n  white-space: nowrap;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  grid-column-start: 2;\n  text-align: left;\n`;\n\nconst IconWrapper = styled.div`\n  display: flex;\n`;\n\nconst FolderIconWrapper = styled.div`\n  svg {\n    height: 24px;\n    width: 24px;\n  }\n`;\n\nconst FolderName = styled(Button)`\n  display: grid;\n  grid-template-columns: auto 1fr auto;\n  padding-left: calc(0.75 * ${spacing.normal} * var(--level));\n  gap: ${spacing.xxsmall};\n  border: none;\n  outline: none;\n  color: ${colors.text.primary};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\n\n  &:hover {\n    box-shadow: none;\n    outline: none;\n    background: ${colors.brand.lightest};\n    color: ${colors.text.primary};\n  }\n\n  &[data-focused='true'] {\n    background: ${colors.brand.lightest};\n  }\n\n  &[data-selected='true'] {\n    background: ${colors.brand.lighter};\n    &:hover {\n      background: ${colors.brand.light};\n    }\n  }\n\n  &[data-creating='true'][data-focused='true'] {\n    color: ${colors.brand.primary};\n  }\n\n  &[data-creating='true'] {\n    background: none;\n  }\n`;\n\nconst StyledDone = styled(Done)`\n  color: ${colors.support.green};\n`;\n\nconst FolderNameLink = styled(SafeLink)`\n  display: grid;\n  align-items: center;\n  grid-template-columns: ${spacing.medium} 1fr auto;\n  padding: ${spacing.small} ${spacing.xxsmall};\n  padding-left: calc(0.75 * ${spacing.normal} * var(--level));\n  gap: ${spacing.xxsmall};\n  cursor: pointer;\n\n  border: none;\n  box-shadow: none;\n  color: ${colors.text.primary};\n  font-size: ${fonts.sizes('16px')};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\n  &[data-selected='true'] {\n    color: ${colors.brand.primary};\n    font-weight: ${fonts.weight.semibold};\n  }\n  &:hover,\n  &:focus {\n    color: ${colors.brand.primary};\n  }\n`;\n\ninterface Props extends CommonFolderItemsProps {\n  isOpen: boolean;\n  folder: IFolder;\n  isCreatingFolder?: boolean;\n  index: number;\n}\n\nconst FolderItem = ({\n  focusedFolder,\n  folder,\n  isOpen,\n  level,\n  loading,\n  selectedFolder,\n  onCloseFolder,\n  onOpenFolder,\n  setFocusedFolder,\n  setSelectedFolder,\n  targetResource,\n  visibleFolders,\n  maxLevel,\n  isCreatingFolder,\n  type,\n  closeTree,\n  index,\n}: Props) => {\n  const { t } = useTranslation();\n  const { id, name } = folder;\n  const ref = useRef<HTMLButtonElement & HTMLAnchorElement>(null);\n  const selected = selectedFolder ? selectedFolder.id === id : false;\n\n  const levelVariable = useMemo(() => ({ '--level': level } as unknown as CSSProperties), [level]);\n\n  const focused = focusedFolder?.id === id;\n\n  const handleClickFolder = () => {\n    if (!selected) {\n      setSelectedFolder(folder);\n    }\n    setFocusedFolder(folder);\n    if (type === 'picker') {\n      if (selected) {\n        closeTree();\n      }\n    }\n  };\n\n  useEffect(() => {\n    if (focusedFolder?.id === id && !isCreatingFolder) {\n      if (type === 'navigation') {\n        ref.current?.focus();\n      }\n      if (type === 'picker') {\n        ref.current?.focus();\n        ref.current?.scrollIntoView({\n          behavior: 'smooth',\n          block: 'start',\n        });\n      }\n    }\n  }, [focusedFolder, ref, id, isCreatingFolder, type]);\n\n  const linkPath = `/minndla/folders/${id}`;\n\n  const containsResource =\n    targetResource && folder.resources.some((resource) => resource.resourceId === targetResource.resourceId);\n\n  const emptyFolder = folder.subfolders.length === 0;\n  const isMaxDepth = level > maxLevel;\n  const hideArrow = isMaxDepth || emptyFolder;\n\n  const FolderIcon = folder.status === 'shared' ? FolderShared : FolderOutlined;\n\n  const tabable = selected || focused || (!focusedFolder && !folder.parentId && index === 0);\n\n  return type === 'navigation' ? (\n    <FolderNameLink\n      role=\"treeitem\"\n      aria-owns={folder.subfolders.length ? treestructureId(type, `subfolders-${folder.id}`) : undefined}\n      aria-expanded={isMaxDepth || emptyFolder ? undefined : isOpen}\n      aria-current={selected ? 'page' : undefined}\n      aria-describedby={containsResource ? `alreadyAdded-${folder.id}` : undefined}\n      ref={ref}\n      style={levelVariable}\n      onKeyDown={(e: KeyboardEvent<HTMLElement>) => {\n        if (e.key === 'Enter') {\n          setSelectedFolder(folder);\n          return;\n        }\n        arrowNavigation(e, id, visibleFolders, setFocusedFolder, onOpenFolder, onCloseFolder);\n      }}\n      to={loading ? '' : linkPath}\n      tabIndex={tabable ? 0 : -1}\n      data-selected={selected}\n      onFocus={() => setFocusedFolder(folder)}\n      onClick={handleClickFolder}\n    >\n      {!hideArrow && (\n        <OpenButton\n          aria-hidden\n          tabIndex={-1}\n          data-open={isOpen}\n          onClick={(e) => {\n            e.stopPropagation();\n            e.preventDefault();\n            ref.current?.focus();\n            if (isOpen) {\n              onCloseFolder(id);\n            } else {\n              onOpenFolder(id);\n            }\n          }}\n        >\n          <ArrowDropDownRounded />\n        </OpenButton>\n      )}\n      <StyledName>{name}</StyledName>\n    </FolderNameLink>\n  ) : (\n    <FolderName\n      tabIndex={-1}\n      role=\"treeitem\"\n      id={treestructureId(type, folder.id)}\n      aria-expanded={isMaxDepth || emptyFolder ? undefined : isOpen}\n      aria-selected={selected}\n      data-focused={focusedFolder?.id === folder.id}\n      aria-describedby={containsResource ? `alreadyAdded-${folder.id}` : undefined}\n      aria-label={`${name}${folder.status === 'shared' ? `, ${t('myNdla.folder.sharing.shared')}` : ''}`}\n      variant=\"ghost\"\n      shape=\"sharp\"\n      fontWeight=\"normal\"\n      colorTheme=\"light\"\n      ref={ref}\n      style={levelVariable}\n      data-selected={selected}\n      disabled={loading}\n      onFocus={() => setFocusedFolder(focusedFolder || folder)}\n      onClick={handleClickFolder}\n      data-creating={isCreatingFolder}\n    >\n      <IconWrapper>\n        {!hideArrow && (\n          <OpenButton\n            aria-hidden\n            tabIndex={-1}\n            data-open={isOpen}\n            onClick={(e) => {\n              e.stopPropagation();\n              setFocusedFolder(folder);\n              if (isOpen) {\n                onCloseFolder(id);\n              } else {\n                onOpenFolder(id);\n              }\n            }}\n          >\n            <ArrowDropDownRounded />\n          </OpenButton>\n        )}\n        <FolderIconWrapper>\n          <FolderIcon />\n        </FolderIconWrapper>\n      </IconWrapper>\n      <StyledName>{name}</StyledName>\n      {containsResource && (\n        <StyledDone\n          aria-label={t('myNdla.alreadyInFolder')}\n          id={`alreadyAdded-${folder.id}`}\n          title={t('myNdla.alreadyInFolder')}\n        />\n      )}\n    </FolderName>\n  );\n};\n\nexport default FolderItem;\n"]} */",
60
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FolderItem.tsx"],"names":[],"mappings":"AA4DoC","file":"FolderItem.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 { CSSProperties, KeyboardEvent, useEffect, useMemo, useRef } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { ArrowDropDownRounded } from '@ndla/icons/common';\nimport { FolderOutlined, FolderShared } from '@ndla/icons/contentType';\nimport { Done } from '@ndla/icons/editor';\nimport { ButtonV2 as Button } from '@ndla/button';\nimport { colors, spacing, animations, misc, fonts } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\nimport { IFolder } from '@ndla/types-backend/learningpath-api';\nimport { CommonFolderItemsProps } from './types';\nimport { arrowNavigation } from './arrowNavigation';\nimport { treestructureId } from './helperFunctions';\n\nconst OpenButton = styled.span`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  align-self: stretch;\n  color: ${colors.brand.tertiary};\n  ${misc.transition.default};\n  cursor: pointer;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n  svg {\n    width: 24px;\n    height: 24px;\n    transform: rotate(-90deg);\n  }\n  &[data-open='true'] {\n    svg {\n      transform: rotate(0deg);\n    }\n  }\n  &[data-hide-arrow='true'] {\n    visibility: hidden;\n  }\n`;\n\nconst StyledName = styled.span`\n  white-space: nowrap;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  grid-column-start: 2;\n  text-align: left;\n`;\n\nconst IconWrapper = styled.div`\n  display: flex;\n`;\n\nconst FolderIconWrapper = styled.div`\n  svg {\n    height: 24px;\n    width: 24px;\n  }\n`;\n\nconst FolderName = styled(Button)`\n  display: grid;\n  grid-template-columns: auto 1fr auto;\n  padding-left: calc(0.75 * ${spacing.normal} * var(--level));\n  gap: ${spacing.xxsmall};\n  border: none;\n  outline: none;\n  color: ${colors.text.primary};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\n\n  &:hover {\n    box-shadow: none;\n    outline: none;\n    background: ${colors.brand.lightest};\n    color: ${colors.text.primary};\n  }\n\n  &[data-focused='true'] {\n    background: ${colors.brand.lightest};\n  }\n\n  &[data-selected='true'] {\n    background: ${colors.brand.lighter};\n    &:hover {\n      background: ${colors.brand.light};\n    }\n  }\n\n  &[data-creating='true'][data-focused='true'] {\n    color: ${colors.brand.primary};\n  }\n\n  &[data-creating='true'] {\n    background: none;\n  }\n`;\n\nconst StyledDone = styled(Done)`\n  color: ${colors.support.green};\n`;\n\nconst FolderNameLink = styled(SafeLink)`\n  display: grid;\n  align-items: center;\n  grid-template-columns: ${spacing.medium} 1fr auto;\n  padding: ${spacing.small} ${spacing.xxsmall};\n  padding-left: calc(0.75 * ${spacing.normal} * var(--level));\n  gap: ${spacing.xxsmall};\n  cursor: pointer;\n\n  border: none;\n  box-shadow: none;\n  color: ${colors.text.primary};\n  font-size: ${fonts.sizes('16px')};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\n  &[data-selected='true'] {\n    color: ${colors.brand.primary};\n    font-weight: ${fonts.weight.semibold};\n  }\n  &:hover,\n  &:focus {\n    color: ${colors.brand.primary};\n  }\n`;\n\ninterface Props extends CommonFolderItemsProps {\n  isOpen: boolean;\n  folder: IFolder;\n  isCreatingFolder?: boolean;\n  index: number;\n}\n\nconst FolderItem = ({\n  focusedFolder,\n  folder,\n  isOpen,\n  level,\n  loading,\n  selectedFolder,\n  onCloseFolder,\n  onOpenFolder,\n  setFocusedFolder,\n  setSelectedFolder,\n  targetResource,\n  visibleFolders,\n  maxLevel,\n  isCreatingFolder,\n  type,\n  closeTree,\n  index,\n}: Props) => {\n  const { t } = useTranslation();\n  const { id, name } = folder;\n  const ref = useRef<HTMLButtonElement & HTMLAnchorElement>(null);\n  const selected = selectedFolder ? selectedFolder.id === id : false;\n\n  const levelVariable = useMemo(() => ({ '--level': level } as unknown as CSSProperties), [level]);\n\n  const focused = focusedFolder?.id === id;\n\n  const handleClickFolder = () => {\n    if (!selected) {\n      setSelectedFolder(folder);\n    }\n    setFocusedFolder(folder);\n    if (type === 'picker') {\n      if (selected) {\n        closeTree();\n      }\n    }\n  };\n\n  useEffect(() => {\n    if (focusedFolder?.id === id && !isCreatingFolder) {\n      if (type === 'navigation') {\n        ref.current?.focus();\n      }\n      if (type === 'picker') {\n        ref.current?.focus();\n        ref.current?.scrollIntoView({\n          behavior: 'smooth',\n          block: 'start',\n        });\n      }\n    }\n  }, [focusedFolder, ref, id, isCreatingFolder, type]);\n\n  const linkPath = `/minndla/folders/${id}`;\n\n  const containsResource =\n    targetResource && folder.resources.some((resource) => resource.resourceId === targetResource.resourceId);\n\n  const emptyFolder = folder.subfolders.length === 0;\n  const isMaxDepth = level > maxLevel;\n  const hideArrow = isMaxDepth || emptyFolder;\n\n  const FolderIcon = folder.status === 'shared' ? FolderShared : FolderOutlined;\n\n  const tabable = selected || focused || (!focusedFolder && !folder.parentId && index === 0);\n\n  return type === 'navigation' ? (\n    <FolderNameLink\n      role=\"treeitem\"\n      aria-owns={folder.subfolders.length ? treestructureId(type, `subfolders-${folder.id}`) : undefined}\n      aria-expanded={isMaxDepth || emptyFolder ? undefined : isOpen}\n      aria-current={selected ? 'page' : undefined}\n      aria-describedby={containsResource ? `alreadyAdded-${folder.id}` : undefined}\n      ref={ref}\n      style={levelVariable}\n      onKeyDown={(e: KeyboardEvent<HTMLElement>) => {\n        if (e.key === 'Enter') {\n          setSelectedFolder(folder);\n          return;\n        }\n        arrowNavigation(e, id, visibleFolders, setFocusedFolder, onOpenFolder, onCloseFolder);\n      }}\n      to={loading ? '' : linkPath}\n      tabIndex={tabable ? 0 : -1}\n      data-selected={selected}\n      onFocus={() => setFocusedFolder(folder)}\n      onClick={handleClickFolder}\n    >\n      <OpenButton\n        aria-hidden\n        tabIndex={-1}\n        data-open={isOpen}\n        data-hide-arrow={hideArrow}\n        onClick={(e) => {\n          e.stopPropagation();\n          e.preventDefault();\n          ref.current?.focus();\n          if (isOpen) {\n            onCloseFolder(id);\n          } else {\n            onOpenFolder(id);\n          }\n        }}\n      >\n        <ArrowDropDownRounded />\n      </OpenButton>\n      <StyledName>{name}</StyledName>\n    </FolderNameLink>\n  ) : (\n    <FolderName\n      tabIndex={-1}\n      role=\"treeitem\"\n      id={treestructureId(type, folder.id)}\n      aria-expanded={isMaxDepth || emptyFolder ? undefined : isOpen}\n      aria-selected={selected}\n      data-focused={focusedFolder?.id === folder.id}\n      aria-describedby={containsResource ? `alreadyAdded-${folder.id}` : undefined}\n      aria-label={`${name}${folder.status === 'shared' ? `, ${t('myNdla.folder.sharing.shared')}` : ''}`}\n      variant=\"ghost\"\n      shape=\"sharp\"\n      fontWeight=\"normal\"\n      colorTheme=\"light\"\n      ref={ref}\n      style={levelVariable}\n      data-selected={selected}\n      disabled={loading}\n      onFocus={() => setFocusedFolder(focusedFolder || folder)}\n      onClick={handleClickFolder}\n      data-creating={isCreatingFolder}\n    >\n      <IconWrapper>\n        <OpenButton\n          aria-hidden\n          tabIndex={-1}\n          data-open={isOpen}\n          data-hide-arrow={hideArrow}\n          onClick={(e) => {\n            e.stopPropagation();\n            setFocusedFolder(folder);\n            if (isOpen) {\n              onCloseFolder(id);\n            } else {\n              onOpenFolder(id);\n            }\n          }}\n        >\n          <ArrowDropDownRounded />\n        </OpenButton>\n        <FolderIconWrapper>\n          <FolderIcon />\n        </FolderIconWrapper>\n      </IconWrapper>\n      <StyledName>{name}</StyledName>\n      {containsResource && (\n        <StyledDone\n          aria-label={t('myNdla.alreadyInFolder')}\n          id={`alreadyAdded-${folder.id}`}\n          title={t('myNdla.alreadyInFolder')}\n        />\n      )}\n    </FolderName>\n  );\n};\n\nexport default FolderItem;\n"]} */",
61
61
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
62
62
  });
63
63
  var FolderName = /*#__PURE__*/_styled(Button, {
64
64
  target: "e11ok6h82",
65
65
  label: "FolderName"
66
- })("display:grid;grid-template-columns:auto 1fr auto;padding-left:calc(0.75 * ", spacing.normal, " * var(--level));gap:", spacing.xxsmall, ";border:none;outline:none;color:", colors.text.primary, ";transition:", animations.durations.superFast, ";word-break:break-word;&:hover{box-shadow:none;outline:none;background:", colors.brand.lightest, ";color:", colors.text.primary, ";}&[data-focused='true']{background:", colors.brand.lightest, ";}&[data-selected='true']{background:", colors.brand.lighter, ";&:hover{background:", colors.brand.light, ";}}&[data-creating='true'][data-focused='true']{color:", colors.brand.primary, ";}&[data-creating='true']{background:none;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FolderItem.tsx"],"names":[],"mappings":"AAgEiC","file":"FolderItem.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 { CSSProperties, KeyboardEvent, useEffect, useMemo, useRef } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { ArrowDropDownRounded } from '@ndla/icons/common';\nimport { FolderOutlined, FolderShared } from '@ndla/icons/contentType';\nimport { Done } from '@ndla/icons/editor';\nimport { ButtonV2 as Button } from '@ndla/button';\nimport { colors, spacing, animations, misc, fonts } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\nimport { IFolder } from '@ndla/types-backend/learningpath-api';\nimport { CommonFolderItemsProps } from './types';\nimport { arrowNavigation } from './arrowNavigation';\nimport { treestructureId } from './helperFunctions';\n\nconst OpenButton = styled.span`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  align-self: stretch;\n  color: ${colors.brand.tertiary};\n  ${misc.transition.default};\n  cursor: pointer;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n  svg {\n    width: 24px;\n    height: 24px;\n    transform: rotate(-90deg);\n  }\n  &[data-open='true'] {\n    svg {\n      transform: rotate(0deg);\n    }\n  }\n`;\n\nconst StyledName = styled.span`\n  white-space: nowrap;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  grid-column-start: 2;\n  text-align: left;\n`;\n\nconst IconWrapper = styled.div`\n  display: flex;\n`;\n\nconst FolderIconWrapper = styled.div`\n  svg {\n    height: 24px;\n    width: 24px;\n  }\n`;\n\nconst FolderName = styled(Button)`\n  display: grid;\n  grid-template-columns: auto 1fr auto;\n  padding-left: calc(0.75 * ${spacing.normal} * var(--level));\n  gap: ${spacing.xxsmall};\n  border: none;\n  outline: none;\n  color: ${colors.text.primary};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\n\n  &:hover {\n    box-shadow: none;\n    outline: none;\n    background: ${colors.brand.lightest};\n    color: ${colors.text.primary};\n  }\n\n  &[data-focused='true'] {\n    background: ${colors.brand.lightest};\n  }\n\n  &[data-selected='true'] {\n    background: ${colors.brand.lighter};\n    &:hover {\n      background: ${colors.brand.light};\n    }\n  }\n\n  &[data-creating='true'][data-focused='true'] {\n    color: ${colors.brand.primary};\n  }\n\n  &[data-creating='true'] {\n    background: none;\n  }\n`;\n\nconst StyledDone = styled(Done)`\n  color: ${colors.support.green};\n`;\n\nconst FolderNameLink = styled(SafeLink)`\n  display: grid;\n  align-items: center;\n  grid-template-columns: ${spacing.medium} 1fr auto;\n  padding: ${spacing.small} ${spacing.xxsmall};\n  padding-left: calc(0.75 * ${spacing.normal} * var(--level));\n  gap: ${spacing.xxsmall};\n  cursor: pointer;\n\n  border: none;\n  box-shadow: none;\n  color: ${colors.text.primary};\n  font-size: ${fonts.sizes('16px')};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\n  &[data-selected='true'] {\n    color: ${colors.brand.primary};\n    font-weight: ${fonts.weight.semibold};\n  }\n  &:hover,\n  &:focus {\n    color: ${colors.brand.primary};\n  }\n`;\n\ninterface Props extends CommonFolderItemsProps {\n  isOpen: boolean;\n  folder: IFolder;\n  isCreatingFolder?: boolean;\n  index: number;\n}\n\nconst FolderItem = ({\n  focusedFolder,\n  folder,\n  isOpen,\n  level,\n  loading,\n  selectedFolder,\n  onCloseFolder,\n  onOpenFolder,\n  setFocusedFolder,\n  setSelectedFolder,\n  targetResource,\n  visibleFolders,\n  maxLevel,\n  isCreatingFolder,\n  type,\n  closeTree,\n  index,\n}: Props) => {\n  const { t } = useTranslation();\n  const { id, name } = folder;\n  const ref = useRef<HTMLButtonElement & HTMLAnchorElement>(null);\n  const selected = selectedFolder ? selectedFolder.id === id : false;\n\n  const levelVariable = useMemo(() => ({ '--level': level } as unknown as CSSProperties), [level]);\n\n  const focused = focusedFolder?.id === id;\n\n  const handleClickFolder = () => {\n    if (!selected) {\n      setSelectedFolder(folder);\n    }\n    setFocusedFolder(folder);\n    if (type === 'picker') {\n      if (selected) {\n        closeTree();\n      }\n    }\n  };\n\n  useEffect(() => {\n    if (focusedFolder?.id === id && !isCreatingFolder) {\n      if (type === 'navigation') {\n        ref.current?.focus();\n      }\n      if (type === 'picker') {\n        ref.current?.focus();\n        ref.current?.scrollIntoView({\n          behavior: 'smooth',\n          block: 'start',\n        });\n      }\n    }\n  }, [focusedFolder, ref, id, isCreatingFolder, type]);\n\n  const linkPath = `/minndla/folders/${id}`;\n\n  const containsResource =\n    targetResource && folder.resources.some((resource) => resource.resourceId === targetResource.resourceId);\n\n  const emptyFolder = folder.subfolders.length === 0;\n  const isMaxDepth = level > maxLevel;\n  const hideArrow = isMaxDepth || emptyFolder;\n\n  const FolderIcon = folder.status === 'shared' ? FolderShared : FolderOutlined;\n\n  const tabable = selected || focused || (!focusedFolder && !folder.parentId && index === 0);\n\n  return type === 'navigation' ? (\n    <FolderNameLink\n      role=\"treeitem\"\n      aria-owns={folder.subfolders.length ? treestructureId(type, `subfolders-${folder.id}`) : undefined}\n      aria-expanded={isMaxDepth || emptyFolder ? undefined : isOpen}\n      aria-current={selected ? 'page' : undefined}\n      aria-describedby={containsResource ? `alreadyAdded-${folder.id}` : undefined}\n      ref={ref}\n      style={levelVariable}\n      onKeyDown={(e: KeyboardEvent<HTMLElement>) => {\n        if (e.key === 'Enter') {\n          setSelectedFolder(folder);\n          return;\n        }\n        arrowNavigation(e, id, visibleFolders, setFocusedFolder, onOpenFolder, onCloseFolder);\n      }}\n      to={loading ? '' : linkPath}\n      tabIndex={tabable ? 0 : -1}\n      data-selected={selected}\n      onFocus={() => setFocusedFolder(folder)}\n      onClick={handleClickFolder}\n    >\n      {!hideArrow && (\n        <OpenButton\n          aria-hidden\n          tabIndex={-1}\n          data-open={isOpen}\n          onClick={(e) => {\n            e.stopPropagation();\n            e.preventDefault();\n            ref.current?.focus();\n            if (isOpen) {\n              onCloseFolder(id);\n            } else {\n              onOpenFolder(id);\n            }\n          }}\n        >\n          <ArrowDropDownRounded />\n        </OpenButton>\n      )}\n      <StyledName>{name}</StyledName>\n    </FolderNameLink>\n  ) : (\n    <FolderName\n      tabIndex={-1}\n      role=\"treeitem\"\n      id={treestructureId(type, folder.id)}\n      aria-expanded={isMaxDepth || emptyFolder ? undefined : isOpen}\n      aria-selected={selected}\n      data-focused={focusedFolder?.id === folder.id}\n      aria-describedby={containsResource ? `alreadyAdded-${folder.id}` : undefined}\n      aria-label={`${name}${folder.status === 'shared' ? `, ${t('myNdla.folder.sharing.shared')}` : ''}`}\n      variant=\"ghost\"\n      shape=\"sharp\"\n      fontWeight=\"normal\"\n      colorTheme=\"light\"\n      ref={ref}\n      style={levelVariable}\n      data-selected={selected}\n      disabled={loading}\n      onFocus={() => setFocusedFolder(focusedFolder || folder)}\n      onClick={handleClickFolder}\n      data-creating={isCreatingFolder}\n    >\n      <IconWrapper>\n        {!hideArrow && (\n          <OpenButton\n            aria-hidden\n            tabIndex={-1}\n            data-open={isOpen}\n            onClick={(e) => {\n              e.stopPropagation();\n              setFocusedFolder(folder);\n              if (isOpen) {\n                onCloseFolder(id);\n              } else {\n                onOpenFolder(id);\n              }\n            }}\n          >\n            <ArrowDropDownRounded />\n          </OpenButton>\n        )}\n        <FolderIconWrapper>\n          <FolderIcon />\n        </FolderIconWrapper>\n      </IconWrapper>\n      <StyledName>{name}</StyledName>\n      {containsResource && (\n        <StyledDone\n          aria-label={t('myNdla.alreadyInFolder')}\n          id={`alreadyAdded-${folder.id}`}\n          title={t('myNdla.alreadyInFolder')}\n        />\n      )}\n    </FolderName>\n  );\n};\n\nexport default FolderItem;\n"]} */"));
66
+ })("display:grid;grid-template-columns:auto 1fr auto;padding-left:calc(0.75 * ", spacing.normal, " * var(--level));gap:", spacing.xxsmall, ";border:none;outline:none;color:", colors.text.primary, ";transition:", animations.durations.superFast, ";word-break:break-word;&:hover{box-shadow:none;outline:none;background:", colors.brand.lightest, ";color:", colors.text.primary, ";}&[data-focused='true']{background:", colors.brand.lightest, ";}&[data-selected='true']{background:", colors.brand.lighter, ";&:hover{background:", colors.brand.light, ";}}&[data-creating='true'][data-focused='true']{color:", colors.brand.primary, ";}&[data-creating='true']{background:none;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FolderItem.tsx"],"names":[],"mappings":"AAmEiC","file":"FolderItem.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 { CSSProperties, KeyboardEvent, useEffect, useMemo, useRef } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { ArrowDropDownRounded } from '@ndla/icons/common';\nimport { FolderOutlined, FolderShared } from '@ndla/icons/contentType';\nimport { Done } from '@ndla/icons/editor';\nimport { ButtonV2 as Button } from '@ndla/button';\nimport { colors, spacing, animations, misc, fonts } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\nimport { IFolder } from '@ndla/types-backend/learningpath-api';\nimport { CommonFolderItemsProps } from './types';\nimport { arrowNavigation } from './arrowNavigation';\nimport { treestructureId } from './helperFunctions';\n\nconst OpenButton = styled.span`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  align-self: stretch;\n  color: ${colors.brand.tertiary};\n  ${misc.transition.default};\n  cursor: pointer;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n  svg {\n    width: 24px;\n    height: 24px;\n    transform: rotate(-90deg);\n  }\n  &[data-open='true'] {\n    svg {\n      transform: rotate(0deg);\n    }\n  }\n  &[data-hide-arrow='true'] {\n    visibility: hidden;\n  }\n`;\n\nconst StyledName = styled.span`\n  white-space: nowrap;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  grid-column-start: 2;\n  text-align: left;\n`;\n\nconst IconWrapper = styled.div`\n  display: flex;\n`;\n\nconst FolderIconWrapper = styled.div`\n  svg {\n    height: 24px;\n    width: 24px;\n  }\n`;\n\nconst FolderName = styled(Button)`\n  display: grid;\n  grid-template-columns: auto 1fr auto;\n  padding-left: calc(0.75 * ${spacing.normal} * var(--level));\n  gap: ${spacing.xxsmall};\n  border: none;\n  outline: none;\n  color: ${colors.text.primary};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\n\n  &:hover {\n    box-shadow: none;\n    outline: none;\n    background: ${colors.brand.lightest};\n    color: ${colors.text.primary};\n  }\n\n  &[data-focused='true'] {\n    background: ${colors.brand.lightest};\n  }\n\n  &[data-selected='true'] {\n    background: ${colors.brand.lighter};\n    &:hover {\n      background: ${colors.brand.light};\n    }\n  }\n\n  &[data-creating='true'][data-focused='true'] {\n    color: ${colors.brand.primary};\n  }\n\n  &[data-creating='true'] {\n    background: none;\n  }\n`;\n\nconst StyledDone = styled(Done)`\n  color: ${colors.support.green};\n`;\n\nconst FolderNameLink = styled(SafeLink)`\n  display: grid;\n  align-items: center;\n  grid-template-columns: ${spacing.medium} 1fr auto;\n  padding: ${spacing.small} ${spacing.xxsmall};\n  padding-left: calc(0.75 * ${spacing.normal} * var(--level));\n  gap: ${spacing.xxsmall};\n  cursor: pointer;\n\n  border: none;\n  box-shadow: none;\n  color: ${colors.text.primary};\n  font-size: ${fonts.sizes('16px')};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\n  &[data-selected='true'] {\n    color: ${colors.brand.primary};\n    font-weight: ${fonts.weight.semibold};\n  }\n  &:hover,\n  &:focus {\n    color: ${colors.brand.primary};\n  }\n`;\n\ninterface Props extends CommonFolderItemsProps {\n  isOpen: boolean;\n  folder: IFolder;\n  isCreatingFolder?: boolean;\n  index: number;\n}\n\nconst FolderItem = ({\n  focusedFolder,\n  folder,\n  isOpen,\n  level,\n  loading,\n  selectedFolder,\n  onCloseFolder,\n  onOpenFolder,\n  setFocusedFolder,\n  setSelectedFolder,\n  targetResource,\n  visibleFolders,\n  maxLevel,\n  isCreatingFolder,\n  type,\n  closeTree,\n  index,\n}: Props) => {\n  const { t } = useTranslation();\n  const { id, name } = folder;\n  const ref = useRef<HTMLButtonElement & HTMLAnchorElement>(null);\n  const selected = selectedFolder ? selectedFolder.id === id : false;\n\n  const levelVariable = useMemo(() => ({ '--level': level } as unknown as CSSProperties), [level]);\n\n  const focused = focusedFolder?.id === id;\n\n  const handleClickFolder = () => {\n    if (!selected) {\n      setSelectedFolder(folder);\n    }\n    setFocusedFolder(folder);\n    if (type === 'picker') {\n      if (selected) {\n        closeTree();\n      }\n    }\n  };\n\n  useEffect(() => {\n    if (focusedFolder?.id === id && !isCreatingFolder) {\n      if (type === 'navigation') {\n        ref.current?.focus();\n      }\n      if (type === 'picker') {\n        ref.current?.focus();\n        ref.current?.scrollIntoView({\n          behavior: 'smooth',\n          block: 'start',\n        });\n      }\n    }\n  }, [focusedFolder, ref, id, isCreatingFolder, type]);\n\n  const linkPath = `/minndla/folders/${id}`;\n\n  const containsResource =\n    targetResource && folder.resources.some((resource) => resource.resourceId === targetResource.resourceId);\n\n  const emptyFolder = folder.subfolders.length === 0;\n  const isMaxDepth = level > maxLevel;\n  const hideArrow = isMaxDepth || emptyFolder;\n\n  const FolderIcon = folder.status === 'shared' ? FolderShared : FolderOutlined;\n\n  const tabable = selected || focused || (!focusedFolder && !folder.parentId && index === 0);\n\n  return type === 'navigation' ? (\n    <FolderNameLink\n      role=\"treeitem\"\n      aria-owns={folder.subfolders.length ? treestructureId(type, `subfolders-${folder.id}`) : undefined}\n      aria-expanded={isMaxDepth || emptyFolder ? undefined : isOpen}\n      aria-current={selected ? 'page' : undefined}\n      aria-describedby={containsResource ? `alreadyAdded-${folder.id}` : undefined}\n      ref={ref}\n      style={levelVariable}\n      onKeyDown={(e: KeyboardEvent<HTMLElement>) => {\n        if (e.key === 'Enter') {\n          setSelectedFolder(folder);\n          return;\n        }\n        arrowNavigation(e, id, visibleFolders, setFocusedFolder, onOpenFolder, onCloseFolder);\n      }}\n      to={loading ? '' : linkPath}\n      tabIndex={tabable ? 0 : -1}\n      data-selected={selected}\n      onFocus={() => setFocusedFolder(folder)}\n      onClick={handleClickFolder}\n    >\n      <OpenButton\n        aria-hidden\n        tabIndex={-1}\n        data-open={isOpen}\n        data-hide-arrow={hideArrow}\n        onClick={(e) => {\n          e.stopPropagation();\n          e.preventDefault();\n          ref.current?.focus();\n          if (isOpen) {\n            onCloseFolder(id);\n          } else {\n            onOpenFolder(id);\n          }\n        }}\n      >\n        <ArrowDropDownRounded />\n      </OpenButton>\n      <StyledName>{name}</StyledName>\n    </FolderNameLink>\n  ) : (\n    <FolderName\n      tabIndex={-1}\n      role=\"treeitem\"\n      id={treestructureId(type, folder.id)}\n      aria-expanded={isMaxDepth || emptyFolder ? undefined : isOpen}\n      aria-selected={selected}\n      data-focused={focusedFolder?.id === folder.id}\n      aria-describedby={containsResource ? `alreadyAdded-${folder.id}` : undefined}\n      aria-label={`${name}${folder.status === 'shared' ? `, ${t('myNdla.folder.sharing.shared')}` : ''}`}\n      variant=\"ghost\"\n      shape=\"sharp\"\n      fontWeight=\"normal\"\n      colorTheme=\"light\"\n      ref={ref}\n      style={levelVariable}\n      data-selected={selected}\n      disabled={loading}\n      onFocus={() => setFocusedFolder(focusedFolder || folder)}\n      onClick={handleClickFolder}\n      data-creating={isCreatingFolder}\n    >\n      <IconWrapper>\n        <OpenButton\n          aria-hidden\n          tabIndex={-1}\n          data-open={isOpen}\n          data-hide-arrow={hideArrow}\n          onClick={(e) => {\n            e.stopPropagation();\n            setFocusedFolder(folder);\n            if (isOpen) {\n              onCloseFolder(id);\n            } else {\n              onOpenFolder(id);\n            }\n          }}\n        >\n          <ArrowDropDownRounded />\n        </OpenButton>\n        <FolderIconWrapper>\n          <FolderIcon />\n        </FolderIconWrapper>\n      </IconWrapper>\n      <StyledName>{name}</StyledName>\n      {containsResource && (\n        <StyledDone\n          aria-label={t('myNdla.alreadyInFolder')}\n          id={`alreadyAdded-${folder.id}`}\n          title={t('myNdla.alreadyInFolder')}\n        />\n      )}\n    </FolderName>\n  );\n};\n\nexport default FolderItem;\n"]} */"));
67
67
  var StyledDone = /*#__PURE__*/_styled(Done, {
68
68
  target: "e11ok6h81",
69
69
  label: "StyledDone"
70
- })("color:", colors.support.green, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FolderItem.tsx"],"names":[],"mappings":"AAsG+B","file":"FolderItem.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 { CSSProperties, KeyboardEvent, useEffect, useMemo, useRef } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { ArrowDropDownRounded } from '@ndla/icons/common';\nimport { FolderOutlined, FolderShared } from '@ndla/icons/contentType';\nimport { Done } from '@ndla/icons/editor';\nimport { ButtonV2 as Button } from '@ndla/button';\nimport { colors, spacing, animations, misc, fonts } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\nimport { IFolder } from '@ndla/types-backend/learningpath-api';\nimport { CommonFolderItemsProps } from './types';\nimport { arrowNavigation } from './arrowNavigation';\nimport { treestructureId } from './helperFunctions';\n\nconst OpenButton = styled.span`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  align-self: stretch;\n  color: ${colors.brand.tertiary};\n  ${misc.transition.default};\n  cursor: pointer;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n  svg {\n    width: 24px;\n    height: 24px;\n    transform: rotate(-90deg);\n  }\n  &[data-open='true'] {\n    svg {\n      transform: rotate(0deg);\n    }\n  }\n`;\n\nconst StyledName = styled.span`\n  white-space: nowrap;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  grid-column-start: 2;\n  text-align: left;\n`;\n\nconst IconWrapper = styled.div`\n  display: flex;\n`;\n\nconst FolderIconWrapper = styled.div`\n  svg {\n    height: 24px;\n    width: 24px;\n  }\n`;\n\nconst FolderName = styled(Button)`\n  display: grid;\n  grid-template-columns: auto 1fr auto;\n  padding-left: calc(0.75 * ${spacing.normal} * var(--level));\n  gap: ${spacing.xxsmall};\n  border: none;\n  outline: none;\n  color: ${colors.text.primary};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\n\n  &:hover {\n    box-shadow: none;\n    outline: none;\n    background: ${colors.brand.lightest};\n    color: ${colors.text.primary};\n  }\n\n  &[data-focused='true'] {\n    background: ${colors.brand.lightest};\n  }\n\n  &[data-selected='true'] {\n    background: ${colors.brand.lighter};\n    &:hover {\n      background: ${colors.brand.light};\n    }\n  }\n\n  &[data-creating='true'][data-focused='true'] {\n    color: ${colors.brand.primary};\n  }\n\n  &[data-creating='true'] {\n    background: none;\n  }\n`;\n\nconst StyledDone = styled(Done)`\n  color: ${colors.support.green};\n`;\n\nconst FolderNameLink = styled(SafeLink)`\n  display: grid;\n  align-items: center;\n  grid-template-columns: ${spacing.medium} 1fr auto;\n  padding: ${spacing.small} ${spacing.xxsmall};\n  padding-left: calc(0.75 * ${spacing.normal} * var(--level));\n  gap: ${spacing.xxsmall};\n  cursor: pointer;\n\n  border: none;\n  box-shadow: none;\n  color: ${colors.text.primary};\n  font-size: ${fonts.sizes('16px')};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\n  &[data-selected='true'] {\n    color: ${colors.brand.primary};\n    font-weight: ${fonts.weight.semibold};\n  }\n  &:hover,\n  &:focus {\n    color: ${colors.brand.primary};\n  }\n`;\n\ninterface Props extends CommonFolderItemsProps {\n  isOpen: boolean;\n  folder: IFolder;\n  isCreatingFolder?: boolean;\n  index: number;\n}\n\nconst FolderItem = ({\n  focusedFolder,\n  folder,\n  isOpen,\n  level,\n  loading,\n  selectedFolder,\n  onCloseFolder,\n  onOpenFolder,\n  setFocusedFolder,\n  setSelectedFolder,\n  targetResource,\n  visibleFolders,\n  maxLevel,\n  isCreatingFolder,\n  type,\n  closeTree,\n  index,\n}: Props) => {\n  const { t } = useTranslation();\n  const { id, name } = folder;\n  const ref = useRef<HTMLButtonElement & HTMLAnchorElement>(null);\n  const selected = selectedFolder ? selectedFolder.id === id : false;\n\n  const levelVariable = useMemo(() => ({ '--level': level } as unknown as CSSProperties), [level]);\n\n  const focused = focusedFolder?.id === id;\n\n  const handleClickFolder = () => {\n    if (!selected) {\n      setSelectedFolder(folder);\n    }\n    setFocusedFolder(folder);\n    if (type === 'picker') {\n      if (selected) {\n        closeTree();\n      }\n    }\n  };\n\n  useEffect(() => {\n    if (focusedFolder?.id === id && !isCreatingFolder) {\n      if (type === 'navigation') {\n        ref.current?.focus();\n      }\n      if (type === 'picker') {\n        ref.current?.focus();\n        ref.current?.scrollIntoView({\n          behavior: 'smooth',\n          block: 'start',\n        });\n      }\n    }\n  }, [focusedFolder, ref, id, isCreatingFolder, type]);\n\n  const linkPath = `/minndla/folders/${id}`;\n\n  const containsResource =\n    targetResource && folder.resources.some((resource) => resource.resourceId === targetResource.resourceId);\n\n  const emptyFolder = folder.subfolders.length === 0;\n  const isMaxDepth = level > maxLevel;\n  const hideArrow = isMaxDepth || emptyFolder;\n\n  const FolderIcon = folder.status === 'shared' ? FolderShared : FolderOutlined;\n\n  const tabable = selected || focused || (!focusedFolder && !folder.parentId && index === 0);\n\n  return type === 'navigation' ? (\n    <FolderNameLink\n      role=\"treeitem\"\n      aria-owns={folder.subfolders.length ? treestructureId(type, `subfolders-${folder.id}`) : undefined}\n      aria-expanded={isMaxDepth || emptyFolder ? undefined : isOpen}\n      aria-current={selected ? 'page' : undefined}\n      aria-describedby={containsResource ? `alreadyAdded-${folder.id}` : undefined}\n      ref={ref}\n      style={levelVariable}\n      onKeyDown={(e: KeyboardEvent<HTMLElement>) => {\n        if (e.key === 'Enter') {\n          setSelectedFolder(folder);\n          return;\n        }\n        arrowNavigation(e, id, visibleFolders, setFocusedFolder, onOpenFolder, onCloseFolder);\n      }}\n      to={loading ? '' : linkPath}\n      tabIndex={tabable ? 0 : -1}\n      data-selected={selected}\n      onFocus={() => setFocusedFolder(folder)}\n      onClick={handleClickFolder}\n    >\n      {!hideArrow && (\n        <OpenButton\n          aria-hidden\n          tabIndex={-1}\n          data-open={isOpen}\n          onClick={(e) => {\n            e.stopPropagation();\n            e.preventDefault();\n            ref.current?.focus();\n            if (isOpen) {\n              onCloseFolder(id);\n            } else {\n              onOpenFolder(id);\n            }\n          }}\n        >\n          <ArrowDropDownRounded />\n        </OpenButton>\n      )}\n      <StyledName>{name}</StyledName>\n    </FolderNameLink>\n  ) : (\n    <FolderName\n      tabIndex={-1}\n      role=\"treeitem\"\n      id={treestructureId(type, folder.id)}\n      aria-expanded={isMaxDepth || emptyFolder ? undefined : isOpen}\n      aria-selected={selected}\n      data-focused={focusedFolder?.id === folder.id}\n      aria-describedby={containsResource ? `alreadyAdded-${folder.id}` : undefined}\n      aria-label={`${name}${folder.status === 'shared' ? `, ${t('myNdla.folder.sharing.shared')}` : ''}`}\n      variant=\"ghost\"\n      shape=\"sharp\"\n      fontWeight=\"normal\"\n      colorTheme=\"light\"\n      ref={ref}\n      style={levelVariable}\n      data-selected={selected}\n      disabled={loading}\n      onFocus={() => setFocusedFolder(focusedFolder || folder)}\n      onClick={handleClickFolder}\n      data-creating={isCreatingFolder}\n    >\n      <IconWrapper>\n        {!hideArrow && (\n          <OpenButton\n            aria-hidden\n            tabIndex={-1}\n            data-open={isOpen}\n            onClick={(e) => {\n              e.stopPropagation();\n              setFocusedFolder(folder);\n              if (isOpen) {\n                onCloseFolder(id);\n              } else {\n                onOpenFolder(id);\n              }\n            }}\n          >\n            <ArrowDropDownRounded />\n          </OpenButton>\n        )}\n        <FolderIconWrapper>\n          <FolderIcon />\n        </FolderIconWrapper>\n      </IconWrapper>\n      <StyledName>{name}</StyledName>\n      {containsResource && (\n        <StyledDone\n          aria-label={t('myNdla.alreadyInFolder')}\n          id={`alreadyAdded-${folder.id}`}\n          title={t('myNdla.alreadyInFolder')}\n        />\n      )}\n    </FolderName>\n  );\n};\n\nexport default FolderItem;\n"]} */"));
70
+ })("color:", colors.support.green, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FolderItem.tsx"],"names":[],"mappings":"AAyG+B","file":"FolderItem.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 { CSSProperties, KeyboardEvent, useEffect, useMemo, useRef } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { ArrowDropDownRounded } from '@ndla/icons/common';\nimport { FolderOutlined, FolderShared } from '@ndla/icons/contentType';\nimport { Done } from '@ndla/icons/editor';\nimport { ButtonV2 as Button } from '@ndla/button';\nimport { colors, spacing, animations, misc, fonts } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\nimport { IFolder } from '@ndla/types-backend/learningpath-api';\nimport { CommonFolderItemsProps } from './types';\nimport { arrowNavigation } from './arrowNavigation';\nimport { treestructureId } from './helperFunctions';\n\nconst OpenButton = styled.span`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  align-self: stretch;\n  color: ${colors.brand.tertiary};\n  ${misc.transition.default};\n  cursor: pointer;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n  svg {\n    width: 24px;\n    height: 24px;\n    transform: rotate(-90deg);\n  }\n  &[data-open='true'] {\n    svg {\n      transform: rotate(0deg);\n    }\n  }\n  &[data-hide-arrow='true'] {\n    visibility: hidden;\n  }\n`;\n\nconst StyledName = styled.span`\n  white-space: nowrap;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  grid-column-start: 2;\n  text-align: left;\n`;\n\nconst IconWrapper = styled.div`\n  display: flex;\n`;\n\nconst FolderIconWrapper = styled.div`\n  svg {\n    height: 24px;\n    width: 24px;\n  }\n`;\n\nconst FolderName = styled(Button)`\n  display: grid;\n  grid-template-columns: auto 1fr auto;\n  padding-left: calc(0.75 * ${spacing.normal} * var(--level));\n  gap: ${spacing.xxsmall};\n  border: none;\n  outline: none;\n  color: ${colors.text.primary};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\n\n  &:hover {\n    box-shadow: none;\n    outline: none;\n    background: ${colors.brand.lightest};\n    color: ${colors.text.primary};\n  }\n\n  &[data-focused='true'] {\n    background: ${colors.brand.lightest};\n  }\n\n  &[data-selected='true'] {\n    background: ${colors.brand.lighter};\n    &:hover {\n      background: ${colors.brand.light};\n    }\n  }\n\n  &[data-creating='true'][data-focused='true'] {\n    color: ${colors.brand.primary};\n  }\n\n  &[data-creating='true'] {\n    background: none;\n  }\n`;\n\nconst StyledDone = styled(Done)`\n  color: ${colors.support.green};\n`;\n\nconst FolderNameLink = styled(SafeLink)`\n  display: grid;\n  align-items: center;\n  grid-template-columns: ${spacing.medium} 1fr auto;\n  padding: ${spacing.small} ${spacing.xxsmall};\n  padding-left: calc(0.75 * ${spacing.normal} * var(--level));\n  gap: ${spacing.xxsmall};\n  cursor: pointer;\n\n  border: none;\n  box-shadow: none;\n  color: ${colors.text.primary};\n  font-size: ${fonts.sizes('16px')};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\n  &[data-selected='true'] {\n    color: ${colors.brand.primary};\n    font-weight: ${fonts.weight.semibold};\n  }\n  &:hover,\n  &:focus {\n    color: ${colors.brand.primary};\n  }\n`;\n\ninterface Props extends CommonFolderItemsProps {\n  isOpen: boolean;\n  folder: IFolder;\n  isCreatingFolder?: boolean;\n  index: number;\n}\n\nconst FolderItem = ({\n  focusedFolder,\n  folder,\n  isOpen,\n  level,\n  loading,\n  selectedFolder,\n  onCloseFolder,\n  onOpenFolder,\n  setFocusedFolder,\n  setSelectedFolder,\n  targetResource,\n  visibleFolders,\n  maxLevel,\n  isCreatingFolder,\n  type,\n  closeTree,\n  index,\n}: Props) => {\n  const { t } = useTranslation();\n  const { id, name } = folder;\n  const ref = useRef<HTMLButtonElement & HTMLAnchorElement>(null);\n  const selected = selectedFolder ? selectedFolder.id === id : false;\n\n  const levelVariable = useMemo(() => ({ '--level': level } as unknown as CSSProperties), [level]);\n\n  const focused = focusedFolder?.id === id;\n\n  const handleClickFolder = () => {\n    if (!selected) {\n      setSelectedFolder(folder);\n    }\n    setFocusedFolder(folder);\n    if (type === 'picker') {\n      if (selected) {\n        closeTree();\n      }\n    }\n  };\n\n  useEffect(() => {\n    if (focusedFolder?.id === id && !isCreatingFolder) {\n      if (type === 'navigation') {\n        ref.current?.focus();\n      }\n      if (type === 'picker') {\n        ref.current?.focus();\n        ref.current?.scrollIntoView({\n          behavior: 'smooth',\n          block: 'start',\n        });\n      }\n    }\n  }, [focusedFolder, ref, id, isCreatingFolder, type]);\n\n  const linkPath = `/minndla/folders/${id}`;\n\n  const containsResource =\n    targetResource && folder.resources.some((resource) => resource.resourceId === targetResource.resourceId);\n\n  const emptyFolder = folder.subfolders.length === 0;\n  const isMaxDepth = level > maxLevel;\n  const hideArrow = isMaxDepth || emptyFolder;\n\n  const FolderIcon = folder.status === 'shared' ? FolderShared : FolderOutlined;\n\n  const tabable = selected || focused || (!focusedFolder && !folder.parentId && index === 0);\n\n  return type === 'navigation' ? (\n    <FolderNameLink\n      role=\"treeitem\"\n      aria-owns={folder.subfolders.length ? treestructureId(type, `subfolders-${folder.id}`) : undefined}\n      aria-expanded={isMaxDepth || emptyFolder ? undefined : isOpen}\n      aria-current={selected ? 'page' : undefined}\n      aria-describedby={containsResource ? `alreadyAdded-${folder.id}` : undefined}\n      ref={ref}\n      style={levelVariable}\n      onKeyDown={(e: KeyboardEvent<HTMLElement>) => {\n        if (e.key === 'Enter') {\n          setSelectedFolder(folder);\n          return;\n        }\n        arrowNavigation(e, id, visibleFolders, setFocusedFolder, onOpenFolder, onCloseFolder);\n      }}\n      to={loading ? '' : linkPath}\n      tabIndex={tabable ? 0 : -1}\n      data-selected={selected}\n      onFocus={() => setFocusedFolder(folder)}\n      onClick={handleClickFolder}\n    >\n      <OpenButton\n        aria-hidden\n        tabIndex={-1}\n        data-open={isOpen}\n        data-hide-arrow={hideArrow}\n        onClick={(e) => {\n          e.stopPropagation();\n          e.preventDefault();\n          ref.current?.focus();\n          if (isOpen) {\n            onCloseFolder(id);\n          } else {\n            onOpenFolder(id);\n          }\n        }}\n      >\n        <ArrowDropDownRounded />\n      </OpenButton>\n      <StyledName>{name}</StyledName>\n    </FolderNameLink>\n  ) : (\n    <FolderName\n      tabIndex={-1}\n      role=\"treeitem\"\n      id={treestructureId(type, folder.id)}\n      aria-expanded={isMaxDepth || emptyFolder ? undefined : isOpen}\n      aria-selected={selected}\n      data-focused={focusedFolder?.id === folder.id}\n      aria-describedby={containsResource ? `alreadyAdded-${folder.id}` : undefined}\n      aria-label={`${name}${folder.status === 'shared' ? `, ${t('myNdla.folder.sharing.shared')}` : ''}`}\n      variant=\"ghost\"\n      shape=\"sharp\"\n      fontWeight=\"normal\"\n      colorTheme=\"light\"\n      ref={ref}\n      style={levelVariable}\n      data-selected={selected}\n      disabled={loading}\n      onFocus={() => setFocusedFolder(focusedFolder || folder)}\n      onClick={handleClickFolder}\n      data-creating={isCreatingFolder}\n    >\n      <IconWrapper>\n        <OpenButton\n          aria-hidden\n          tabIndex={-1}\n          data-open={isOpen}\n          data-hide-arrow={hideArrow}\n          onClick={(e) => {\n            e.stopPropagation();\n            setFocusedFolder(folder);\n            if (isOpen) {\n              onCloseFolder(id);\n            } else {\n              onOpenFolder(id);\n            }\n          }}\n        >\n          <ArrowDropDownRounded />\n        </OpenButton>\n        <FolderIconWrapper>\n          <FolderIcon />\n        </FolderIconWrapper>\n      </IconWrapper>\n      <StyledName>{name}</StyledName>\n      {containsResource && (\n        <StyledDone\n          aria-label={t('myNdla.alreadyInFolder')}\n          id={`alreadyAdded-${folder.id}`}\n          title={t('myNdla.alreadyInFolder')}\n        />\n      )}\n    </FolderName>\n  );\n};\n\nexport default FolderItem;\n"]} */"));
71
71
  var FolderNameLink = /*#__PURE__*/_styled(SafeLink, {
72
72
  target: "e11ok6h80",
73
73
  label: "FolderNameLink"
74
- })("display:grid;align-items:center;grid-template-columns:", spacing.medium, " 1fr auto;padding:", spacing.small, " ", spacing.xxsmall, ";padding-left:calc(0.75 * ", spacing.normal, " * var(--level));gap:", spacing.xxsmall, ";cursor:pointer;border:none;box-shadow:none;color:", colors.text.primary, ";font-size:", fonts.sizes('16px'), ";transition:", animations.durations.superFast, ";word-break:break-word;&[data-selected='true']{color:", colors.brand.primary, ";font-weight:", fonts.weight.semibold, ";}&:hover,&:focus{color:", colors.brand.primary, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FolderItem.tsx"],"names":[],"mappings":"AA0GuC","file":"FolderItem.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 { CSSProperties, KeyboardEvent, useEffect, useMemo, useRef } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { ArrowDropDownRounded } from '@ndla/icons/common';\nimport { FolderOutlined, FolderShared } from '@ndla/icons/contentType';\nimport { Done } from '@ndla/icons/editor';\nimport { ButtonV2 as Button } from '@ndla/button';\nimport { colors, spacing, animations, misc, fonts } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\nimport { IFolder } from '@ndla/types-backend/learningpath-api';\nimport { CommonFolderItemsProps } from './types';\nimport { arrowNavigation } from './arrowNavigation';\nimport { treestructureId } from './helperFunctions';\n\nconst OpenButton = styled.span`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  align-self: stretch;\n  color: ${colors.brand.tertiary};\n  ${misc.transition.default};\n  cursor: pointer;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n  svg {\n    width: 24px;\n    height: 24px;\n    transform: rotate(-90deg);\n  }\n  &[data-open='true'] {\n    svg {\n      transform: rotate(0deg);\n    }\n  }\n`;\n\nconst StyledName = styled.span`\n  white-space: nowrap;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  grid-column-start: 2;\n  text-align: left;\n`;\n\nconst IconWrapper = styled.div`\n  display: flex;\n`;\n\nconst FolderIconWrapper = styled.div`\n  svg {\n    height: 24px;\n    width: 24px;\n  }\n`;\n\nconst FolderName = styled(Button)`\n  display: grid;\n  grid-template-columns: auto 1fr auto;\n  padding-left: calc(0.75 * ${spacing.normal} * var(--level));\n  gap: ${spacing.xxsmall};\n  border: none;\n  outline: none;\n  color: ${colors.text.primary};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\n\n  &:hover {\n    box-shadow: none;\n    outline: none;\n    background: ${colors.brand.lightest};\n    color: ${colors.text.primary};\n  }\n\n  &[data-focused='true'] {\n    background: ${colors.brand.lightest};\n  }\n\n  &[data-selected='true'] {\n    background: ${colors.brand.lighter};\n    &:hover {\n      background: ${colors.brand.light};\n    }\n  }\n\n  &[data-creating='true'][data-focused='true'] {\n    color: ${colors.brand.primary};\n  }\n\n  &[data-creating='true'] {\n    background: none;\n  }\n`;\n\nconst StyledDone = styled(Done)`\n  color: ${colors.support.green};\n`;\n\nconst FolderNameLink = styled(SafeLink)`\n  display: grid;\n  align-items: center;\n  grid-template-columns: ${spacing.medium} 1fr auto;\n  padding: ${spacing.small} ${spacing.xxsmall};\n  padding-left: calc(0.75 * ${spacing.normal} * var(--level));\n  gap: ${spacing.xxsmall};\n  cursor: pointer;\n\n  border: none;\n  box-shadow: none;\n  color: ${colors.text.primary};\n  font-size: ${fonts.sizes('16px')};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\n  &[data-selected='true'] {\n    color: ${colors.brand.primary};\n    font-weight: ${fonts.weight.semibold};\n  }\n  &:hover,\n  &:focus {\n    color: ${colors.brand.primary};\n  }\n`;\n\ninterface Props extends CommonFolderItemsProps {\n  isOpen: boolean;\n  folder: IFolder;\n  isCreatingFolder?: boolean;\n  index: number;\n}\n\nconst FolderItem = ({\n  focusedFolder,\n  folder,\n  isOpen,\n  level,\n  loading,\n  selectedFolder,\n  onCloseFolder,\n  onOpenFolder,\n  setFocusedFolder,\n  setSelectedFolder,\n  targetResource,\n  visibleFolders,\n  maxLevel,\n  isCreatingFolder,\n  type,\n  closeTree,\n  index,\n}: Props) => {\n  const { t } = useTranslation();\n  const { id, name } = folder;\n  const ref = useRef<HTMLButtonElement & HTMLAnchorElement>(null);\n  const selected = selectedFolder ? selectedFolder.id === id : false;\n\n  const levelVariable = useMemo(() => ({ '--level': level } as unknown as CSSProperties), [level]);\n\n  const focused = focusedFolder?.id === id;\n\n  const handleClickFolder = () => {\n    if (!selected) {\n      setSelectedFolder(folder);\n    }\n    setFocusedFolder(folder);\n    if (type === 'picker') {\n      if (selected) {\n        closeTree();\n      }\n    }\n  };\n\n  useEffect(() => {\n    if (focusedFolder?.id === id && !isCreatingFolder) {\n      if (type === 'navigation') {\n        ref.current?.focus();\n      }\n      if (type === 'picker') {\n        ref.current?.focus();\n        ref.current?.scrollIntoView({\n          behavior: 'smooth',\n          block: 'start',\n        });\n      }\n    }\n  }, [focusedFolder, ref, id, isCreatingFolder, type]);\n\n  const linkPath = `/minndla/folders/${id}`;\n\n  const containsResource =\n    targetResource && folder.resources.some((resource) => resource.resourceId === targetResource.resourceId);\n\n  const emptyFolder = folder.subfolders.length === 0;\n  const isMaxDepth = level > maxLevel;\n  const hideArrow = isMaxDepth || emptyFolder;\n\n  const FolderIcon = folder.status === 'shared' ? FolderShared : FolderOutlined;\n\n  const tabable = selected || focused || (!focusedFolder && !folder.parentId && index === 0);\n\n  return type === 'navigation' ? (\n    <FolderNameLink\n      role=\"treeitem\"\n      aria-owns={folder.subfolders.length ? treestructureId(type, `subfolders-${folder.id}`) : undefined}\n      aria-expanded={isMaxDepth || emptyFolder ? undefined : isOpen}\n      aria-current={selected ? 'page' : undefined}\n      aria-describedby={containsResource ? `alreadyAdded-${folder.id}` : undefined}\n      ref={ref}\n      style={levelVariable}\n      onKeyDown={(e: KeyboardEvent<HTMLElement>) => {\n        if (e.key === 'Enter') {\n          setSelectedFolder(folder);\n          return;\n        }\n        arrowNavigation(e, id, visibleFolders, setFocusedFolder, onOpenFolder, onCloseFolder);\n      }}\n      to={loading ? '' : linkPath}\n      tabIndex={tabable ? 0 : -1}\n      data-selected={selected}\n      onFocus={() => setFocusedFolder(folder)}\n      onClick={handleClickFolder}\n    >\n      {!hideArrow && (\n        <OpenButton\n          aria-hidden\n          tabIndex={-1}\n          data-open={isOpen}\n          onClick={(e) => {\n            e.stopPropagation();\n            e.preventDefault();\n            ref.current?.focus();\n            if (isOpen) {\n              onCloseFolder(id);\n            } else {\n              onOpenFolder(id);\n            }\n          }}\n        >\n          <ArrowDropDownRounded />\n        </OpenButton>\n      )}\n      <StyledName>{name}</StyledName>\n    </FolderNameLink>\n  ) : (\n    <FolderName\n      tabIndex={-1}\n      role=\"treeitem\"\n      id={treestructureId(type, folder.id)}\n      aria-expanded={isMaxDepth || emptyFolder ? undefined : isOpen}\n      aria-selected={selected}\n      data-focused={focusedFolder?.id === folder.id}\n      aria-describedby={containsResource ? `alreadyAdded-${folder.id}` : undefined}\n      aria-label={`${name}${folder.status === 'shared' ? `, ${t('myNdla.folder.sharing.shared')}` : ''}`}\n      variant=\"ghost\"\n      shape=\"sharp\"\n      fontWeight=\"normal\"\n      colorTheme=\"light\"\n      ref={ref}\n      style={levelVariable}\n      data-selected={selected}\n      disabled={loading}\n      onFocus={() => setFocusedFolder(focusedFolder || folder)}\n      onClick={handleClickFolder}\n      data-creating={isCreatingFolder}\n    >\n      <IconWrapper>\n        {!hideArrow && (\n          <OpenButton\n            aria-hidden\n            tabIndex={-1}\n            data-open={isOpen}\n            onClick={(e) => {\n              e.stopPropagation();\n              setFocusedFolder(folder);\n              if (isOpen) {\n                onCloseFolder(id);\n              } else {\n                onOpenFolder(id);\n              }\n            }}\n          >\n            <ArrowDropDownRounded />\n          </OpenButton>\n        )}\n        <FolderIconWrapper>\n          <FolderIcon />\n        </FolderIconWrapper>\n      </IconWrapper>\n      <StyledName>{name}</StyledName>\n      {containsResource && (\n        <StyledDone\n          aria-label={t('myNdla.alreadyInFolder')}\n          id={`alreadyAdded-${folder.id}`}\n          title={t('myNdla.alreadyInFolder')}\n        />\n      )}\n    </FolderName>\n  );\n};\n\nexport default FolderItem;\n"]} */"));
74
+ })("display:grid;align-items:center;grid-template-columns:", spacing.medium, " 1fr auto;padding:", spacing.small, " ", spacing.xxsmall, ";padding-left:calc(0.75 * ", spacing.normal, " * var(--level));gap:", spacing.xxsmall, ";cursor:pointer;border:none;box-shadow:none;color:", colors.text.primary, ";font-size:", fonts.sizes('16px'), ";transition:", animations.durations.superFast, ";word-break:break-word;&[data-selected='true']{color:", colors.brand.primary, ";font-weight:", fonts.weight.semibold, ";}&:hover,&:focus{color:", colors.brand.primary, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FolderItem.tsx"],"names":[],"mappings":"AA6GuC","file":"FolderItem.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 { CSSProperties, KeyboardEvent, useEffect, useMemo, useRef } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { ArrowDropDownRounded } from '@ndla/icons/common';\nimport { FolderOutlined, FolderShared } from '@ndla/icons/contentType';\nimport { Done } from '@ndla/icons/editor';\nimport { ButtonV2 as Button } from '@ndla/button';\nimport { colors, spacing, animations, misc, fonts } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\nimport { IFolder } from '@ndla/types-backend/learningpath-api';\nimport { CommonFolderItemsProps } from './types';\nimport { arrowNavigation } from './arrowNavigation';\nimport { treestructureId } from './helperFunctions';\n\nconst OpenButton = styled.span`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  align-self: stretch;\n  color: ${colors.brand.tertiary};\n  ${misc.transition.default};\n  cursor: pointer;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n  svg {\n    width: 24px;\n    height: 24px;\n    transform: rotate(-90deg);\n  }\n  &[data-open='true'] {\n    svg {\n      transform: rotate(0deg);\n    }\n  }\n  &[data-hide-arrow='true'] {\n    visibility: hidden;\n  }\n`;\n\nconst StyledName = styled.span`\n  white-space: nowrap;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  grid-column-start: 2;\n  text-align: left;\n`;\n\nconst IconWrapper = styled.div`\n  display: flex;\n`;\n\nconst FolderIconWrapper = styled.div`\n  svg {\n    height: 24px;\n    width: 24px;\n  }\n`;\n\nconst FolderName = styled(Button)`\n  display: grid;\n  grid-template-columns: auto 1fr auto;\n  padding-left: calc(0.75 * ${spacing.normal} * var(--level));\n  gap: ${spacing.xxsmall};\n  border: none;\n  outline: none;\n  color: ${colors.text.primary};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\n\n  &:hover {\n    box-shadow: none;\n    outline: none;\n    background: ${colors.brand.lightest};\n    color: ${colors.text.primary};\n  }\n\n  &[data-focused='true'] {\n    background: ${colors.brand.lightest};\n  }\n\n  &[data-selected='true'] {\n    background: ${colors.brand.lighter};\n    &:hover {\n      background: ${colors.brand.light};\n    }\n  }\n\n  &[data-creating='true'][data-focused='true'] {\n    color: ${colors.brand.primary};\n  }\n\n  &[data-creating='true'] {\n    background: none;\n  }\n`;\n\nconst StyledDone = styled(Done)`\n  color: ${colors.support.green};\n`;\n\nconst FolderNameLink = styled(SafeLink)`\n  display: grid;\n  align-items: center;\n  grid-template-columns: ${spacing.medium} 1fr auto;\n  padding: ${spacing.small} ${spacing.xxsmall};\n  padding-left: calc(0.75 * ${spacing.normal} * var(--level));\n  gap: ${spacing.xxsmall};\n  cursor: pointer;\n\n  border: none;\n  box-shadow: none;\n  color: ${colors.text.primary};\n  font-size: ${fonts.sizes('16px')};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\n  &[data-selected='true'] {\n    color: ${colors.brand.primary};\n    font-weight: ${fonts.weight.semibold};\n  }\n  &:hover,\n  &:focus {\n    color: ${colors.brand.primary};\n  }\n`;\n\ninterface Props extends CommonFolderItemsProps {\n  isOpen: boolean;\n  folder: IFolder;\n  isCreatingFolder?: boolean;\n  index: number;\n}\n\nconst FolderItem = ({\n  focusedFolder,\n  folder,\n  isOpen,\n  level,\n  loading,\n  selectedFolder,\n  onCloseFolder,\n  onOpenFolder,\n  setFocusedFolder,\n  setSelectedFolder,\n  targetResource,\n  visibleFolders,\n  maxLevel,\n  isCreatingFolder,\n  type,\n  closeTree,\n  index,\n}: Props) => {\n  const { t } = useTranslation();\n  const { id, name } = folder;\n  const ref = useRef<HTMLButtonElement & HTMLAnchorElement>(null);\n  const selected = selectedFolder ? selectedFolder.id === id : false;\n\n  const levelVariable = useMemo(() => ({ '--level': level } as unknown as CSSProperties), [level]);\n\n  const focused = focusedFolder?.id === id;\n\n  const handleClickFolder = () => {\n    if (!selected) {\n      setSelectedFolder(folder);\n    }\n    setFocusedFolder(folder);\n    if (type === 'picker') {\n      if (selected) {\n        closeTree();\n      }\n    }\n  };\n\n  useEffect(() => {\n    if (focusedFolder?.id === id && !isCreatingFolder) {\n      if (type === 'navigation') {\n        ref.current?.focus();\n      }\n      if (type === 'picker') {\n        ref.current?.focus();\n        ref.current?.scrollIntoView({\n          behavior: 'smooth',\n          block: 'start',\n        });\n      }\n    }\n  }, [focusedFolder, ref, id, isCreatingFolder, type]);\n\n  const linkPath = `/minndla/folders/${id}`;\n\n  const containsResource =\n    targetResource && folder.resources.some((resource) => resource.resourceId === targetResource.resourceId);\n\n  const emptyFolder = folder.subfolders.length === 0;\n  const isMaxDepth = level > maxLevel;\n  const hideArrow = isMaxDepth || emptyFolder;\n\n  const FolderIcon = folder.status === 'shared' ? FolderShared : FolderOutlined;\n\n  const tabable = selected || focused || (!focusedFolder && !folder.parentId && index === 0);\n\n  return type === 'navigation' ? (\n    <FolderNameLink\n      role=\"treeitem\"\n      aria-owns={folder.subfolders.length ? treestructureId(type, `subfolders-${folder.id}`) : undefined}\n      aria-expanded={isMaxDepth || emptyFolder ? undefined : isOpen}\n      aria-current={selected ? 'page' : undefined}\n      aria-describedby={containsResource ? `alreadyAdded-${folder.id}` : undefined}\n      ref={ref}\n      style={levelVariable}\n      onKeyDown={(e: KeyboardEvent<HTMLElement>) => {\n        if (e.key === 'Enter') {\n          setSelectedFolder(folder);\n          return;\n        }\n        arrowNavigation(e, id, visibleFolders, setFocusedFolder, onOpenFolder, onCloseFolder);\n      }}\n      to={loading ? '' : linkPath}\n      tabIndex={tabable ? 0 : -1}\n      data-selected={selected}\n      onFocus={() => setFocusedFolder(folder)}\n      onClick={handleClickFolder}\n    >\n      <OpenButton\n        aria-hidden\n        tabIndex={-1}\n        data-open={isOpen}\n        data-hide-arrow={hideArrow}\n        onClick={(e) => {\n          e.stopPropagation();\n          e.preventDefault();\n          ref.current?.focus();\n          if (isOpen) {\n            onCloseFolder(id);\n          } else {\n            onOpenFolder(id);\n          }\n        }}\n      >\n        <ArrowDropDownRounded />\n      </OpenButton>\n      <StyledName>{name}</StyledName>\n    </FolderNameLink>\n  ) : (\n    <FolderName\n      tabIndex={-1}\n      role=\"treeitem\"\n      id={treestructureId(type, folder.id)}\n      aria-expanded={isMaxDepth || emptyFolder ? undefined : isOpen}\n      aria-selected={selected}\n      data-focused={focusedFolder?.id === folder.id}\n      aria-describedby={containsResource ? `alreadyAdded-${folder.id}` : undefined}\n      aria-label={`${name}${folder.status === 'shared' ? `, ${t('myNdla.folder.sharing.shared')}` : ''}`}\n      variant=\"ghost\"\n      shape=\"sharp\"\n      fontWeight=\"normal\"\n      colorTheme=\"light\"\n      ref={ref}\n      style={levelVariable}\n      data-selected={selected}\n      disabled={loading}\n      onFocus={() => setFocusedFolder(focusedFolder || folder)}\n      onClick={handleClickFolder}\n      data-creating={isCreatingFolder}\n    >\n      <IconWrapper>\n        <OpenButton\n          aria-hidden\n          tabIndex={-1}\n          data-open={isOpen}\n          data-hide-arrow={hideArrow}\n          onClick={(e) => {\n            e.stopPropagation();\n            setFocusedFolder(folder);\n            if (isOpen) {\n              onCloseFolder(id);\n            } else {\n              onOpenFolder(id);\n            }\n          }}\n        >\n          <ArrowDropDownRounded />\n        </OpenButton>\n        <FolderIconWrapper>\n          <FolderIcon />\n        </FolderIconWrapper>\n      </IconWrapper>\n      <StyledName>{name}</StyledName>\n      {containsResource && (\n        <StyledDone\n          aria-label={t('myNdla.alreadyInFolder')}\n          id={`alreadyAdded-${folder.id}`}\n          title={t('myNdla.alreadyInFolder')}\n        />\n      )}\n    </FolderName>\n  );\n};\n\nexport default FolderItem;\n"]} */"));
75
75
  var FolderItem = function FolderItem(_ref) {
76
76
  var focusedFolder = _ref.focusedFolder,
77
77
  folder = _ref.folder,
@@ -160,10 +160,11 @@ var FolderItem = function FolderItem(_ref) {
160
160
  return setFocusedFolder(folder);
161
161
  },
162
162
  onClick: handleClickFolder,
163
- children: [!hideArrow && _jsx(OpenButton, {
163
+ children: [_jsx(OpenButton, {
164
164
  "aria-hidden": true,
165
165
  tabIndex: -1,
166
166
  "data-open": isOpen,
167
+ "data-hide-arrow": hideArrow,
167
168
  onClick: function onClick(e) {
168
169
  var _ref$current4;
169
170
  e.stopPropagation();
@@ -202,10 +203,11 @@ var FolderItem = function FolderItem(_ref) {
202
203
  onClick: handleClickFolder,
203
204
  "data-creating": isCreatingFolder,
204
205
  children: [_jsxs(IconWrapper, {
205
- children: [!hideArrow && _jsx(OpenButton, {
206
+ children: [_jsx(OpenButton, {
206
207
  "aria-hidden": true,
207
208
  tabIndex: -1,
208
209
  "data-open": isOpen,
210
+ "data-hide-arrow": hideArrow,
209
211
  onClick: function onClick(e) {
210
212
  e.stopPropagation();
211
213
  setFocusedFolder(folder);