@ndla/ui 42.1.0 → 42.1.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -35,6 +35,11 @@ function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return _ty
35
35
  function _toPrimitive(input, hint) { if (_typeof(input) !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (_typeof(res) !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
36
36
  function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }
37
37
  function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }
38
+ var StyledSpinner = /*#__PURE__*/(0, _base.default)(_icons.Spinner, {
39
+ target: "esbqk1r2",
40
+ label: "StyledSpinner"
41
+ })("margin:", _core.spacing.small, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZvbGRlcklucHV0LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEwQnFDIiwiZmlsZSI6IkZvbGRlcklucHV0LnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDIyLXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgSWNvbkJ1dHRvblYyIH0gZnJvbSAnQG5kbGEvYnV0dG9uJztcbmltcG9ydCB7IENyb3NzIH0gZnJvbSAnQG5kbGEvaWNvbnMvYWN0aW9uJztcbmltcG9ydCBSZWFjdCwgeyBDb21wb25lbnRQcm9wcywgZm9yd2FyZFJlZiwgdXNlRWZmZWN0IH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgaXNNb2JpbGUgfSBmcm9tICdyZWFjdC1kZXZpY2UtZGV0ZWN0JztcbmltcG9ydCB7IHVzZVRyYW5zbGF0aW9uIH0gZnJvbSAncmVhY3QtaTE4bmV4dCc7XG5pbXBvcnQgeyBjb2xvcnMsIHNwYWNpbmcgfSBmcm9tICdAbmRsYS9jb3JlJztcbmltcG9ydCB7IElucHV0VjIgfSBmcm9tICdAbmRsYS9mb3Jtcyc7XG5pbXBvcnQgeyBEb25lIH0gZnJvbSAnQG5kbGEvaWNvbnMvZWRpdG9yJztcbmltcG9ydCB7IFNwaW5uZXIgfSBmcm9tICdAbmRsYS9pY29ucyc7XG5pbXBvcnQgeyB1c2VGb3J3YXJkZWRSZWYgfSBmcm9tICdAbmRsYS91dGlsJztcblxuaW50ZXJmYWNlIFByb3BzIGV4dGVuZHMgQ29tcG9uZW50UHJvcHM8dHlwZW9mIElucHV0VjI+IHtcbiAgbG9hZGluZz86IGJvb2xlYW47XG4gIG9uQ2xvc2U/OiAoKSA9PiB2b2lkO1xuICBvblNhdmU6ICgpID0+IHZvaWQ7XG59XG5cbmNvbnN0IFN0eWxlZFNwaW5uZXIgPSBzdHlsZWQoU3Bpbm5lcilgXG4gIG1hcmdpbjogJHtzcGFjaW5nLnNtYWxsfTtcbmA7XG5cbi8vIFNvdXJjZTogaHR0cHM6Ly9rb3ZhcnQuZ2l0aHViLmlvL2Rhc2hlZC1ib3JkZXItZ2VuZXJhdG9yL1xuY29uc3QgYm9yZGVyU3R5bGUgPSAoZXJyb3I/OiBib29sZWFuKSA9PlxuICBgdXJsKFwiZGF0YTppbWFnZS9zdmcreG1sLCUzY3N2ZyB3aWR0aD0nMTAwJTI1JyBoZWlnaHQ9JzEwMCUyNScgeG1sbnM9J2h0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnJyUzZSUzY3JlY3Qgd2lkdGg9JzEwMCUyNScgaGVpZ2h0PScxMDAlMjUnIGZpbGw9J25vbmUnIHN0cm9rZT0nJHtlbmNvZGVVUklDb21wb25lbnQoXG4gICAgZXJyb3IgPyBjb2xvcnMuc3VwcG9ydC5yZWQgOiBjb2xvcnMuYnJhbmQudGVydGlhcnksXG4gICl9JyBzdHJva2Utd2lkdGg9JzInIHN0cm9rZS1kYXNoYXJyYXk9JzglMmM4JyBzdHJva2UtZGFzaG9mZnNldD0nNCcgc3Ryb2tlLWxpbmVjYXA9J3NxdWFyZScvJTNlJTNjL3N2ZyUzZVwiKWA7XG5cbmludGVyZmFjZSBTdHlsZWRJbnB1dFByb3BzIHtcbiAgZXJyb3I/OiBzdHJpbmc7XG59XG5cbmNvbnN0IFN0eWxlZElucHV0ID0gc3R5bGVkKElucHV0VjIpPFN0eWxlZElucHV0UHJvcHM+YFxuICBiYWNrZ3JvdW5kLWNvbG9yOiB3aGl0ZTtcbiAgYmFja2dyb3VuZC1pbWFnZTogJHsoeyBlcnJvciB9KSA9PiBib3JkZXJTdHlsZSghIWVycm9yKX07XG4gIGJvcmRlcjogbm9uZTtcbiAgYm9yZGVyLXJhZGl1czogMDtcbiAgZmxleC13cmFwOiBub3dyYXA7XG4gIGlucHV0IHtcbiAgICBsaW5lLWhlaWdodDogMS43NWVtO1xuICAgIGNvbG9yOiAke2NvbG9ycy5icmFuZC5wcmltYXJ5fTtcbiAgICBjYXJldC1jb2xvcjogJHtjb2xvcnMuYnJhbmQudGVydGlhcnl9O1xuICAgIDo6c2VsZWN0aW9uIHtcbiAgICAgIGJhY2tncm91bmQ6ICR7Y29sb3JzLmJyYW5kLmxpZ2h0ZXJ9O1xuICAgIH1cbiAgICA6OnBsYWNlaG9sZGVyIHtcbiAgICAgIGNvbG9yOiAke2NvbG9ycy5icmFuZC50ZXJ0aWFyeX07XG4gICAgfVxuICB9XG5gO1xuXG5jb25zdCBSb3cgPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBnYXA6ICR7c3BhY2luZy54eHNtYWxsfTtcbiAgcGFkZGluZy1yaWdodDogJHtzcGFjaW5nLnhzbWFsbH07XG5gO1xuXG5jb25zdCBGb2xkZXJJbnB1dCA9IGZvcndhcmRSZWY8SFRNTElucHV0RWxlbWVudCwgUHJvcHM+KCh7IGxvYWRpbmcsIGVycm9yLCBvbkNsb3NlLCBvblNhdmUsIC4uLnJlc3QgfSwgcmVmKSA9PiB7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcbiAgY29uc3QgaW5wdXRSZWYgPSB1c2VGb3J3YXJkZWRSZWYocmVmKTtcblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGlmIChpc01vYmlsZSkge1xuICAgICAgaW5wdXRSZWYuY3VycmVudD8uc2Nyb2xsSW50b1ZpZXcoeyBiZWhhdmlvcjogJ3Ntb290aCcgfSk7XG4gICAgfVxuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSByZWFjdC1ob29rcy9leGhhdXN0aXZlLWRlcHNcbiAgfSwgW10pO1xuXG4gIHJldHVybiAoXG4gICAgPFN0eWxlZElucHV0XG4gICAgICBhdXRvQ29tcGxldGU9XCJvZmZcIlxuICAgICAgd2hpdGVcbiAgICAgIGVycm9yPXtlcnJvcn1cbiAgICAgIGFyaWEtZGlzYWJsZWQ9e2xvYWRpbmcgPyB0cnVlIDogdW5kZWZpbmVkfVxuICAgICAgYXJpYS1kZXNjcmliZWRieT17J2ZvbGRlci1pbnB1dC1zcGlubmVyJ31cbiAgICAgIHJlZj17cmVmfVxuICAgICAgYWZ0ZXI9e1xuICAgICAgICA8Um93PlxuICAgICAgICAgIHshbG9hZGluZyAmJiAoXG4gICAgICAgICAgICA8PlxuICAgICAgICAgICAgICB7IWVycm9yICYmIChcbiAgICAgICAgICAgICAgICA8SWNvbkJ1dHRvblYyXG4gICAgICAgICAgICAgICAgICB2YXJpYW50PXsnZ2hvc3QnfVxuICAgICAgICAgICAgICAgICAgY29sb3JUaGVtZT1cImxpZ2h0XCJcbiAgICAgICAgICAgICAgICAgIHRhYkluZGV4PXswfVxuICAgICAgICAgICAgICAgICAgYXJpYS1sYWJlbD17dCgnc2F2ZScpfVxuICAgICAgICAgICAgICAgICAgdGl0bGU9e3QoJ3NhdmUnKX1cbiAgICAgICAgICAgICAgICAgIHNpemU9XCJzbWFsbFwiXG4gICAgICAgICAgICAgICAgICBvbkNsaWNrPXtvblNhdmV9XG4gICAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgICAgPERvbmUgLz5cbiAgICAgICAgICAgICAgICA8L0ljb25CdXR0b25WMj5cbiAgICAgICAgICAgICAgKX1cbiAgICAgICAgICAgICAgPEljb25CdXR0b25WMiBhcmlhLWxhYmVsPXt0KCdjbG9zZScpfSB0aXRsZT17dCgnY2xvc2UnKX0gc2l6ZT1cInNtYWxsXCIgdmFyaWFudD1cImdob3N0XCIgb25DbGljaz17b25DbG9zZX0+XG4gICAgICAgICAgICAgICAgPENyb3NzIC8+XG4gICAgICAgICAgICAgIDwvSWNvbkJ1dHRvblYyPlxuICAgICAgICAgICAgPC8+XG4gICAgICAgICAgKX1cbiAgICAgICAgICA8ZGl2IGFyaWEtbGl2ZT1cImFzc2VydGl2ZVwiPlxuICAgICAgICAgICAge2xvYWRpbmcgJiYgPFN0eWxlZFNwaW5uZXIgc2l6ZT1cIm5vcm1hbFwiIGlkPVwiZm9sZGVyLXNwaW5uZXJcIiBhcmlhLWxhYmVsPXt0KCdsb2FkaW5nJyl9IC8+fVxuICAgICAgICAgIDwvZGl2PlxuICAgICAgICA8L1Jvdz5cbiAgICAgIH1cbiAgICAgIHsuLi5yZXN0fVxuICAgIC8+XG4gICk7XG59KTtcblxuZXhwb3J0IGRlZmF1bHQgRm9sZGVySW5wdXQ7XG4iXX0= */"));
42
+
38
43
  // Source: https://kovart.github.io/dashed-border-generator/
39
44
  var borderStyle = function borderStyle(error) {
40
45
  return "url(\"data:image/svg+xml,%3csvg width='100%25' height='100%25' xmlns='http://www.w3.org/2000/svg'%3e%3crect width='100%25' height='100%25' fill='none' stroke='".concat(encodeURIComponent(error ? _core.colors.support.red : _core.colors.brand.tertiary), "' stroke-width='2' stroke-dasharray='8%2c8' stroke-dashoffset='4' stroke-linecap='square'/%3e%3c/svg%3e\")");
@@ -45,11 +50,11 @@ var StyledInput = /*#__PURE__*/(0, _base.default)(_forms.InputV2, {
45
50
  })("background-color:white;background-image:", function (_ref) {
46
51
  var error = _ref.error;
47
52
  return borderStyle(!!error);
48
- }, ";border:none;border-radius:0;flex-wrap:nowrap;input{line-height:1.75em;color:", _core.colors.brand.primary, ";caret-color:", _core.colors.brand.tertiary, ";::selection{background:", _core.colors.brand.lighter, ";}::placeholder{color:", _core.colors.brand.tertiary, ";}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZvbGRlcklucHV0LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFvQ3FEIiwiZmlsZSI6IkZvbGRlcklucHV0LnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDIyLXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgSWNvbkJ1dHRvblYyIH0gZnJvbSAnQG5kbGEvYnV0dG9uJztcbmltcG9ydCB7IENyb3NzIH0gZnJvbSAnQG5kbGEvaWNvbnMvYWN0aW9uJztcbmltcG9ydCBSZWFjdCwgeyBDb21wb25lbnRQcm9wcywgZm9yd2FyZFJlZiwgdXNlRWZmZWN0IH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgaXNNb2JpbGUgfSBmcm9tICdyZWFjdC1kZXZpY2UtZGV0ZWN0JztcbmltcG9ydCB7IHVzZVRyYW5zbGF0aW9uIH0gZnJvbSAncmVhY3QtaTE4bmV4dCc7XG5pbXBvcnQgeyBjb2xvcnMsIHNwYWNpbmcgfSBmcm9tICdAbmRsYS9jb3JlJztcbmltcG9ydCB7IElucHV0VjIgfSBmcm9tICdAbmRsYS9mb3Jtcyc7XG5pbXBvcnQgeyBEb25lIH0gZnJvbSAnQG5kbGEvaWNvbnMvZWRpdG9yJztcbmltcG9ydCB7IFNwaW5uZXIgfSBmcm9tICdAbmRsYS9pY29ucyc7XG5pbXBvcnQgeyB1c2VGb3J3YXJkZWRSZWYgfSBmcm9tICdAbmRsYS91dGlsJztcblxuaW50ZXJmYWNlIFByb3BzIGV4dGVuZHMgQ29tcG9uZW50UHJvcHM8dHlwZW9mIElucHV0VjI+IHtcbiAgbG9hZGluZz86IGJvb2xlYW47XG4gIG9uQ2xvc2U/OiAoKSA9PiB2b2lkO1xuICBvblNhdmU6ICgpID0+IHZvaWQ7XG59XG5cbi8vIFNvdXJjZTogaHR0cHM6Ly9rb3ZhcnQuZ2l0aHViLmlvL2Rhc2hlZC1ib3JkZXItZ2VuZXJhdG9yL1xuY29uc3QgYm9yZGVyU3R5bGUgPSAoZXJyb3I/OiBib29sZWFuKSA9PlxuICBgdXJsKFwiZGF0YTppbWFnZS9zdmcreG1sLCUzY3N2ZyB3aWR0aD0nMTAwJTI1JyBoZWlnaHQ9JzEwMCUyNScgeG1sbnM9J2h0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnJyUzZSUzY3JlY3Qgd2lkdGg9JzEwMCUyNScgaGVpZ2h0PScxMDAlMjUnIGZpbGw9J25vbmUnIHN0cm9rZT0nJHtlbmNvZGVVUklDb21wb25lbnQoXG4gICAgZXJyb3IgPyBjb2xvcnMuc3VwcG9ydC5yZWQgOiBjb2xvcnMuYnJhbmQudGVydGlhcnksXG4gICl9JyBzdHJva2Utd2lkdGg9JzInIHN0cm9rZS1kYXNoYXJyYXk9JzglMmM4JyBzdHJva2UtZGFzaG9mZnNldD0nNCcgc3Ryb2tlLWxpbmVjYXA9J3NxdWFyZScvJTNlJTNjL3N2ZyUzZVwiKWA7XG5cbmludGVyZmFjZSBTdHlsZWRJbnB1dFByb3BzIHtcbiAgZXJyb3I/OiBzdHJpbmc7XG59XG5cbmNvbnN0IFN0eWxlZElucHV0ID0gc3R5bGVkKElucHV0VjIpPFN0eWxlZElucHV0UHJvcHM+YFxuICBiYWNrZ3JvdW5kLWNvbG9yOiB3aGl0ZTtcbiAgYmFja2dyb3VuZC1pbWFnZTogJHsoeyBlcnJvciB9KSA9PiBib3JkZXJTdHlsZSghIWVycm9yKX07XG4gIGJvcmRlcjogbm9uZTtcbiAgYm9yZGVyLXJhZGl1czogMDtcbiAgZmxleC13cmFwOiBub3dyYXA7XG4gIGlucHV0IHtcbiAgICBsaW5lLWhlaWdodDogMS43NWVtO1xuICAgIGNvbG9yOiAke2NvbG9ycy5icmFuZC5wcmltYXJ5fTtcbiAgICBjYXJldC1jb2xvcjogJHtjb2xvcnMuYnJhbmQudGVydGlhcnl9O1xuICAgIDo6c2VsZWN0aW9uIHtcbiAgICAgIGJhY2tncm91bmQ6ICR7Y29sb3JzLmJyYW5kLmxpZ2h0ZXJ9O1xuICAgIH1cbiAgICA6OnBsYWNlaG9sZGVyIHtcbiAgICAgIGNvbG9yOiAke2NvbG9ycy5icmFuZC50ZXJ0aWFyeX07XG4gICAgfVxuICB9XG5gO1xuXG5jb25zdCBSb3cgPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBnYXA6ICR7c3BhY2luZy54eHNtYWxsfTtcbiAgcGFkZGluZy1yaWdodDogJHtzcGFjaW5nLnhzbWFsbH07XG5gO1xuXG5jb25zdCBGb2xkZXJJbnB1dCA9IGZvcndhcmRSZWY8SFRNTElucHV0RWxlbWVudCwgUHJvcHM+KCh7IGxvYWRpbmcsIGVycm9yLCBvbkNsb3NlLCBvblNhdmUsIC4uLnJlc3QgfSwgcmVmKSA9PiB7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcbiAgY29uc3QgaW5wdXRSZWYgPSB1c2VGb3J3YXJkZWRSZWYocmVmKTtcblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGlmIChpc01vYmlsZSkge1xuICAgICAgaW5wdXRSZWYuY3VycmVudD8uc2Nyb2xsSW50b1ZpZXcoeyBiZWhhdmlvcjogJ3Ntb290aCcgfSk7XG4gICAgfVxuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSByZWFjdC1ob29rcy9leGhhdXN0aXZlLWRlcHNcbiAgfSwgW10pO1xuXG4gIHJldHVybiAoXG4gICAgPFN0eWxlZElucHV0XG4gICAgICBhdXRvQ29tcGxldGU9XCJvZmZcIlxuICAgICAgd2hpdGVcbiAgICAgIGVycm9yPXtlcnJvcn1cbiAgICAgIGFyaWEtZGlzYWJsZWQ9e2xvYWRpbmcgPyB0cnVlIDogdW5kZWZpbmVkfVxuICAgICAgYXJpYS1kZXNjcmliZWRieT17J2ZvbGRlci1pbnB1dC1zcGlubmVyJ31cbiAgICAgIHJlZj17cmVmfVxuICAgICAgYWZ0ZXI9e1xuICAgICAgICA8Um93PlxuICAgICAgICAgIHshbG9hZGluZyAmJiAoXG4gICAgICAgICAgICA8PlxuICAgICAgICAgICAgICB7IWVycm9yICYmIChcbiAgICAgICAgICAgICAgICA8SWNvbkJ1dHRvblYyXG4gICAgICAgICAgICAgICAgICB2YXJpYW50PXsnZ2hvc3QnfVxuICAgICAgICAgICAgICAgICAgY29sb3JUaGVtZT1cImxpZ2h0XCJcbiAgICAgICAgICAgICAgICAgIHRhYkluZGV4PXswfVxuICAgICAgICAgICAgICAgICAgYXJpYS1sYWJlbD17dCgnc2F2ZScpfVxuICAgICAgICAgICAgICAgICAgdGl0bGU9e3QoJ3NhdmUnKX1cbiAgICAgICAgICAgICAgICAgIHNpemU9XCJzbWFsbFwiXG4gICAgICAgICAgICAgICAgICBvbkNsaWNrPXtvblNhdmV9XG4gICAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgICAgPERvbmUgLz5cbiAgICAgICAgICAgICAgICA8L0ljb25CdXR0b25WMj5cbiAgICAgICAgICAgICAgKX1cbiAgICAgICAgICAgICAgPEljb25CdXR0b25WMiBhcmlhLWxhYmVsPXt0KCdjbG9zZScpfSB0aXRsZT17dCgnY2xvc2UnKX0gc2l6ZT1cInNtYWxsXCIgdmFyaWFudD1cImdob3N0XCIgb25DbGljaz17b25DbG9zZX0+XG4gICAgICAgICAgICAgICAgPENyb3NzIC8+XG4gICAgICAgICAgICAgIDwvSWNvbkJ1dHRvblYyPlxuICAgICAgICAgICAgPC8+XG4gICAgICAgICAgKX1cbiAgICAgICAgICA8ZGl2IGFyaWEtbGl2ZT1cImFzc2VydGl2ZVwiPlxuICAgICAgICAgICAge2xvYWRpbmcgJiYgPFNwaW5uZXIgc2l6ZT1cIm5vcm1hbFwiIG1hcmdpbj17c3BhY2luZy5zbWFsbH0gaWQ9XCJmb2xkZXItc3Bpbm5lclwiIGFyaWEtbGFiZWw9e3QoJ2xvYWRpbmcnKX0gLz59XG4gICAgICAgICAgPC9kaXY+XG4gICAgICAgIDwvUm93PlxuICAgICAgfVxuICAgICAgey4uLnJlc3R9XG4gICAgLz5cbiAgKTtcbn0pO1xuXG5leHBvcnQgZGVmYXVsdCBGb2xkZXJJbnB1dDtcbiJdfQ== */"));
53
+ }, ";border:none;border-radius:0;flex-wrap:nowrap;input{line-height:1.75em;color:", _core.colors.brand.primary, ";caret-color:", _core.colors.brand.tertiary, ";::selection{background:", _core.colors.brand.lighter, ";}::placeholder{color:", _core.colors.brand.tertiary, ";}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZvbGRlcklucHV0LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF3Q3FEIiwiZmlsZSI6IkZvbGRlcklucHV0LnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDIyLXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgSWNvbkJ1dHRvblYyIH0gZnJvbSAnQG5kbGEvYnV0dG9uJztcbmltcG9ydCB7IENyb3NzIH0gZnJvbSAnQG5kbGEvaWNvbnMvYWN0aW9uJztcbmltcG9ydCBSZWFjdCwgeyBDb21wb25lbnRQcm9wcywgZm9yd2FyZFJlZiwgdXNlRWZmZWN0IH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgaXNNb2JpbGUgfSBmcm9tICdyZWFjdC1kZXZpY2UtZGV0ZWN0JztcbmltcG9ydCB7IHVzZVRyYW5zbGF0aW9uIH0gZnJvbSAncmVhY3QtaTE4bmV4dCc7XG5pbXBvcnQgeyBjb2xvcnMsIHNwYWNpbmcgfSBmcm9tICdAbmRsYS9jb3JlJztcbmltcG9ydCB7IElucHV0VjIgfSBmcm9tICdAbmRsYS9mb3Jtcyc7XG5pbXBvcnQgeyBEb25lIH0gZnJvbSAnQG5kbGEvaWNvbnMvZWRpdG9yJztcbmltcG9ydCB7IFNwaW5uZXIgfSBmcm9tICdAbmRsYS9pY29ucyc7XG5pbXBvcnQgeyB1c2VGb3J3YXJkZWRSZWYgfSBmcm9tICdAbmRsYS91dGlsJztcblxuaW50ZXJmYWNlIFByb3BzIGV4dGVuZHMgQ29tcG9uZW50UHJvcHM8dHlwZW9mIElucHV0VjI+IHtcbiAgbG9hZGluZz86IGJvb2xlYW47XG4gIG9uQ2xvc2U/OiAoKSA9PiB2b2lkO1xuICBvblNhdmU6ICgpID0+IHZvaWQ7XG59XG5cbmNvbnN0IFN0eWxlZFNwaW5uZXIgPSBzdHlsZWQoU3Bpbm5lcilgXG4gIG1hcmdpbjogJHtzcGFjaW5nLnNtYWxsfTtcbmA7XG5cbi8vIFNvdXJjZTogaHR0cHM6Ly9rb3ZhcnQuZ2l0aHViLmlvL2Rhc2hlZC1ib3JkZXItZ2VuZXJhdG9yL1xuY29uc3QgYm9yZGVyU3R5bGUgPSAoZXJyb3I/OiBib29sZWFuKSA9PlxuICBgdXJsKFwiZGF0YTppbWFnZS9zdmcreG1sLCUzY3N2ZyB3aWR0aD0nMTAwJTI1JyBoZWlnaHQ9JzEwMCUyNScgeG1sbnM9J2h0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnJyUzZSUzY3JlY3Qgd2lkdGg9JzEwMCUyNScgaGVpZ2h0PScxMDAlMjUnIGZpbGw9J25vbmUnIHN0cm9rZT0nJHtlbmNvZGVVUklDb21wb25lbnQoXG4gICAgZXJyb3IgPyBjb2xvcnMuc3VwcG9ydC5yZWQgOiBjb2xvcnMuYnJhbmQudGVydGlhcnksXG4gICl9JyBzdHJva2Utd2lkdGg9JzInIHN0cm9rZS1kYXNoYXJyYXk9JzglMmM4JyBzdHJva2UtZGFzaG9mZnNldD0nNCcgc3Ryb2tlLWxpbmVjYXA9J3NxdWFyZScvJTNlJTNjL3N2ZyUzZVwiKWA7XG5cbmludGVyZmFjZSBTdHlsZWRJbnB1dFByb3BzIHtcbiAgZXJyb3I/OiBzdHJpbmc7XG59XG5cbmNvbnN0IFN0eWxlZElucHV0ID0gc3R5bGVkKElucHV0VjIpPFN0eWxlZElucHV0UHJvcHM+YFxuICBiYWNrZ3JvdW5kLWNvbG9yOiB3aGl0ZTtcbiAgYmFja2dyb3VuZC1pbWFnZTogJHsoeyBlcnJvciB9KSA9PiBib3JkZXJTdHlsZSghIWVycm9yKX07XG4gIGJvcmRlcjogbm9uZTtcbiAgYm9yZGVyLXJhZGl1czogMDtcbiAgZmxleC13cmFwOiBub3dyYXA7XG4gIGlucHV0IHtcbiAgICBsaW5lLWhlaWdodDogMS43NWVtO1xuICAgIGNvbG9yOiAke2NvbG9ycy5icmFuZC5wcmltYXJ5fTtcbiAgICBjYXJldC1jb2xvcjogJHtjb2xvcnMuYnJhbmQudGVydGlhcnl9O1xuICAgIDo6c2VsZWN0aW9uIHtcbiAgICAgIGJhY2tncm91bmQ6ICR7Y29sb3JzLmJyYW5kLmxpZ2h0ZXJ9O1xuICAgIH1cbiAgICA6OnBsYWNlaG9sZGVyIHtcbiAgICAgIGNvbG9yOiAke2NvbG9ycy5icmFuZC50ZXJ0aWFyeX07XG4gICAgfVxuICB9XG5gO1xuXG5jb25zdCBSb3cgPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBnYXA6ICR7c3BhY2luZy54eHNtYWxsfTtcbiAgcGFkZGluZy1yaWdodDogJHtzcGFjaW5nLnhzbWFsbH07XG5gO1xuXG5jb25zdCBGb2xkZXJJbnB1dCA9IGZvcndhcmRSZWY8SFRNTElucHV0RWxlbWVudCwgUHJvcHM+KCh7IGxvYWRpbmcsIGVycm9yLCBvbkNsb3NlLCBvblNhdmUsIC4uLnJlc3QgfSwgcmVmKSA9PiB7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcbiAgY29uc3QgaW5wdXRSZWYgPSB1c2VGb3J3YXJkZWRSZWYocmVmKTtcblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGlmIChpc01vYmlsZSkge1xuICAgICAgaW5wdXRSZWYuY3VycmVudD8uc2Nyb2xsSW50b1ZpZXcoeyBiZWhhdmlvcjogJ3Ntb290aCcgfSk7XG4gICAgfVxuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSByZWFjdC1ob29rcy9leGhhdXN0aXZlLWRlcHNcbiAgfSwgW10pO1xuXG4gIHJldHVybiAoXG4gICAgPFN0eWxlZElucHV0XG4gICAgICBhdXRvQ29tcGxldGU9XCJvZmZcIlxuICAgICAgd2hpdGVcbiAgICAgIGVycm9yPXtlcnJvcn1cbiAgICAgIGFyaWEtZGlzYWJsZWQ9e2xvYWRpbmcgPyB0cnVlIDogdW5kZWZpbmVkfVxuICAgICAgYXJpYS1kZXNjcmliZWRieT17J2ZvbGRlci1pbnB1dC1zcGlubmVyJ31cbiAgICAgIHJlZj17cmVmfVxuICAgICAgYWZ0ZXI9e1xuICAgICAgICA8Um93PlxuICAgICAgICAgIHshbG9hZGluZyAmJiAoXG4gICAgICAgICAgICA8PlxuICAgICAgICAgICAgICB7IWVycm9yICYmIChcbiAgICAgICAgICAgICAgICA8SWNvbkJ1dHRvblYyXG4gICAgICAgICAgICAgICAgICB2YXJpYW50PXsnZ2hvc3QnfVxuICAgICAgICAgICAgICAgICAgY29sb3JUaGVtZT1cImxpZ2h0XCJcbiAgICAgICAgICAgICAgICAgIHRhYkluZGV4PXswfVxuICAgICAgICAgICAgICAgICAgYXJpYS1sYWJlbD17dCgnc2F2ZScpfVxuICAgICAgICAgICAgICAgICAgdGl0bGU9e3QoJ3NhdmUnKX1cbiAgICAgICAgICAgICAgICAgIHNpemU9XCJzbWFsbFwiXG4gICAgICAgICAgICAgICAgICBvbkNsaWNrPXtvblNhdmV9XG4gICAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgICAgPERvbmUgLz5cbiAgICAgICAgICAgICAgICA8L0ljb25CdXR0b25WMj5cbiAgICAgICAgICAgICAgKX1cbiAgICAgICAgICAgICAgPEljb25CdXR0b25WMiBhcmlhLWxhYmVsPXt0KCdjbG9zZScpfSB0aXRsZT17dCgnY2xvc2UnKX0gc2l6ZT1cInNtYWxsXCIgdmFyaWFudD1cImdob3N0XCIgb25DbGljaz17b25DbG9zZX0+XG4gICAgICAgICAgICAgICAgPENyb3NzIC8+XG4gICAgICAgICAgICAgIDwvSWNvbkJ1dHRvblYyPlxuICAgICAgICAgICAgPC8+XG4gICAgICAgICAgKX1cbiAgICAgICAgICA8ZGl2IGFyaWEtbGl2ZT1cImFzc2VydGl2ZVwiPlxuICAgICAgICAgICAge2xvYWRpbmcgJiYgPFN0eWxlZFNwaW5uZXIgc2l6ZT1cIm5vcm1hbFwiIGlkPVwiZm9sZGVyLXNwaW5uZXJcIiBhcmlhLWxhYmVsPXt0KCdsb2FkaW5nJyl9IC8+fVxuICAgICAgICAgIDwvZGl2PlxuICAgICAgICA8L1Jvdz5cbiAgICAgIH1cbiAgICAgIHsuLi5yZXN0fVxuICAgIC8+XG4gICk7XG59KTtcblxuZXhwb3J0IGRlZmF1bHQgRm9sZGVySW5wdXQ7XG4iXX0= */"));
49
54
  var Row = /*#__PURE__*/(0, _base.default)("div", {
50
55
  target: "esbqk1r0",
51
56
  label: "Row"
52
- })("display:flex;align-items:center;gap:", _core.spacing.xxsmall, ";padding-right:", _core.spacing.xsmall, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZvbGRlcklucHV0LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF1RHNCIiwiZmlsZSI6IkZvbGRlcklucHV0LnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDIyLXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgSWNvbkJ1dHRvblYyIH0gZnJvbSAnQG5kbGEvYnV0dG9uJztcbmltcG9ydCB7IENyb3NzIH0gZnJvbSAnQG5kbGEvaWNvbnMvYWN0aW9uJztcbmltcG9ydCBSZWFjdCwgeyBDb21wb25lbnRQcm9wcywgZm9yd2FyZFJlZiwgdXNlRWZmZWN0IH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgaXNNb2JpbGUgfSBmcm9tICdyZWFjdC1kZXZpY2UtZGV0ZWN0JztcbmltcG9ydCB7IHVzZVRyYW5zbGF0aW9uIH0gZnJvbSAncmVhY3QtaTE4bmV4dCc7XG5pbXBvcnQgeyBjb2xvcnMsIHNwYWNpbmcgfSBmcm9tICdAbmRsYS9jb3JlJztcbmltcG9ydCB7IElucHV0VjIgfSBmcm9tICdAbmRsYS9mb3Jtcyc7XG5pbXBvcnQgeyBEb25lIH0gZnJvbSAnQG5kbGEvaWNvbnMvZWRpdG9yJztcbmltcG9ydCB7IFNwaW5uZXIgfSBmcm9tICdAbmRsYS9pY29ucyc7XG5pbXBvcnQgeyB1c2VGb3J3YXJkZWRSZWYgfSBmcm9tICdAbmRsYS91dGlsJztcblxuaW50ZXJmYWNlIFByb3BzIGV4dGVuZHMgQ29tcG9uZW50UHJvcHM8dHlwZW9mIElucHV0VjI+IHtcbiAgbG9hZGluZz86IGJvb2xlYW47XG4gIG9uQ2xvc2U/OiAoKSA9PiB2b2lkO1xuICBvblNhdmU6ICgpID0+IHZvaWQ7XG59XG5cbi8vIFNvdXJjZTogaHR0cHM6Ly9rb3ZhcnQuZ2l0aHViLmlvL2Rhc2hlZC1ib3JkZXItZ2VuZXJhdG9yL1xuY29uc3QgYm9yZGVyU3R5bGUgPSAoZXJyb3I/OiBib29sZWFuKSA9PlxuICBgdXJsKFwiZGF0YTppbWFnZS9zdmcreG1sLCUzY3N2ZyB3aWR0aD0nMTAwJTI1JyBoZWlnaHQ9JzEwMCUyNScgeG1sbnM9J2h0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnJyUzZSUzY3JlY3Qgd2lkdGg9JzEwMCUyNScgaGVpZ2h0PScxMDAlMjUnIGZpbGw9J25vbmUnIHN0cm9rZT0nJHtlbmNvZGVVUklDb21wb25lbnQoXG4gICAgZXJyb3IgPyBjb2xvcnMuc3VwcG9ydC5yZWQgOiBjb2xvcnMuYnJhbmQudGVydGlhcnksXG4gICl9JyBzdHJva2Utd2lkdGg9JzInIHN0cm9rZS1kYXNoYXJyYXk9JzglMmM4JyBzdHJva2UtZGFzaG9mZnNldD0nNCcgc3Ryb2tlLWxpbmVjYXA9J3NxdWFyZScvJTNlJTNjL3N2ZyUzZVwiKWA7XG5cbmludGVyZmFjZSBTdHlsZWRJbnB1dFByb3BzIHtcbiAgZXJyb3I/OiBzdHJpbmc7XG59XG5cbmNvbnN0IFN0eWxlZElucHV0ID0gc3R5bGVkKElucHV0VjIpPFN0eWxlZElucHV0UHJvcHM+YFxuICBiYWNrZ3JvdW5kLWNvbG9yOiB3aGl0ZTtcbiAgYmFja2dyb3VuZC1pbWFnZTogJHsoeyBlcnJvciB9KSA9PiBib3JkZXJTdHlsZSghIWVycm9yKX07XG4gIGJvcmRlcjogbm9uZTtcbiAgYm9yZGVyLXJhZGl1czogMDtcbiAgZmxleC13cmFwOiBub3dyYXA7XG4gIGlucHV0IHtcbiAgICBsaW5lLWhlaWdodDogMS43NWVtO1xuICAgIGNvbG9yOiAke2NvbG9ycy5icmFuZC5wcmltYXJ5fTtcbiAgICBjYXJldC1jb2xvcjogJHtjb2xvcnMuYnJhbmQudGVydGlhcnl9O1xuICAgIDo6c2VsZWN0aW9uIHtcbiAgICAgIGJhY2tncm91bmQ6ICR7Y29sb3JzLmJyYW5kLmxpZ2h0ZXJ9O1xuICAgIH1cbiAgICA6OnBsYWNlaG9sZGVyIHtcbiAgICAgIGNvbG9yOiAke2NvbG9ycy5icmFuZC50ZXJ0aWFyeX07XG4gICAgfVxuICB9XG5gO1xuXG5jb25zdCBSb3cgPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBnYXA6ICR7c3BhY2luZy54eHNtYWxsfTtcbiAgcGFkZGluZy1yaWdodDogJHtzcGFjaW5nLnhzbWFsbH07XG5gO1xuXG5jb25zdCBGb2xkZXJJbnB1dCA9IGZvcndhcmRSZWY8SFRNTElucHV0RWxlbWVudCwgUHJvcHM+KCh7IGxvYWRpbmcsIGVycm9yLCBvbkNsb3NlLCBvblNhdmUsIC4uLnJlc3QgfSwgcmVmKSA9PiB7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcbiAgY29uc3QgaW5wdXRSZWYgPSB1c2VGb3J3YXJkZWRSZWYocmVmKTtcblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGlmIChpc01vYmlsZSkge1xuICAgICAgaW5wdXRSZWYuY3VycmVudD8uc2Nyb2xsSW50b1ZpZXcoeyBiZWhhdmlvcjogJ3Ntb290aCcgfSk7XG4gICAgfVxuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSByZWFjdC1ob29rcy9leGhhdXN0aXZlLWRlcHNcbiAgfSwgW10pO1xuXG4gIHJldHVybiAoXG4gICAgPFN0eWxlZElucHV0XG4gICAgICBhdXRvQ29tcGxldGU9XCJvZmZcIlxuICAgICAgd2hpdGVcbiAgICAgIGVycm9yPXtlcnJvcn1cbiAgICAgIGFyaWEtZGlzYWJsZWQ9e2xvYWRpbmcgPyB0cnVlIDogdW5kZWZpbmVkfVxuICAgICAgYXJpYS1kZXNjcmliZWRieT17J2ZvbGRlci1pbnB1dC1zcGlubmVyJ31cbiAgICAgIHJlZj17cmVmfVxuICAgICAgYWZ0ZXI9e1xuICAgICAgICA8Um93PlxuICAgICAgICAgIHshbG9hZGluZyAmJiAoXG4gICAgICAgICAgICA8PlxuICAgICAgICAgICAgICB7IWVycm9yICYmIChcbiAgICAgICAgICAgICAgICA8SWNvbkJ1dHRvblYyXG4gICAgICAgICAgICAgICAgICB2YXJpYW50PXsnZ2hvc3QnfVxuICAgICAgICAgICAgICAgICAgY29sb3JUaGVtZT1cImxpZ2h0XCJcbiAgICAgICAgICAgICAgICAgIHRhYkluZGV4PXswfVxuICAgICAgICAgICAgICAgICAgYXJpYS1sYWJlbD17dCgnc2F2ZScpfVxuICAgICAgICAgICAgICAgICAgdGl0bGU9e3QoJ3NhdmUnKX1cbiAgICAgICAgICAgICAgICAgIHNpemU9XCJzbWFsbFwiXG4gICAgICAgICAgICAgICAgICBvbkNsaWNrPXtvblNhdmV9XG4gICAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgICAgPERvbmUgLz5cbiAgICAgICAgICAgICAgICA8L0ljb25CdXR0b25WMj5cbiAgICAgICAgICAgICAgKX1cbiAgICAgICAgICAgICAgPEljb25CdXR0b25WMiBhcmlhLWxhYmVsPXt0KCdjbG9zZScpfSB0aXRsZT17dCgnY2xvc2UnKX0gc2l6ZT1cInNtYWxsXCIgdmFyaWFudD1cImdob3N0XCIgb25DbGljaz17b25DbG9zZX0+XG4gICAgICAgICAgICAgICAgPENyb3NzIC8+XG4gICAgICAgICAgICAgIDwvSWNvbkJ1dHRvblYyPlxuICAgICAgICAgICAgPC8+XG4gICAgICAgICAgKX1cbiAgICAgICAgICA8ZGl2IGFyaWEtbGl2ZT1cImFzc2VydGl2ZVwiPlxuICAgICAgICAgICAge2xvYWRpbmcgJiYgPFNwaW5uZXIgc2l6ZT1cIm5vcm1hbFwiIG1hcmdpbj17c3BhY2luZy5zbWFsbH0gaWQ9XCJmb2xkZXItc3Bpbm5lclwiIGFyaWEtbGFiZWw9e3QoJ2xvYWRpbmcnKX0gLz59XG4gICAgICAgICAgPC9kaXY+XG4gICAgICAgIDwvUm93PlxuICAgICAgfVxuICAgICAgey4uLnJlc3R9XG4gICAgLz5cbiAgKTtcbn0pO1xuXG5leHBvcnQgZGVmYXVsdCBGb2xkZXJJbnB1dDtcbiJdfQ== */"));
57
+ })("display:flex;align-items:center;gap:", _core.spacing.xxsmall, ";padding-right:", _core.spacing.xsmall, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZvbGRlcklucHV0LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEyRHNCIiwiZmlsZSI6IkZvbGRlcklucHV0LnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDIyLXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgSWNvbkJ1dHRvblYyIH0gZnJvbSAnQG5kbGEvYnV0dG9uJztcbmltcG9ydCB7IENyb3NzIH0gZnJvbSAnQG5kbGEvaWNvbnMvYWN0aW9uJztcbmltcG9ydCBSZWFjdCwgeyBDb21wb25lbnRQcm9wcywgZm9yd2FyZFJlZiwgdXNlRWZmZWN0IH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgaXNNb2JpbGUgfSBmcm9tICdyZWFjdC1kZXZpY2UtZGV0ZWN0JztcbmltcG9ydCB7IHVzZVRyYW5zbGF0aW9uIH0gZnJvbSAncmVhY3QtaTE4bmV4dCc7XG5pbXBvcnQgeyBjb2xvcnMsIHNwYWNpbmcgfSBmcm9tICdAbmRsYS9jb3JlJztcbmltcG9ydCB7IElucHV0VjIgfSBmcm9tICdAbmRsYS9mb3Jtcyc7XG5pbXBvcnQgeyBEb25lIH0gZnJvbSAnQG5kbGEvaWNvbnMvZWRpdG9yJztcbmltcG9ydCB7IFNwaW5uZXIgfSBmcm9tICdAbmRsYS9pY29ucyc7XG5pbXBvcnQgeyB1c2VGb3J3YXJkZWRSZWYgfSBmcm9tICdAbmRsYS91dGlsJztcblxuaW50ZXJmYWNlIFByb3BzIGV4dGVuZHMgQ29tcG9uZW50UHJvcHM8dHlwZW9mIElucHV0VjI+IHtcbiAgbG9hZGluZz86IGJvb2xlYW47XG4gIG9uQ2xvc2U/OiAoKSA9PiB2b2lkO1xuICBvblNhdmU6ICgpID0+IHZvaWQ7XG59XG5cbmNvbnN0IFN0eWxlZFNwaW5uZXIgPSBzdHlsZWQoU3Bpbm5lcilgXG4gIG1hcmdpbjogJHtzcGFjaW5nLnNtYWxsfTtcbmA7XG5cbi8vIFNvdXJjZTogaHR0cHM6Ly9rb3ZhcnQuZ2l0aHViLmlvL2Rhc2hlZC1ib3JkZXItZ2VuZXJhdG9yL1xuY29uc3QgYm9yZGVyU3R5bGUgPSAoZXJyb3I/OiBib29sZWFuKSA9PlxuICBgdXJsKFwiZGF0YTppbWFnZS9zdmcreG1sLCUzY3N2ZyB3aWR0aD0nMTAwJTI1JyBoZWlnaHQ9JzEwMCUyNScgeG1sbnM9J2h0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnJyUzZSUzY3JlY3Qgd2lkdGg9JzEwMCUyNScgaGVpZ2h0PScxMDAlMjUnIGZpbGw9J25vbmUnIHN0cm9rZT0nJHtlbmNvZGVVUklDb21wb25lbnQoXG4gICAgZXJyb3IgPyBjb2xvcnMuc3VwcG9ydC5yZWQgOiBjb2xvcnMuYnJhbmQudGVydGlhcnksXG4gICl9JyBzdHJva2Utd2lkdGg9JzInIHN0cm9rZS1kYXNoYXJyYXk9JzglMmM4JyBzdHJva2UtZGFzaG9mZnNldD0nNCcgc3Ryb2tlLWxpbmVjYXA9J3NxdWFyZScvJTNlJTNjL3N2ZyUzZVwiKWA7XG5cbmludGVyZmFjZSBTdHlsZWRJbnB1dFByb3BzIHtcbiAgZXJyb3I/OiBzdHJpbmc7XG59XG5cbmNvbnN0IFN0eWxlZElucHV0ID0gc3R5bGVkKElucHV0VjIpPFN0eWxlZElucHV0UHJvcHM+YFxuICBiYWNrZ3JvdW5kLWNvbG9yOiB3aGl0ZTtcbiAgYmFja2dyb3VuZC1pbWFnZTogJHsoeyBlcnJvciB9KSA9PiBib3JkZXJTdHlsZSghIWVycm9yKX07XG4gIGJvcmRlcjogbm9uZTtcbiAgYm9yZGVyLXJhZGl1czogMDtcbiAgZmxleC13cmFwOiBub3dyYXA7XG4gIGlucHV0IHtcbiAgICBsaW5lLWhlaWdodDogMS43NWVtO1xuICAgIGNvbG9yOiAke2NvbG9ycy5icmFuZC5wcmltYXJ5fTtcbiAgICBjYXJldC1jb2xvcjogJHtjb2xvcnMuYnJhbmQudGVydGlhcnl9O1xuICAgIDo6c2VsZWN0aW9uIHtcbiAgICAgIGJhY2tncm91bmQ6ICR7Y29sb3JzLmJyYW5kLmxpZ2h0ZXJ9O1xuICAgIH1cbiAgICA6OnBsYWNlaG9sZGVyIHtcbiAgICAgIGNvbG9yOiAke2NvbG9ycy5icmFuZC50ZXJ0aWFyeX07XG4gICAgfVxuICB9XG5gO1xuXG5jb25zdCBSb3cgPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBnYXA6ICR7c3BhY2luZy54eHNtYWxsfTtcbiAgcGFkZGluZy1yaWdodDogJHtzcGFjaW5nLnhzbWFsbH07XG5gO1xuXG5jb25zdCBGb2xkZXJJbnB1dCA9IGZvcndhcmRSZWY8SFRNTElucHV0RWxlbWVudCwgUHJvcHM+KCh7IGxvYWRpbmcsIGVycm9yLCBvbkNsb3NlLCBvblNhdmUsIC4uLnJlc3QgfSwgcmVmKSA9PiB7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcbiAgY29uc3QgaW5wdXRSZWYgPSB1c2VGb3J3YXJkZWRSZWYocmVmKTtcblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGlmIChpc01vYmlsZSkge1xuICAgICAgaW5wdXRSZWYuY3VycmVudD8uc2Nyb2xsSW50b1ZpZXcoeyBiZWhhdmlvcjogJ3Ntb290aCcgfSk7XG4gICAgfVxuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSByZWFjdC1ob29rcy9leGhhdXN0aXZlLWRlcHNcbiAgfSwgW10pO1xuXG4gIHJldHVybiAoXG4gICAgPFN0eWxlZElucHV0XG4gICAgICBhdXRvQ29tcGxldGU9XCJvZmZcIlxuICAgICAgd2hpdGVcbiAgICAgIGVycm9yPXtlcnJvcn1cbiAgICAgIGFyaWEtZGlzYWJsZWQ9e2xvYWRpbmcgPyB0cnVlIDogdW5kZWZpbmVkfVxuICAgICAgYXJpYS1kZXNjcmliZWRieT17J2ZvbGRlci1pbnB1dC1zcGlubmVyJ31cbiAgICAgIHJlZj17cmVmfVxuICAgICAgYWZ0ZXI9e1xuICAgICAgICA8Um93PlxuICAgICAgICAgIHshbG9hZGluZyAmJiAoXG4gICAgICAgICAgICA8PlxuICAgICAgICAgICAgICB7IWVycm9yICYmIChcbiAgICAgICAgICAgICAgICA8SWNvbkJ1dHRvblYyXG4gICAgICAgICAgICAgICAgICB2YXJpYW50PXsnZ2hvc3QnfVxuICAgICAgICAgICAgICAgICAgY29sb3JUaGVtZT1cImxpZ2h0XCJcbiAgICAgICAgICAgICAgICAgIHRhYkluZGV4PXswfVxuICAgICAgICAgICAgICAgICAgYXJpYS1sYWJlbD17dCgnc2F2ZScpfVxuICAgICAgICAgICAgICAgICAgdGl0bGU9e3QoJ3NhdmUnKX1cbiAgICAgICAgICAgICAgICAgIHNpemU9XCJzbWFsbFwiXG4gICAgICAgICAgICAgICAgICBvbkNsaWNrPXtvblNhdmV9XG4gICAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgICAgPERvbmUgLz5cbiAgICAgICAgICAgICAgICA8L0ljb25CdXR0b25WMj5cbiAgICAgICAgICAgICAgKX1cbiAgICAgICAgICAgICAgPEljb25CdXR0b25WMiBhcmlhLWxhYmVsPXt0KCdjbG9zZScpfSB0aXRsZT17dCgnY2xvc2UnKX0gc2l6ZT1cInNtYWxsXCIgdmFyaWFudD1cImdob3N0XCIgb25DbGljaz17b25DbG9zZX0+XG4gICAgICAgICAgICAgICAgPENyb3NzIC8+XG4gICAgICAgICAgICAgIDwvSWNvbkJ1dHRvblYyPlxuICAgICAgICAgICAgPC8+XG4gICAgICAgICAgKX1cbiAgICAgICAgICA8ZGl2IGFyaWEtbGl2ZT1cImFzc2VydGl2ZVwiPlxuICAgICAgICAgICAge2xvYWRpbmcgJiYgPFN0eWxlZFNwaW5uZXIgc2l6ZT1cIm5vcm1hbFwiIGlkPVwiZm9sZGVyLXNwaW5uZXJcIiBhcmlhLWxhYmVsPXt0KCdsb2FkaW5nJyl9IC8+fVxuICAgICAgICAgIDwvZGl2PlxuICAgICAgICA8L1Jvdz5cbiAgICAgIH1cbiAgICAgIHsuLi5yZXN0fVxuICAgIC8+XG4gICk7XG59KTtcblxuZXhwb3J0IGRlZmF1bHQgRm9sZGVySW5wdXQ7XG4iXX0= */"));
53
58
  var FolderInput = /*#__PURE__*/(0, _react.forwardRef)(function (_ref2, ref) {
54
59
  var loading = _ref2.loading,
55
60
  error = _ref2.error,
@@ -96,9 +101,8 @@ var FolderInput = /*#__PURE__*/(0, _react.forwardRef)(function (_ref2, ref) {
96
101
  })]
97
102
  }), (0, _jsxRuntime.jsx)("div", {
98
103
  "aria-live": "assertive",
99
- children: loading && (0, _jsxRuntime.jsx)(_icons.Spinner, {
104
+ children: loading && (0, _jsxRuntime.jsx)(StyledSpinner, {
100
105
  size: "normal",
101
- margin: _core.spacing.small,
102
106
  id: "folder-spinner",
103
107
  "aria-label": t('loading')
104
108
  })
@@ -33,7 +33,7 @@ var OpenButton = /*#__PURE__*/(0, _base.default)("span", {
33
33
  })("display:flex;align-items:center;justify-content:center;align-self:stretch;color:", _core.colors.brand.tertiary, ";", _core.misc.transition.default, ";cursor:pointer;&:hover{color:", _core.colors.brand.primary, ";}svg{width:24px;height:24px;transform:rotate(", function (_ref) {
34
34
  var isOpen = _ref.isOpen;
35
35
  return isOpen ? '0' : '-90';
36
- }, "deg);}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FolderItem.tsx"],"names":[],"mappings":"AAsBmD","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 React, { KeyboardEvent, useEffect, 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, spacingUnit, 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<{ isOpen: boolean }>`\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(${({ isOpen }) => (isOpen ? '0' : '-90')}deg);\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 shouldForwardProp = (name: string) => !['selected', 'level', 'focused', 'isCreatingFolder'].includes(name);\n\ninterface FolderNameProps {\n  selected?: boolean;\n  level: number;\n  isCreatingFolder?: boolean;\n  focused?: boolean;\n}\n\nconst FolderName = styled(Button, { shouldForwardProp })<FolderNameProps>`\n  display: grid;\n  grid-template-columns: auto 1fr auto;\n  padding-left: ${({ level }) => 0.75 * spacingUnit * level}px;\n  gap: ${spacing.xxsmall};\n  border: none;\n  outline: none;\n  background: ${({ selected, isCreatingFolder, focused }) =>\n    isCreatingFolder ? 'none' : selected ? colors.brand.lighter : focused && colors.brand.lightest};\n  color: ${({ isCreatingFolder, focused }) =>\n    isCreatingFolder && focused ? colors.brand.primary : 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: ${({ selected }) => (selected ? colors.brand.light : colors.brand.lightest)};\n    color: ${colors.text.primary};\n  }\n`;\n\nconst StyledDone = styled(Done)`\n  color: ${colors.support.green};\n`;\n\nconst FolderNameLink = styled(SafeLink, { shouldForwardProp })<FolderNameProps>`\n  display: grid;\n  align-items: center;\n  grid-template-columns: ${spacing.medium} 1fr auto;\n  padding: ${spacing.small} ${spacing.xxsmall};\n  margin-left: ${({ level }) => 0.75 * spacingUnit * level}px;\n  gap: ${spacing.xxsmall};\n  cursor: pointer;\n\n  border: none;\n  box-shadow: none;\n  color: ${({ selected }) => (selected ? colors.brand.primary : colors.text.primary)};\n  font-weight: ${({ selected }) => selected && fonts.weight.semibold};\n  font-size: ${fonts.sizes('16px')};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\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 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?.scrollIntoView({\n          behavior: 'smooth',\n          block: 'nearest',\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      level={level}\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      selected={selected}\n      onFocus={() => setFocusedFolder(folder)}\n      onClick={handleClickFolder}\n    >\n      {!hideArrow && (\n        <OpenButton\n          aria-hidden\n          tabIndex={-1}\n          isOpen={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      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      level={level}\n      selected={selected}\n      disabled={loading}\n      onFocus={(e) => {\n        setFocusedFolder(focusedFolder || folder);\n      }}\n      onClick={handleClickFolder}\n      isCreatingFolder={isCreatingFolder}\n    >\n      <IconWrapper>\n        {!hideArrow && (\n          <OpenButton\n            aria-hidden\n            tabIndex={-1}\n            isOpen={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
+ }, "deg);}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FolderItem.tsx"],"names":[],"mappings":"AAsBmD","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 React, { KeyboardEvent, useEffect, 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, spacingUnit, 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<{ isOpen: boolean }>`\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(${({ isOpen }) => (isOpen ? '0' : '-90')}deg);\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 shouldForwardProp = (name: string) => !['selected', 'level', 'focused', 'isCreatingFolder'].includes(name);\n\ninterface FolderNameProps {\n  selected?: boolean;\n  level: number;\n  isCreatingFolder?: boolean;\n  focused?: boolean;\n}\n\nconst FolderName = styled(Button, { shouldForwardProp })<FolderNameProps>`\n  display: grid;\n  grid-template-columns: auto 1fr auto;\n  padding-left: ${({ level }) => 0.75 * spacingUnit * level}px;\n  gap: ${spacing.xxsmall};\n  border: none;\n  outline: none;\n  background: ${({ selected, isCreatingFolder, focused }) =>\n    isCreatingFolder ? 'none' : selected ? colors.brand.lighter : focused && colors.brand.lightest};\n  color: ${({ isCreatingFolder, focused }) =>\n    isCreatingFolder && focused ? colors.brand.primary : 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: ${({ selected }) => (selected ? colors.brand.light : colors.brand.lightest)};\n    color: ${colors.text.primary};\n  }\n`;\n\nconst StyledDone = styled(Done)`\n  color: ${colors.support.green};\n`;\n\nconst FolderNameLink = styled(SafeLink, { shouldForwardProp })<FolderNameProps>`\n  display: grid;\n  align-items: center;\n  grid-template-columns: ${spacing.medium} 1fr auto;\n  padding: ${spacing.small} ${spacing.xxsmall};\n  margin-left: ${({ level }) => 0.75 * spacingUnit * level}px;\n  gap: ${spacing.xxsmall};\n  cursor: pointer;\n\n  border: none;\n  box-shadow: none;\n  color: ${({ selected }) => (selected ? colors.brand.primary : colors.text.primary)};\n  font-weight: ${({ selected }) => selected && fonts.weight.semibold};\n  font-size: ${fonts.sizes('16px')};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\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 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      level={level}\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      selected={selected}\n      onFocus={() => setFocusedFolder(folder)}\n      onClick={handleClickFolder}\n    >\n      {!hideArrow && (\n        <OpenButton\n          aria-hidden\n          tabIndex={-1}\n          isOpen={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      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      level={level}\n      selected={selected}\n      disabled={loading}\n      onFocus={(e) => {\n        setFocusedFolder(focusedFolder || folder);\n      }}\n      onClick={handleClickFolder}\n      isCreatingFolder={isCreatingFolder}\n    >\n      <IconWrapper>\n        {!hideArrow && (\n          <OpenButton\n            aria-hidden\n            tabIndex={-1}\n            isOpen={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"]} */"));
37
37
  var StyledName = /*#__PURE__*/(0, _base.default)("span", {
38
38
  target: "e11ok6h85",
39
39
  label: "StyledName"
@@ -43,7 +43,7 @@ var StyledName = /*#__PURE__*/(0, _base.default)("span", {
43
43
  } : {
44
44
  name: "woa3z4",
45
45
  styles: "white-space:nowrap;overflow:hidden;text-overflow:ellipsis;grid-column-start:2;text-align:left",
46
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FolderItem.tsx"],"names":[],"mappings":"AAwC8B","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 React, { KeyboardEvent, useEffect, 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, spacingUnit, 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<{ isOpen: boolean }>`\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(${({ isOpen }) => (isOpen ? '0' : '-90')}deg);\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 shouldForwardProp = (name: string) => !['selected', 'level', 'focused', 'isCreatingFolder'].includes(name);\n\ninterface FolderNameProps {\n  selected?: boolean;\n  level: number;\n  isCreatingFolder?: boolean;\n  focused?: boolean;\n}\n\nconst FolderName = styled(Button, { shouldForwardProp })<FolderNameProps>`\n  display: grid;\n  grid-template-columns: auto 1fr auto;\n  padding-left: ${({ level }) => 0.75 * spacingUnit * level}px;\n  gap: ${spacing.xxsmall};\n  border: none;\n  outline: none;\n  background: ${({ selected, isCreatingFolder, focused }) =>\n    isCreatingFolder ? 'none' : selected ? colors.brand.lighter : focused && colors.brand.lightest};\n  color: ${({ isCreatingFolder, focused }) =>\n    isCreatingFolder && focused ? colors.brand.primary : 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: ${({ selected }) => (selected ? colors.brand.light : colors.brand.lightest)};\n    color: ${colors.text.primary};\n  }\n`;\n\nconst StyledDone = styled(Done)`\n  color: ${colors.support.green};\n`;\n\nconst FolderNameLink = styled(SafeLink, { shouldForwardProp })<FolderNameProps>`\n  display: grid;\n  align-items: center;\n  grid-template-columns: ${spacing.medium} 1fr auto;\n  padding: ${spacing.small} ${spacing.xxsmall};\n  margin-left: ${({ level }) => 0.75 * spacingUnit * level}px;\n  gap: ${spacing.xxsmall};\n  cursor: pointer;\n\n  border: none;\n  box-shadow: none;\n  color: ${({ selected }) => (selected ? colors.brand.primary : colors.text.primary)};\n  font-weight: ${({ selected }) => selected && fonts.weight.semibold};\n  font-size: ${fonts.sizes('16px')};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\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 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?.scrollIntoView({\n          behavior: 'smooth',\n          block: 'nearest',\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      level={level}\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      selected={selected}\n      onFocus={() => setFocusedFolder(folder)}\n      onClick={handleClickFolder}\n    >\n      {!hideArrow && (\n        <OpenButton\n          aria-hidden\n          tabIndex={-1}\n          isOpen={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      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      level={level}\n      selected={selected}\n      disabled={loading}\n      onFocus={(e) => {\n        setFocusedFolder(focusedFolder || folder);\n      }}\n      onClick={handleClickFolder}\n      isCreatingFolder={isCreatingFolder}\n    >\n      <IconWrapper>\n        {!hideArrow && (\n          <OpenButton\n            aria-hidden\n            tabIndex={-1}\n            isOpen={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"]} */",
46
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FolderItem.tsx"],"names":[],"mappings":"AAwC8B","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 React, { KeyboardEvent, useEffect, 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, spacingUnit, 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<{ isOpen: boolean }>`\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(${({ isOpen }) => (isOpen ? '0' : '-90')}deg);\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 shouldForwardProp = (name: string) => !['selected', 'level', 'focused', 'isCreatingFolder'].includes(name);\n\ninterface FolderNameProps {\n  selected?: boolean;\n  level: number;\n  isCreatingFolder?: boolean;\n  focused?: boolean;\n}\n\nconst FolderName = styled(Button, { shouldForwardProp })<FolderNameProps>`\n  display: grid;\n  grid-template-columns: auto 1fr auto;\n  padding-left: ${({ level }) => 0.75 * spacingUnit * level}px;\n  gap: ${spacing.xxsmall};\n  border: none;\n  outline: none;\n  background: ${({ selected, isCreatingFolder, focused }) =>\n    isCreatingFolder ? 'none' : selected ? colors.brand.lighter : focused && colors.brand.lightest};\n  color: ${({ isCreatingFolder, focused }) =>\n    isCreatingFolder && focused ? colors.brand.primary : 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: ${({ selected }) => (selected ? colors.brand.light : colors.brand.lightest)};\n    color: ${colors.text.primary};\n  }\n`;\n\nconst StyledDone = styled(Done)`\n  color: ${colors.support.green};\n`;\n\nconst FolderNameLink = styled(SafeLink, { shouldForwardProp })<FolderNameProps>`\n  display: grid;\n  align-items: center;\n  grid-template-columns: ${spacing.medium} 1fr auto;\n  padding: ${spacing.small} ${spacing.xxsmall};\n  margin-left: ${({ level }) => 0.75 * spacingUnit * level}px;\n  gap: ${spacing.xxsmall};\n  cursor: pointer;\n\n  border: none;\n  box-shadow: none;\n  color: ${({ selected }) => (selected ? colors.brand.primary : colors.text.primary)};\n  font-weight: ${({ selected }) => selected && fonts.weight.semibold};\n  font-size: ${fonts.sizes('16px')};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\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 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      level={level}\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      selected={selected}\n      onFocus={() => setFocusedFolder(folder)}\n      onClick={handleClickFolder}\n    >\n      {!hideArrow && (\n        <OpenButton\n          aria-hidden\n          tabIndex={-1}\n          isOpen={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      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      level={level}\n      selected={selected}\n      disabled={loading}\n      onFocus={(e) => {\n        setFocusedFolder(focusedFolder || folder);\n      }}\n      onClick={handleClickFolder}\n      isCreatingFolder={isCreatingFolder}\n    >\n      <IconWrapper>\n        {!hideArrow && (\n          <OpenButton\n            aria-hidden\n            tabIndex={-1}\n            isOpen={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"]} */",
47
47
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
48
48
  });
49
49
  var IconWrapper = /*#__PURE__*/(0, _base.default)("div", {
@@ -55,7 +55,7 @@ var IconWrapper = /*#__PURE__*/(0, _base.default)("div", {
55
55
  } : {
56
56
  name: "zjik7",
57
57
  styles: "display:flex",
58
- 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 React, { KeyboardEvent, useEffect, 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, spacingUnit, 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<{ isOpen: boolean }>`\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(${({ isOpen }) => (isOpen ? '0' : '-90')}deg);\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 shouldForwardProp = (name: string) => !['selected', 'level', 'focused', 'isCreatingFolder'].includes(name);\n\ninterface FolderNameProps {\n  selected?: boolean;\n  level: number;\n  isCreatingFolder?: boolean;\n  focused?: boolean;\n}\n\nconst FolderName = styled(Button, { shouldForwardProp })<FolderNameProps>`\n  display: grid;\n  grid-template-columns: auto 1fr auto;\n  padding-left: ${({ level }) => 0.75 * spacingUnit * level}px;\n  gap: ${spacing.xxsmall};\n  border: none;\n  outline: none;\n  background: ${({ selected, isCreatingFolder, focused }) =>\n    isCreatingFolder ? 'none' : selected ? colors.brand.lighter : focused && colors.brand.lightest};\n  color: ${({ isCreatingFolder, focused }) =>\n    isCreatingFolder && focused ? colors.brand.primary : 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: ${({ selected }) => (selected ? colors.brand.light : colors.brand.lightest)};\n    color: ${colors.text.primary};\n  }\n`;\n\nconst StyledDone = styled(Done)`\n  color: ${colors.support.green};\n`;\n\nconst FolderNameLink = styled(SafeLink, { shouldForwardProp })<FolderNameProps>`\n  display: grid;\n  align-items: center;\n  grid-template-columns: ${spacing.medium} 1fr auto;\n  padding: ${spacing.small} ${spacing.xxsmall};\n  margin-left: ${({ level }) => 0.75 * spacingUnit * level}px;\n  gap: ${spacing.xxsmall};\n  cursor: pointer;\n\n  border: none;\n  box-shadow: none;\n  color: ${({ selected }) => (selected ? colors.brand.primary : colors.text.primary)};\n  font-weight: ${({ selected }) => selected && fonts.weight.semibold};\n  font-size: ${fonts.sizes('16px')};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\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 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?.scrollIntoView({\n          behavior: 'smooth',\n          block: 'nearest',\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      level={level}\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      selected={selected}\n      onFocus={() => setFocusedFolder(folder)}\n      onClick={handleClickFolder}\n    >\n      {!hideArrow && (\n        <OpenButton\n          aria-hidden\n          tabIndex={-1}\n          isOpen={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      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      level={level}\n      selected={selected}\n      disabled={loading}\n      onFocus={(e) => {\n        setFocusedFolder(focusedFolder || folder);\n      }}\n      onClick={handleClickFolder}\n      isCreatingFolder={isCreatingFolder}\n    >\n      <IconWrapper>\n        {!hideArrow && (\n          <OpenButton\n            aria-hidden\n            tabIndex={-1}\n            isOpen={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"]} */",
58
+ 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 React, { KeyboardEvent, useEffect, 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, spacingUnit, 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<{ isOpen: boolean }>`\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(${({ isOpen }) => (isOpen ? '0' : '-90')}deg);\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 shouldForwardProp = (name: string) => !['selected', 'level', 'focused', 'isCreatingFolder'].includes(name);\n\ninterface FolderNameProps {\n  selected?: boolean;\n  level: number;\n  isCreatingFolder?: boolean;\n  focused?: boolean;\n}\n\nconst FolderName = styled(Button, { shouldForwardProp })<FolderNameProps>`\n  display: grid;\n  grid-template-columns: auto 1fr auto;\n  padding-left: ${({ level }) => 0.75 * spacingUnit * level}px;\n  gap: ${spacing.xxsmall};\n  border: none;\n  outline: none;\n  background: ${({ selected, isCreatingFolder, focused }) =>\n    isCreatingFolder ? 'none' : selected ? colors.brand.lighter : focused && colors.brand.lightest};\n  color: ${({ isCreatingFolder, focused }) =>\n    isCreatingFolder && focused ? colors.brand.primary : 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: ${({ selected }) => (selected ? colors.brand.light : colors.brand.lightest)};\n    color: ${colors.text.primary};\n  }\n`;\n\nconst StyledDone = styled(Done)`\n  color: ${colors.support.green};\n`;\n\nconst FolderNameLink = styled(SafeLink, { shouldForwardProp })<FolderNameProps>`\n  display: grid;\n  align-items: center;\n  grid-template-columns: ${spacing.medium} 1fr auto;\n  padding: ${spacing.small} ${spacing.xxsmall};\n  margin-left: ${({ level }) => 0.75 * spacingUnit * level}px;\n  gap: ${spacing.xxsmall};\n  cursor: pointer;\n\n  border: none;\n  box-shadow: none;\n  color: ${({ selected }) => (selected ? colors.brand.primary : colors.text.primary)};\n  font-weight: ${({ selected }) => selected && fonts.weight.semibold};\n  font-size: ${fonts.sizes('16px')};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\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 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      level={level}\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      selected={selected}\n      onFocus={() => setFocusedFolder(folder)}\n      onClick={handleClickFolder}\n    >\n      {!hideArrow && (\n        <OpenButton\n          aria-hidden\n          tabIndex={-1}\n          isOpen={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      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      level={level}\n      selected={selected}\n      disabled={loading}\n      onFocus={(e) => {\n        setFocusedFolder(focusedFolder || folder);\n      }}\n      onClick={handleClickFolder}\n      isCreatingFolder={isCreatingFolder}\n    >\n      <IconWrapper>\n        {!hideArrow && (\n          <OpenButton\n            aria-hidden\n            tabIndex={-1}\n            isOpen={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"]} */",
59
59
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
60
60
  });
61
61
  var FolderIconWrapper = /*#__PURE__*/(0, _base.default)("div", {
@@ -67,7 +67,7 @@ var FolderIconWrapper = /*#__PURE__*/(0, _base.default)("div", {
67
67
  } : {
68
68
  name: "h1kfx5",
69
69
  styles: "svg{height:24px;width:24px;}",
70
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FolderItem.tsx"],"names":[],"mappings":"AAoDoC","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 React, { KeyboardEvent, useEffect, 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, spacingUnit, 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<{ isOpen: boolean }>`\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(${({ isOpen }) => (isOpen ? '0' : '-90')}deg);\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 shouldForwardProp = (name: string) => !['selected', 'level', 'focused', 'isCreatingFolder'].includes(name);\n\ninterface FolderNameProps {\n  selected?: boolean;\n  level: number;\n  isCreatingFolder?: boolean;\n  focused?: boolean;\n}\n\nconst FolderName = styled(Button, { shouldForwardProp })<FolderNameProps>`\n  display: grid;\n  grid-template-columns: auto 1fr auto;\n  padding-left: ${({ level }) => 0.75 * spacingUnit * level}px;\n  gap: ${spacing.xxsmall};\n  border: none;\n  outline: none;\n  background: ${({ selected, isCreatingFolder, focused }) =>\n    isCreatingFolder ? 'none' : selected ? colors.brand.lighter : focused && colors.brand.lightest};\n  color: ${({ isCreatingFolder, focused }) =>\n    isCreatingFolder && focused ? colors.brand.primary : 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: ${({ selected }) => (selected ? colors.brand.light : colors.brand.lightest)};\n    color: ${colors.text.primary};\n  }\n`;\n\nconst StyledDone = styled(Done)`\n  color: ${colors.support.green};\n`;\n\nconst FolderNameLink = styled(SafeLink, { shouldForwardProp })<FolderNameProps>`\n  display: grid;\n  align-items: center;\n  grid-template-columns: ${spacing.medium} 1fr auto;\n  padding: ${spacing.small} ${spacing.xxsmall};\n  margin-left: ${({ level }) => 0.75 * spacingUnit * level}px;\n  gap: ${spacing.xxsmall};\n  cursor: pointer;\n\n  border: none;\n  box-shadow: none;\n  color: ${({ selected }) => (selected ? colors.brand.primary : colors.text.primary)};\n  font-weight: ${({ selected }) => selected && fonts.weight.semibold};\n  font-size: ${fonts.sizes('16px')};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\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 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?.scrollIntoView({\n          behavior: 'smooth',\n          block: 'nearest',\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      level={level}\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      selected={selected}\n      onFocus={() => setFocusedFolder(folder)}\n      onClick={handleClickFolder}\n    >\n      {!hideArrow && (\n        <OpenButton\n          aria-hidden\n          tabIndex={-1}\n          isOpen={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      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      level={level}\n      selected={selected}\n      disabled={loading}\n      onFocus={(e) => {\n        setFocusedFolder(focusedFolder || folder);\n      }}\n      onClick={handleClickFolder}\n      isCreatingFolder={isCreatingFolder}\n    >\n      <IconWrapper>\n        {!hideArrow && (\n          <OpenButton\n            aria-hidden\n            tabIndex={-1}\n            isOpen={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
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FolderItem.tsx"],"names":[],"mappings":"AAoDoC","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 React, { KeyboardEvent, useEffect, 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, spacingUnit, 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<{ isOpen: boolean }>`\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(${({ isOpen }) => (isOpen ? '0' : '-90')}deg);\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 shouldForwardProp = (name: string) => !['selected', 'level', 'focused', 'isCreatingFolder'].includes(name);\n\ninterface FolderNameProps {\n  selected?: boolean;\n  level: number;\n  isCreatingFolder?: boolean;\n  focused?: boolean;\n}\n\nconst FolderName = styled(Button, { shouldForwardProp })<FolderNameProps>`\n  display: grid;\n  grid-template-columns: auto 1fr auto;\n  padding-left: ${({ level }) => 0.75 * spacingUnit * level}px;\n  gap: ${spacing.xxsmall};\n  border: none;\n  outline: none;\n  background: ${({ selected, isCreatingFolder, focused }) =>\n    isCreatingFolder ? 'none' : selected ? colors.brand.lighter : focused && colors.brand.lightest};\n  color: ${({ isCreatingFolder, focused }) =>\n    isCreatingFolder && focused ? colors.brand.primary : 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: ${({ selected }) => (selected ? colors.brand.light : colors.brand.lightest)};\n    color: ${colors.text.primary};\n  }\n`;\n\nconst StyledDone = styled(Done)`\n  color: ${colors.support.green};\n`;\n\nconst FolderNameLink = styled(SafeLink, { shouldForwardProp })<FolderNameProps>`\n  display: grid;\n  align-items: center;\n  grid-template-columns: ${spacing.medium} 1fr auto;\n  padding: ${spacing.small} ${spacing.xxsmall};\n  margin-left: ${({ level }) => 0.75 * spacingUnit * level}px;\n  gap: ${spacing.xxsmall};\n  cursor: pointer;\n\n  border: none;\n  box-shadow: none;\n  color: ${({ selected }) => (selected ? colors.brand.primary : colors.text.primary)};\n  font-weight: ${({ selected }) => selected && fonts.weight.semibold};\n  font-size: ${fonts.sizes('16px')};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\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 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      level={level}\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      selected={selected}\n      onFocus={() => setFocusedFolder(folder)}\n      onClick={handleClickFolder}\n    >\n      {!hideArrow && (\n        <OpenButton\n          aria-hidden\n          tabIndex={-1}\n          isOpen={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      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      level={level}\n      selected={selected}\n      disabled={loading}\n      onFocus={(e) => {\n        setFocusedFolder(focusedFolder || folder);\n      }}\n      onClick={handleClickFolder}\n      isCreatingFolder={isCreatingFolder}\n    >\n      <IconWrapper>\n        {!hideArrow && (\n          <OpenButton\n            aria-hidden\n            tabIndex={-1}\n            isOpen={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"]} */",
71
71
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
72
72
  });
73
73
  var shouldForwardProp = function shouldForwardProp(name) {
@@ -92,11 +92,11 @@ var FolderName = /*#__PURE__*/(0, _base.default)(_button.ButtonV2, {
92
92
  }, ";transition:", _core.animations.durations.superFast, ";word-break:break-word;&:hover{box-shadow:none;outline:none;background:", function (_ref5) {
93
93
  var selected = _ref5.selected;
94
94
  return selected ? _core.colors.brand.light : _core.colors.brand.lightest;
95
- }, ";color:", _core.colors.text.primary, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FolderItem.tsx"],"names":[],"mappings":"AAoEyE","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 React, { KeyboardEvent, useEffect, 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, spacingUnit, 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<{ isOpen: boolean }>`\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(${({ isOpen }) => (isOpen ? '0' : '-90')}deg);\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 shouldForwardProp = (name: string) => !['selected', 'level', 'focused', 'isCreatingFolder'].includes(name);\n\ninterface FolderNameProps {\n  selected?: boolean;\n  level: number;\n  isCreatingFolder?: boolean;\n  focused?: boolean;\n}\n\nconst FolderName = styled(Button, { shouldForwardProp })<FolderNameProps>`\n  display: grid;\n  grid-template-columns: auto 1fr auto;\n  padding-left: ${({ level }) => 0.75 * spacingUnit * level}px;\n  gap: ${spacing.xxsmall};\n  border: none;\n  outline: none;\n  background: ${({ selected, isCreatingFolder, focused }) =>\n    isCreatingFolder ? 'none' : selected ? colors.brand.lighter : focused && colors.brand.lightest};\n  color: ${({ isCreatingFolder, focused }) =>\n    isCreatingFolder && focused ? colors.brand.primary : 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: ${({ selected }) => (selected ? colors.brand.light : colors.brand.lightest)};\n    color: ${colors.text.primary};\n  }\n`;\n\nconst StyledDone = styled(Done)`\n  color: ${colors.support.green};\n`;\n\nconst FolderNameLink = styled(SafeLink, { shouldForwardProp })<FolderNameProps>`\n  display: grid;\n  align-items: center;\n  grid-template-columns: ${spacing.medium} 1fr auto;\n  padding: ${spacing.small} ${spacing.xxsmall};\n  margin-left: ${({ level }) => 0.75 * spacingUnit * level}px;\n  gap: ${spacing.xxsmall};\n  cursor: pointer;\n\n  border: none;\n  box-shadow: none;\n  color: ${({ selected }) => (selected ? colors.brand.primary : colors.text.primary)};\n  font-weight: ${({ selected }) => selected && fonts.weight.semibold};\n  font-size: ${fonts.sizes('16px')};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\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 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?.scrollIntoView({\n          behavior: 'smooth',\n          block: 'nearest',\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      level={level}\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      selected={selected}\n      onFocus={() => setFocusedFolder(folder)}\n      onClick={handleClickFolder}\n    >\n      {!hideArrow && (\n        <OpenButton\n          aria-hidden\n          tabIndex={-1}\n          isOpen={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      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      level={level}\n      selected={selected}\n      disabled={loading}\n      onFocus={(e) => {\n        setFocusedFolder(focusedFolder || folder);\n      }}\n      onClick={handleClickFolder}\n      isCreatingFolder={isCreatingFolder}\n    >\n      <IconWrapper>\n        {!hideArrow && (\n          <OpenButton\n            aria-hidden\n            tabIndex={-1}\n            isOpen={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"]} */"));
95
+ }, ";color:", _core.colors.text.primary, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FolderItem.tsx"],"names":[],"mappings":"AAoEyE","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 React, { KeyboardEvent, useEffect, 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, spacingUnit, 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<{ isOpen: boolean }>`\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(${({ isOpen }) => (isOpen ? '0' : '-90')}deg);\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 shouldForwardProp = (name: string) => !['selected', 'level', 'focused', 'isCreatingFolder'].includes(name);\n\ninterface FolderNameProps {\n  selected?: boolean;\n  level: number;\n  isCreatingFolder?: boolean;\n  focused?: boolean;\n}\n\nconst FolderName = styled(Button, { shouldForwardProp })<FolderNameProps>`\n  display: grid;\n  grid-template-columns: auto 1fr auto;\n  padding-left: ${({ level }) => 0.75 * spacingUnit * level}px;\n  gap: ${spacing.xxsmall};\n  border: none;\n  outline: none;\n  background: ${({ selected, isCreatingFolder, focused }) =>\n    isCreatingFolder ? 'none' : selected ? colors.brand.lighter : focused && colors.brand.lightest};\n  color: ${({ isCreatingFolder, focused }) =>\n    isCreatingFolder && focused ? colors.brand.primary : 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: ${({ selected }) => (selected ? colors.brand.light : colors.brand.lightest)};\n    color: ${colors.text.primary};\n  }\n`;\n\nconst StyledDone = styled(Done)`\n  color: ${colors.support.green};\n`;\n\nconst FolderNameLink = styled(SafeLink, { shouldForwardProp })<FolderNameProps>`\n  display: grid;\n  align-items: center;\n  grid-template-columns: ${spacing.medium} 1fr auto;\n  padding: ${spacing.small} ${spacing.xxsmall};\n  margin-left: ${({ level }) => 0.75 * spacingUnit * level}px;\n  gap: ${spacing.xxsmall};\n  cursor: pointer;\n\n  border: none;\n  box-shadow: none;\n  color: ${({ selected }) => (selected ? colors.brand.primary : colors.text.primary)};\n  font-weight: ${({ selected }) => selected && fonts.weight.semibold};\n  font-size: ${fonts.sizes('16px')};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\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 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      level={level}\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      selected={selected}\n      onFocus={() => setFocusedFolder(folder)}\n      onClick={handleClickFolder}\n    >\n      {!hideArrow && (\n        <OpenButton\n          aria-hidden\n          tabIndex={-1}\n          isOpen={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      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      level={level}\n      selected={selected}\n      disabled={loading}\n      onFocus={(e) => {\n        setFocusedFolder(focusedFolder || folder);\n      }}\n      onClick={handleClickFolder}\n      isCreatingFolder={isCreatingFolder}\n    >\n      <IconWrapper>\n        {!hideArrow && (\n          <OpenButton\n            aria-hidden\n            tabIndex={-1}\n            isOpen={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"]} */"));
96
96
  var StyledDone = /*#__PURE__*/(0, _base.default)(_editor.Done, {
97
97
  target: "e11ok6h81",
98
98
  label: "StyledDone"
99
- })("color:", _core.colors.support.green, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FolderItem.tsx"],"names":[],"mappings":"AA0F+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 React, { KeyboardEvent, useEffect, 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, spacingUnit, 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<{ isOpen: boolean }>`\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(${({ isOpen }) => (isOpen ? '0' : '-90')}deg);\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 shouldForwardProp = (name: string) => !['selected', 'level', 'focused', 'isCreatingFolder'].includes(name);\n\ninterface FolderNameProps {\n  selected?: boolean;\n  level: number;\n  isCreatingFolder?: boolean;\n  focused?: boolean;\n}\n\nconst FolderName = styled(Button, { shouldForwardProp })<FolderNameProps>`\n  display: grid;\n  grid-template-columns: auto 1fr auto;\n  padding-left: ${({ level }) => 0.75 * spacingUnit * level}px;\n  gap: ${spacing.xxsmall};\n  border: none;\n  outline: none;\n  background: ${({ selected, isCreatingFolder, focused }) =>\n    isCreatingFolder ? 'none' : selected ? colors.brand.lighter : focused && colors.brand.lightest};\n  color: ${({ isCreatingFolder, focused }) =>\n    isCreatingFolder && focused ? colors.brand.primary : 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: ${({ selected }) => (selected ? colors.brand.light : colors.brand.lightest)};\n    color: ${colors.text.primary};\n  }\n`;\n\nconst StyledDone = styled(Done)`\n  color: ${colors.support.green};\n`;\n\nconst FolderNameLink = styled(SafeLink, { shouldForwardProp })<FolderNameProps>`\n  display: grid;\n  align-items: center;\n  grid-template-columns: ${spacing.medium} 1fr auto;\n  padding: ${spacing.small} ${spacing.xxsmall};\n  margin-left: ${({ level }) => 0.75 * spacingUnit * level}px;\n  gap: ${spacing.xxsmall};\n  cursor: pointer;\n\n  border: none;\n  box-shadow: none;\n  color: ${({ selected }) => (selected ? colors.brand.primary : colors.text.primary)};\n  font-weight: ${({ selected }) => selected && fonts.weight.semibold};\n  font-size: ${fonts.sizes('16px')};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\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 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?.scrollIntoView({\n          behavior: 'smooth',\n          block: 'nearest',\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      level={level}\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      selected={selected}\n      onFocus={() => setFocusedFolder(folder)}\n      onClick={handleClickFolder}\n    >\n      {!hideArrow && (\n        <OpenButton\n          aria-hidden\n          tabIndex={-1}\n          isOpen={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      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      level={level}\n      selected={selected}\n      disabled={loading}\n      onFocus={(e) => {\n        setFocusedFolder(focusedFolder || folder);\n      }}\n      onClick={handleClickFolder}\n      isCreatingFolder={isCreatingFolder}\n    >\n      <IconWrapper>\n        {!hideArrow && (\n          <OpenButton\n            aria-hidden\n            tabIndex={-1}\n            isOpen={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"]} */"));
99
+ })("color:", _core.colors.support.green, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FolderItem.tsx"],"names":[],"mappings":"AA0F+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 React, { KeyboardEvent, useEffect, 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, spacingUnit, 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<{ isOpen: boolean }>`\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(${({ isOpen }) => (isOpen ? '0' : '-90')}deg);\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 shouldForwardProp = (name: string) => !['selected', 'level', 'focused', 'isCreatingFolder'].includes(name);\n\ninterface FolderNameProps {\n  selected?: boolean;\n  level: number;\n  isCreatingFolder?: boolean;\n  focused?: boolean;\n}\n\nconst FolderName = styled(Button, { shouldForwardProp })<FolderNameProps>`\n  display: grid;\n  grid-template-columns: auto 1fr auto;\n  padding-left: ${({ level }) => 0.75 * spacingUnit * level}px;\n  gap: ${spacing.xxsmall};\n  border: none;\n  outline: none;\n  background: ${({ selected, isCreatingFolder, focused }) =>\n    isCreatingFolder ? 'none' : selected ? colors.brand.lighter : focused && colors.brand.lightest};\n  color: ${({ isCreatingFolder, focused }) =>\n    isCreatingFolder && focused ? colors.brand.primary : 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: ${({ selected }) => (selected ? colors.brand.light : colors.brand.lightest)};\n    color: ${colors.text.primary};\n  }\n`;\n\nconst StyledDone = styled(Done)`\n  color: ${colors.support.green};\n`;\n\nconst FolderNameLink = styled(SafeLink, { shouldForwardProp })<FolderNameProps>`\n  display: grid;\n  align-items: center;\n  grid-template-columns: ${spacing.medium} 1fr auto;\n  padding: ${spacing.small} ${spacing.xxsmall};\n  margin-left: ${({ level }) => 0.75 * spacingUnit * level}px;\n  gap: ${spacing.xxsmall};\n  cursor: pointer;\n\n  border: none;\n  box-shadow: none;\n  color: ${({ selected }) => (selected ? colors.brand.primary : colors.text.primary)};\n  font-weight: ${({ selected }) => selected && fonts.weight.semibold};\n  font-size: ${fonts.sizes('16px')};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\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 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      level={level}\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      selected={selected}\n      onFocus={() => setFocusedFolder(folder)}\n      onClick={handleClickFolder}\n    >\n      {!hideArrow && (\n        <OpenButton\n          aria-hidden\n          tabIndex={-1}\n          isOpen={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      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      level={level}\n      selected={selected}\n      disabled={loading}\n      onFocus={(e) => {\n        setFocusedFolder(focusedFolder || folder);\n      }}\n      onClick={handleClickFolder}\n      isCreatingFolder={isCreatingFolder}\n    >\n      <IconWrapper>\n        {!hideArrow && (\n          <OpenButton\n            aria-hidden\n            tabIndex={-1}\n            isOpen={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"]} */"));
100
100
  var FolderNameLink = /*#__PURE__*/(0, _base.default)(_safelink.default, {
101
101
  shouldForwardProp: shouldForwardProp,
102
102
  target: "e11ok6h80",
@@ -110,7 +110,7 @@ var FolderNameLink = /*#__PURE__*/(0, _base.default)(_safelink.default, {
110
110
  }, ";font-weight:", function (_ref8) {
111
111
  var selected = _ref8.selected;
112
112
  return selected && _core.fonts.weight.semibold;
113
- }, ";font-size:", _core.fonts.sizes('16px'), ";transition:", _core.animations.durations.superFast, ";word-break:break-word;&:hover,&:focus{color:", _core.colors.brand.primary, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FolderItem.tsx"],"names":[],"mappings":"AA8F+E","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 React, { KeyboardEvent, useEffect, 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, spacingUnit, 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<{ isOpen: boolean }>`\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(${({ isOpen }) => (isOpen ? '0' : '-90')}deg);\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 shouldForwardProp = (name: string) => !['selected', 'level', 'focused', 'isCreatingFolder'].includes(name);\n\ninterface FolderNameProps {\n  selected?: boolean;\n  level: number;\n  isCreatingFolder?: boolean;\n  focused?: boolean;\n}\n\nconst FolderName = styled(Button, { shouldForwardProp })<FolderNameProps>`\n  display: grid;\n  grid-template-columns: auto 1fr auto;\n  padding-left: ${({ level }) => 0.75 * spacingUnit * level}px;\n  gap: ${spacing.xxsmall};\n  border: none;\n  outline: none;\n  background: ${({ selected, isCreatingFolder, focused }) =>\n    isCreatingFolder ? 'none' : selected ? colors.brand.lighter : focused && colors.brand.lightest};\n  color: ${({ isCreatingFolder, focused }) =>\n    isCreatingFolder && focused ? colors.brand.primary : 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: ${({ selected }) => (selected ? colors.brand.light : colors.brand.lightest)};\n    color: ${colors.text.primary};\n  }\n`;\n\nconst StyledDone = styled(Done)`\n  color: ${colors.support.green};\n`;\n\nconst FolderNameLink = styled(SafeLink, { shouldForwardProp })<FolderNameProps>`\n  display: grid;\n  align-items: center;\n  grid-template-columns: ${spacing.medium} 1fr auto;\n  padding: ${spacing.small} ${spacing.xxsmall};\n  margin-left: ${({ level }) => 0.75 * spacingUnit * level}px;\n  gap: ${spacing.xxsmall};\n  cursor: pointer;\n\n  border: none;\n  box-shadow: none;\n  color: ${({ selected }) => (selected ? colors.brand.primary : colors.text.primary)};\n  font-weight: ${({ selected }) => selected && fonts.weight.semibold};\n  font-size: ${fonts.sizes('16px')};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\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 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?.scrollIntoView({\n          behavior: 'smooth',\n          block: 'nearest',\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      level={level}\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      selected={selected}\n      onFocus={() => setFocusedFolder(folder)}\n      onClick={handleClickFolder}\n    >\n      {!hideArrow && (\n        <OpenButton\n          aria-hidden\n          tabIndex={-1}\n          isOpen={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      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      level={level}\n      selected={selected}\n      disabled={loading}\n      onFocus={(e) => {\n        setFocusedFolder(focusedFolder || folder);\n      }}\n      onClick={handleClickFolder}\n      isCreatingFolder={isCreatingFolder}\n    >\n      <IconWrapper>\n        {!hideArrow && (\n          <OpenButton\n            aria-hidden\n            tabIndex={-1}\n            isOpen={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"]} */"));
113
+ }, ";font-size:", _core.fonts.sizes('16px'), ";transition:", _core.animations.durations.superFast, ";word-break:break-word;&:hover,&:focus{color:", _core.colors.brand.primary, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FolderItem.tsx"],"names":[],"mappings":"AA8F+E","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 React, { KeyboardEvent, useEffect, 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, spacingUnit, 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<{ isOpen: boolean }>`\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(${({ isOpen }) => (isOpen ? '0' : '-90')}deg);\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 shouldForwardProp = (name: string) => !['selected', 'level', 'focused', 'isCreatingFolder'].includes(name);\n\ninterface FolderNameProps {\n  selected?: boolean;\n  level: number;\n  isCreatingFolder?: boolean;\n  focused?: boolean;\n}\n\nconst FolderName = styled(Button, { shouldForwardProp })<FolderNameProps>`\n  display: grid;\n  grid-template-columns: auto 1fr auto;\n  padding-left: ${({ level }) => 0.75 * spacingUnit * level}px;\n  gap: ${spacing.xxsmall};\n  border: none;\n  outline: none;\n  background: ${({ selected, isCreatingFolder, focused }) =>\n    isCreatingFolder ? 'none' : selected ? colors.brand.lighter : focused && colors.brand.lightest};\n  color: ${({ isCreatingFolder, focused }) =>\n    isCreatingFolder && focused ? colors.brand.primary : 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: ${({ selected }) => (selected ? colors.brand.light : colors.brand.lightest)};\n    color: ${colors.text.primary};\n  }\n`;\n\nconst StyledDone = styled(Done)`\n  color: ${colors.support.green};\n`;\n\nconst FolderNameLink = styled(SafeLink, { shouldForwardProp })<FolderNameProps>`\n  display: grid;\n  align-items: center;\n  grid-template-columns: ${spacing.medium} 1fr auto;\n  padding: ${spacing.small} ${spacing.xxsmall};\n  margin-left: ${({ level }) => 0.75 * spacingUnit * level}px;\n  gap: ${spacing.xxsmall};\n  cursor: pointer;\n\n  border: none;\n  box-shadow: none;\n  color: ${({ selected }) => (selected ? colors.brand.primary : colors.text.primary)};\n  font-weight: ${({ selected }) => selected && fonts.weight.semibold};\n  font-size: ${fonts.sizes('16px')};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\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 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      level={level}\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      selected={selected}\n      onFocus={() => setFocusedFolder(folder)}\n      onClick={handleClickFolder}\n    >\n      {!hideArrow && (\n        <OpenButton\n          aria-hidden\n          tabIndex={-1}\n          isOpen={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      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      level={level}\n      selected={selected}\n      disabled={loading}\n      onFocus={(e) => {\n        setFocusedFolder(focusedFolder || folder);\n      }}\n      onClick={handleClickFolder}\n      isCreatingFolder={isCreatingFolder}\n    >\n      <IconWrapper>\n        {!hideArrow && (\n          <OpenButton\n            aria-hidden\n            tabIndex={-1}\n            isOpen={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"]} */"));
114
114
  var FolderItem = function FolderItem(_ref9) {
115
115
  var focusedFolder = _ref9.focusedFolder,
116
116
  folder = _ref9.folder,
@@ -154,10 +154,11 @@ var FolderItem = function FolderItem(_ref9) {
154
154
  (_ref$current = ref.current) === null || _ref$current === void 0 ? void 0 : _ref$current.focus();
155
155
  }
156
156
  if (type === 'picker') {
157
- var _ref$current2;
158
- (_ref$current2 = ref.current) === null || _ref$current2 === void 0 ? void 0 : _ref$current2.scrollIntoView({
157
+ var _ref$current2, _ref$current3;
158
+ (_ref$current2 = ref.current) === null || _ref$current2 === void 0 ? void 0 : _ref$current2.focus();
159
+ (_ref$current3 = ref.current) === null || _ref$current3 === void 0 ? void 0 : _ref$current3.scrollIntoView({
159
160
  behavior: 'smooth',
160
- block: 'nearest'
161
+ block: 'start'
161
162
  });
162
163
  }
163
164
  }
@@ -198,10 +199,10 @@ var FolderItem = function FolderItem(_ref9) {
198
199
  tabIndex: -1,
199
200
  isOpen: isOpen,
200
201
  onClick: function onClick(e) {
201
- var _ref$current3;
202
+ var _ref$current4;
202
203
  e.stopPropagation();
203
204
  e.preventDefault();
204
- (_ref$current3 = ref.current) === null || _ref$current3 === void 0 ? void 0 : _ref$current3.focus();
205
+ (_ref$current4 = ref.current) === null || _ref$current4 === void 0 ? void 0 : _ref$current4.focus();
205
206
  if (isOpen) {
206
207
  onCloseFolder(id);
207
208
  } else {
package/lib/index.d.ts CHANGED
@@ -101,3 +101,4 @@ export type { HeadingLevel } from './types';
101
101
  export { default as FrontpageArticle } from './FrontpageArticle';
102
102
  export { DefinitionTerm, DefinitionDescription } from './DefinitionList';
103
103
  export type { ProgrammeV2 } from './ProgrammeCard';
104
+ export { Gloss } from './Gloss';
package/lib/index.js CHANGED
@@ -502,6 +502,12 @@ Object.defineProperty(exports, "FrontpageToolbox", {
502
502
  return _Frontpage.FrontpageToolbox;
503
503
  }
504
504
  });
505
+ Object.defineProperty(exports, "Gloss", {
506
+ enumerable: true,
507
+ get: function get() {
508
+ return _Gloss.Gloss;
509
+ }
510
+ });
505
511
  Object.defineProperty(exports, "Grid", {
506
512
  enumerable: true,
507
513
  get: function get() {
@@ -1339,6 +1345,7 @@ var _Grid = require("./Grid");
1339
1345
  var _Typography = require("./Typography");
1340
1346
  var _FrontpageArticle = _interopRequireDefault(require("./FrontpageArticle"));
1341
1347
  var _DefinitionList = require("./DefinitionList");
1348
+ var _Gloss = require("./Gloss");
1342
1349
  function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
1343
1350
  function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
1344
1351
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }