@ndla/ui 25.3.0 → 26.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (50) hide show
  1. package/es/LanguageSelector/LanguageSelector.js +12 -7
  2. package/es/TreeStructure/FolderItem.js +110 -94
  3. package/es/TreeStructure/FolderItems.js +26 -30
  4. package/es/TreeStructure/FolderNameInput.js +35 -27
  5. package/es/TreeStructure/NavigationLink.js +81 -0
  6. package/es/TreeStructure/TreeStructure.js +169 -45
  7. package/es/locale/messages-en.js +2 -0
  8. package/es/locale/messages-nb.js +2 -0
  9. package/es/locale/messages-nn.js +2 -0
  10. package/es/locale/messages-se.js +2 -0
  11. package/es/locale/messages-sma.js +2 -0
  12. package/lib/LanguageSelector/LanguageSelector.js +13 -7
  13. package/lib/TreeStructure/FolderItem.d.ts +2 -3
  14. package/lib/TreeStructure/FolderItem.js +107 -92
  15. package/lib/TreeStructure/FolderItems.d.ts +1 -3
  16. package/lib/TreeStructure/FolderItems.js +26 -29
  17. package/lib/TreeStructure/FolderNameInput.d.ts +2 -1
  18. package/lib/TreeStructure/FolderNameInput.js +33 -26
  19. package/lib/TreeStructure/NavigationLink.d.ts +15 -0
  20. package/lib/TreeStructure/NavigationLink.js +100 -0
  21. package/lib/TreeStructure/TreeStructure.d.ts +1 -2
  22. package/lib/TreeStructure/TreeStructure.js +163 -45
  23. package/lib/TreeStructure/types.d.ts +4 -1
  24. package/lib/locale/messages-en.d.ts +2 -0
  25. package/lib/locale/messages-en.js +2 -0
  26. package/lib/locale/messages-nb.d.ts +2 -0
  27. package/lib/locale/messages-nb.js +2 -0
  28. package/lib/locale/messages-nn.d.ts +2 -0
  29. package/lib/locale/messages-nn.js +2 -0
  30. package/lib/locale/messages-se.d.ts +2 -0
  31. package/lib/locale/messages-se.js +2 -0
  32. package/lib/locale/messages-sma.d.ts +2 -0
  33. package/lib/locale/messages-sma.js +2 -0
  34. package/package.json +11 -11
  35. package/src/LanguageSelector/LanguageSelector.tsx +4 -1
  36. package/src/TreeStructure/FolderItem.tsx +126 -104
  37. package/src/TreeStructure/FolderItems.tsx +51 -43
  38. package/src/TreeStructure/FolderNameInput.tsx +43 -28
  39. package/src/TreeStructure/NavigationLink.tsx +100 -0
  40. package/src/TreeStructure/TreeStructure.tsx +187 -61
  41. package/src/TreeStructure/types.ts +5 -1
  42. package/src/locale/messages-en.ts +2 -0
  43. package/src/locale/messages-nb.ts +2 -0
  44. package/src/locale/messages-nn.ts +2 -0
  45. package/src/locale/messages-se.ts +2 -0
  46. package/src/locale/messages-sma.ts +2 -0
  47. package/es/TreeStructure/TreeStructureWrapper.js +0 -13
  48. package/lib/TreeStructure/TreeStructureWrapper.d.ts +0 -12
  49. package/lib/TreeStructure/TreeStructureWrapper.js +0 -24
  50. package/src/TreeStructure/TreeStructureWrapper.tsx +0 -31
@@ -1,11 +1,5 @@
1
1
  import _styled from "@emotion/styled-base";
2
2
 
3
- function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
4
-
5
- function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
6
-
7
- function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
8
-
9
3
  function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
10
4
 
11
5
  /**
@@ -17,101 +11,107 @@ function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringif
17
11
  */
18
12
  import React, { useEffect, useRef } from 'react';
19
13
  import { useTranslation } from 'react-i18next';
20
- import { ArrowDropDown } from '@ndla/icons/common';
14
+ import { ArrowDropDownRounded } from '@ndla/icons/common';
21
15
  import { Done } from '@ndla/icons/editor';
22
- import { MenuButton } from '@ndla/button';
23
- import { FolderOutlined } from '@ndla/icons/contentType';
24
- import { colors, spacing, misc, animations } from '@ndla/core';
16
+ import { ButtonV2 as Button } from '@ndla/button';
17
+ import { colors, spacing, animations, spacingUnit, misc, fonts } from '@ndla/core';
25
18
  import SafeLink from '@ndla/safelink';
26
19
  import { arrowNavigation } from './arrowNavigation';
27
20
  import { jsx as ___EmotionJSX } from "@emotion/core";
28
21
 
29
- var OpenButton = _styled("button", {
22
+ var OpenButton = _styled("span", {
30
23
  target: "e11ok6h80",
31
24
  label: "OpenButton"
32
- })("background:transparent;border:0;transform:rotate(", function (_ref) {
25
+ })("display:flex;align-items:center;justify-content:center;align-self:stretch;color:", colors.brand.tertiary, ";", misc.transition["default"], ";cursor:pointer;&:hover{color:", colors.brand.primary, ";}svg{width:24px;height:24px;transform:rotate(", function (_ref) {
33
26
  var isOpen = _ref.isOpen;
34
27
  return isOpen ? '0' : '-90';
35
- }, "deg);padding:", spacing.xsmall, ";display:flex;margin:0;color:", colors.brand.secondary, ";cursor:pointer;&:hover{color:", colors.brand.primary, ";}svg{width:16px;height:16px;transform:", function (_ref2) {
36
- var isOpen = _ref2.isOpen;
37
- return isOpen ? 'translateX(3px)' : 'translateY(3px)';
38
- }, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FolderItem.tsx"],"names":[],"mappings":"AAoBqD","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, MouseEvent, useEffect, useRef } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { ArrowDropDown } from '@ndla/icons/common';\nimport { Done } from '@ndla/icons/editor';\nimport { MenuButton } from '@ndla/button';\nimport { FolderOutlined } from '@ndla/icons/contentType';\nimport { colors, spacing, misc, animations } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\nimport { CommonFolderItemsProps, FolderType } from './types';\nimport { arrowNavigation } from './arrowNavigation';\n\nconst OpenButton = styled.button<{ isOpen: boolean }>`\n  background: transparent;\n  border: 0;\n  transform: rotate(${({ isOpen }) => (isOpen ? '0' : '-90')}deg);\n  padding: ${spacing.xsmall};\n  display: flex;\n  margin: 0;\n  color: ${colors.brand.secondary};\n  cursor: pointer;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n  svg {\n    width: 16px;\n    height: 16px;\n    transform: ${({ isOpen }) => (isOpen ? 'translateX(3px)' : 'translateY(3px)')};\n  }\n`;\n\nconst FolderItemWrapper = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst WrapperForFolderChild = styled.div`\n  display: flex;\n  flex-direction: row;\n  align-items: center;\n  gap: ${spacing.xsmall};\n`;\n\nconst shouldForwardProp = (name: string) => !['selected', 'noArrow', 'fullWidth'].includes(name);\n\ninterface FolderNameProps {\n  selected?: boolean;\n  noArrow?: boolean;\n  fullWidth?: boolean;\n}\n\nconst FolderName = styled('button', { shouldForwardProp })<FolderNameProps>`\n  cursor: pointer;\n  padding: ${spacing.xsmall};\n  margin: 0;\n  outline-offset: -2px;\n  outline-color: ${colors.brand.primary};\n  margin-left: ${({ noArrow }) => (noArrow ? `29px` : `0px`)};\n  flex-grow: ${({ fullWidth }) => fullWidth && 1};\n  display: grid;\n  grid-template-columns: auto 1fr auto;\n  align-items: center;\n  gap: ${spacing.xxsmall};\n  border: 0;\n  border-radius: ${misc.borderRadius};\n  box-shadow: none;\n  background: ${({ selected }) => (selected ? colors.brand.lighter : 'transparent')};\n  color: ${colors.text.primary};\n  transition: ${animations.durations.superFast};\n  text-align: left;\n  line-height: 1;\n  word-break: break-word;\n  &:hover,\n  &:focus {\n    background: ${({ selected }) => (selected ? colors.brand.light : colors.brand.lightest)};\n    color: ${colors.brand.primary};\n    + ${WrapperForFolderChild} {\n      opacity: 1;\n    }\n  }\n`;\n\nconst StyledDone = styled(Done)`\n  color: ${colors.support.green};\n`;\n\nconst FolderNameLink = FolderName.withComponent(SafeLink);\n\ninterface Props extends CommonFolderItemsProps {\n  hideArrow?: boolean;\n  isOpen: boolean;\n  folder: FolderType;\n  noPaddingWhenArrowIsHidden?: boolean;\n}\n\nconst FolderItem = ({\n  focusedFolderId,\n  menuItems,\n  hideArrow,\n  folder,\n  isOpen,\n  level,\n  loading,\n  selectedFolder,\n  noPaddingWhenArrowIsHidden,\n  onCloseFolder,\n  onOpenFolder,\n  onSelectFolder,\n  openOnFolderClick,\n  setFocusedId,\n  setSelectedFolder,\n  targetResource,\n  visibleFolders,\n  framed,\n}: Props) => {\n  const { t } = useTranslation();\n  const { id, icon, name } = folder;\n  const ref = useRef<HTMLButtonElement & HTMLAnchorElement>(null);\n  const selected = selectedFolder && selectedFolder.id === id;\n  const focused = focusedFolderId === id;\n\n  const handleClickFolder = () => {\n    if (openOnFolderClick) {\n      if (selected) {\n        if (isOpen) {\n          onCloseFolder(id);\n        } else {\n          onOpenFolder(id);\n        }\n      }\n    }\n    if (!selected) {\n      setSelectedFolder(folder);\n      setFocusedId(id);\n    }\n    onSelectFolder?.(id);\n  };\n\n  useEffect(() => {\n    if (focusedFolderId === id) {\n      ref.current?.focus();\n    }\n  }, [focusedFolderId, ref, id]);\n\n  const actions = menuItems?.map((item) => {\n    const { onClick } = item;\n    return {\n      ...item,\n      onClick: (e?: MouseEvent<HTMLDivElement>) => onClick(e, folder),\n    };\n  });\n\n  const linkPath = `/minndla${level > 0 ? '/folders' : ''}/${id}`;\n\n  const containsResource =\n    targetResource && folder.resources.some((resource) => resource.resourceId === targetResource.resourceId);\n\n  return (\n    <FolderItemWrapper>\n      {!hideArrow && (\n        <OpenButton\n          tabIndex={-1}\n          isOpen={isOpen}\n          disabled={loading}\n          onClick={() => (isOpen ? onCloseFolder(id) : onOpenFolder(id))}>\n          <ArrowDropDown />\n        </OpenButton>\n      )}\n      {onSelectFolder ? (\n        <>\n          <FolderName\n            fullWidth={framed}\n            ref={ref}\n            onKeyDown={(e) => arrowNavigation(e, id, visibleFolders, setFocusedId, onOpenFolder, onCloseFolder)}\n            noArrow={hideArrow && !noPaddingWhenArrowIsHidden}\n            tabIndex={selected || focused ? 0 : -1}\n            selected={selected}\n            disabled={loading}\n            onFocus={() => setFocusedId(id)}\n            onClick={handleClickFolder}>\n            {icon || <FolderOutlined />}\n            {name}\n            <WrapperForFolderChild>\n              {containsResource && <StyledDone title={t('myNdla.alreadyInFolder')} />}\n              {actions && (\n                <MenuButton\n                  onClick={(e) => e.stopPropagation()}\n                  size=\"xsmall\"\n                  menuItems={actions}\n                  tabIndex={selected || id === focusedFolderId ? 0 : -1}\n                />\n              )}\n            </WrapperForFolderChild>\n          </FolderName>\n        </>\n      ) : (\n        <FolderNameLink\n          ref={ref}\n          onKeyDown={(e: KeyboardEvent<HTMLElement>) =>\n            arrowNavigation(e, id, visibleFolders, setFocusedId, onOpenFolder, onCloseFolder)\n          }\n          noArrow={hideArrow}\n          to={loading ? '' : linkPath}\n          tabIndex={selected || focused || level === 0 ? 0 : -1}\n          selected={selected}\n          onFocus={() => setFocusedId(id)}\n          onClick={handleClickFolder}>\n          {icon || <FolderOutlined />}\n          {name}\n        </FolderNameLink>\n      )}\n    </FolderItemWrapper>\n  );\n};\n\nexport default FolderItem;\n"]} */"));
28
+ }, "deg);}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FolderItem.tsx"],"names":[],"mappings":"AAmBmD","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 { 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 { CommonFolderItemsProps, FolderType } from './types';\nimport { arrowNavigation } from './arrowNavigation';\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  grid-column-start: 2;\n  text-align: left;\n`;\n\nconst WrapperForFolderChild = styled.div`\n  display: flex;\n  flex-direction: row;\n  align-items: center;\n  gap: ${spacing.xsmall};\n  margin-left: auto;\n`;\n\nconst shouldForwardProp = (name: string) => !['selected', 'noArrow', 'fullWidth', 'level'].includes(name);\n\ninterface FolderNameProps {\n  selected?: boolean;\n  noArrow?: boolean;\n  fullWidth?: boolean;\n  level: number;\n  isCreatingFolder?: boolean;\n}\n\nconst FolderName = styled(Button, { shouldForwardProp })<FolderNameProps>`\n  display: grid;\n  grid-template-columns: ${spacing.medium} 1fr auto;\n\n  padding-left: ${({ level }) => 0.75 * spacingUnit * level}px;\n  gap: ${spacing.xxsmall};\n  border: none;\n  outline: none;\n  background: ${({ selected, isCreatingFolder }) => selected && !isCreatingFolder && colors.brand.lighter};\n  color: ${({ isCreatingFolder, selected }) =>\n    isCreatingFolder && selected ? colors.brand.primary : colors.text.primary};\n  transition: ${animations.durations.superFast};\n  line-height: 1;\n  word-break: break-word;\n  &:hover,\n  &:focus {\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  line-height: 1;\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: FolderType;\n  isCreatingFolder?: boolean;\n}\n\nconst FolderItem = ({\n  focusedFolderId,\n  folder,\n  isOpen,\n  level,\n  loading,\n  selectedFolder,\n  onCloseFolder,\n  onOpenFolder,\n  onSelectFolder,\n  openOnFolderClick,\n  setFocusedId,\n  setSelectedFolder,\n  targetResource,\n  visibleFolders,\n  framed,\n  maxLevel,\n  isCreatingFolder,\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;\n  const focused = focusedFolderId === id;\n\n  const handleClickFolder = () => {\n    if (openOnFolderClick) {\n      if (selected) {\n        if (isOpen) {\n          onCloseFolder(id);\n        } else {\n          onOpenFolder(id);\n        }\n      }\n    }\n    if (!selected) {\n      setSelectedFolder(folder);\n      setFocusedId(id);\n    }\n    onSelectFolder?.(id);\n  };\n\n  useEffect(() => {\n    if (focusedFolderId === id && !isCreatingFolder) {\n      ref.current?.focus();\n    }\n  }, [focusedFolderId, ref, id, isCreatingFolder]);\n\n  const linkPath = `/minndla${level > 0 ? '/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\n  const isMaxDepth = level > maxLevel;\n\n  const hideArrow = isMaxDepth || emptyFolder;\n\n  return onSelectFolder ? (\n    <FolderName\n      variant=\"ghost\"\n      shape=\"sharp\"\n      fontWeight=\"normal\"\n      colorTheme=\"light\"\n      ref={ref}\n      level={level}\n      fullWidth={framed}\n      onKeyDown={(e) => arrowNavigation(e, id, visibleFolders, setFocusedId, onOpenFolder, onCloseFolder)}\n      noArrow={hideArrow}\n      tabIndex={selected || focused ? 0 : -1}\n      selected={selected}\n      disabled={loading}\n      onFocus={() => setFocusedId(id)}\n      onClick={handleClickFolder}\n      isCreatingFolder={isCreatingFolder}>\n      {!hideArrow && (\n        <OpenButton\n          tabIndex={-1}\n          isOpen={isOpen}\n          onClick={() => {\n            ref.current?.focus();\n            if (isOpen) {\n              onCloseFolder(id);\n            } else {\n              onOpenFolder(id);\n            }\n          }}>\n          <ArrowDropDownRounded />\n        </OpenButton>\n      )}\n      <StyledName>{name}</StyledName>\n      <WrapperForFolderChild>\n        {containsResource && <StyledDone title={t('myNdla.alreadyInFolder')} />}\n      </WrapperForFolderChild>\n    </FolderName>\n  ) : (\n    <FolderNameLink\n      ref={ref}\n      level={level}\n      onKeyDown={(e: KeyboardEvent<HTMLElement>) =>\n        arrowNavigation(e, id, visibleFolders, setFocusedId, onOpenFolder, onCloseFolder)\n      }\n      noArrow={!isMaxDepth}\n      to={loading ? '' : linkPath}\n      tabIndex={selected || focused ? 0 : -1}\n      selected={selected}\n      onFocus={() => setFocusedId(id)}\n      onClick={handleClickFolder}>\n      {(!hideArrow || level === 0) && (\n        <OpenButton\n          tabIndex={-1}\n          isOpen={isOpen}\n          onClick={() => {\n            ref.current?.focus();\n            if (isOpen) {\n              onCloseFolder(id);\n            } else {\n              onOpenFolder(id);\n            }\n          }}>\n          <ArrowDropDownRounded />\n        </OpenButton>\n      )}\n      <StyledName>{name}</StyledName>\n    </FolderNameLink>\n  );\n};\n\nexport default FolderItem;\n"]} */"));
39
29
 
40
- var FolderItemWrapper = _styled("div", {
30
+ var StyledName = _styled("span", {
41
31
  target: "e11ok6h81",
42
- label: "FolderItemWrapper"
32
+ label: "StyledName"
43
33
  })(process.env.NODE_ENV === "production" ? {
44
- name: "70qvj9",
45
- styles: "display:flex;align-items:center;"
34
+ name: "1x6liyo",
35
+ styles: "grid-column-start:2;text-align:left;"
46
36
  } : {
47
- name: "70qvj9",
48
- styles: "display:flex;align-items:center;",
49
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FolderItem.tsx"],"names":[],"mappings":"AAuCoC","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, MouseEvent, useEffect, useRef } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { ArrowDropDown } from '@ndla/icons/common';\nimport { Done } from '@ndla/icons/editor';\nimport { MenuButton } from '@ndla/button';\nimport { FolderOutlined } from '@ndla/icons/contentType';\nimport { colors, spacing, misc, animations } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\nimport { CommonFolderItemsProps, FolderType } from './types';\nimport { arrowNavigation } from './arrowNavigation';\n\nconst OpenButton = styled.button<{ isOpen: boolean }>`\n  background: transparent;\n  border: 0;\n  transform: rotate(${({ isOpen }) => (isOpen ? '0' : '-90')}deg);\n  padding: ${spacing.xsmall};\n  display: flex;\n  margin: 0;\n  color: ${colors.brand.secondary};\n  cursor: pointer;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n  svg {\n    width: 16px;\n    height: 16px;\n    transform: ${({ isOpen }) => (isOpen ? 'translateX(3px)' : 'translateY(3px)')};\n  }\n`;\n\nconst FolderItemWrapper = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst WrapperForFolderChild = styled.div`\n  display: flex;\n  flex-direction: row;\n  align-items: center;\n  gap: ${spacing.xsmall};\n`;\n\nconst shouldForwardProp = (name: string) => !['selected', 'noArrow', 'fullWidth'].includes(name);\n\ninterface FolderNameProps {\n  selected?: boolean;\n  noArrow?: boolean;\n  fullWidth?: boolean;\n}\n\nconst FolderName = styled('button', { shouldForwardProp })<FolderNameProps>`\n  cursor: pointer;\n  padding: ${spacing.xsmall};\n  margin: 0;\n  outline-offset: -2px;\n  outline-color: ${colors.brand.primary};\n  margin-left: ${({ noArrow }) => (noArrow ? `29px` : `0px`)};\n  flex-grow: ${({ fullWidth }) => fullWidth && 1};\n  display: grid;\n  grid-template-columns: auto 1fr auto;\n  align-items: center;\n  gap: ${spacing.xxsmall};\n  border: 0;\n  border-radius: ${misc.borderRadius};\n  box-shadow: none;\n  background: ${({ selected }) => (selected ? colors.brand.lighter : 'transparent')};\n  color: ${colors.text.primary};\n  transition: ${animations.durations.superFast};\n  text-align: left;\n  line-height: 1;\n  word-break: break-word;\n  &:hover,\n  &:focus {\n    background: ${({ selected }) => (selected ? colors.brand.light : colors.brand.lightest)};\n    color: ${colors.brand.primary};\n    + ${WrapperForFolderChild} {\n      opacity: 1;\n    }\n  }\n`;\n\nconst StyledDone = styled(Done)`\n  color: ${colors.support.green};\n`;\n\nconst FolderNameLink = FolderName.withComponent(SafeLink);\n\ninterface Props extends CommonFolderItemsProps {\n  hideArrow?: boolean;\n  isOpen: boolean;\n  folder: FolderType;\n  noPaddingWhenArrowIsHidden?: boolean;\n}\n\nconst FolderItem = ({\n  focusedFolderId,\n  menuItems,\n  hideArrow,\n  folder,\n  isOpen,\n  level,\n  loading,\n  selectedFolder,\n  noPaddingWhenArrowIsHidden,\n  onCloseFolder,\n  onOpenFolder,\n  onSelectFolder,\n  openOnFolderClick,\n  setFocusedId,\n  setSelectedFolder,\n  targetResource,\n  visibleFolders,\n  framed,\n}: Props) => {\n  const { t } = useTranslation();\n  const { id, icon, name } = folder;\n  const ref = useRef<HTMLButtonElement & HTMLAnchorElement>(null);\n  const selected = selectedFolder && selectedFolder.id === id;\n  const focused = focusedFolderId === id;\n\n  const handleClickFolder = () => {\n    if (openOnFolderClick) {\n      if (selected) {\n        if (isOpen) {\n          onCloseFolder(id);\n        } else {\n          onOpenFolder(id);\n        }\n      }\n    }\n    if (!selected) {\n      setSelectedFolder(folder);\n      setFocusedId(id);\n    }\n    onSelectFolder?.(id);\n  };\n\n  useEffect(() => {\n    if (focusedFolderId === id) {\n      ref.current?.focus();\n    }\n  }, [focusedFolderId, ref, id]);\n\n  const actions = menuItems?.map((item) => {\n    const { onClick } = item;\n    return {\n      ...item,\n      onClick: (e?: MouseEvent<HTMLDivElement>) => onClick(e, folder),\n    };\n  });\n\n  const linkPath = `/minndla${level > 0 ? '/folders' : ''}/${id}`;\n\n  const containsResource =\n    targetResource && folder.resources.some((resource) => resource.resourceId === targetResource.resourceId);\n\n  return (\n    <FolderItemWrapper>\n      {!hideArrow && (\n        <OpenButton\n          tabIndex={-1}\n          isOpen={isOpen}\n          disabled={loading}\n          onClick={() => (isOpen ? onCloseFolder(id) : onOpenFolder(id))}>\n          <ArrowDropDown />\n        </OpenButton>\n      )}\n      {onSelectFolder ? (\n        <>\n          <FolderName\n            fullWidth={framed}\n            ref={ref}\n            onKeyDown={(e) => arrowNavigation(e, id, visibleFolders, setFocusedId, onOpenFolder, onCloseFolder)}\n            noArrow={hideArrow && !noPaddingWhenArrowIsHidden}\n            tabIndex={selected || focused ? 0 : -1}\n            selected={selected}\n            disabled={loading}\n            onFocus={() => setFocusedId(id)}\n            onClick={handleClickFolder}>\n            {icon || <FolderOutlined />}\n            {name}\n            <WrapperForFolderChild>\n              {containsResource && <StyledDone title={t('myNdla.alreadyInFolder')} />}\n              {actions && (\n                <MenuButton\n                  onClick={(e) => e.stopPropagation()}\n                  size=\"xsmall\"\n                  menuItems={actions}\n                  tabIndex={selected || id === focusedFolderId ? 0 : -1}\n                />\n              )}\n            </WrapperForFolderChild>\n          </FolderName>\n        </>\n      ) : (\n        <FolderNameLink\n          ref={ref}\n          onKeyDown={(e: KeyboardEvent<HTMLElement>) =>\n            arrowNavigation(e, id, visibleFolders, setFocusedId, onOpenFolder, onCloseFolder)\n          }\n          noArrow={hideArrow}\n          to={loading ? '' : linkPath}\n          tabIndex={selected || focused || level === 0 ? 0 : -1}\n          selected={selected}\n          onFocus={() => setFocusedId(id)}\n          onClick={handleClickFolder}>\n          {icon || <FolderOutlined />}\n          {name}\n        </FolderNameLink>\n      )}\n    </FolderItemWrapper>\n  );\n};\n\nexport default FolderItem;\n"]} */",
37
+ name: "1x6liyo",
38
+ styles: "grid-column-start:2;text-align:left;",
39
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FolderItem.tsx"],"names":[],"mappings":"AAqC8B","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 { 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 { CommonFolderItemsProps, FolderType } from './types';\nimport { arrowNavigation } from './arrowNavigation';\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  grid-column-start: 2;\n  text-align: left;\n`;\n\nconst WrapperForFolderChild = styled.div`\n  display: flex;\n  flex-direction: row;\n  align-items: center;\n  gap: ${spacing.xsmall};\n  margin-left: auto;\n`;\n\nconst shouldForwardProp = (name: string) => !['selected', 'noArrow', 'fullWidth', 'level'].includes(name);\n\ninterface FolderNameProps {\n  selected?: boolean;\n  noArrow?: boolean;\n  fullWidth?: boolean;\n  level: number;\n  isCreatingFolder?: boolean;\n}\n\nconst FolderName = styled(Button, { shouldForwardProp })<FolderNameProps>`\n  display: grid;\n  grid-template-columns: ${spacing.medium} 1fr auto;\n\n  padding-left: ${({ level }) => 0.75 * spacingUnit * level}px;\n  gap: ${spacing.xxsmall};\n  border: none;\n  outline: none;\n  background: ${({ selected, isCreatingFolder }) => selected && !isCreatingFolder && colors.brand.lighter};\n  color: ${({ isCreatingFolder, selected }) =>\n    isCreatingFolder && selected ? colors.brand.primary : colors.text.primary};\n  transition: ${animations.durations.superFast};\n  line-height: 1;\n  word-break: break-word;\n  &:hover,\n  &:focus {\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  line-height: 1;\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: FolderType;\n  isCreatingFolder?: boolean;\n}\n\nconst FolderItem = ({\n  focusedFolderId,\n  folder,\n  isOpen,\n  level,\n  loading,\n  selectedFolder,\n  onCloseFolder,\n  onOpenFolder,\n  onSelectFolder,\n  openOnFolderClick,\n  setFocusedId,\n  setSelectedFolder,\n  targetResource,\n  visibleFolders,\n  framed,\n  maxLevel,\n  isCreatingFolder,\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;\n  const focused = focusedFolderId === id;\n\n  const handleClickFolder = () => {\n    if (openOnFolderClick) {\n      if (selected) {\n        if (isOpen) {\n          onCloseFolder(id);\n        } else {\n          onOpenFolder(id);\n        }\n      }\n    }\n    if (!selected) {\n      setSelectedFolder(folder);\n      setFocusedId(id);\n    }\n    onSelectFolder?.(id);\n  };\n\n  useEffect(() => {\n    if (focusedFolderId === id && !isCreatingFolder) {\n      ref.current?.focus();\n    }\n  }, [focusedFolderId, ref, id, isCreatingFolder]);\n\n  const linkPath = `/minndla${level > 0 ? '/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\n  const isMaxDepth = level > maxLevel;\n\n  const hideArrow = isMaxDepth || emptyFolder;\n\n  return onSelectFolder ? (\n    <FolderName\n      variant=\"ghost\"\n      shape=\"sharp\"\n      fontWeight=\"normal\"\n      colorTheme=\"light\"\n      ref={ref}\n      level={level}\n      fullWidth={framed}\n      onKeyDown={(e) => arrowNavigation(e, id, visibleFolders, setFocusedId, onOpenFolder, onCloseFolder)}\n      noArrow={hideArrow}\n      tabIndex={selected || focused ? 0 : -1}\n      selected={selected}\n      disabled={loading}\n      onFocus={() => setFocusedId(id)}\n      onClick={handleClickFolder}\n      isCreatingFolder={isCreatingFolder}>\n      {!hideArrow && (\n        <OpenButton\n          tabIndex={-1}\n          isOpen={isOpen}\n          onClick={() => {\n            ref.current?.focus();\n            if (isOpen) {\n              onCloseFolder(id);\n            } else {\n              onOpenFolder(id);\n            }\n          }}>\n          <ArrowDropDownRounded />\n        </OpenButton>\n      )}\n      <StyledName>{name}</StyledName>\n      <WrapperForFolderChild>\n        {containsResource && <StyledDone title={t('myNdla.alreadyInFolder')} />}\n      </WrapperForFolderChild>\n    </FolderName>\n  ) : (\n    <FolderNameLink\n      ref={ref}\n      level={level}\n      onKeyDown={(e: KeyboardEvent<HTMLElement>) =>\n        arrowNavigation(e, id, visibleFolders, setFocusedId, onOpenFolder, onCloseFolder)\n      }\n      noArrow={!isMaxDepth}\n      to={loading ? '' : linkPath}\n      tabIndex={selected || focused ? 0 : -1}\n      selected={selected}\n      onFocus={() => setFocusedId(id)}\n      onClick={handleClickFolder}>\n      {(!hideArrow || level === 0) && (\n        <OpenButton\n          tabIndex={-1}\n          isOpen={isOpen}\n          onClick={() => {\n            ref.current?.focus();\n            if (isOpen) {\n              onCloseFolder(id);\n            } else {\n              onOpenFolder(id);\n            }\n          }}>\n          <ArrowDropDownRounded />\n        </OpenButton>\n      )}\n      <StyledName>{name}</StyledName>\n    </FolderNameLink>\n  );\n};\n\nexport default FolderItem;\n"]} */",
50
40
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
51
41
  });
52
42
 
53
43
  var WrapperForFolderChild = _styled("div", {
54
44
  target: "e11ok6h82",
55
45
  label: "WrapperForFolderChild"
56
- })("display:flex;flex-direction:row;align-items:center;gap:", spacing.xsmall, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FolderItem.tsx"],"names":[],"mappings":"AA4CwC","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, MouseEvent, useEffect, useRef } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { ArrowDropDown } from '@ndla/icons/common';\nimport { Done } from '@ndla/icons/editor';\nimport { MenuButton } from '@ndla/button';\nimport { FolderOutlined } from '@ndla/icons/contentType';\nimport { colors, spacing, misc, animations } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\nimport { CommonFolderItemsProps, FolderType } from './types';\nimport { arrowNavigation } from './arrowNavigation';\n\nconst OpenButton = styled.button<{ isOpen: boolean }>`\n  background: transparent;\n  border: 0;\n  transform: rotate(${({ isOpen }) => (isOpen ? '0' : '-90')}deg);\n  padding: ${spacing.xsmall};\n  display: flex;\n  margin: 0;\n  color: ${colors.brand.secondary};\n  cursor: pointer;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n  svg {\n    width: 16px;\n    height: 16px;\n    transform: ${({ isOpen }) => (isOpen ? 'translateX(3px)' : 'translateY(3px)')};\n  }\n`;\n\nconst FolderItemWrapper = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst WrapperForFolderChild = styled.div`\n  display: flex;\n  flex-direction: row;\n  align-items: center;\n  gap: ${spacing.xsmall};\n`;\n\nconst shouldForwardProp = (name: string) => !['selected', 'noArrow', 'fullWidth'].includes(name);\n\ninterface FolderNameProps {\n  selected?: boolean;\n  noArrow?: boolean;\n  fullWidth?: boolean;\n}\n\nconst FolderName = styled('button', { shouldForwardProp })<FolderNameProps>`\n  cursor: pointer;\n  padding: ${spacing.xsmall};\n  margin: 0;\n  outline-offset: -2px;\n  outline-color: ${colors.brand.primary};\n  margin-left: ${({ noArrow }) => (noArrow ? `29px` : `0px`)};\n  flex-grow: ${({ fullWidth }) => fullWidth && 1};\n  display: grid;\n  grid-template-columns: auto 1fr auto;\n  align-items: center;\n  gap: ${spacing.xxsmall};\n  border: 0;\n  border-radius: ${misc.borderRadius};\n  box-shadow: none;\n  background: ${({ selected }) => (selected ? colors.brand.lighter : 'transparent')};\n  color: ${colors.text.primary};\n  transition: ${animations.durations.superFast};\n  text-align: left;\n  line-height: 1;\n  word-break: break-word;\n  &:hover,\n  &:focus {\n    background: ${({ selected }) => (selected ? colors.brand.light : colors.brand.lightest)};\n    color: ${colors.brand.primary};\n    + ${WrapperForFolderChild} {\n      opacity: 1;\n    }\n  }\n`;\n\nconst StyledDone = styled(Done)`\n  color: ${colors.support.green};\n`;\n\nconst FolderNameLink = FolderName.withComponent(SafeLink);\n\ninterface Props extends CommonFolderItemsProps {\n  hideArrow?: boolean;\n  isOpen: boolean;\n  folder: FolderType;\n  noPaddingWhenArrowIsHidden?: boolean;\n}\n\nconst FolderItem = ({\n  focusedFolderId,\n  menuItems,\n  hideArrow,\n  folder,\n  isOpen,\n  level,\n  loading,\n  selectedFolder,\n  noPaddingWhenArrowIsHidden,\n  onCloseFolder,\n  onOpenFolder,\n  onSelectFolder,\n  openOnFolderClick,\n  setFocusedId,\n  setSelectedFolder,\n  targetResource,\n  visibleFolders,\n  framed,\n}: Props) => {\n  const { t } = useTranslation();\n  const { id, icon, name } = folder;\n  const ref = useRef<HTMLButtonElement & HTMLAnchorElement>(null);\n  const selected = selectedFolder && selectedFolder.id === id;\n  const focused = focusedFolderId === id;\n\n  const handleClickFolder = () => {\n    if (openOnFolderClick) {\n      if (selected) {\n        if (isOpen) {\n          onCloseFolder(id);\n        } else {\n          onOpenFolder(id);\n        }\n      }\n    }\n    if (!selected) {\n      setSelectedFolder(folder);\n      setFocusedId(id);\n    }\n    onSelectFolder?.(id);\n  };\n\n  useEffect(() => {\n    if (focusedFolderId === id) {\n      ref.current?.focus();\n    }\n  }, [focusedFolderId, ref, id]);\n\n  const actions = menuItems?.map((item) => {\n    const { onClick } = item;\n    return {\n      ...item,\n      onClick: (e?: MouseEvent<HTMLDivElement>) => onClick(e, folder),\n    };\n  });\n\n  const linkPath = `/minndla${level > 0 ? '/folders' : ''}/${id}`;\n\n  const containsResource =\n    targetResource && folder.resources.some((resource) => resource.resourceId === targetResource.resourceId);\n\n  return (\n    <FolderItemWrapper>\n      {!hideArrow && (\n        <OpenButton\n          tabIndex={-1}\n          isOpen={isOpen}\n          disabled={loading}\n          onClick={() => (isOpen ? onCloseFolder(id) : onOpenFolder(id))}>\n          <ArrowDropDown />\n        </OpenButton>\n      )}\n      {onSelectFolder ? (\n        <>\n          <FolderName\n            fullWidth={framed}\n            ref={ref}\n            onKeyDown={(e) => arrowNavigation(e, id, visibleFolders, setFocusedId, onOpenFolder, onCloseFolder)}\n            noArrow={hideArrow && !noPaddingWhenArrowIsHidden}\n            tabIndex={selected || focused ? 0 : -1}\n            selected={selected}\n            disabled={loading}\n            onFocus={() => setFocusedId(id)}\n            onClick={handleClickFolder}>\n            {icon || <FolderOutlined />}\n            {name}\n            <WrapperForFolderChild>\n              {containsResource && <StyledDone title={t('myNdla.alreadyInFolder')} />}\n              {actions && (\n                <MenuButton\n                  onClick={(e) => e.stopPropagation()}\n                  size=\"xsmall\"\n                  menuItems={actions}\n                  tabIndex={selected || id === focusedFolderId ? 0 : -1}\n                />\n              )}\n            </WrapperForFolderChild>\n          </FolderName>\n        </>\n      ) : (\n        <FolderNameLink\n          ref={ref}\n          onKeyDown={(e: KeyboardEvent<HTMLElement>) =>\n            arrowNavigation(e, id, visibleFolders, setFocusedId, onOpenFolder, onCloseFolder)\n          }\n          noArrow={hideArrow}\n          to={loading ? '' : linkPath}\n          tabIndex={selected || focused || level === 0 ? 0 : -1}\n          selected={selected}\n          onFocus={() => setFocusedId(id)}\n          onClick={handleClickFolder}>\n          {icon || <FolderOutlined />}\n          {name}\n        </FolderNameLink>\n      )}\n    </FolderItemWrapper>\n  );\n};\n\nexport default FolderItem;\n"]} */"));
46
+ })("display:flex;flex-direction:row;align-items:center;gap:", spacing.xsmall, ";margin-left:auto;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FolderItem.tsx"],"names":[],"mappings":"AA0CwC","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 { 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 { CommonFolderItemsProps, FolderType } from './types';\nimport { arrowNavigation } from './arrowNavigation';\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  grid-column-start: 2;\n  text-align: left;\n`;\n\nconst WrapperForFolderChild = styled.div`\n  display: flex;\n  flex-direction: row;\n  align-items: center;\n  gap: ${spacing.xsmall};\n  margin-left: auto;\n`;\n\nconst shouldForwardProp = (name: string) => !['selected', 'noArrow', 'fullWidth', 'level'].includes(name);\n\ninterface FolderNameProps {\n  selected?: boolean;\n  noArrow?: boolean;\n  fullWidth?: boolean;\n  level: number;\n  isCreatingFolder?: boolean;\n}\n\nconst FolderName = styled(Button, { shouldForwardProp })<FolderNameProps>`\n  display: grid;\n  grid-template-columns: ${spacing.medium} 1fr auto;\n\n  padding-left: ${({ level }) => 0.75 * spacingUnit * level}px;\n  gap: ${spacing.xxsmall};\n  border: none;\n  outline: none;\n  background: ${({ selected, isCreatingFolder }) => selected && !isCreatingFolder && colors.brand.lighter};\n  color: ${({ isCreatingFolder, selected }) =>\n    isCreatingFolder && selected ? colors.brand.primary : colors.text.primary};\n  transition: ${animations.durations.superFast};\n  line-height: 1;\n  word-break: break-word;\n  &:hover,\n  &:focus {\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  line-height: 1;\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: FolderType;\n  isCreatingFolder?: boolean;\n}\n\nconst FolderItem = ({\n  focusedFolderId,\n  folder,\n  isOpen,\n  level,\n  loading,\n  selectedFolder,\n  onCloseFolder,\n  onOpenFolder,\n  onSelectFolder,\n  openOnFolderClick,\n  setFocusedId,\n  setSelectedFolder,\n  targetResource,\n  visibleFolders,\n  framed,\n  maxLevel,\n  isCreatingFolder,\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;\n  const focused = focusedFolderId === id;\n\n  const handleClickFolder = () => {\n    if (openOnFolderClick) {\n      if (selected) {\n        if (isOpen) {\n          onCloseFolder(id);\n        } else {\n          onOpenFolder(id);\n        }\n      }\n    }\n    if (!selected) {\n      setSelectedFolder(folder);\n      setFocusedId(id);\n    }\n    onSelectFolder?.(id);\n  };\n\n  useEffect(() => {\n    if (focusedFolderId === id && !isCreatingFolder) {\n      ref.current?.focus();\n    }\n  }, [focusedFolderId, ref, id, isCreatingFolder]);\n\n  const linkPath = `/minndla${level > 0 ? '/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\n  const isMaxDepth = level > maxLevel;\n\n  const hideArrow = isMaxDepth || emptyFolder;\n\n  return onSelectFolder ? (\n    <FolderName\n      variant=\"ghost\"\n      shape=\"sharp\"\n      fontWeight=\"normal\"\n      colorTheme=\"light\"\n      ref={ref}\n      level={level}\n      fullWidth={framed}\n      onKeyDown={(e) => arrowNavigation(e, id, visibleFolders, setFocusedId, onOpenFolder, onCloseFolder)}\n      noArrow={hideArrow}\n      tabIndex={selected || focused ? 0 : -1}\n      selected={selected}\n      disabled={loading}\n      onFocus={() => setFocusedId(id)}\n      onClick={handleClickFolder}\n      isCreatingFolder={isCreatingFolder}>\n      {!hideArrow && (\n        <OpenButton\n          tabIndex={-1}\n          isOpen={isOpen}\n          onClick={() => {\n            ref.current?.focus();\n            if (isOpen) {\n              onCloseFolder(id);\n            } else {\n              onOpenFolder(id);\n            }\n          }}>\n          <ArrowDropDownRounded />\n        </OpenButton>\n      )}\n      <StyledName>{name}</StyledName>\n      <WrapperForFolderChild>\n        {containsResource && <StyledDone title={t('myNdla.alreadyInFolder')} />}\n      </WrapperForFolderChild>\n    </FolderName>\n  ) : (\n    <FolderNameLink\n      ref={ref}\n      level={level}\n      onKeyDown={(e: KeyboardEvent<HTMLElement>) =>\n        arrowNavigation(e, id, visibleFolders, setFocusedId, onOpenFolder, onCloseFolder)\n      }\n      noArrow={!isMaxDepth}\n      to={loading ? '' : linkPath}\n      tabIndex={selected || focused ? 0 : -1}\n      selected={selected}\n      onFocus={() => setFocusedId(id)}\n      onClick={handleClickFolder}>\n      {(!hideArrow || level === 0) && (\n        <OpenButton\n          tabIndex={-1}\n          isOpen={isOpen}\n          onClick={() => {\n            ref.current?.focus();\n            if (isOpen) {\n              onCloseFolder(id);\n            } else {\n              onOpenFolder(id);\n            }\n          }}>\n          <ArrowDropDownRounded />\n        </OpenButton>\n      )}\n      <StyledName>{name}</StyledName>\n    </FolderNameLink>\n  );\n};\n\nexport default FolderItem;\n"]} */"));
57
47
 
58
48
  var shouldForwardProp = function shouldForwardProp(name) {
59
- return !['selected', 'noArrow', 'fullWidth'].includes(name);
49
+ return !['selected', 'noArrow', 'fullWidth', 'level'].includes(name);
60
50
  };
61
51
 
62
- var FolderName = /*#__PURE__*/_styled('button', {
52
+ var FolderName = /*#__PURE__*/_styled(Button, {
63
53
  shouldForwardProp: shouldForwardProp,
64
54
  target: "e11ok6h83",
65
55
  label: "FolderName"
66
- })("cursor:pointer;padding:", spacing.xsmall, ";margin:0;outline-offset:-2px;outline-color:", colors.brand.primary, ";margin-left:", function (_ref3) {
67
- var noArrow = _ref3.noArrow;
68
- return noArrow ? "29px" : "0px";
69
- }, ";flex-grow:", function (_ref4) {
70
- var fullWidth = _ref4.fullWidth;
71
- return fullWidth && 1;
72
- }, ";display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:", spacing.xxsmall, ";border:0;border-radius:", misc.borderRadius, ";box-shadow:none;background:", function (_ref5) {
56
+ })("display:grid;grid-template-columns:", spacing.medium, " 1fr auto;padding-left:", function (_ref2) {
57
+ var level = _ref2.level;
58
+ return 0.75 * spacingUnit * level;
59
+ }, "px;gap:", spacing.xxsmall, ";border:none;outline:none;background:", function (_ref3) {
60
+ var selected = _ref3.selected,
61
+ isCreatingFolder = _ref3.isCreatingFolder;
62
+ return selected && !isCreatingFolder && colors.brand.lighter;
63
+ }, ";color:", function (_ref4) {
64
+ var isCreatingFolder = _ref4.isCreatingFolder,
65
+ selected = _ref4.selected;
66
+ return isCreatingFolder && selected ? colors.brand.primary : colors.text.primary;
67
+ }, ";transition:", animations.durations.superFast, ";line-height:1;word-break:break-word;&:hover,&:focus{box-shadow:none;outline:none;background:", function (_ref5) {
73
68
  var selected = _ref5.selected;
74
- return selected ? colors.brand.lighter : 'transparent';
75
- }, ";color:", colors.text.primary, ";transition:", animations.durations.superFast, ";text-align:left;line-height:1;word-break:break-word;&:hover,&:focus{background:", function (_ref6) {
76
- var selected = _ref6.selected;
77
69
  return selected ? colors.brand.light : colors.brand.lightest;
78
- }, ";color:", colors.brand.primary, ";+ ", WrapperForFolderChild, "{opacity:1;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FolderItem.tsx"],"names":[],"mappings":"AA2D2E","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, MouseEvent, useEffect, useRef } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { ArrowDropDown } from '@ndla/icons/common';\nimport { Done } from '@ndla/icons/editor';\nimport { MenuButton } from '@ndla/button';\nimport { FolderOutlined } from '@ndla/icons/contentType';\nimport { colors, spacing, misc, animations } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\nimport { CommonFolderItemsProps, FolderType } from './types';\nimport { arrowNavigation } from './arrowNavigation';\n\nconst OpenButton = styled.button<{ isOpen: boolean }>`\n  background: transparent;\n  border: 0;\n  transform: rotate(${({ isOpen }) => (isOpen ? '0' : '-90')}deg);\n  padding: ${spacing.xsmall};\n  display: flex;\n  margin: 0;\n  color: ${colors.brand.secondary};\n  cursor: pointer;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n  svg {\n    width: 16px;\n    height: 16px;\n    transform: ${({ isOpen }) => (isOpen ? 'translateX(3px)' : 'translateY(3px)')};\n  }\n`;\n\nconst FolderItemWrapper = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst WrapperForFolderChild = styled.div`\n  display: flex;\n  flex-direction: row;\n  align-items: center;\n  gap: ${spacing.xsmall};\n`;\n\nconst shouldForwardProp = (name: string) => !['selected', 'noArrow', 'fullWidth'].includes(name);\n\ninterface FolderNameProps {\n  selected?: boolean;\n  noArrow?: boolean;\n  fullWidth?: boolean;\n}\n\nconst FolderName = styled('button', { shouldForwardProp })<FolderNameProps>`\n  cursor: pointer;\n  padding: ${spacing.xsmall};\n  margin: 0;\n  outline-offset: -2px;\n  outline-color: ${colors.brand.primary};\n  margin-left: ${({ noArrow }) => (noArrow ? `29px` : `0px`)};\n  flex-grow: ${({ fullWidth }) => fullWidth && 1};\n  display: grid;\n  grid-template-columns: auto 1fr auto;\n  align-items: center;\n  gap: ${spacing.xxsmall};\n  border: 0;\n  border-radius: ${misc.borderRadius};\n  box-shadow: none;\n  background: ${({ selected }) => (selected ? colors.brand.lighter : 'transparent')};\n  color: ${colors.text.primary};\n  transition: ${animations.durations.superFast};\n  text-align: left;\n  line-height: 1;\n  word-break: break-word;\n  &:hover,\n  &:focus {\n    background: ${({ selected }) => (selected ? colors.brand.light : colors.brand.lightest)};\n    color: ${colors.brand.primary};\n    + ${WrapperForFolderChild} {\n      opacity: 1;\n    }\n  }\n`;\n\nconst StyledDone = styled(Done)`\n  color: ${colors.support.green};\n`;\n\nconst FolderNameLink = FolderName.withComponent(SafeLink);\n\ninterface Props extends CommonFolderItemsProps {\n  hideArrow?: boolean;\n  isOpen: boolean;\n  folder: FolderType;\n  noPaddingWhenArrowIsHidden?: boolean;\n}\n\nconst FolderItem = ({\n  focusedFolderId,\n  menuItems,\n  hideArrow,\n  folder,\n  isOpen,\n  level,\n  loading,\n  selectedFolder,\n  noPaddingWhenArrowIsHidden,\n  onCloseFolder,\n  onOpenFolder,\n  onSelectFolder,\n  openOnFolderClick,\n  setFocusedId,\n  setSelectedFolder,\n  targetResource,\n  visibleFolders,\n  framed,\n}: Props) => {\n  const { t } = useTranslation();\n  const { id, icon, name } = folder;\n  const ref = useRef<HTMLButtonElement & HTMLAnchorElement>(null);\n  const selected = selectedFolder && selectedFolder.id === id;\n  const focused = focusedFolderId === id;\n\n  const handleClickFolder = () => {\n    if (openOnFolderClick) {\n      if (selected) {\n        if (isOpen) {\n          onCloseFolder(id);\n        } else {\n          onOpenFolder(id);\n        }\n      }\n    }\n    if (!selected) {\n      setSelectedFolder(folder);\n      setFocusedId(id);\n    }\n    onSelectFolder?.(id);\n  };\n\n  useEffect(() => {\n    if (focusedFolderId === id) {\n      ref.current?.focus();\n    }\n  }, [focusedFolderId, ref, id]);\n\n  const actions = menuItems?.map((item) => {\n    const { onClick } = item;\n    return {\n      ...item,\n      onClick: (e?: MouseEvent<HTMLDivElement>) => onClick(e, folder),\n    };\n  });\n\n  const linkPath = `/minndla${level > 0 ? '/folders' : ''}/${id}`;\n\n  const containsResource =\n    targetResource && folder.resources.some((resource) => resource.resourceId === targetResource.resourceId);\n\n  return (\n    <FolderItemWrapper>\n      {!hideArrow && (\n        <OpenButton\n          tabIndex={-1}\n          isOpen={isOpen}\n          disabled={loading}\n          onClick={() => (isOpen ? onCloseFolder(id) : onOpenFolder(id))}>\n          <ArrowDropDown />\n        </OpenButton>\n      )}\n      {onSelectFolder ? (\n        <>\n          <FolderName\n            fullWidth={framed}\n            ref={ref}\n            onKeyDown={(e) => arrowNavigation(e, id, visibleFolders, setFocusedId, onOpenFolder, onCloseFolder)}\n            noArrow={hideArrow && !noPaddingWhenArrowIsHidden}\n            tabIndex={selected || focused ? 0 : -1}\n            selected={selected}\n            disabled={loading}\n            onFocus={() => setFocusedId(id)}\n            onClick={handleClickFolder}>\n            {icon || <FolderOutlined />}\n            {name}\n            <WrapperForFolderChild>\n              {containsResource && <StyledDone title={t('myNdla.alreadyInFolder')} />}\n              {actions && (\n                <MenuButton\n                  onClick={(e) => e.stopPropagation()}\n                  size=\"xsmall\"\n                  menuItems={actions}\n                  tabIndex={selected || id === focusedFolderId ? 0 : -1}\n                />\n              )}\n            </WrapperForFolderChild>\n          </FolderName>\n        </>\n      ) : (\n        <FolderNameLink\n          ref={ref}\n          onKeyDown={(e: KeyboardEvent<HTMLElement>) =>\n            arrowNavigation(e, id, visibleFolders, setFocusedId, onOpenFolder, onCloseFolder)\n          }\n          noArrow={hideArrow}\n          to={loading ? '' : linkPath}\n          tabIndex={selected || focused || level === 0 ? 0 : -1}\n          selected={selected}\n          onFocus={() => setFocusedId(id)}\n          onClick={handleClickFolder}>\n          {icon || <FolderOutlined />}\n          {name}\n        </FolderNameLink>\n      )}\n    </FolderItemWrapper>\n  );\n};\n\nexport default FolderItem;\n"]} */"));
70
+ }, ";color:", colors.text.primary, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FolderItem.tsx"],"names":[],"mappings":"AA4DyE","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 { 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 { CommonFolderItemsProps, FolderType } from './types';\nimport { arrowNavigation } from './arrowNavigation';\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  grid-column-start: 2;\n  text-align: left;\n`;\n\nconst WrapperForFolderChild = styled.div`\n  display: flex;\n  flex-direction: row;\n  align-items: center;\n  gap: ${spacing.xsmall};\n  margin-left: auto;\n`;\n\nconst shouldForwardProp = (name: string) => !['selected', 'noArrow', 'fullWidth', 'level'].includes(name);\n\ninterface FolderNameProps {\n  selected?: boolean;\n  noArrow?: boolean;\n  fullWidth?: boolean;\n  level: number;\n  isCreatingFolder?: boolean;\n}\n\nconst FolderName = styled(Button, { shouldForwardProp })<FolderNameProps>`\n  display: grid;\n  grid-template-columns: ${spacing.medium} 1fr auto;\n\n  padding-left: ${({ level }) => 0.75 * spacingUnit * level}px;\n  gap: ${spacing.xxsmall};\n  border: none;\n  outline: none;\n  background: ${({ selected, isCreatingFolder }) => selected && !isCreatingFolder && colors.brand.lighter};\n  color: ${({ isCreatingFolder, selected }) =>\n    isCreatingFolder && selected ? colors.brand.primary : colors.text.primary};\n  transition: ${animations.durations.superFast};\n  line-height: 1;\n  word-break: break-word;\n  &:hover,\n  &:focus {\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  line-height: 1;\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: FolderType;\n  isCreatingFolder?: boolean;\n}\n\nconst FolderItem = ({\n  focusedFolderId,\n  folder,\n  isOpen,\n  level,\n  loading,\n  selectedFolder,\n  onCloseFolder,\n  onOpenFolder,\n  onSelectFolder,\n  openOnFolderClick,\n  setFocusedId,\n  setSelectedFolder,\n  targetResource,\n  visibleFolders,\n  framed,\n  maxLevel,\n  isCreatingFolder,\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;\n  const focused = focusedFolderId === id;\n\n  const handleClickFolder = () => {\n    if (openOnFolderClick) {\n      if (selected) {\n        if (isOpen) {\n          onCloseFolder(id);\n        } else {\n          onOpenFolder(id);\n        }\n      }\n    }\n    if (!selected) {\n      setSelectedFolder(folder);\n      setFocusedId(id);\n    }\n    onSelectFolder?.(id);\n  };\n\n  useEffect(() => {\n    if (focusedFolderId === id && !isCreatingFolder) {\n      ref.current?.focus();\n    }\n  }, [focusedFolderId, ref, id, isCreatingFolder]);\n\n  const linkPath = `/minndla${level > 0 ? '/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\n  const isMaxDepth = level > maxLevel;\n\n  const hideArrow = isMaxDepth || emptyFolder;\n\n  return onSelectFolder ? (\n    <FolderName\n      variant=\"ghost\"\n      shape=\"sharp\"\n      fontWeight=\"normal\"\n      colorTheme=\"light\"\n      ref={ref}\n      level={level}\n      fullWidth={framed}\n      onKeyDown={(e) => arrowNavigation(e, id, visibleFolders, setFocusedId, onOpenFolder, onCloseFolder)}\n      noArrow={hideArrow}\n      tabIndex={selected || focused ? 0 : -1}\n      selected={selected}\n      disabled={loading}\n      onFocus={() => setFocusedId(id)}\n      onClick={handleClickFolder}\n      isCreatingFolder={isCreatingFolder}>\n      {!hideArrow && (\n        <OpenButton\n          tabIndex={-1}\n          isOpen={isOpen}\n          onClick={() => {\n            ref.current?.focus();\n            if (isOpen) {\n              onCloseFolder(id);\n            } else {\n              onOpenFolder(id);\n            }\n          }}>\n          <ArrowDropDownRounded />\n        </OpenButton>\n      )}\n      <StyledName>{name}</StyledName>\n      <WrapperForFolderChild>\n        {containsResource && <StyledDone title={t('myNdla.alreadyInFolder')} />}\n      </WrapperForFolderChild>\n    </FolderName>\n  ) : (\n    <FolderNameLink\n      ref={ref}\n      level={level}\n      onKeyDown={(e: KeyboardEvent<HTMLElement>) =>\n        arrowNavigation(e, id, visibleFolders, setFocusedId, onOpenFolder, onCloseFolder)\n      }\n      noArrow={!isMaxDepth}\n      to={loading ? '' : linkPath}\n      tabIndex={selected || focused ? 0 : -1}\n      selected={selected}\n      onFocus={() => setFocusedId(id)}\n      onClick={handleClickFolder}>\n      {(!hideArrow || level === 0) && (\n        <OpenButton\n          tabIndex={-1}\n          isOpen={isOpen}\n          onClick={() => {\n            ref.current?.focus();\n            if (isOpen) {\n              onCloseFolder(id);\n            } else {\n              onOpenFolder(id);\n            }\n          }}>\n          <ArrowDropDownRounded />\n        </OpenButton>\n      )}\n      <StyledName>{name}</StyledName>\n    </FolderNameLink>\n  );\n};\n\nexport default FolderItem;\n"]} */"));
79
71
 
80
72
  var StyledDone = /*#__PURE__*/_styled(Done, {
81
73
  target: "e11ok6h84",
82
74
  label: "StyledDone"
83
- })("color:", 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, MouseEvent, useEffect, useRef } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { ArrowDropDown } from '@ndla/icons/common';\nimport { Done } from '@ndla/icons/editor';\nimport { MenuButton } from '@ndla/button';\nimport { FolderOutlined } from '@ndla/icons/contentType';\nimport { colors, spacing, misc, animations } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\nimport { CommonFolderItemsProps, FolderType } from './types';\nimport { arrowNavigation } from './arrowNavigation';\n\nconst OpenButton = styled.button<{ isOpen: boolean }>`\n  background: transparent;\n  border: 0;\n  transform: rotate(${({ isOpen }) => (isOpen ? '0' : '-90')}deg);\n  padding: ${spacing.xsmall};\n  display: flex;\n  margin: 0;\n  color: ${colors.brand.secondary};\n  cursor: pointer;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n  svg {\n    width: 16px;\n    height: 16px;\n    transform: ${({ isOpen }) => (isOpen ? 'translateX(3px)' : 'translateY(3px)')};\n  }\n`;\n\nconst FolderItemWrapper = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst WrapperForFolderChild = styled.div`\n  display: flex;\n  flex-direction: row;\n  align-items: center;\n  gap: ${spacing.xsmall};\n`;\n\nconst shouldForwardProp = (name: string) => !['selected', 'noArrow', 'fullWidth'].includes(name);\n\ninterface FolderNameProps {\n  selected?: boolean;\n  noArrow?: boolean;\n  fullWidth?: boolean;\n}\n\nconst FolderName = styled('button', { shouldForwardProp })<FolderNameProps>`\n  cursor: pointer;\n  padding: ${spacing.xsmall};\n  margin: 0;\n  outline-offset: -2px;\n  outline-color: ${colors.brand.primary};\n  margin-left: ${({ noArrow }) => (noArrow ? `29px` : `0px`)};\n  flex-grow: ${({ fullWidth }) => fullWidth && 1};\n  display: grid;\n  grid-template-columns: auto 1fr auto;\n  align-items: center;\n  gap: ${spacing.xxsmall};\n  border: 0;\n  border-radius: ${misc.borderRadius};\n  box-shadow: none;\n  background: ${({ selected }) => (selected ? colors.brand.lighter : 'transparent')};\n  color: ${colors.text.primary};\n  transition: ${animations.durations.superFast};\n  text-align: left;\n  line-height: 1;\n  word-break: break-word;\n  &:hover,\n  &:focus {\n    background: ${({ selected }) => (selected ? colors.brand.light : colors.brand.lightest)};\n    color: ${colors.brand.primary};\n    + ${WrapperForFolderChild} {\n      opacity: 1;\n    }\n  }\n`;\n\nconst StyledDone = styled(Done)`\n  color: ${colors.support.green};\n`;\n\nconst FolderNameLink = FolderName.withComponent(SafeLink);\n\ninterface Props extends CommonFolderItemsProps {\n  hideArrow?: boolean;\n  isOpen: boolean;\n  folder: FolderType;\n  noPaddingWhenArrowIsHidden?: boolean;\n}\n\nconst FolderItem = ({\n  focusedFolderId,\n  menuItems,\n  hideArrow,\n  folder,\n  isOpen,\n  level,\n  loading,\n  selectedFolder,\n  noPaddingWhenArrowIsHidden,\n  onCloseFolder,\n  onOpenFolder,\n  onSelectFolder,\n  openOnFolderClick,\n  setFocusedId,\n  setSelectedFolder,\n  targetResource,\n  visibleFolders,\n  framed,\n}: Props) => {\n  const { t } = useTranslation();\n  const { id, icon, name } = folder;\n  const ref = useRef<HTMLButtonElement & HTMLAnchorElement>(null);\n  const selected = selectedFolder && selectedFolder.id === id;\n  const focused = focusedFolderId === id;\n\n  const handleClickFolder = () => {\n    if (openOnFolderClick) {\n      if (selected) {\n        if (isOpen) {\n          onCloseFolder(id);\n        } else {\n          onOpenFolder(id);\n        }\n      }\n    }\n    if (!selected) {\n      setSelectedFolder(folder);\n      setFocusedId(id);\n    }\n    onSelectFolder?.(id);\n  };\n\n  useEffect(() => {\n    if (focusedFolderId === id) {\n      ref.current?.focus();\n    }\n  }, [focusedFolderId, ref, id]);\n\n  const actions = menuItems?.map((item) => {\n    const { onClick } = item;\n    return {\n      ...item,\n      onClick: (e?: MouseEvent<HTMLDivElement>) => onClick(e, folder),\n    };\n  });\n\n  const linkPath = `/minndla${level > 0 ? '/folders' : ''}/${id}`;\n\n  const containsResource =\n    targetResource && folder.resources.some((resource) => resource.resourceId === targetResource.resourceId);\n\n  return (\n    <FolderItemWrapper>\n      {!hideArrow && (\n        <OpenButton\n          tabIndex={-1}\n          isOpen={isOpen}\n          disabled={loading}\n          onClick={() => (isOpen ? onCloseFolder(id) : onOpenFolder(id))}>\n          <ArrowDropDown />\n        </OpenButton>\n      )}\n      {onSelectFolder ? (\n        <>\n          <FolderName\n            fullWidth={framed}\n            ref={ref}\n            onKeyDown={(e) => arrowNavigation(e, id, visibleFolders, setFocusedId, onOpenFolder, onCloseFolder)}\n            noArrow={hideArrow && !noPaddingWhenArrowIsHidden}\n            tabIndex={selected || focused ? 0 : -1}\n            selected={selected}\n            disabled={loading}\n            onFocus={() => setFocusedId(id)}\n            onClick={handleClickFolder}>\n            {icon || <FolderOutlined />}\n            {name}\n            <WrapperForFolderChild>\n              {containsResource && <StyledDone title={t('myNdla.alreadyInFolder')} />}\n              {actions && (\n                <MenuButton\n                  onClick={(e) => e.stopPropagation()}\n                  size=\"xsmall\"\n                  menuItems={actions}\n                  tabIndex={selected || id === focusedFolderId ? 0 : -1}\n                />\n              )}\n            </WrapperForFolderChild>\n          </FolderName>\n        </>\n      ) : (\n        <FolderNameLink\n          ref={ref}\n          onKeyDown={(e: KeyboardEvent<HTMLElement>) =>\n            arrowNavigation(e, id, visibleFolders, setFocusedId, onOpenFolder, onCloseFolder)\n          }\n          noArrow={hideArrow}\n          to={loading ? '' : linkPath}\n          tabIndex={selected || focused || level === 0 ? 0 : -1}\n          selected={selected}\n          onFocus={() => setFocusedId(id)}\n          onClick={handleClickFolder}>\n          {icon || <FolderOutlined />}\n          {name}\n        </FolderNameLink>\n      )}\n    </FolderItemWrapper>\n  );\n};\n\nexport default FolderItem;\n"]} */"));
75
+ })("color:", colors.support.green, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FolderItem.tsx"],"names":[],"mappings":"AAmF+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 { 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 { CommonFolderItemsProps, FolderType } from './types';\nimport { arrowNavigation } from './arrowNavigation';\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  grid-column-start: 2;\n  text-align: left;\n`;\n\nconst WrapperForFolderChild = styled.div`\n  display: flex;\n  flex-direction: row;\n  align-items: center;\n  gap: ${spacing.xsmall};\n  margin-left: auto;\n`;\n\nconst shouldForwardProp = (name: string) => !['selected', 'noArrow', 'fullWidth', 'level'].includes(name);\n\ninterface FolderNameProps {\n  selected?: boolean;\n  noArrow?: boolean;\n  fullWidth?: boolean;\n  level: number;\n  isCreatingFolder?: boolean;\n}\n\nconst FolderName = styled(Button, { shouldForwardProp })<FolderNameProps>`\n  display: grid;\n  grid-template-columns: ${spacing.medium} 1fr auto;\n\n  padding-left: ${({ level }) => 0.75 * spacingUnit * level}px;\n  gap: ${spacing.xxsmall};\n  border: none;\n  outline: none;\n  background: ${({ selected, isCreatingFolder }) => selected && !isCreatingFolder && colors.brand.lighter};\n  color: ${({ isCreatingFolder, selected }) =>\n    isCreatingFolder && selected ? colors.brand.primary : colors.text.primary};\n  transition: ${animations.durations.superFast};\n  line-height: 1;\n  word-break: break-word;\n  &:hover,\n  &:focus {\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  line-height: 1;\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: FolderType;\n  isCreatingFolder?: boolean;\n}\n\nconst FolderItem = ({\n  focusedFolderId,\n  folder,\n  isOpen,\n  level,\n  loading,\n  selectedFolder,\n  onCloseFolder,\n  onOpenFolder,\n  onSelectFolder,\n  openOnFolderClick,\n  setFocusedId,\n  setSelectedFolder,\n  targetResource,\n  visibleFolders,\n  framed,\n  maxLevel,\n  isCreatingFolder,\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;\n  const focused = focusedFolderId === id;\n\n  const handleClickFolder = () => {\n    if (openOnFolderClick) {\n      if (selected) {\n        if (isOpen) {\n          onCloseFolder(id);\n        } else {\n          onOpenFolder(id);\n        }\n      }\n    }\n    if (!selected) {\n      setSelectedFolder(folder);\n      setFocusedId(id);\n    }\n    onSelectFolder?.(id);\n  };\n\n  useEffect(() => {\n    if (focusedFolderId === id && !isCreatingFolder) {\n      ref.current?.focus();\n    }\n  }, [focusedFolderId, ref, id, isCreatingFolder]);\n\n  const linkPath = `/minndla${level > 0 ? '/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\n  const isMaxDepth = level > maxLevel;\n\n  const hideArrow = isMaxDepth || emptyFolder;\n\n  return onSelectFolder ? (\n    <FolderName\n      variant=\"ghost\"\n      shape=\"sharp\"\n      fontWeight=\"normal\"\n      colorTheme=\"light\"\n      ref={ref}\n      level={level}\n      fullWidth={framed}\n      onKeyDown={(e) => arrowNavigation(e, id, visibleFolders, setFocusedId, onOpenFolder, onCloseFolder)}\n      noArrow={hideArrow}\n      tabIndex={selected || focused ? 0 : -1}\n      selected={selected}\n      disabled={loading}\n      onFocus={() => setFocusedId(id)}\n      onClick={handleClickFolder}\n      isCreatingFolder={isCreatingFolder}>\n      {!hideArrow && (\n        <OpenButton\n          tabIndex={-1}\n          isOpen={isOpen}\n          onClick={() => {\n            ref.current?.focus();\n            if (isOpen) {\n              onCloseFolder(id);\n            } else {\n              onOpenFolder(id);\n            }\n          }}>\n          <ArrowDropDownRounded />\n        </OpenButton>\n      )}\n      <StyledName>{name}</StyledName>\n      <WrapperForFolderChild>\n        {containsResource && <StyledDone title={t('myNdla.alreadyInFolder')} />}\n      </WrapperForFolderChild>\n    </FolderName>\n  ) : (\n    <FolderNameLink\n      ref={ref}\n      level={level}\n      onKeyDown={(e: KeyboardEvent<HTMLElement>) =>\n        arrowNavigation(e, id, visibleFolders, setFocusedId, onOpenFolder, onCloseFolder)\n      }\n      noArrow={!isMaxDepth}\n      to={loading ? '' : linkPath}\n      tabIndex={selected || focused ? 0 : -1}\n      selected={selected}\n      onFocus={() => setFocusedId(id)}\n      onClick={handleClickFolder}>\n      {(!hideArrow || level === 0) && (\n        <OpenButton\n          tabIndex={-1}\n          isOpen={isOpen}\n          onClick={() => {\n            ref.current?.focus();\n            if (isOpen) {\n              onCloseFolder(id);\n            } else {\n              onOpenFolder(id);\n            }\n          }}>\n          <ArrowDropDownRounded />\n        </OpenButton>\n      )}\n      <StyledName>{name}</StyledName>\n    </FolderNameLink>\n  );\n};\n\nexport default FolderItem;\n"]} */"));
84
76
 
85
- var FolderNameLink = FolderName.withComponent(SafeLink, {
77
+ var FolderNameLink = /*#__PURE__*/_styled(SafeLink, {
78
+ shouldForwardProp: shouldForwardProp,
86
79
  target: "e11ok6h85",
87
80
  label: "FolderNameLink"
88
- });
89
-
90
- var FolderItem = function FolderItem(_ref7) {
91
- var focusedFolderId = _ref7.focusedFolderId,
92
- menuItems = _ref7.menuItems,
93
- hideArrow = _ref7.hideArrow,
94
- folder = _ref7.folder,
95
- isOpen = _ref7.isOpen,
96
- level = _ref7.level,
97
- loading = _ref7.loading,
98
- selectedFolder = _ref7.selectedFolder,
99
- noPaddingWhenArrowIsHidden = _ref7.noPaddingWhenArrowIsHidden,
100
- onCloseFolder = _ref7.onCloseFolder,
101
- onOpenFolder = _ref7.onOpenFolder,
102
- onSelectFolder = _ref7.onSelectFolder,
103
- openOnFolderClick = _ref7.openOnFolderClick,
104
- setFocusedId = _ref7.setFocusedId,
105
- setSelectedFolder = _ref7.setSelectedFolder,
106
- targetResource = _ref7.targetResource,
107
- visibleFolders = _ref7.visibleFolders,
108
- framed = _ref7.framed;
81
+ })("display:grid;align-items:center;grid-template-columns:", spacing.medium, " 1fr auto;padding:", spacing.small, " ", spacing.xxsmall, ";margin-left:", function (_ref6) {
82
+ var level = _ref6.level;
83
+ return 0.75 * spacingUnit * level;
84
+ }, "px;gap:", spacing.xxsmall, ";cursor:pointer;border:none;box-shadow:none;color:", function (_ref7) {
85
+ var selected = _ref7.selected;
86
+ return selected ? colors.brand.primary : colors.text.primary;
87
+ }, ";font-weight:", function (_ref8) {
88
+ var selected = _ref8.selected;
89
+ return selected && fonts.weight.semibold;
90
+ }, ";font-size:", fonts.sizes('16px'), ";transition:", animations.durations.superFast, ";line-height:1;word-break:break-word;&:hover,&:focus{color:", colors.brand.primary, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FolderItem.tsx"],"names":[],"mappings":"AAuF+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 { 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 { CommonFolderItemsProps, FolderType } from './types';\nimport { arrowNavigation } from './arrowNavigation';\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  grid-column-start: 2;\n  text-align: left;\n`;\n\nconst WrapperForFolderChild = styled.div`\n  display: flex;\n  flex-direction: row;\n  align-items: center;\n  gap: ${spacing.xsmall};\n  margin-left: auto;\n`;\n\nconst shouldForwardProp = (name: string) => !['selected', 'noArrow', 'fullWidth', 'level'].includes(name);\n\ninterface FolderNameProps {\n  selected?: boolean;\n  noArrow?: boolean;\n  fullWidth?: boolean;\n  level: number;\n  isCreatingFolder?: boolean;\n}\n\nconst FolderName = styled(Button, { shouldForwardProp })<FolderNameProps>`\n  display: grid;\n  grid-template-columns: ${spacing.medium} 1fr auto;\n\n  padding-left: ${({ level }) => 0.75 * spacingUnit * level}px;\n  gap: ${spacing.xxsmall};\n  border: none;\n  outline: none;\n  background: ${({ selected, isCreatingFolder }) => selected && !isCreatingFolder && colors.brand.lighter};\n  color: ${({ isCreatingFolder, selected }) =>\n    isCreatingFolder && selected ? colors.brand.primary : colors.text.primary};\n  transition: ${animations.durations.superFast};\n  line-height: 1;\n  word-break: break-word;\n  &:hover,\n  &:focus {\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  line-height: 1;\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: FolderType;\n  isCreatingFolder?: boolean;\n}\n\nconst FolderItem = ({\n  focusedFolderId,\n  folder,\n  isOpen,\n  level,\n  loading,\n  selectedFolder,\n  onCloseFolder,\n  onOpenFolder,\n  onSelectFolder,\n  openOnFolderClick,\n  setFocusedId,\n  setSelectedFolder,\n  targetResource,\n  visibleFolders,\n  framed,\n  maxLevel,\n  isCreatingFolder,\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;\n  const focused = focusedFolderId === id;\n\n  const handleClickFolder = () => {\n    if (openOnFolderClick) {\n      if (selected) {\n        if (isOpen) {\n          onCloseFolder(id);\n        } else {\n          onOpenFolder(id);\n        }\n      }\n    }\n    if (!selected) {\n      setSelectedFolder(folder);\n      setFocusedId(id);\n    }\n    onSelectFolder?.(id);\n  };\n\n  useEffect(() => {\n    if (focusedFolderId === id && !isCreatingFolder) {\n      ref.current?.focus();\n    }\n  }, [focusedFolderId, ref, id, isCreatingFolder]);\n\n  const linkPath = `/minndla${level > 0 ? '/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\n  const isMaxDepth = level > maxLevel;\n\n  const hideArrow = isMaxDepth || emptyFolder;\n\n  return onSelectFolder ? (\n    <FolderName\n      variant=\"ghost\"\n      shape=\"sharp\"\n      fontWeight=\"normal\"\n      colorTheme=\"light\"\n      ref={ref}\n      level={level}\n      fullWidth={framed}\n      onKeyDown={(e) => arrowNavigation(e, id, visibleFolders, setFocusedId, onOpenFolder, onCloseFolder)}\n      noArrow={hideArrow}\n      tabIndex={selected || focused ? 0 : -1}\n      selected={selected}\n      disabled={loading}\n      onFocus={() => setFocusedId(id)}\n      onClick={handleClickFolder}\n      isCreatingFolder={isCreatingFolder}>\n      {!hideArrow && (\n        <OpenButton\n          tabIndex={-1}\n          isOpen={isOpen}\n          onClick={() => {\n            ref.current?.focus();\n            if (isOpen) {\n              onCloseFolder(id);\n            } else {\n              onOpenFolder(id);\n            }\n          }}>\n          <ArrowDropDownRounded />\n        </OpenButton>\n      )}\n      <StyledName>{name}</StyledName>\n      <WrapperForFolderChild>\n        {containsResource && <StyledDone title={t('myNdla.alreadyInFolder')} />}\n      </WrapperForFolderChild>\n    </FolderName>\n  ) : (\n    <FolderNameLink\n      ref={ref}\n      level={level}\n      onKeyDown={(e: KeyboardEvent<HTMLElement>) =>\n        arrowNavigation(e, id, visibleFolders, setFocusedId, onOpenFolder, onCloseFolder)\n      }\n      noArrow={!isMaxDepth}\n      to={loading ? '' : linkPath}\n      tabIndex={selected || focused ? 0 : -1}\n      selected={selected}\n      onFocus={() => setFocusedId(id)}\n      onClick={handleClickFolder}>\n      {(!hideArrow || level === 0) && (\n        <OpenButton\n          tabIndex={-1}\n          isOpen={isOpen}\n          onClick={() => {\n            ref.current?.focus();\n            if (isOpen) {\n              onCloseFolder(id);\n            } else {\n              onOpenFolder(id);\n            }\n          }}>\n          <ArrowDropDownRounded />\n        </OpenButton>\n      )}\n      <StyledName>{name}</StyledName>\n    </FolderNameLink>\n  );\n};\n\nexport default FolderItem;\n"]} */"));
91
+
92
+ var FolderItem = function FolderItem(_ref9) {
93
+ var focusedFolderId = _ref9.focusedFolderId,
94
+ folder = _ref9.folder,
95
+ isOpen = _ref9.isOpen,
96
+ level = _ref9.level,
97
+ loading = _ref9.loading,
98
+ selectedFolder = _ref9.selectedFolder,
99
+ onCloseFolder = _ref9.onCloseFolder,
100
+ onOpenFolder = _ref9.onOpenFolder,
101
+ onSelectFolder = _ref9.onSelectFolder,
102
+ openOnFolderClick = _ref9.openOnFolderClick,
103
+ setFocusedId = _ref9.setFocusedId,
104
+ setSelectedFolder = _ref9.setSelectedFolder,
105
+ targetResource = _ref9.targetResource,
106
+ visibleFolders = _ref9.visibleFolders,
107
+ framed = _ref9.framed,
108
+ maxLevel = _ref9.maxLevel,
109
+ isCreatingFolder = _ref9.isCreatingFolder;
109
110
 
110
111
  var _useTranslation = useTranslation(),
111
112
  t = _useTranslation.t;
112
113
 
113
114
  var id = folder.id,
114
- icon = folder.icon,
115
115
  name = folder.name;
116
116
  var ref = useRef(null);
117
117
  var selected = selectedFolder && selectedFolder.id === id;
@@ -137,68 +137,84 @@ var FolderItem = function FolderItem(_ref7) {
137
137
  };
138
138
 
139
139
  useEffect(function () {
140
- if (focusedFolderId === id) {
140
+ if (focusedFolderId === id && !isCreatingFolder) {
141
141
  var _ref$current;
142
142
 
143
143
  (_ref$current = ref.current) === null || _ref$current === void 0 ? void 0 : _ref$current.focus();
144
144
  }
145
- }, [focusedFolderId, ref, id]);
146
- var actions = menuItems === null || menuItems === void 0 ? void 0 : menuItems.map(function (item) {
147
- var _onClick = item.onClick;
148
- return _objectSpread(_objectSpread({}, item), {}, {
149
- onClick: function onClick(e) {
150
- return _onClick(e, folder);
151
- }
152
- });
153
- });
145
+ }, [focusedFolderId, ref, id, isCreatingFolder]);
154
146
  var linkPath = "/minndla".concat(level > 0 ? '/folders' : '', "/").concat(id);
155
147
  var containsResource = targetResource && folder.resources.some(function (resource) {
156
148
  return resource.resourceId === targetResource.resourceId;
157
149
  });
158
- return ___EmotionJSX(FolderItemWrapper, null, !hideArrow && ___EmotionJSX(OpenButton, {
159
- tabIndex: -1,
160
- isOpen: isOpen,
161
- disabled: loading,
162
- onClick: function onClick() {
163
- return isOpen ? onCloseFolder(id) : onOpenFolder(id);
164
- }
165
- }, ___EmotionJSX(ArrowDropDown, null)), onSelectFolder ? ___EmotionJSX(React.Fragment, null, ___EmotionJSX(FolderName, {
166
- fullWidth: framed,
150
+ var emptyFolder = folder.subfolders.length === 0;
151
+ var isMaxDepth = level > maxLevel;
152
+ var hideArrow = isMaxDepth || emptyFolder;
153
+ return onSelectFolder ? ___EmotionJSX(FolderName, {
154
+ variant: "ghost",
155
+ shape: "sharp",
156
+ fontWeight: "normal",
157
+ colorTheme: "light",
167
158
  ref: ref,
159
+ level: level,
160
+ fullWidth: framed,
168
161
  onKeyDown: function onKeyDown(e) {
169
162
  return arrowNavigation(e, id, visibleFolders, setFocusedId, onOpenFolder, onCloseFolder);
170
163
  },
171
- noArrow: hideArrow && !noPaddingWhenArrowIsHidden,
164
+ noArrow: hideArrow,
172
165
  tabIndex: selected || focused ? 0 : -1,
173
166
  selected: selected,
174
167
  disabled: loading,
175
168
  onFocus: function onFocus() {
176
169
  return setFocusedId(id);
177
170
  },
178
- onClick: handleClickFolder
179
- }, icon || ___EmotionJSX(FolderOutlined, null), name, ___EmotionJSX(WrapperForFolderChild, null, containsResource && ___EmotionJSX(StyledDone, {
171
+ onClick: handleClickFolder,
172
+ isCreatingFolder: isCreatingFolder
173
+ }, !hideArrow && ___EmotionJSX(OpenButton, {
174
+ tabIndex: -1,
175
+ isOpen: isOpen,
176
+ onClick: function onClick() {
177
+ var _ref$current2;
178
+
179
+ (_ref$current2 = ref.current) === null || _ref$current2 === void 0 ? void 0 : _ref$current2.focus();
180
+
181
+ if (isOpen) {
182
+ onCloseFolder(id);
183
+ } else {
184
+ onOpenFolder(id);
185
+ }
186
+ }
187
+ }, ___EmotionJSX(ArrowDropDownRounded, null)), ___EmotionJSX(StyledName, null, name), ___EmotionJSX(WrapperForFolderChild, null, containsResource && ___EmotionJSX(StyledDone, {
180
188
  title: t('myNdla.alreadyInFolder')
181
- }), actions && ___EmotionJSX(MenuButton, {
182
- onClick: function onClick(e) {
183
- return e.stopPropagation();
184
- },
185
- size: "xsmall",
186
- menuItems: actions,
187
- tabIndex: selected || id === focusedFolderId ? 0 : -1
188
- })))) : ___EmotionJSX(FolderNameLink, {
189
+ }))) : ___EmotionJSX(FolderNameLink, {
189
190
  ref: ref,
191
+ level: level,
190
192
  onKeyDown: function onKeyDown(e) {
191
193
  return arrowNavigation(e, id, visibleFolders, setFocusedId, onOpenFolder, onCloseFolder);
192
194
  },
193
- noArrow: hideArrow,
195
+ noArrow: !isMaxDepth,
194
196
  to: loading ? '' : linkPath,
195
- tabIndex: selected || focused || level === 0 ? 0 : -1,
197
+ tabIndex: selected || focused ? 0 : -1,
196
198
  selected: selected,
197
199
  onFocus: function onFocus() {
198
200
  return setFocusedId(id);
199
201
  },
200
202
  onClick: handleClickFolder
201
- }, icon || ___EmotionJSX(FolderOutlined, null), name));
203
+ }, (!hideArrow || level === 0) && ___EmotionJSX(OpenButton, {
204
+ tabIndex: -1,
205
+ isOpen: isOpen,
206
+ onClick: function onClick() {
207
+ var _ref$current3;
208
+
209
+ (_ref$current3 = ref.current) === null || _ref$current3 === void 0 ? void 0 : _ref$current3.focus();
210
+
211
+ if (isOpen) {
212
+ onCloseFolder(id);
213
+ } else {
214
+ onOpenFolder(id);
215
+ }
216
+ }
217
+ }, ___EmotionJSX(ArrowDropDownRounded, null)), ___EmotionJSX(StyledName, null, name));
202
218
  };
203
219
 
204
220
  export default FolderItem;