@ndla/ui 54.0.0 → 54.0.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (60) hide show
  1. package/es/Article/ArticleByline.js +15 -7
  2. package/es/Article/ArticleParagraph.js +5 -5
  3. package/es/BlogPost/BlogPost.js +6 -5
  4. package/es/CampaignBlock/CampaignBlock.js +7 -7
  5. package/es/CodeBlock/CodeBlock.js +4 -4
  6. package/es/Embed/IframeEmbed.js +1 -0
  7. package/es/KeyFigure/KeyFigure.js +5 -5
  8. package/es/MyNdla/Resource/Folder.js +37 -24
  9. package/es/ResourceBox/ResourceBox.js +6 -6
  10. package/es/Search/SearchResultSleeve.js +11 -11
  11. package/es/Table/Table.js +6 -6
  12. package/es/TreeStructure/FolderItem.js +7 -7
  13. package/es/locale/messages-en.js +17 -3
  14. package/es/locale/messages-nb.js +17 -3
  15. package/es/locale/messages-nn.js +18 -4
  16. package/es/locale/messages-se.js +17 -3
  17. package/es/locale/messages-sma.js +17 -3
  18. package/lib/Article/ArticleByline.js +15 -7
  19. package/lib/Article/ArticleParagraph.js +5 -5
  20. package/lib/BlogPost/BlogPost.js +6 -5
  21. package/lib/CampaignBlock/CampaignBlock.js +7 -7
  22. package/lib/CodeBlock/CodeBlock.js +4 -4
  23. package/lib/Embed/IframeEmbed.js +1 -0
  24. package/lib/KeyFigure/KeyFigure.js +5 -5
  25. package/lib/MyNdla/Resource/Folder.d.ts +3 -1
  26. package/lib/MyNdla/Resource/Folder.js +35 -22
  27. package/lib/ResourceBox/ResourceBox.js +6 -6
  28. package/lib/Search/SearchResultSleeve.js +11 -11
  29. package/lib/Table/Table.js +6 -6
  30. package/lib/TreeStructure/FolderItem.js +7 -7
  31. package/lib/locale/messages-en.d.ts +14 -0
  32. package/lib/locale/messages-en.js +17 -3
  33. package/lib/locale/messages-nb.d.ts +14 -0
  34. package/lib/locale/messages-nb.js +17 -3
  35. package/lib/locale/messages-nn.d.ts +15 -1
  36. package/lib/locale/messages-nn.js +18 -4
  37. package/lib/locale/messages-se.d.ts +14 -0
  38. package/lib/locale/messages-se.js +17 -3
  39. package/lib/locale/messages-sma.d.ts +14 -0
  40. package/lib/locale/messages-sma.js +17 -3
  41. package/package.json +10 -10
  42. package/src/Article/ArticleByline.tsx +9 -2
  43. package/src/Article/ArticleParagraph.tsx +3 -0
  44. package/src/BlogPost/BlogPost.tsx +2 -1
  45. package/src/CampaignBlock/CampaignBlock.tsx +1 -1
  46. package/src/CodeBlock/CodeBlock.tsx +1 -1
  47. package/src/Embed/IframeEmbed.tsx +1 -0
  48. package/src/KeyFigure/KeyFigure.tsx +1 -1
  49. package/src/MyNdla/Resource/Folder.stories.tsx +5 -0
  50. package/src/MyNdla/Resource/Folder.tsx +41 -8
  51. package/src/ResourceBox/ResourceBox.tsx +2 -2
  52. package/src/Search/SearchResultSleeve.tsx +3 -3
  53. package/src/Table/Table.stories.tsx +39 -0
  54. package/src/Table/Table.tsx +11 -0
  55. package/src/TreeStructure/FolderItem.tsx +1 -1
  56. package/src/locale/messages-en.ts +14 -0
  57. package/src/locale/messages-nb.ts +14 -0
  58. package/src/locale/messages-nn.ts +15 -1
  59. package/src/locale/messages-se.ts +14 -0
  60. package/src/locale/messages-sma.ts +14 -0
@@ -22,7 +22,7 @@ import { jsx as _jsx, jsxs as _jsxs } from "@emotion/react/jsx-runtime";
22
22
  const OpenButton = /*#__PURE__*/_styled("span", {
23
23
  target: "e11ok6h86",
24
24
  label: "OpenButton"
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(-90deg);}&[data-open=\"true\"]{svg{transform:rotate(0deg);}}&[data-hide-arrow=\"true\"]{visibility:hidden;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FolderItem.tsx"],"names":[],"mappings":"AAsB8B","file":"FolderItem.tsx","sourcesContent":["/**\n * Copyright (c) 2022-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { CSSProperties, KeyboardEvent, useEffect, useMemo, useRef } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport styled from \"@emotion/styled\";\nimport { ButtonV2 as Button } from \"@ndla/button\";\nimport { colors, spacing, animations, misc, fonts } from \"@ndla/core\";\nimport { ArrowDropDownRounded } from \"@ndla/icons/common\";\nimport { FolderOutlined, FolderShared } from \"@ndla/icons/contentType\";\nimport { Done } from \"@ndla/icons/editor\";\nimport { SafeLink } from \"@ndla/safelink\";\nimport { IFolder } from \"@ndla/types-backend/myndla-api\";\nimport { arrowNavigation } from \"./arrowNavigation\";\nimport { treestructureId } from \"./helperFunctions\";\nimport { CommonFolderItemsProps } from \"./types\";\n\nconst OpenButton = styled.span`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  align-self: stretch;\n  color: ${colors.brand.tertiary};\n  ${misc.transition.default};\n  cursor: pointer;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n  svg {\n    width: 24px;\n    height: 24px;\n    transform: rotate(-90deg);\n  }\n  &[data-open=\"true\"] {\n    svg {\n      transform: rotate(0deg);\n    }\n  }\n  &[data-hide-arrow=\"true\"] {\n    visibility: hidden;\n  }\n`;\n\nconst StyledName = styled.span`\n  white-space: nowrap;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  grid-column-start: 2;\n  text-align: left;\n`;\n\nconst IconWrapper = styled.div`\n  display: flex;\n`;\n\nconst FolderIconWrapper = styled.div`\n  svg {\n    height: 24px;\n    width: 24px;\n  }\n`;\n\nconst FolderName = styled(Button)`\n  display: grid;\n  grid-template-columns: auto 1fr auto;\n  padding-left: calc(0.75 * ${spacing.normal} * var(--level));\n  gap: ${spacing.xxsmall};\n  border: none;\n  outline: none;\n  color: ${colors.text.primary};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\n\n  &:hover {\n    box-shadow: none;\n    outline: none;\n    background: ${colors.brand.lightest};\n    color: ${colors.text.primary};\n  }\n\n  &[data-focused=\"true\"] {\n    background: ${colors.brand.lightest};\n  }\n\n  &[data-selected=\"true\"] {\n    background: ${colors.brand.lighter};\n    &:hover {\n      background: ${colors.brand.light};\n    }\n  }\n\n  &[data-creating=\"true\"][data-focused=\"true\"] {\n    color: ${colors.brand.primary};\n  }\n\n  &[data-creating=\"true\"] {\n    background: none;\n  }\n`;\n\nconst StyledDone = styled(Done)`\n  color: ${colors.support.green};\n`;\n\nconst FolderNameLink = styled(SafeLink)`\n  display: grid;\n  align-items: center;\n  grid-template-columns: ${spacing.medium} 1fr auto;\n  padding: ${spacing.small} ${spacing.xxsmall};\n  padding-left: calc(0.75 * ${spacing.normal} * var(--level));\n  gap: ${spacing.xxsmall};\n  cursor: pointer;\n\n  border: none;\n  box-shadow: none;\n  color: ${colors.text.primary};\n  font-size: ${fonts.sizes(\"16px\")};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\n  &[data-selected=\"true\"] {\n    color: ${colors.brand.primary};\n    font-weight: ${fonts.weight.semibold};\n  }\n  &:hover,\n  &:focus {\n    color: ${colors.brand.primary};\n  }\n`;\n\ninterface Props extends CommonFolderItemsProps {\n  isOpen: boolean;\n  folder: IFolder;\n  isCreatingFolder?: boolean;\n  index: number;\n}\n\nconst FolderItem = ({\n  focusedFolder,\n  folder,\n  isOpen,\n  level,\n  loading,\n  selectedFolder,\n  onCloseFolder,\n  onOpenFolder,\n  setFocusedFolder,\n  setSelectedFolder,\n  targetResource,\n  visibleFolders,\n  maxLevel,\n  isCreatingFolder,\n  type,\n  closeTree,\n  index,\n}: Props) => {\n  const { t } = useTranslation();\n  const { id, name } = folder;\n  const ref = useRef<HTMLButtonElement & HTMLAnchorElement>(null);\n  const selected = selectedFolder ? selectedFolder.id === id : false;\n\n  const levelVariable = useMemo(() => ({ \"--level\": level }) as unknown as CSSProperties, [level]);\n\n  const focused = focusedFolder?.id === id;\n\n  const handleClickFolder = () => {\n    if (!selected) {\n      setSelectedFolder(folder);\n    }\n    setFocusedFolder(folder);\n    if (type === \"picker\") {\n      if (selected) {\n        closeTree();\n      }\n    }\n  };\n\n  useEffect(() => {\n    if (focusedFolder?.id === id && !isCreatingFolder) {\n      if (type === \"navigation\") {\n        ref.current?.focus();\n      }\n      if (type === \"picker\") {\n        ref.current?.scrollIntoView({\n          behavior: \"smooth\",\n          block: \"start\",\n        });\n      }\n    }\n  }, [focusedFolder, ref, id, isCreatingFolder, type]);\n\n  const linkPath = `/minndla/folders/${id}`;\n\n  const containsResource =\n    targetResource && folder.resources.some((resource) => resource.resourceId === targetResource.resourceId);\n\n  const emptyFolder = folder.subfolders.length === 0;\n  const isMaxDepth = level > maxLevel;\n  const hideArrow = isMaxDepth || emptyFolder;\n\n  const FolderIcon = folder.status === \"shared\" ? FolderShared : FolderOutlined;\n\n  const tabable = selected || focused || (!focusedFolder && !folder.parentId && index === 0);\n\n  return type === \"navigation\" ? (\n    <FolderNameLink\n      role=\"treeitem\"\n      aria-owns={folder.subfolders.length ? treestructureId(type, `subfolders-${folder.id}`) : undefined}\n      aria-expanded={isMaxDepth || emptyFolder ? undefined : isOpen}\n      aria-current={selected ? \"page\" : undefined}\n      aria-describedby={containsResource ? `alreadyAdded-${folder.id}` : undefined}\n      ref={ref}\n      style={levelVariable}\n      onKeyDown={(e: KeyboardEvent<HTMLElement>) => {\n        if (e.key === \"Enter\") {\n          setSelectedFolder(folder);\n          return;\n        }\n        arrowNavigation(e, id, visibleFolders, setFocusedFolder, onOpenFolder, onCloseFolder);\n      }}\n      to={loading ? \"\" : linkPath}\n      tabIndex={tabable ? 0 : -1}\n      data-selected={selected}\n      onFocus={() => setFocusedFolder(folder)}\n      onClick={handleClickFolder}\n    >\n      <OpenButton\n        aria-hidden\n        tabIndex={-1}\n        data-open={isOpen}\n        data-hide-arrow={hideArrow}\n        onClick={(e) => {\n          e.stopPropagation();\n          e.preventDefault();\n          ref.current?.focus();\n          if (isOpen) {\n            onCloseFolder(id);\n          } else {\n            onOpenFolder(id);\n          }\n        }}\n      >\n        <ArrowDropDownRounded />\n      </OpenButton>\n      <StyledName>{name}</StyledName>\n    </FolderNameLink>\n  ) : (\n    <FolderName\n      tabIndex={-1}\n      role=\"treeitem\"\n      id={treestructureId(type, folder.id)}\n      aria-expanded={isMaxDepth || emptyFolder ? undefined : isOpen}\n      aria-selected={selected}\n      data-focused={focusedFolder?.id === folder.id}\n      aria-describedby={containsResource ? `alreadyAdded-${folder.id}` : undefined}\n      aria-label={`${name}${folder.status === \"shared\" ? `, ${t(\"myNdla.folder.sharing.shared\")}` : \"\"}`}\n      variant=\"ghost\"\n      shape=\"sharp\"\n      fontWeight=\"normal\"\n      colorTheme=\"light\"\n      ref={ref}\n      style={levelVariable}\n      data-selected={selected}\n      disabled={loading}\n      onFocus={() => setFocusedFolder(focusedFolder || folder)}\n      onClick={handleClickFolder}\n      data-creating={isCreatingFolder}\n    >\n      <IconWrapper>\n        <OpenButton\n          aria-hidden\n          tabIndex={-1}\n          data-open={isOpen}\n          data-hide-arrow={hideArrow}\n          onClick={(e) => {\n            e.stopPropagation();\n            setFocusedFolder(folder);\n            if (isOpen) {\n              onCloseFolder(id);\n            } else {\n              onOpenFolder(id);\n            }\n          }}\n        >\n          <ArrowDropDownRounded />\n        </OpenButton>\n        <FolderIconWrapper>\n          <FolderIcon />\n        </FolderIconWrapper>\n      </IconWrapper>\n      <StyledName>{name}</StyledName>\n      {containsResource && (\n        <StyledDone\n          aria-label={t(\"myNdla.alreadyInFolder\")}\n          id={`alreadyAdded-${folder.id}`}\n          title={t(\"myNdla.alreadyInFolder\")}\n        />\n      )}\n    </FolderName>\n  );\n};\n\nexport default FolderItem;\n"]} */"));
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(-90deg);}&[data-open=\"true\"]{svg{transform:rotate(0deg);}}&[data-hide-arrow=\"true\"]{visibility:hidden;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FolderItem.tsx"],"names":[],"mappings":"AAsB8B","file":"FolderItem.tsx","sourcesContent":["/**\n * Copyright (c) 2022-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { CSSProperties, KeyboardEvent, useEffect, useMemo, useRef } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport styled from \"@emotion/styled\";\nimport { ButtonV2 as Button } from \"@ndla/button\";\nimport { colors, spacing, animations, misc, fonts } from \"@ndla/core\";\nimport { ArrowDropDownRounded } from \"@ndla/icons/common\";\nimport { FolderOutlined, FolderShared } from \"@ndla/icons/contentType\";\nimport { Done } from \"@ndla/icons/editor\";\nimport { SafeLink } from \"@ndla/safelink\";\nimport { IFolder } from \"@ndla/types-backend/myndla-api\";\nimport { arrowNavigation } from \"./arrowNavigation\";\nimport { treestructureId } from \"./helperFunctions\";\nimport { CommonFolderItemsProps } from \"./types\";\n\nconst OpenButton = styled.span`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  align-self: stretch;\n  color: ${colors.brand.tertiary};\n  ${misc.transition.default};\n  cursor: pointer;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n  svg {\n    width: 24px;\n    height: 24px;\n    transform: rotate(-90deg);\n  }\n  &[data-open=\"true\"] {\n    svg {\n      transform: rotate(0deg);\n    }\n  }\n  &[data-hide-arrow=\"true\"] {\n    visibility: hidden;\n  }\n`;\n\nconst StyledName = styled.span`\n  white-space: nowrap;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  grid-column-start: 2;\n  text-align: left;\n`;\n\nconst IconWrapper = styled.div`\n  display: flex;\n`;\n\nconst FolderIconWrapper = styled.div`\n  svg {\n    height: 24px;\n    width: 24px;\n  }\n`;\n\nconst FolderName = styled(Button)`\n  display: grid;\n  grid-template-columns: auto 1fr auto;\n  padding-left: calc(0.75 * ${spacing.normal} * var(--level));\n  gap: ${spacing.xxsmall};\n  border: none;\n  outline: none;\n  color: ${colors.text.primary};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\n\n  &:hover {\n    box-shadow: none;\n    outline: none;\n    background: ${colors.brand.lightest};\n    color: ${colors.text.primary};\n  }\n\n  &[data-focused=\"true\"] {\n    background: ${colors.brand.lightest};\n  }\n\n  &[data-selected=\"true\"] {\n    background: ${colors.brand.lighter};\n    &:hover {\n      background: ${colors.brand.light};\n    }\n  }\n\n  &[data-creating=\"true\"][data-focused=\"true\"] {\n    color: ${colors.brand.primary};\n  }\n\n  &[data-creating=\"true\"] {\n    background: none;\n  }\n`;\n\nconst StyledDone = styled(Done)`\n  color: ${colors.support.green};\n`;\n\nconst FolderNameLink = styled(SafeLink)`\n  display: grid;\n  align-items: center;\n  grid-template-columns: ${spacing.medium} 1fr auto;\n  padding: ${spacing.small} ${spacing.xxsmall};\n  padding-left: calc(0.75 * ${spacing.normal} * var(--level));\n  gap: ${spacing.xxsmall};\n  cursor: pointer;\n\n  border: none;\n  box-shadow: none;\n  color: ${colors.text.primary};\n  ${fonts.sizes(\"16px\")};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\n  &[data-selected=\"true\"] {\n    color: ${colors.brand.primary};\n    font-weight: ${fonts.weight.semibold};\n  }\n  &:hover,\n  &:focus {\n    color: ${colors.brand.primary};\n  }\n`;\n\ninterface Props extends CommonFolderItemsProps {\n  isOpen: boolean;\n  folder: IFolder;\n  isCreatingFolder?: boolean;\n  index: number;\n}\n\nconst FolderItem = ({\n  focusedFolder,\n  folder,\n  isOpen,\n  level,\n  loading,\n  selectedFolder,\n  onCloseFolder,\n  onOpenFolder,\n  setFocusedFolder,\n  setSelectedFolder,\n  targetResource,\n  visibleFolders,\n  maxLevel,\n  isCreatingFolder,\n  type,\n  closeTree,\n  index,\n}: Props) => {\n  const { t } = useTranslation();\n  const { id, name } = folder;\n  const ref = useRef<HTMLButtonElement & HTMLAnchorElement>(null);\n  const selected = selectedFolder ? selectedFolder.id === id : false;\n\n  const levelVariable = useMemo(() => ({ \"--level\": level }) as unknown as CSSProperties, [level]);\n\n  const focused = focusedFolder?.id === id;\n\n  const handleClickFolder = () => {\n    if (!selected) {\n      setSelectedFolder(folder);\n    }\n    setFocusedFolder(folder);\n    if (type === \"picker\") {\n      if (selected) {\n        closeTree();\n      }\n    }\n  };\n\n  useEffect(() => {\n    if (focusedFolder?.id === id && !isCreatingFolder) {\n      if (type === \"navigation\") {\n        ref.current?.focus();\n      }\n      if (type === \"picker\") {\n        ref.current?.scrollIntoView({\n          behavior: \"smooth\",\n          block: \"start\",\n        });\n      }\n    }\n  }, [focusedFolder, ref, id, isCreatingFolder, type]);\n\n  const linkPath = `/minndla/folders/${id}`;\n\n  const containsResource =\n    targetResource && folder.resources.some((resource) => resource.resourceId === targetResource.resourceId);\n\n  const emptyFolder = folder.subfolders.length === 0;\n  const isMaxDepth = level > maxLevel;\n  const hideArrow = isMaxDepth || emptyFolder;\n\n  const FolderIcon = folder.status === \"shared\" ? FolderShared : FolderOutlined;\n\n  const tabable = selected || focused || (!focusedFolder && !folder.parentId && index === 0);\n\n  return type === \"navigation\" ? (\n    <FolderNameLink\n      role=\"treeitem\"\n      aria-owns={folder.subfolders.length ? treestructureId(type, `subfolders-${folder.id}`) : undefined}\n      aria-expanded={isMaxDepth || emptyFolder ? undefined : isOpen}\n      aria-current={selected ? \"page\" : undefined}\n      aria-describedby={containsResource ? `alreadyAdded-${folder.id}` : undefined}\n      ref={ref}\n      style={levelVariable}\n      onKeyDown={(e: KeyboardEvent<HTMLElement>) => {\n        if (e.key === \"Enter\") {\n          setSelectedFolder(folder);\n          return;\n        }\n        arrowNavigation(e, id, visibleFolders, setFocusedFolder, onOpenFolder, onCloseFolder);\n      }}\n      to={loading ? \"\" : linkPath}\n      tabIndex={tabable ? 0 : -1}\n      data-selected={selected}\n      onFocus={() => setFocusedFolder(folder)}\n      onClick={handleClickFolder}\n    >\n      <OpenButton\n        aria-hidden\n        tabIndex={-1}\n        data-open={isOpen}\n        data-hide-arrow={hideArrow}\n        onClick={(e) => {\n          e.stopPropagation();\n          e.preventDefault();\n          ref.current?.focus();\n          if (isOpen) {\n            onCloseFolder(id);\n          } else {\n            onOpenFolder(id);\n          }\n        }}\n      >\n        <ArrowDropDownRounded />\n      </OpenButton>\n      <StyledName>{name}</StyledName>\n    </FolderNameLink>\n  ) : (\n    <FolderName\n      tabIndex={-1}\n      role=\"treeitem\"\n      id={treestructureId(type, folder.id)}\n      aria-expanded={isMaxDepth || emptyFolder ? undefined : isOpen}\n      aria-selected={selected}\n      data-focused={focusedFolder?.id === folder.id}\n      aria-describedby={containsResource ? `alreadyAdded-${folder.id}` : undefined}\n      aria-label={`${name}${folder.status === \"shared\" ? `, ${t(\"myNdla.folder.sharing.shared\")}` : \"\"}`}\n      variant=\"ghost\"\n      shape=\"sharp\"\n      fontWeight=\"normal\"\n      colorTheme=\"light\"\n      ref={ref}\n      style={levelVariable}\n      data-selected={selected}\n      disabled={loading}\n      onFocus={() => setFocusedFolder(focusedFolder || folder)}\n      onClick={handleClickFolder}\n      data-creating={isCreatingFolder}\n    >\n      <IconWrapper>\n        <OpenButton\n          aria-hidden\n          tabIndex={-1}\n          data-open={isOpen}\n          data-hide-arrow={hideArrow}\n          onClick={(e) => {\n            e.stopPropagation();\n            setFocusedFolder(folder);\n            if (isOpen) {\n              onCloseFolder(id);\n            } else {\n              onOpenFolder(id);\n            }\n          }}\n        >\n          <ArrowDropDownRounded />\n        </OpenButton>\n        <FolderIconWrapper>\n          <FolderIcon />\n        </FolderIconWrapper>\n      </IconWrapper>\n      <StyledName>{name}</StyledName>\n      {containsResource && (\n        <StyledDone\n          aria-label={t(\"myNdla.alreadyInFolder\")}\n          id={`alreadyAdded-${folder.id}`}\n          title={t(\"myNdla.alreadyInFolder\")}\n        />\n      )}\n    </FolderName>\n  );\n};\n\nexport default FolderItem;\n"]} */"));
26
26
  const StyledName = /*#__PURE__*/_styled("span", {
27
27
  target: "e11ok6h85",
28
28
  label: "StyledName"
@@ -32,7 +32,7 @@ const StyledName = /*#__PURE__*/_styled("span", {
32
32
  } : {
33
33
  name: "woa3z4",
34
34
  styles: "white-space:nowrap;overflow:hidden;text-overflow:ellipsis;grid-column-start:2;text-align:left",
35
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FolderItem.tsx"],"names":[],"mappings":"AAgD8B","file":"FolderItem.tsx","sourcesContent":["/**\n * Copyright (c) 2022-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { CSSProperties, KeyboardEvent, useEffect, useMemo, useRef } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport styled from \"@emotion/styled\";\nimport { ButtonV2 as Button } from \"@ndla/button\";\nimport { colors, spacing, animations, misc, fonts } from \"@ndla/core\";\nimport { ArrowDropDownRounded } from \"@ndla/icons/common\";\nimport { FolderOutlined, FolderShared } from \"@ndla/icons/contentType\";\nimport { Done } from \"@ndla/icons/editor\";\nimport { SafeLink } from \"@ndla/safelink\";\nimport { IFolder } from \"@ndla/types-backend/myndla-api\";\nimport { arrowNavigation } from \"./arrowNavigation\";\nimport { treestructureId } from \"./helperFunctions\";\nimport { CommonFolderItemsProps } from \"./types\";\n\nconst OpenButton = styled.span`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  align-self: stretch;\n  color: ${colors.brand.tertiary};\n  ${misc.transition.default};\n  cursor: pointer;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n  svg {\n    width: 24px;\n    height: 24px;\n    transform: rotate(-90deg);\n  }\n  &[data-open=\"true\"] {\n    svg {\n      transform: rotate(0deg);\n    }\n  }\n  &[data-hide-arrow=\"true\"] {\n    visibility: hidden;\n  }\n`;\n\nconst StyledName = styled.span`\n  white-space: nowrap;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  grid-column-start: 2;\n  text-align: left;\n`;\n\nconst IconWrapper = styled.div`\n  display: flex;\n`;\n\nconst FolderIconWrapper = styled.div`\n  svg {\n    height: 24px;\n    width: 24px;\n  }\n`;\n\nconst FolderName = styled(Button)`\n  display: grid;\n  grid-template-columns: auto 1fr auto;\n  padding-left: calc(0.75 * ${spacing.normal} * var(--level));\n  gap: ${spacing.xxsmall};\n  border: none;\n  outline: none;\n  color: ${colors.text.primary};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\n\n  &:hover {\n    box-shadow: none;\n    outline: none;\n    background: ${colors.brand.lightest};\n    color: ${colors.text.primary};\n  }\n\n  &[data-focused=\"true\"] {\n    background: ${colors.brand.lightest};\n  }\n\n  &[data-selected=\"true\"] {\n    background: ${colors.brand.lighter};\n    &:hover {\n      background: ${colors.brand.light};\n    }\n  }\n\n  &[data-creating=\"true\"][data-focused=\"true\"] {\n    color: ${colors.brand.primary};\n  }\n\n  &[data-creating=\"true\"] {\n    background: none;\n  }\n`;\n\nconst StyledDone = styled(Done)`\n  color: ${colors.support.green};\n`;\n\nconst FolderNameLink = styled(SafeLink)`\n  display: grid;\n  align-items: center;\n  grid-template-columns: ${spacing.medium} 1fr auto;\n  padding: ${spacing.small} ${spacing.xxsmall};\n  padding-left: calc(0.75 * ${spacing.normal} * var(--level));\n  gap: ${spacing.xxsmall};\n  cursor: pointer;\n\n  border: none;\n  box-shadow: none;\n  color: ${colors.text.primary};\n  font-size: ${fonts.sizes(\"16px\")};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\n  &[data-selected=\"true\"] {\n    color: ${colors.brand.primary};\n    font-weight: ${fonts.weight.semibold};\n  }\n  &:hover,\n  &:focus {\n    color: ${colors.brand.primary};\n  }\n`;\n\ninterface Props extends CommonFolderItemsProps {\n  isOpen: boolean;\n  folder: IFolder;\n  isCreatingFolder?: boolean;\n  index: number;\n}\n\nconst FolderItem = ({\n  focusedFolder,\n  folder,\n  isOpen,\n  level,\n  loading,\n  selectedFolder,\n  onCloseFolder,\n  onOpenFolder,\n  setFocusedFolder,\n  setSelectedFolder,\n  targetResource,\n  visibleFolders,\n  maxLevel,\n  isCreatingFolder,\n  type,\n  closeTree,\n  index,\n}: Props) => {\n  const { t } = useTranslation();\n  const { id, name } = folder;\n  const ref = useRef<HTMLButtonElement & HTMLAnchorElement>(null);\n  const selected = selectedFolder ? selectedFolder.id === id : false;\n\n  const levelVariable = useMemo(() => ({ \"--level\": level }) as unknown as CSSProperties, [level]);\n\n  const focused = focusedFolder?.id === id;\n\n  const handleClickFolder = () => {\n    if (!selected) {\n      setSelectedFolder(folder);\n    }\n    setFocusedFolder(folder);\n    if (type === \"picker\") {\n      if (selected) {\n        closeTree();\n      }\n    }\n  };\n\n  useEffect(() => {\n    if (focusedFolder?.id === id && !isCreatingFolder) {\n      if (type === \"navigation\") {\n        ref.current?.focus();\n      }\n      if (type === \"picker\") {\n        ref.current?.scrollIntoView({\n          behavior: \"smooth\",\n          block: \"start\",\n        });\n      }\n    }\n  }, [focusedFolder, ref, id, isCreatingFolder, type]);\n\n  const linkPath = `/minndla/folders/${id}`;\n\n  const containsResource =\n    targetResource && folder.resources.some((resource) => resource.resourceId === targetResource.resourceId);\n\n  const emptyFolder = folder.subfolders.length === 0;\n  const isMaxDepth = level > maxLevel;\n  const hideArrow = isMaxDepth || emptyFolder;\n\n  const FolderIcon = folder.status === \"shared\" ? FolderShared : FolderOutlined;\n\n  const tabable = selected || focused || (!focusedFolder && !folder.parentId && index === 0);\n\n  return type === \"navigation\" ? (\n    <FolderNameLink\n      role=\"treeitem\"\n      aria-owns={folder.subfolders.length ? treestructureId(type, `subfolders-${folder.id}`) : undefined}\n      aria-expanded={isMaxDepth || emptyFolder ? undefined : isOpen}\n      aria-current={selected ? \"page\" : undefined}\n      aria-describedby={containsResource ? `alreadyAdded-${folder.id}` : undefined}\n      ref={ref}\n      style={levelVariable}\n      onKeyDown={(e: KeyboardEvent<HTMLElement>) => {\n        if (e.key === \"Enter\") {\n          setSelectedFolder(folder);\n          return;\n        }\n        arrowNavigation(e, id, visibleFolders, setFocusedFolder, onOpenFolder, onCloseFolder);\n      }}\n      to={loading ? \"\" : linkPath}\n      tabIndex={tabable ? 0 : -1}\n      data-selected={selected}\n      onFocus={() => setFocusedFolder(folder)}\n      onClick={handleClickFolder}\n    >\n      <OpenButton\n        aria-hidden\n        tabIndex={-1}\n        data-open={isOpen}\n        data-hide-arrow={hideArrow}\n        onClick={(e) => {\n          e.stopPropagation();\n          e.preventDefault();\n          ref.current?.focus();\n          if (isOpen) {\n            onCloseFolder(id);\n          } else {\n            onOpenFolder(id);\n          }\n        }}\n      >\n        <ArrowDropDownRounded />\n      </OpenButton>\n      <StyledName>{name}</StyledName>\n    </FolderNameLink>\n  ) : (\n    <FolderName\n      tabIndex={-1}\n      role=\"treeitem\"\n      id={treestructureId(type, folder.id)}\n      aria-expanded={isMaxDepth || emptyFolder ? undefined : isOpen}\n      aria-selected={selected}\n      data-focused={focusedFolder?.id === folder.id}\n      aria-describedby={containsResource ? `alreadyAdded-${folder.id}` : undefined}\n      aria-label={`${name}${folder.status === \"shared\" ? `, ${t(\"myNdla.folder.sharing.shared\")}` : \"\"}`}\n      variant=\"ghost\"\n      shape=\"sharp\"\n      fontWeight=\"normal\"\n      colorTheme=\"light\"\n      ref={ref}\n      style={levelVariable}\n      data-selected={selected}\n      disabled={loading}\n      onFocus={() => setFocusedFolder(focusedFolder || folder)}\n      onClick={handleClickFolder}\n      data-creating={isCreatingFolder}\n    >\n      <IconWrapper>\n        <OpenButton\n          aria-hidden\n          tabIndex={-1}\n          data-open={isOpen}\n          data-hide-arrow={hideArrow}\n          onClick={(e) => {\n            e.stopPropagation();\n            setFocusedFolder(folder);\n            if (isOpen) {\n              onCloseFolder(id);\n            } else {\n              onOpenFolder(id);\n            }\n          }}\n        >\n          <ArrowDropDownRounded />\n        </OpenButton>\n        <FolderIconWrapper>\n          <FolderIcon />\n        </FolderIconWrapper>\n      </IconWrapper>\n      <StyledName>{name}</StyledName>\n      {containsResource && (\n        <StyledDone\n          aria-label={t(\"myNdla.alreadyInFolder\")}\n          id={`alreadyAdded-${folder.id}`}\n          title={t(\"myNdla.alreadyInFolder\")}\n        />\n      )}\n    </FolderName>\n  );\n};\n\nexport default FolderItem;\n"]} */",
35
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FolderItem.tsx"],"names":[],"mappings":"AAgD8B","file":"FolderItem.tsx","sourcesContent":["/**\n * Copyright (c) 2022-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { CSSProperties, KeyboardEvent, useEffect, useMemo, useRef } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport styled from \"@emotion/styled\";\nimport { ButtonV2 as Button } from \"@ndla/button\";\nimport { colors, spacing, animations, misc, fonts } from \"@ndla/core\";\nimport { ArrowDropDownRounded } from \"@ndla/icons/common\";\nimport { FolderOutlined, FolderShared } from \"@ndla/icons/contentType\";\nimport { Done } from \"@ndla/icons/editor\";\nimport { SafeLink } from \"@ndla/safelink\";\nimport { IFolder } from \"@ndla/types-backend/myndla-api\";\nimport { arrowNavigation } from \"./arrowNavigation\";\nimport { treestructureId } from \"./helperFunctions\";\nimport { CommonFolderItemsProps } from \"./types\";\n\nconst OpenButton = styled.span`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  align-self: stretch;\n  color: ${colors.brand.tertiary};\n  ${misc.transition.default};\n  cursor: pointer;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n  svg {\n    width: 24px;\n    height: 24px;\n    transform: rotate(-90deg);\n  }\n  &[data-open=\"true\"] {\n    svg {\n      transform: rotate(0deg);\n    }\n  }\n  &[data-hide-arrow=\"true\"] {\n    visibility: hidden;\n  }\n`;\n\nconst StyledName = styled.span`\n  white-space: nowrap;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  grid-column-start: 2;\n  text-align: left;\n`;\n\nconst IconWrapper = styled.div`\n  display: flex;\n`;\n\nconst FolderIconWrapper = styled.div`\n  svg {\n    height: 24px;\n    width: 24px;\n  }\n`;\n\nconst FolderName = styled(Button)`\n  display: grid;\n  grid-template-columns: auto 1fr auto;\n  padding-left: calc(0.75 * ${spacing.normal} * var(--level));\n  gap: ${spacing.xxsmall};\n  border: none;\n  outline: none;\n  color: ${colors.text.primary};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\n\n  &:hover {\n    box-shadow: none;\n    outline: none;\n    background: ${colors.brand.lightest};\n    color: ${colors.text.primary};\n  }\n\n  &[data-focused=\"true\"] {\n    background: ${colors.brand.lightest};\n  }\n\n  &[data-selected=\"true\"] {\n    background: ${colors.brand.lighter};\n    &:hover {\n      background: ${colors.brand.light};\n    }\n  }\n\n  &[data-creating=\"true\"][data-focused=\"true\"] {\n    color: ${colors.brand.primary};\n  }\n\n  &[data-creating=\"true\"] {\n    background: none;\n  }\n`;\n\nconst StyledDone = styled(Done)`\n  color: ${colors.support.green};\n`;\n\nconst FolderNameLink = styled(SafeLink)`\n  display: grid;\n  align-items: center;\n  grid-template-columns: ${spacing.medium} 1fr auto;\n  padding: ${spacing.small} ${spacing.xxsmall};\n  padding-left: calc(0.75 * ${spacing.normal} * var(--level));\n  gap: ${spacing.xxsmall};\n  cursor: pointer;\n\n  border: none;\n  box-shadow: none;\n  color: ${colors.text.primary};\n  ${fonts.sizes(\"16px\")};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\n  &[data-selected=\"true\"] {\n    color: ${colors.brand.primary};\n    font-weight: ${fonts.weight.semibold};\n  }\n  &:hover,\n  &:focus {\n    color: ${colors.brand.primary};\n  }\n`;\n\ninterface Props extends CommonFolderItemsProps {\n  isOpen: boolean;\n  folder: IFolder;\n  isCreatingFolder?: boolean;\n  index: number;\n}\n\nconst FolderItem = ({\n  focusedFolder,\n  folder,\n  isOpen,\n  level,\n  loading,\n  selectedFolder,\n  onCloseFolder,\n  onOpenFolder,\n  setFocusedFolder,\n  setSelectedFolder,\n  targetResource,\n  visibleFolders,\n  maxLevel,\n  isCreatingFolder,\n  type,\n  closeTree,\n  index,\n}: Props) => {\n  const { t } = useTranslation();\n  const { id, name } = folder;\n  const ref = useRef<HTMLButtonElement & HTMLAnchorElement>(null);\n  const selected = selectedFolder ? selectedFolder.id === id : false;\n\n  const levelVariable = useMemo(() => ({ \"--level\": level }) as unknown as CSSProperties, [level]);\n\n  const focused = focusedFolder?.id === id;\n\n  const handleClickFolder = () => {\n    if (!selected) {\n      setSelectedFolder(folder);\n    }\n    setFocusedFolder(folder);\n    if (type === \"picker\") {\n      if (selected) {\n        closeTree();\n      }\n    }\n  };\n\n  useEffect(() => {\n    if (focusedFolder?.id === id && !isCreatingFolder) {\n      if (type === \"navigation\") {\n        ref.current?.focus();\n      }\n      if (type === \"picker\") {\n        ref.current?.scrollIntoView({\n          behavior: \"smooth\",\n          block: \"start\",\n        });\n      }\n    }\n  }, [focusedFolder, ref, id, isCreatingFolder, type]);\n\n  const linkPath = `/minndla/folders/${id}`;\n\n  const containsResource =\n    targetResource && folder.resources.some((resource) => resource.resourceId === targetResource.resourceId);\n\n  const emptyFolder = folder.subfolders.length === 0;\n  const isMaxDepth = level > maxLevel;\n  const hideArrow = isMaxDepth || emptyFolder;\n\n  const FolderIcon = folder.status === \"shared\" ? FolderShared : FolderOutlined;\n\n  const tabable = selected || focused || (!focusedFolder && !folder.parentId && index === 0);\n\n  return type === \"navigation\" ? (\n    <FolderNameLink\n      role=\"treeitem\"\n      aria-owns={folder.subfolders.length ? treestructureId(type, `subfolders-${folder.id}`) : undefined}\n      aria-expanded={isMaxDepth || emptyFolder ? undefined : isOpen}\n      aria-current={selected ? \"page\" : undefined}\n      aria-describedby={containsResource ? `alreadyAdded-${folder.id}` : undefined}\n      ref={ref}\n      style={levelVariable}\n      onKeyDown={(e: KeyboardEvent<HTMLElement>) => {\n        if (e.key === \"Enter\") {\n          setSelectedFolder(folder);\n          return;\n        }\n        arrowNavigation(e, id, visibleFolders, setFocusedFolder, onOpenFolder, onCloseFolder);\n      }}\n      to={loading ? \"\" : linkPath}\n      tabIndex={tabable ? 0 : -1}\n      data-selected={selected}\n      onFocus={() => setFocusedFolder(folder)}\n      onClick={handleClickFolder}\n    >\n      <OpenButton\n        aria-hidden\n        tabIndex={-1}\n        data-open={isOpen}\n        data-hide-arrow={hideArrow}\n        onClick={(e) => {\n          e.stopPropagation();\n          e.preventDefault();\n          ref.current?.focus();\n          if (isOpen) {\n            onCloseFolder(id);\n          } else {\n            onOpenFolder(id);\n          }\n        }}\n      >\n        <ArrowDropDownRounded />\n      </OpenButton>\n      <StyledName>{name}</StyledName>\n    </FolderNameLink>\n  ) : (\n    <FolderName\n      tabIndex={-1}\n      role=\"treeitem\"\n      id={treestructureId(type, folder.id)}\n      aria-expanded={isMaxDepth || emptyFolder ? undefined : isOpen}\n      aria-selected={selected}\n      data-focused={focusedFolder?.id === folder.id}\n      aria-describedby={containsResource ? `alreadyAdded-${folder.id}` : undefined}\n      aria-label={`${name}${folder.status === \"shared\" ? `, ${t(\"myNdla.folder.sharing.shared\")}` : \"\"}`}\n      variant=\"ghost\"\n      shape=\"sharp\"\n      fontWeight=\"normal\"\n      colorTheme=\"light\"\n      ref={ref}\n      style={levelVariable}\n      data-selected={selected}\n      disabled={loading}\n      onFocus={() => setFocusedFolder(focusedFolder || folder)}\n      onClick={handleClickFolder}\n      data-creating={isCreatingFolder}\n    >\n      <IconWrapper>\n        <OpenButton\n          aria-hidden\n          tabIndex={-1}\n          data-open={isOpen}\n          data-hide-arrow={hideArrow}\n          onClick={(e) => {\n            e.stopPropagation();\n            setFocusedFolder(folder);\n            if (isOpen) {\n              onCloseFolder(id);\n            } else {\n              onOpenFolder(id);\n            }\n          }}\n        >\n          <ArrowDropDownRounded />\n        </OpenButton>\n        <FolderIconWrapper>\n          <FolderIcon />\n        </FolderIconWrapper>\n      </IconWrapper>\n      <StyledName>{name}</StyledName>\n      {containsResource && (\n        <StyledDone\n          aria-label={t(\"myNdla.alreadyInFolder\")}\n          id={`alreadyAdded-${folder.id}`}\n          title={t(\"myNdla.alreadyInFolder\")}\n        />\n      )}\n    </FolderName>\n  );\n};\n\nexport default FolderItem;\n"]} */",
36
36
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
37
37
  });
38
38
  const IconWrapper = /*#__PURE__*/_styled("div", {
@@ -44,7 +44,7 @@ const IconWrapper = /*#__PURE__*/_styled("div", {
44
44
  } : {
45
45
  name: "zjik7",
46
46
  styles: "display:flex",
47
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FolderItem.tsx"],"names":[],"mappings":"AAwD8B","file":"FolderItem.tsx","sourcesContent":["/**\n * Copyright (c) 2022-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { CSSProperties, KeyboardEvent, useEffect, useMemo, useRef } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport styled from \"@emotion/styled\";\nimport { ButtonV2 as Button } from \"@ndla/button\";\nimport { colors, spacing, animations, misc, fonts } from \"@ndla/core\";\nimport { ArrowDropDownRounded } from \"@ndla/icons/common\";\nimport { FolderOutlined, FolderShared } from \"@ndla/icons/contentType\";\nimport { Done } from \"@ndla/icons/editor\";\nimport { SafeLink } from \"@ndla/safelink\";\nimport { IFolder } from \"@ndla/types-backend/myndla-api\";\nimport { arrowNavigation } from \"./arrowNavigation\";\nimport { treestructureId } from \"./helperFunctions\";\nimport { CommonFolderItemsProps } from \"./types\";\n\nconst OpenButton = styled.span`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  align-self: stretch;\n  color: ${colors.brand.tertiary};\n  ${misc.transition.default};\n  cursor: pointer;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n  svg {\n    width: 24px;\n    height: 24px;\n    transform: rotate(-90deg);\n  }\n  &[data-open=\"true\"] {\n    svg {\n      transform: rotate(0deg);\n    }\n  }\n  &[data-hide-arrow=\"true\"] {\n    visibility: hidden;\n  }\n`;\n\nconst StyledName = styled.span`\n  white-space: nowrap;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  grid-column-start: 2;\n  text-align: left;\n`;\n\nconst IconWrapper = styled.div`\n  display: flex;\n`;\n\nconst FolderIconWrapper = styled.div`\n  svg {\n    height: 24px;\n    width: 24px;\n  }\n`;\n\nconst FolderName = styled(Button)`\n  display: grid;\n  grid-template-columns: auto 1fr auto;\n  padding-left: calc(0.75 * ${spacing.normal} * var(--level));\n  gap: ${spacing.xxsmall};\n  border: none;\n  outline: none;\n  color: ${colors.text.primary};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\n\n  &:hover {\n    box-shadow: none;\n    outline: none;\n    background: ${colors.brand.lightest};\n    color: ${colors.text.primary};\n  }\n\n  &[data-focused=\"true\"] {\n    background: ${colors.brand.lightest};\n  }\n\n  &[data-selected=\"true\"] {\n    background: ${colors.brand.lighter};\n    &:hover {\n      background: ${colors.brand.light};\n    }\n  }\n\n  &[data-creating=\"true\"][data-focused=\"true\"] {\n    color: ${colors.brand.primary};\n  }\n\n  &[data-creating=\"true\"] {\n    background: none;\n  }\n`;\n\nconst StyledDone = styled(Done)`\n  color: ${colors.support.green};\n`;\n\nconst FolderNameLink = styled(SafeLink)`\n  display: grid;\n  align-items: center;\n  grid-template-columns: ${spacing.medium} 1fr auto;\n  padding: ${spacing.small} ${spacing.xxsmall};\n  padding-left: calc(0.75 * ${spacing.normal} * var(--level));\n  gap: ${spacing.xxsmall};\n  cursor: pointer;\n\n  border: none;\n  box-shadow: none;\n  color: ${colors.text.primary};\n  font-size: ${fonts.sizes(\"16px\")};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\n  &[data-selected=\"true\"] {\n    color: ${colors.brand.primary};\n    font-weight: ${fonts.weight.semibold};\n  }\n  &:hover,\n  &:focus {\n    color: ${colors.brand.primary};\n  }\n`;\n\ninterface Props extends CommonFolderItemsProps {\n  isOpen: boolean;\n  folder: IFolder;\n  isCreatingFolder?: boolean;\n  index: number;\n}\n\nconst FolderItem = ({\n  focusedFolder,\n  folder,\n  isOpen,\n  level,\n  loading,\n  selectedFolder,\n  onCloseFolder,\n  onOpenFolder,\n  setFocusedFolder,\n  setSelectedFolder,\n  targetResource,\n  visibleFolders,\n  maxLevel,\n  isCreatingFolder,\n  type,\n  closeTree,\n  index,\n}: Props) => {\n  const { t } = useTranslation();\n  const { id, name } = folder;\n  const ref = useRef<HTMLButtonElement & HTMLAnchorElement>(null);\n  const selected = selectedFolder ? selectedFolder.id === id : false;\n\n  const levelVariable = useMemo(() => ({ \"--level\": level }) as unknown as CSSProperties, [level]);\n\n  const focused = focusedFolder?.id === id;\n\n  const handleClickFolder = () => {\n    if (!selected) {\n      setSelectedFolder(folder);\n    }\n    setFocusedFolder(folder);\n    if (type === \"picker\") {\n      if (selected) {\n        closeTree();\n      }\n    }\n  };\n\n  useEffect(() => {\n    if (focusedFolder?.id === id && !isCreatingFolder) {\n      if (type === \"navigation\") {\n        ref.current?.focus();\n      }\n      if (type === \"picker\") {\n        ref.current?.scrollIntoView({\n          behavior: \"smooth\",\n          block: \"start\",\n        });\n      }\n    }\n  }, [focusedFolder, ref, id, isCreatingFolder, type]);\n\n  const linkPath = `/minndla/folders/${id}`;\n\n  const containsResource =\n    targetResource && folder.resources.some((resource) => resource.resourceId === targetResource.resourceId);\n\n  const emptyFolder = folder.subfolders.length === 0;\n  const isMaxDepth = level > maxLevel;\n  const hideArrow = isMaxDepth || emptyFolder;\n\n  const FolderIcon = folder.status === \"shared\" ? FolderShared : FolderOutlined;\n\n  const tabable = selected || focused || (!focusedFolder && !folder.parentId && index === 0);\n\n  return type === \"navigation\" ? (\n    <FolderNameLink\n      role=\"treeitem\"\n      aria-owns={folder.subfolders.length ? treestructureId(type, `subfolders-${folder.id}`) : undefined}\n      aria-expanded={isMaxDepth || emptyFolder ? undefined : isOpen}\n      aria-current={selected ? \"page\" : undefined}\n      aria-describedby={containsResource ? `alreadyAdded-${folder.id}` : undefined}\n      ref={ref}\n      style={levelVariable}\n      onKeyDown={(e: KeyboardEvent<HTMLElement>) => {\n        if (e.key === \"Enter\") {\n          setSelectedFolder(folder);\n          return;\n        }\n        arrowNavigation(e, id, visibleFolders, setFocusedFolder, onOpenFolder, onCloseFolder);\n      }}\n      to={loading ? \"\" : linkPath}\n      tabIndex={tabable ? 0 : -1}\n      data-selected={selected}\n      onFocus={() => setFocusedFolder(folder)}\n      onClick={handleClickFolder}\n    >\n      <OpenButton\n        aria-hidden\n        tabIndex={-1}\n        data-open={isOpen}\n        data-hide-arrow={hideArrow}\n        onClick={(e) => {\n          e.stopPropagation();\n          e.preventDefault();\n          ref.current?.focus();\n          if (isOpen) {\n            onCloseFolder(id);\n          } else {\n            onOpenFolder(id);\n          }\n        }}\n      >\n        <ArrowDropDownRounded />\n      </OpenButton>\n      <StyledName>{name}</StyledName>\n    </FolderNameLink>\n  ) : (\n    <FolderName\n      tabIndex={-1}\n      role=\"treeitem\"\n      id={treestructureId(type, folder.id)}\n      aria-expanded={isMaxDepth || emptyFolder ? undefined : isOpen}\n      aria-selected={selected}\n      data-focused={focusedFolder?.id === folder.id}\n      aria-describedby={containsResource ? `alreadyAdded-${folder.id}` : undefined}\n      aria-label={`${name}${folder.status === \"shared\" ? `, ${t(\"myNdla.folder.sharing.shared\")}` : \"\"}`}\n      variant=\"ghost\"\n      shape=\"sharp\"\n      fontWeight=\"normal\"\n      colorTheme=\"light\"\n      ref={ref}\n      style={levelVariable}\n      data-selected={selected}\n      disabled={loading}\n      onFocus={() => setFocusedFolder(focusedFolder || folder)}\n      onClick={handleClickFolder}\n      data-creating={isCreatingFolder}\n    >\n      <IconWrapper>\n        <OpenButton\n          aria-hidden\n          tabIndex={-1}\n          data-open={isOpen}\n          data-hide-arrow={hideArrow}\n          onClick={(e) => {\n            e.stopPropagation();\n            setFocusedFolder(folder);\n            if (isOpen) {\n              onCloseFolder(id);\n            } else {\n              onOpenFolder(id);\n            }\n          }}\n        >\n          <ArrowDropDownRounded />\n        </OpenButton>\n        <FolderIconWrapper>\n          <FolderIcon />\n        </FolderIconWrapper>\n      </IconWrapper>\n      <StyledName>{name}</StyledName>\n      {containsResource && (\n        <StyledDone\n          aria-label={t(\"myNdla.alreadyInFolder\")}\n          id={`alreadyAdded-${folder.id}`}\n          title={t(\"myNdla.alreadyInFolder\")}\n        />\n      )}\n    </FolderName>\n  );\n};\n\nexport default FolderItem;\n"]} */",
47
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FolderItem.tsx"],"names":[],"mappings":"AAwD8B","file":"FolderItem.tsx","sourcesContent":["/**\n * Copyright (c) 2022-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { CSSProperties, KeyboardEvent, useEffect, useMemo, useRef } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport styled from \"@emotion/styled\";\nimport { ButtonV2 as Button } from \"@ndla/button\";\nimport { colors, spacing, animations, misc, fonts } from \"@ndla/core\";\nimport { ArrowDropDownRounded } from \"@ndla/icons/common\";\nimport { FolderOutlined, FolderShared } from \"@ndla/icons/contentType\";\nimport { Done } from \"@ndla/icons/editor\";\nimport { SafeLink } from \"@ndla/safelink\";\nimport { IFolder } from \"@ndla/types-backend/myndla-api\";\nimport { arrowNavigation } from \"./arrowNavigation\";\nimport { treestructureId } from \"./helperFunctions\";\nimport { CommonFolderItemsProps } from \"./types\";\n\nconst OpenButton = styled.span`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  align-self: stretch;\n  color: ${colors.brand.tertiary};\n  ${misc.transition.default};\n  cursor: pointer;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n  svg {\n    width: 24px;\n    height: 24px;\n    transform: rotate(-90deg);\n  }\n  &[data-open=\"true\"] {\n    svg {\n      transform: rotate(0deg);\n    }\n  }\n  &[data-hide-arrow=\"true\"] {\n    visibility: hidden;\n  }\n`;\n\nconst StyledName = styled.span`\n  white-space: nowrap;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  grid-column-start: 2;\n  text-align: left;\n`;\n\nconst IconWrapper = styled.div`\n  display: flex;\n`;\n\nconst FolderIconWrapper = styled.div`\n  svg {\n    height: 24px;\n    width: 24px;\n  }\n`;\n\nconst FolderName = styled(Button)`\n  display: grid;\n  grid-template-columns: auto 1fr auto;\n  padding-left: calc(0.75 * ${spacing.normal} * var(--level));\n  gap: ${spacing.xxsmall};\n  border: none;\n  outline: none;\n  color: ${colors.text.primary};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\n\n  &:hover {\n    box-shadow: none;\n    outline: none;\n    background: ${colors.brand.lightest};\n    color: ${colors.text.primary};\n  }\n\n  &[data-focused=\"true\"] {\n    background: ${colors.brand.lightest};\n  }\n\n  &[data-selected=\"true\"] {\n    background: ${colors.brand.lighter};\n    &:hover {\n      background: ${colors.brand.light};\n    }\n  }\n\n  &[data-creating=\"true\"][data-focused=\"true\"] {\n    color: ${colors.brand.primary};\n  }\n\n  &[data-creating=\"true\"] {\n    background: none;\n  }\n`;\n\nconst StyledDone = styled(Done)`\n  color: ${colors.support.green};\n`;\n\nconst FolderNameLink = styled(SafeLink)`\n  display: grid;\n  align-items: center;\n  grid-template-columns: ${spacing.medium} 1fr auto;\n  padding: ${spacing.small} ${spacing.xxsmall};\n  padding-left: calc(0.75 * ${spacing.normal} * var(--level));\n  gap: ${spacing.xxsmall};\n  cursor: pointer;\n\n  border: none;\n  box-shadow: none;\n  color: ${colors.text.primary};\n  ${fonts.sizes(\"16px\")};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\n  &[data-selected=\"true\"] {\n    color: ${colors.brand.primary};\n    font-weight: ${fonts.weight.semibold};\n  }\n  &:hover,\n  &:focus {\n    color: ${colors.brand.primary};\n  }\n`;\n\ninterface Props extends CommonFolderItemsProps {\n  isOpen: boolean;\n  folder: IFolder;\n  isCreatingFolder?: boolean;\n  index: number;\n}\n\nconst FolderItem = ({\n  focusedFolder,\n  folder,\n  isOpen,\n  level,\n  loading,\n  selectedFolder,\n  onCloseFolder,\n  onOpenFolder,\n  setFocusedFolder,\n  setSelectedFolder,\n  targetResource,\n  visibleFolders,\n  maxLevel,\n  isCreatingFolder,\n  type,\n  closeTree,\n  index,\n}: Props) => {\n  const { t } = useTranslation();\n  const { id, name } = folder;\n  const ref = useRef<HTMLButtonElement & HTMLAnchorElement>(null);\n  const selected = selectedFolder ? selectedFolder.id === id : false;\n\n  const levelVariable = useMemo(() => ({ \"--level\": level }) as unknown as CSSProperties, [level]);\n\n  const focused = focusedFolder?.id === id;\n\n  const handleClickFolder = () => {\n    if (!selected) {\n      setSelectedFolder(folder);\n    }\n    setFocusedFolder(folder);\n    if (type === \"picker\") {\n      if (selected) {\n        closeTree();\n      }\n    }\n  };\n\n  useEffect(() => {\n    if (focusedFolder?.id === id && !isCreatingFolder) {\n      if (type === \"navigation\") {\n        ref.current?.focus();\n      }\n      if (type === \"picker\") {\n        ref.current?.scrollIntoView({\n          behavior: \"smooth\",\n          block: \"start\",\n        });\n      }\n    }\n  }, [focusedFolder, ref, id, isCreatingFolder, type]);\n\n  const linkPath = `/minndla/folders/${id}`;\n\n  const containsResource =\n    targetResource && folder.resources.some((resource) => resource.resourceId === targetResource.resourceId);\n\n  const emptyFolder = folder.subfolders.length === 0;\n  const isMaxDepth = level > maxLevel;\n  const hideArrow = isMaxDepth || emptyFolder;\n\n  const FolderIcon = folder.status === \"shared\" ? FolderShared : FolderOutlined;\n\n  const tabable = selected || focused || (!focusedFolder && !folder.parentId && index === 0);\n\n  return type === \"navigation\" ? (\n    <FolderNameLink\n      role=\"treeitem\"\n      aria-owns={folder.subfolders.length ? treestructureId(type, `subfolders-${folder.id}`) : undefined}\n      aria-expanded={isMaxDepth || emptyFolder ? undefined : isOpen}\n      aria-current={selected ? \"page\" : undefined}\n      aria-describedby={containsResource ? `alreadyAdded-${folder.id}` : undefined}\n      ref={ref}\n      style={levelVariable}\n      onKeyDown={(e: KeyboardEvent<HTMLElement>) => {\n        if (e.key === \"Enter\") {\n          setSelectedFolder(folder);\n          return;\n        }\n        arrowNavigation(e, id, visibleFolders, setFocusedFolder, onOpenFolder, onCloseFolder);\n      }}\n      to={loading ? \"\" : linkPath}\n      tabIndex={tabable ? 0 : -1}\n      data-selected={selected}\n      onFocus={() => setFocusedFolder(folder)}\n      onClick={handleClickFolder}\n    >\n      <OpenButton\n        aria-hidden\n        tabIndex={-1}\n        data-open={isOpen}\n        data-hide-arrow={hideArrow}\n        onClick={(e) => {\n          e.stopPropagation();\n          e.preventDefault();\n          ref.current?.focus();\n          if (isOpen) {\n            onCloseFolder(id);\n          } else {\n            onOpenFolder(id);\n          }\n        }}\n      >\n        <ArrowDropDownRounded />\n      </OpenButton>\n      <StyledName>{name}</StyledName>\n    </FolderNameLink>\n  ) : (\n    <FolderName\n      tabIndex={-1}\n      role=\"treeitem\"\n      id={treestructureId(type, folder.id)}\n      aria-expanded={isMaxDepth || emptyFolder ? undefined : isOpen}\n      aria-selected={selected}\n      data-focused={focusedFolder?.id === folder.id}\n      aria-describedby={containsResource ? `alreadyAdded-${folder.id}` : undefined}\n      aria-label={`${name}${folder.status === \"shared\" ? `, ${t(\"myNdla.folder.sharing.shared\")}` : \"\"}`}\n      variant=\"ghost\"\n      shape=\"sharp\"\n      fontWeight=\"normal\"\n      colorTheme=\"light\"\n      ref={ref}\n      style={levelVariable}\n      data-selected={selected}\n      disabled={loading}\n      onFocus={() => setFocusedFolder(focusedFolder || folder)}\n      onClick={handleClickFolder}\n      data-creating={isCreatingFolder}\n    >\n      <IconWrapper>\n        <OpenButton\n          aria-hidden\n          tabIndex={-1}\n          data-open={isOpen}\n          data-hide-arrow={hideArrow}\n          onClick={(e) => {\n            e.stopPropagation();\n            setFocusedFolder(folder);\n            if (isOpen) {\n              onCloseFolder(id);\n            } else {\n              onOpenFolder(id);\n            }\n          }}\n        >\n          <ArrowDropDownRounded />\n        </OpenButton>\n        <FolderIconWrapper>\n          <FolderIcon />\n        </FolderIconWrapper>\n      </IconWrapper>\n      <StyledName>{name}</StyledName>\n      {containsResource && (\n        <StyledDone\n          aria-label={t(\"myNdla.alreadyInFolder\")}\n          id={`alreadyAdded-${folder.id}`}\n          title={t(\"myNdla.alreadyInFolder\")}\n        />\n      )}\n    </FolderName>\n  );\n};\n\nexport default FolderItem;\n"]} */",
48
48
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
49
49
  });
50
50
  const FolderIconWrapper = /*#__PURE__*/_styled("div", {
@@ -56,21 +56,21 @@ const FolderIconWrapper = /*#__PURE__*/_styled("div", {
56
56
  } : {
57
57
  name: "h1kfx5",
58
58
  styles: "svg{height:24px;width:24px;}",
59
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FolderItem.tsx"],"names":[],"mappings":"AA4DoC","file":"FolderItem.tsx","sourcesContent":["/**\n * Copyright (c) 2022-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { CSSProperties, KeyboardEvent, useEffect, useMemo, useRef } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport styled from \"@emotion/styled\";\nimport { ButtonV2 as Button } from \"@ndla/button\";\nimport { colors, spacing, animations, misc, fonts } from \"@ndla/core\";\nimport { ArrowDropDownRounded } from \"@ndla/icons/common\";\nimport { FolderOutlined, FolderShared } from \"@ndla/icons/contentType\";\nimport { Done } from \"@ndla/icons/editor\";\nimport { SafeLink } from \"@ndla/safelink\";\nimport { IFolder } from \"@ndla/types-backend/myndla-api\";\nimport { arrowNavigation } from \"./arrowNavigation\";\nimport { treestructureId } from \"./helperFunctions\";\nimport { CommonFolderItemsProps } from \"./types\";\n\nconst OpenButton = styled.span`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  align-self: stretch;\n  color: ${colors.brand.tertiary};\n  ${misc.transition.default};\n  cursor: pointer;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n  svg {\n    width: 24px;\n    height: 24px;\n    transform: rotate(-90deg);\n  }\n  &[data-open=\"true\"] {\n    svg {\n      transform: rotate(0deg);\n    }\n  }\n  &[data-hide-arrow=\"true\"] {\n    visibility: hidden;\n  }\n`;\n\nconst StyledName = styled.span`\n  white-space: nowrap;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  grid-column-start: 2;\n  text-align: left;\n`;\n\nconst IconWrapper = styled.div`\n  display: flex;\n`;\n\nconst FolderIconWrapper = styled.div`\n  svg {\n    height: 24px;\n    width: 24px;\n  }\n`;\n\nconst FolderName = styled(Button)`\n  display: grid;\n  grid-template-columns: auto 1fr auto;\n  padding-left: calc(0.75 * ${spacing.normal} * var(--level));\n  gap: ${spacing.xxsmall};\n  border: none;\n  outline: none;\n  color: ${colors.text.primary};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\n\n  &:hover {\n    box-shadow: none;\n    outline: none;\n    background: ${colors.brand.lightest};\n    color: ${colors.text.primary};\n  }\n\n  &[data-focused=\"true\"] {\n    background: ${colors.brand.lightest};\n  }\n\n  &[data-selected=\"true\"] {\n    background: ${colors.brand.lighter};\n    &:hover {\n      background: ${colors.brand.light};\n    }\n  }\n\n  &[data-creating=\"true\"][data-focused=\"true\"] {\n    color: ${colors.brand.primary};\n  }\n\n  &[data-creating=\"true\"] {\n    background: none;\n  }\n`;\n\nconst StyledDone = styled(Done)`\n  color: ${colors.support.green};\n`;\n\nconst FolderNameLink = styled(SafeLink)`\n  display: grid;\n  align-items: center;\n  grid-template-columns: ${spacing.medium} 1fr auto;\n  padding: ${spacing.small} ${spacing.xxsmall};\n  padding-left: calc(0.75 * ${spacing.normal} * var(--level));\n  gap: ${spacing.xxsmall};\n  cursor: pointer;\n\n  border: none;\n  box-shadow: none;\n  color: ${colors.text.primary};\n  font-size: ${fonts.sizes(\"16px\")};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\n  &[data-selected=\"true\"] {\n    color: ${colors.brand.primary};\n    font-weight: ${fonts.weight.semibold};\n  }\n  &:hover,\n  &:focus {\n    color: ${colors.brand.primary};\n  }\n`;\n\ninterface Props extends CommonFolderItemsProps {\n  isOpen: boolean;\n  folder: IFolder;\n  isCreatingFolder?: boolean;\n  index: number;\n}\n\nconst FolderItem = ({\n  focusedFolder,\n  folder,\n  isOpen,\n  level,\n  loading,\n  selectedFolder,\n  onCloseFolder,\n  onOpenFolder,\n  setFocusedFolder,\n  setSelectedFolder,\n  targetResource,\n  visibleFolders,\n  maxLevel,\n  isCreatingFolder,\n  type,\n  closeTree,\n  index,\n}: Props) => {\n  const { t } = useTranslation();\n  const { id, name } = folder;\n  const ref = useRef<HTMLButtonElement & HTMLAnchorElement>(null);\n  const selected = selectedFolder ? selectedFolder.id === id : false;\n\n  const levelVariable = useMemo(() => ({ \"--level\": level }) as unknown as CSSProperties, [level]);\n\n  const focused = focusedFolder?.id === id;\n\n  const handleClickFolder = () => {\n    if (!selected) {\n      setSelectedFolder(folder);\n    }\n    setFocusedFolder(folder);\n    if (type === \"picker\") {\n      if (selected) {\n        closeTree();\n      }\n    }\n  };\n\n  useEffect(() => {\n    if (focusedFolder?.id === id && !isCreatingFolder) {\n      if (type === \"navigation\") {\n        ref.current?.focus();\n      }\n      if (type === \"picker\") {\n        ref.current?.scrollIntoView({\n          behavior: \"smooth\",\n          block: \"start\",\n        });\n      }\n    }\n  }, [focusedFolder, ref, id, isCreatingFolder, type]);\n\n  const linkPath = `/minndla/folders/${id}`;\n\n  const containsResource =\n    targetResource && folder.resources.some((resource) => resource.resourceId === targetResource.resourceId);\n\n  const emptyFolder = folder.subfolders.length === 0;\n  const isMaxDepth = level > maxLevel;\n  const hideArrow = isMaxDepth || emptyFolder;\n\n  const FolderIcon = folder.status === \"shared\" ? FolderShared : FolderOutlined;\n\n  const tabable = selected || focused || (!focusedFolder && !folder.parentId && index === 0);\n\n  return type === \"navigation\" ? (\n    <FolderNameLink\n      role=\"treeitem\"\n      aria-owns={folder.subfolders.length ? treestructureId(type, `subfolders-${folder.id}`) : undefined}\n      aria-expanded={isMaxDepth || emptyFolder ? undefined : isOpen}\n      aria-current={selected ? \"page\" : undefined}\n      aria-describedby={containsResource ? `alreadyAdded-${folder.id}` : undefined}\n      ref={ref}\n      style={levelVariable}\n      onKeyDown={(e: KeyboardEvent<HTMLElement>) => {\n        if (e.key === \"Enter\") {\n          setSelectedFolder(folder);\n          return;\n        }\n        arrowNavigation(e, id, visibleFolders, setFocusedFolder, onOpenFolder, onCloseFolder);\n      }}\n      to={loading ? \"\" : linkPath}\n      tabIndex={tabable ? 0 : -1}\n      data-selected={selected}\n      onFocus={() => setFocusedFolder(folder)}\n      onClick={handleClickFolder}\n    >\n      <OpenButton\n        aria-hidden\n        tabIndex={-1}\n        data-open={isOpen}\n        data-hide-arrow={hideArrow}\n        onClick={(e) => {\n          e.stopPropagation();\n          e.preventDefault();\n          ref.current?.focus();\n          if (isOpen) {\n            onCloseFolder(id);\n          } else {\n            onOpenFolder(id);\n          }\n        }}\n      >\n        <ArrowDropDownRounded />\n      </OpenButton>\n      <StyledName>{name}</StyledName>\n    </FolderNameLink>\n  ) : (\n    <FolderName\n      tabIndex={-1}\n      role=\"treeitem\"\n      id={treestructureId(type, folder.id)}\n      aria-expanded={isMaxDepth || emptyFolder ? undefined : isOpen}\n      aria-selected={selected}\n      data-focused={focusedFolder?.id === folder.id}\n      aria-describedby={containsResource ? `alreadyAdded-${folder.id}` : undefined}\n      aria-label={`${name}${folder.status === \"shared\" ? `, ${t(\"myNdla.folder.sharing.shared\")}` : \"\"}`}\n      variant=\"ghost\"\n      shape=\"sharp\"\n      fontWeight=\"normal\"\n      colorTheme=\"light\"\n      ref={ref}\n      style={levelVariable}\n      data-selected={selected}\n      disabled={loading}\n      onFocus={() => setFocusedFolder(focusedFolder || folder)}\n      onClick={handleClickFolder}\n      data-creating={isCreatingFolder}\n    >\n      <IconWrapper>\n        <OpenButton\n          aria-hidden\n          tabIndex={-1}\n          data-open={isOpen}\n          data-hide-arrow={hideArrow}\n          onClick={(e) => {\n            e.stopPropagation();\n            setFocusedFolder(folder);\n            if (isOpen) {\n              onCloseFolder(id);\n            } else {\n              onOpenFolder(id);\n            }\n          }}\n        >\n          <ArrowDropDownRounded />\n        </OpenButton>\n        <FolderIconWrapper>\n          <FolderIcon />\n        </FolderIconWrapper>\n      </IconWrapper>\n      <StyledName>{name}</StyledName>\n      {containsResource && (\n        <StyledDone\n          aria-label={t(\"myNdla.alreadyInFolder\")}\n          id={`alreadyAdded-${folder.id}`}\n          title={t(\"myNdla.alreadyInFolder\")}\n        />\n      )}\n    </FolderName>\n  );\n};\n\nexport default FolderItem;\n"]} */",
59
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FolderItem.tsx"],"names":[],"mappings":"AA4DoC","file":"FolderItem.tsx","sourcesContent":["/**\n * Copyright (c) 2022-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { CSSProperties, KeyboardEvent, useEffect, useMemo, useRef } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport styled from \"@emotion/styled\";\nimport { ButtonV2 as Button } from \"@ndla/button\";\nimport { colors, spacing, animations, misc, fonts } from \"@ndla/core\";\nimport { ArrowDropDownRounded } from \"@ndla/icons/common\";\nimport { FolderOutlined, FolderShared } from \"@ndla/icons/contentType\";\nimport { Done } from \"@ndla/icons/editor\";\nimport { SafeLink } from \"@ndla/safelink\";\nimport { IFolder } from \"@ndla/types-backend/myndla-api\";\nimport { arrowNavigation } from \"./arrowNavigation\";\nimport { treestructureId } from \"./helperFunctions\";\nimport { CommonFolderItemsProps } from \"./types\";\n\nconst OpenButton = styled.span`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  align-self: stretch;\n  color: ${colors.brand.tertiary};\n  ${misc.transition.default};\n  cursor: pointer;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n  svg {\n    width: 24px;\n    height: 24px;\n    transform: rotate(-90deg);\n  }\n  &[data-open=\"true\"] {\n    svg {\n      transform: rotate(0deg);\n    }\n  }\n  &[data-hide-arrow=\"true\"] {\n    visibility: hidden;\n  }\n`;\n\nconst StyledName = styled.span`\n  white-space: nowrap;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  grid-column-start: 2;\n  text-align: left;\n`;\n\nconst IconWrapper = styled.div`\n  display: flex;\n`;\n\nconst FolderIconWrapper = styled.div`\n  svg {\n    height: 24px;\n    width: 24px;\n  }\n`;\n\nconst FolderName = styled(Button)`\n  display: grid;\n  grid-template-columns: auto 1fr auto;\n  padding-left: calc(0.75 * ${spacing.normal} * var(--level));\n  gap: ${spacing.xxsmall};\n  border: none;\n  outline: none;\n  color: ${colors.text.primary};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\n\n  &:hover {\n    box-shadow: none;\n    outline: none;\n    background: ${colors.brand.lightest};\n    color: ${colors.text.primary};\n  }\n\n  &[data-focused=\"true\"] {\n    background: ${colors.brand.lightest};\n  }\n\n  &[data-selected=\"true\"] {\n    background: ${colors.brand.lighter};\n    &:hover {\n      background: ${colors.brand.light};\n    }\n  }\n\n  &[data-creating=\"true\"][data-focused=\"true\"] {\n    color: ${colors.brand.primary};\n  }\n\n  &[data-creating=\"true\"] {\n    background: none;\n  }\n`;\n\nconst StyledDone = styled(Done)`\n  color: ${colors.support.green};\n`;\n\nconst FolderNameLink = styled(SafeLink)`\n  display: grid;\n  align-items: center;\n  grid-template-columns: ${spacing.medium} 1fr auto;\n  padding: ${spacing.small} ${spacing.xxsmall};\n  padding-left: calc(0.75 * ${spacing.normal} * var(--level));\n  gap: ${spacing.xxsmall};\n  cursor: pointer;\n\n  border: none;\n  box-shadow: none;\n  color: ${colors.text.primary};\n  ${fonts.sizes(\"16px\")};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\n  &[data-selected=\"true\"] {\n    color: ${colors.brand.primary};\n    font-weight: ${fonts.weight.semibold};\n  }\n  &:hover,\n  &:focus {\n    color: ${colors.brand.primary};\n  }\n`;\n\ninterface Props extends CommonFolderItemsProps {\n  isOpen: boolean;\n  folder: IFolder;\n  isCreatingFolder?: boolean;\n  index: number;\n}\n\nconst FolderItem = ({\n  focusedFolder,\n  folder,\n  isOpen,\n  level,\n  loading,\n  selectedFolder,\n  onCloseFolder,\n  onOpenFolder,\n  setFocusedFolder,\n  setSelectedFolder,\n  targetResource,\n  visibleFolders,\n  maxLevel,\n  isCreatingFolder,\n  type,\n  closeTree,\n  index,\n}: Props) => {\n  const { t } = useTranslation();\n  const { id, name } = folder;\n  const ref = useRef<HTMLButtonElement & HTMLAnchorElement>(null);\n  const selected = selectedFolder ? selectedFolder.id === id : false;\n\n  const levelVariable = useMemo(() => ({ \"--level\": level }) as unknown as CSSProperties, [level]);\n\n  const focused = focusedFolder?.id === id;\n\n  const handleClickFolder = () => {\n    if (!selected) {\n      setSelectedFolder(folder);\n    }\n    setFocusedFolder(folder);\n    if (type === \"picker\") {\n      if (selected) {\n        closeTree();\n      }\n    }\n  };\n\n  useEffect(() => {\n    if (focusedFolder?.id === id && !isCreatingFolder) {\n      if (type === \"navigation\") {\n        ref.current?.focus();\n      }\n      if (type === \"picker\") {\n        ref.current?.scrollIntoView({\n          behavior: \"smooth\",\n          block: \"start\",\n        });\n      }\n    }\n  }, [focusedFolder, ref, id, isCreatingFolder, type]);\n\n  const linkPath = `/minndla/folders/${id}`;\n\n  const containsResource =\n    targetResource && folder.resources.some((resource) => resource.resourceId === targetResource.resourceId);\n\n  const emptyFolder = folder.subfolders.length === 0;\n  const isMaxDepth = level > maxLevel;\n  const hideArrow = isMaxDepth || emptyFolder;\n\n  const FolderIcon = folder.status === \"shared\" ? FolderShared : FolderOutlined;\n\n  const tabable = selected || focused || (!focusedFolder && !folder.parentId && index === 0);\n\n  return type === \"navigation\" ? (\n    <FolderNameLink\n      role=\"treeitem\"\n      aria-owns={folder.subfolders.length ? treestructureId(type, `subfolders-${folder.id}`) : undefined}\n      aria-expanded={isMaxDepth || emptyFolder ? undefined : isOpen}\n      aria-current={selected ? \"page\" : undefined}\n      aria-describedby={containsResource ? `alreadyAdded-${folder.id}` : undefined}\n      ref={ref}\n      style={levelVariable}\n      onKeyDown={(e: KeyboardEvent<HTMLElement>) => {\n        if (e.key === \"Enter\") {\n          setSelectedFolder(folder);\n          return;\n        }\n        arrowNavigation(e, id, visibleFolders, setFocusedFolder, onOpenFolder, onCloseFolder);\n      }}\n      to={loading ? \"\" : linkPath}\n      tabIndex={tabable ? 0 : -1}\n      data-selected={selected}\n      onFocus={() => setFocusedFolder(folder)}\n      onClick={handleClickFolder}\n    >\n      <OpenButton\n        aria-hidden\n        tabIndex={-1}\n        data-open={isOpen}\n        data-hide-arrow={hideArrow}\n        onClick={(e) => {\n          e.stopPropagation();\n          e.preventDefault();\n          ref.current?.focus();\n          if (isOpen) {\n            onCloseFolder(id);\n          } else {\n            onOpenFolder(id);\n          }\n        }}\n      >\n        <ArrowDropDownRounded />\n      </OpenButton>\n      <StyledName>{name}</StyledName>\n    </FolderNameLink>\n  ) : (\n    <FolderName\n      tabIndex={-1}\n      role=\"treeitem\"\n      id={treestructureId(type, folder.id)}\n      aria-expanded={isMaxDepth || emptyFolder ? undefined : isOpen}\n      aria-selected={selected}\n      data-focused={focusedFolder?.id === folder.id}\n      aria-describedby={containsResource ? `alreadyAdded-${folder.id}` : undefined}\n      aria-label={`${name}${folder.status === \"shared\" ? `, ${t(\"myNdla.folder.sharing.shared\")}` : \"\"}`}\n      variant=\"ghost\"\n      shape=\"sharp\"\n      fontWeight=\"normal\"\n      colorTheme=\"light\"\n      ref={ref}\n      style={levelVariable}\n      data-selected={selected}\n      disabled={loading}\n      onFocus={() => setFocusedFolder(focusedFolder || folder)}\n      onClick={handleClickFolder}\n      data-creating={isCreatingFolder}\n    >\n      <IconWrapper>\n        <OpenButton\n          aria-hidden\n          tabIndex={-1}\n          data-open={isOpen}\n          data-hide-arrow={hideArrow}\n          onClick={(e) => {\n            e.stopPropagation();\n            setFocusedFolder(folder);\n            if (isOpen) {\n              onCloseFolder(id);\n            } else {\n              onOpenFolder(id);\n            }\n          }}\n        >\n          <ArrowDropDownRounded />\n        </OpenButton>\n        <FolderIconWrapper>\n          <FolderIcon />\n        </FolderIconWrapper>\n      </IconWrapper>\n      <StyledName>{name}</StyledName>\n      {containsResource && (\n        <StyledDone\n          aria-label={t(\"myNdla.alreadyInFolder\")}\n          id={`alreadyAdded-${folder.id}`}\n          title={t(\"myNdla.alreadyInFolder\")}\n        />\n      )}\n    </FolderName>\n  );\n};\n\nexport default FolderItem;\n"]} */",
60
60
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
61
61
  });
62
62
  const FolderName = /*#__PURE__*/_styled(Button, {
63
63
  target: "e11ok6h82",
64
64
  label: "FolderName"
65
- })("display:grid;grid-template-columns:auto 1fr auto;padding-left:calc(0.75 * ", spacing.normal, " * var(--level));gap:", spacing.xxsmall, ";border:none;outline:none;color:", colors.text.primary, ";transition:", animations.durations.superFast, ";word-break:break-word;&:hover{box-shadow:none;outline:none;background:", colors.brand.lightest, ";color:", colors.text.primary, ";}&[data-focused=\"true\"]{background:", colors.brand.lightest, ";}&[data-selected=\"true\"]{background:", colors.brand.lighter, ";&:hover{background:", colors.brand.light, ";}}&[data-creating=\"true\"][data-focused=\"true\"]{color:", colors.brand.primary, ";}&[data-creating=\"true\"]{background:none;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FolderItem.tsx"],"names":[],"mappings":"AAmEiC","file":"FolderItem.tsx","sourcesContent":["/**\n * Copyright (c) 2022-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { CSSProperties, KeyboardEvent, useEffect, useMemo, useRef } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport styled from \"@emotion/styled\";\nimport { ButtonV2 as Button } from \"@ndla/button\";\nimport { colors, spacing, animations, misc, fonts } from \"@ndla/core\";\nimport { ArrowDropDownRounded } from \"@ndla/icons/common\";\nimport { FolderOutlined, FolderShared } from \"@ndla/icons/contentType\";\nimport { Done } from \"@ndla/icons/editor\";\nimport { SafeLink } from \"@ndla/safelink\";\nimport { IFolder } from \"@ndla/types-backend/myndla-api\";\nimport { arrowNavigation } from \"./arrowNavigation\";\nimport { treestructureId } from \"./helperFunctions\";\nimport { CommonFolderItemsProps } from \"./types\";\n\nconst OpenButton = styled.span`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  align-self: stretch;\n  color: ${colors.brand.tertiary};\n  ${misc.transition.default};\n  cursor: pointer;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n  svg {\n    width: 24px;\n    height: 24px;\n    transform: rotate(-90deg);\n  }\n  &[data-open=\"true\"] {\n    svg {\n      transform: rotate(0deg);\n    }\n  }\n  &[data-hide-arrow=\"true\"] {\n    visibility: hidden;\n  }\n`;\n\nconst StyledName = styled.span`\n  white-space: nowrap;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  grid-column-start: 2;\n  text-align: left;\n`;\n\nconst IconWrapper = styled.div`\n  display: flex;\n`;\n\nconst FolderIconWrapper = styled.div`\n  svg {\n    height: 24px;\n    width: 24px;\n  }\n`;\n\nconst FolderName = styled(Button)`\n  display: grid;\n  grid-template-columns: auto 1fr auto;\n  padding-left: calc(0.75 * ${spacing.normal} * var(--level));\n  gap: ${spacing.xxsmall};\n  border: none;\n  outline: none;\n  color: ${colors.text.primary};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\n\n  &:hover {\n    box-shadow: none;\n    outline: none;\n    background: ${colors.brand.lightest};\n    color: ${colors.text.primary};\n  }\n\n  &[data-focused=\"true\"] {\n    background: ${colors.brand.lightest};\n  }\n\n  &[data-selected=\"true\"] {\n    background: ${colors.brand.lighter};\n    &:hover {\n      background: ${colors.brand.light};\n    }\n  }\n\n  &[data-creating=\"true\"][data-focused=\"true\"] {\n    color: ${colors.brand.primary};\n  }\n\n  &[data-creating=\"true\"] {\n    background: none;\n  }\n`;\n\nconst StyledDone = styled(Done)`\n  color: ${colors.support.green};\n`;\n\nconst FolderNameLink = styled(SafeLink)`\n  display: grid;\n  align-items: center;\n  grid-template-columns: ${spacing.medium} 1fr auto;\n  padding: ${spacing.small} ${spacing.xxsmall};\n  padding-left: calc(0.75 * ${spacing.normal} * var(--level));\n  gap: ${spacing.xxsmall};\n  cursor: pointer;\n\n  border: none;\n  box-shadow: none;\n  color: ${colors.text.primary};\n  font-size: ${fonts.sizes(\"16px\")};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\n  &[data-selected=\"true\"] {\n    color: ${colors.brand.primary};\n    font-weight: ${fonts.weight.semibold};\n  }\n  &:hover,\n  &:focus {\n    color: ${colors.brand.primary};\n  }\n`;\n\ninterface Props extends CommonFolderItemsProps {\n  isOpen: boolean;\n  folder: IFolder;\n  isCreatingFolder?: boolean;\n  index: number;\n}\n\nconst FolderItem = ({\n  focusedFolder,\n  folder,\n  isOpen,\n  level,\n  loading,\n  selectedFolder,\n  onCloseFolder,\n  onOpenFolder,\n  setFocusedFolder,\n  setSelectedFolder,\n  targetResource,\n  visibleFolders,\n  maxLevel,\n  isCreatingFolder,\n  type,\n  closeTree,\n  index,\n}: Props) => {\n  const { t } = useTranslation();\n  const { id, name } = folder;\n  const ref = useRef<HTMLButtonElement & HTMLAnchorElement>(null);\n  const selected = selectedFolder ? selectedFolder.id === id : false;\n\n  const levelVariable = useMemo(() => ({ \"--level\": level }) as unknown as CSSProperties, [level]);\n\n  const focused = focusedFolder?.id === id;\n\n  const handleClickFolder = () => {\n    if (!selected) {\n      setSelectedFolder(folder);\n    }\n    setFocusedFolder(folder);\n    if (type === \"picker\") {\n      if (selected) {\n        closeTree();\n      }\n    }\n  };\n\n  useEffect(() => {\n    if (focusedFolder?.id === id && !isCreatingFolder) {\n      if (type === \"navigation\") {\n        ref.current?.focus();\n      }\n      if (type === \"picker\") {\n        ref.current?.scrollIntoView({\n          behavior: \"smooth\",\n          block: \"start\",\n        });\n      }\n    }\n  }, [focusedFolder, ref, id, isCreatingFolder, type]);\n\n  const linkPath = `/minndla/folders/${id}`;\n\n  const containsResource =\n    targetResource && folder.resources.some((resource) => resource.resourceId === targetResource.resourceId);\n\n  const emptyFolder = folder.subfolders.length === 0;\n  const isMaxDepth = level > maxLevel;\n  const hideArrow = isMaxDepth || emptyFolder;\n\n  const FolderIcon = folder.status === \"shared\" ? FolderShared : FolderOutlined;\n\n  const tabable = selected || focused || (!focusedFolder && !folder.parentId && index === 0);\n\n  return type === \"navigation\" ? (\n    <FolderNameLink\n      role=\"treeitem\"\n      aria-owns={folder.subfolders.length ? treestructureId(type, `subfolders-${folder.id}`) : undefined}\n      aria-expanded={isMaxDepth || emptyFolder ? undefined : isOpen}\n      aria-current={selected ? \"page\" : undefined}\n      aria-describedby={containsResource ? `alreadyAdded-${folder.id}` : undefined}\n      ref={ref}\n      style={levelVariable}\n      onKeyDown={(e: KeyboardEvent<HTMLElement>) => {\n        if (e.key === \"Enter\") {\n          setSelectedFolder(folder);\n          return;\n        }\n        arrowNavigation(e, id, visibleFolders, setFocusedFolder, onOpenFolder, onCloseFolder);\n      }}\n      to={loading ? \"\" : linkPath}\n      tabIndex={tabable ? 0 : -1}\n      data-selected={selected}\n      onFocus={() => setFocusedFolder(folder)}\n      onClick={handleClickFolder}\n    >\n      <OpenButton\n        aria-hidden\n        tabIndex={-1}\n        data-open={isOpen}\n        data-hide-arrow={hideArrow}\n        onClick={(e) => {\n          e.stopPropagation();\n          e.preventDefault();\n          ref.current?.focus();\n          if (isOpen) {\n            onCloseFolder(id);\n          } else {\n            onOpenFolder(id);\n          }\n        }}\n      >\n        <ArrowDropDownRounded />\n      </OpenButton>\n      <StyledName>{name}</StyledName>\n    </FolderNameLink>\n  ) : (\n    <FolderName\n      tabIndex={-1}\n      role=\"treeitem\"\n      id={treestructureId(type, folder.id)}\n      aria-expanded={isMaxDepth || emptyFolder ? undefined : isOpen}\n      aria-selected={selected}\n      data-focused={focusedFolder?.id === folder.id}\n      aria-describedby={containsResource ? `alreadyAdded-${folder.id}` : undefined}\n      aria-label={`${name}${folder.status === \"shared\" ? `, ${t(\"myNdla.folder.sharing.shared\")}` : \"\"}`}\n      variant=\"ghost\"\n      shape=\"sharp\"\n      fontWeight=\"normal\"\n      colorTheme=\"light\"\n      ref={ref}\n      style={levelVariable}\n      data-selected={selected}\n      disabled={loading}\n      onFocus={() => setFocusedFolder(focusedFolder || folder)}\n      onClick={handleClickFolder}\n      data-creating={isCreatingFolder}\n    >\n      <IconWrapper>\n        <OpenButton\n          aria-hidden\n          tabIndex={-1}\n          data-open={isOpen}\n          data-hide-arrow={hideArrow}\n          onClick={(e) => {\n            e.stopPropagation();\n            setFocusedFolder(folder);\n            if (isOpen) {\n              onCloseFolder(id);\n            } else {\n              onOpenFolder(id);\n            }\n          }}\n        >\n          <ArrowDropDownRounded />\n        </OpenButton>\n        <FolderIconWrapper>\n          <FolderIcon />\n        </FolderIconWrapper>\n      </IconWrapper>\n      <StyledName>{name}</StyledName>\n      {containsResource && (\n        <StyledDone\n          aria-label={t(\"myNdla.alreadyInFolder\")}\n          id={`alreadyAdded-${folder.id}`}\n          title={t(\"myNdla.alreadyInFolder\")}\n        />\n      )}\n    </FolderName>\n  );\n};\n\nexport default FolderItem;\n"]} */"));
65
+ })("display:grid;grid-template-columns:auto 1fr auto;padding-left:calc(0.75 * ", spacing.normal, " * var(--level));gap:", spacing.xxsmall, ";border:none;outline:none;color:", colors.text.primary, ";transition:", animations.durations.superFast, ";word-break:break-word;&:hover{box-shadow:none;outline:none;background:", colors.brand.lightest, ";color:", colors.text.primary, ";}&[data-focused=\"true\"]{background:", colors.brand.lightest, ";}&[data-selected=\"true\"]{background:", colors.brand.lighter, ";&:hover{background:", colors.brand.light, ";}}&[data-creating=\"true\"][data-focused=\"true\"]{color:", colors.brand.primary, ";}&[data-creating=\"true\"]{background:none;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FolderItem.tsx"],"names":[],"mappings":"AAmEiC","file":"FolderItem.tsx","sourcesContent":["/**\n * Copyright (c) 2022-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { CSSProperties, KeyboardEvent, useEffect, useMemo, useRef } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport styled from \"@emotion/styled\";\nimport { ButtonV2 as Button } from \"@ndla/button\";\nimport { colors, spacing, animations, misc, fonts } from \"@ndla/core\";\nimport { ArrowDropDownRounded } from \"@ndla/icons/common\";\nimport { FolderOutlined, FolderShared } from \"@ndla/icons/contentType\";\nimport { Done } from \"@ndla/icons/editor\";\nimport { SafeLink } from \"@ndla/safelink\";\nimport { IFolder } from \"@ndla/types-backend/myndla-api\";\nimport { arrowNavigation } from \"./arrowNavigation\";\nimport { treestructureId } from \"./helperFunctions\";\nimport { CommonFolderItemsProps } from \"./types\";\n\nconst OpenButton = styled.span`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  align-self: stretch;\n  color: ${colors.brand.tertiary};\n  ${misc.transition.default};\n  cursor: pointer;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n  svg {\n    width: 24px;\n    height: 24px;\n    transform: rotate(-90deg);\n  }\n  &[data-open=\"true\"] {\n    svg {\n      transform: rotate(0deg);\n    }\n  }\n  &[data-hide-arrow=\"true\"] {\n    visibility: hidden;\n  }\n`;\n\nconst StyledName = styled.span`\n  white-space: nowrap;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  grid-column-start: 2;\n  text-align: left;\n`;\n\nconst IconWrapper = styled.div`\n  display: flex;\n`;\n\nconst FolderIconWrapper = styled.div`\n  svg {\n    height: 24px;\n    width: 24px;\n  }\n`;\n\nconst FolderName = styled(Button)`\n  display: grid;\n  grid-template-columns: auto 1fr auto;\n  padding-left: calc(0.75 * ${spacing.normal} * var(--level));\n  gap: ${spacing.xxsmall};\n  border: none;\n  outline: none;\n  color: ${colors.text.primary};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\n\n  &:hover {\n    box-shadow: none;\n    outline: none;\n    background: ${colors.brand.lightest};\n    color: ${colors.text.primary};\n  }\n\n  &[data-focused=\"true\"] {\n    background: ${colors.brand.lightest};\n  }\n\n  &[data-selected=\"true\"] {\n    background: ${colors.brand.lighter};\n    &:hover {\n      background: ${colors.brand.light};\n    }\n  }\n\n  &[data-creating=\"true\"][data-focused=\"true\"] {\n    color: ${colors.brand.primary};\n  }\n\n  &[data-creating=\"true\"] {\n    background: none;\n  }\n`;\n\nconst StyledDone = styled(Done)`\n  color: ${colors.support.green};\n`;\n\nconst FolderNameLink = styled(SafeLink)`\n  display: grid;\n  align-items: center;\n  grid-template-columns: ${spacing.medium} 1fr auto;\n  padding: ${spacing.small} ${spacing.xxsmall};\n  padding-left: calc(0.75 * ${spacing.normal} * var(--level));\n  gap: ${spacing.xxsmall};\n  cursor: pointer;\n\n  border: none;\n  box-shadow: none;\n  color: ${colors.text.primary};\n  ${fonts.sizes(\"16px\")};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\n  &[data-selected=\"true\"] {\n    color: ${colors.brand.primary};\n    font-weight: ${fonts.weight.semibold};\n  }\n  &:hover,\n  &:focus {\n    color: ${colors.brand.primary};\n  }\n`;\n\ninterface Props extends CommonFolderItemsProps {\n  isOpen: boolean;\n  folder: IFolder;\n  isCreatingFolder?: boolean;\n  index: number;\n}\n\nconst FolderItem = ({\n  focusedFolder,\n  folder,\n  isOpen,\n  level,\n  loading,\n  selectedFolder,\n  onCloseFolder,\n  onOpenFolder,\n  setFocusedFolder,\n  setSelectedFolder,\n  targetResource,\n  visibleFolders,\n  maxLevel,\n  isCreatingFolder,\n  type,\n  closeTree,\n  index,\n}: Props) => {\n  const { t } = useTranslation();\n  const { id, name } = folder;\n  const ref = useRef<HTMLButtonElement & HTMLAnchorElement>(null);\n  const selected = selectedFolder ? selectedFolder.id === id : false;\n\n  const levelVariable = useMemo(() => ({ \"--level\": level }) as unknown as CSSProperties, [level]);\n\n  const focused = focusedFolder?.id === id;\n\n  const handleClickFolder = () => {\n    if (!selected) {\n      setSelectedFolder(folder);\n    }\n    setFocusedFolder(folder);\n    if (type === \"picker\") {\n      if (selected) {\n        closeTree();\n      }\n    }\n  };\n\n  useEffect(() => {\n    if (focusedFolder?.id === id && !isCreatingFolder) {\n      if (type === \"navigation\") {\n        ref.current?.focus();\n      }\n      if (type === \"picker\") {\n        ref.current?.scrollIntoView({\n          behavior: \"smooth\",\n          block: \"start\",\n        });\n      }\n    }\n  }, [focusedFolder, ref, id, isCreatingFolder, type]);\n\n  const linkPath = `/minndla/folders/${id}`;\n\n  const containsResource =\n    targetResource && folder.resources.some((resource) => resource.resourceId === targetResource.resourceId);\n\n  const emptyFolder = folder.subfolders.length === 0;\n  const isMaxDepth = level > maxLevel;\n  const hideArrow = isMaxDepth || emptyFolder;\n\n  const FolderIcon = folder.status === \"shared\" ? FolderShared : FolderOutlined;\n\n  const tabable = selected || focused || (!focusedFolder && !folder.parentId && index === 0);\n\n  return type === \"navigation\" ? (\n    <FolderNameLink\n      role=\"treeitem\"\n      aria-owns={folder.subfolders.length ? treestructureId(type, `subfolders-${folder.id}`) : undefined}\n      aria-expanded={isMaxDepth || emptyFolder ? undefined : isOpen}\n      aria-current={selected ? \"page\" : undefined}\n      aria-describedby={containsResource ? `alreadyAdded-${folder.id}` : undefined}\n      ref={ref}\n      style={levelVariable}\n      onKeyDown={(e: KeyboardEvent<HTMLElement>) => {\n        if (e.key === \"Enter\") {\n          setSelectedFolder(folder);\n          return;\n        }\n        arrowNavigation(e, id, visibleFolders, setFocusedFolder, onOpenFolder, onCloseFolder);\n      }}\n      to={loading ? \"\" : linkPath}\n      tabIndex={tabable ? 0 : -1}\n      data-selected={selected}\n      onFocus={() => setFocusedFolder(folder)}\n      onClick={handleClickFolder}\n    >\n      <OpenButton\n        aria-hidden\n        tabIndex={-1}\n        data-open={isOpen}\n        data-hide-arrow={hideArrow}\n        onClick={(e) => {\n          e.stopPropagation();\n          e.preventDefault();\n          ref.current?.focus();\n          if (isOpen) {\n            onCloseFolder(id);\n          } else {\n            onOpenFolder(id);\n          }\n        }}\n      >\n        <ArrowDropDownRounded />\n      </OpenButton>\n      <StyledName>{name}</StyledName>\n    </FolderNameLink>\n  ) : (\n    <FolderName\n      tabIndex={-1}\n      role=\"treeitem\"\n      id={treestructureId(type, folder.id)}\n      aria-expanded={isMaxDepth || emptyFolder ? undefined : isOpen}\n      aria-selected={selected}\n      data-focused={focusedFolder?.id === folder.id}\n      aria-describedby={containsResource ? `alreadyAdded-${folder.id}` : undefined}\n      aria-label={`${name}${folder.status === \"shared\" ? `, ${t(\"myNdla.folder.sharing.shared\")}` : \"\"}`}\n      variant=\"ghost\"\n      shape=\"sharp\"\n      fontWeight=\"normal\"\n      colorTheme=\"light\"\n      ref={ref}\n      style={levelVariable}\n      data-selected={selected}\n      disabled={loading}\n      onFocus={() => setFocusedFolder(focusedFolder || folder)}\n      onClick={handleClickFolder}\n      data-creating={isCreatingFolder}\n    >\n      <IconWrapper>\n        <OpenButton\n          aria-hidden\n          tabIndex={-1}\n          data-open={isOpen}\n          data-hide-arrow={hideArrow}\n          onClick={(e) => {\n            e.stopPropagation();\n            setFocusedFolder(folder);\n            if (isOpen) {\n              onCloseFolder(id);\n            } else {\n              onOpenFolder(id);\n            }\n          }}\n        >\n          <ArrowDropDownRounded />\n        </OpenButton>\n        <FolderIconWrapper>\n          <FolderIcon />\n        </FolderIconWrapper>\n      </IconWrapper>\n      <StyledName>{name}</StyledName>\n      {containsResource && (\n        <StyledDone\n          aria-label={t(\"myNdla.alreadyInFolder\")}\n          id={`alreadyAdded-${folder.id}`}\n          title={t(\"myNdla.alreadyInFolder\")}\n        />\n      )}\n    </FolderName>\n  );\n};\n\nexport default FolderItem;\n"]} */"));
66
66
  const StyledDone = /*#__PURE__*/_styled(Done, {
67
67
  target: "e11ok6h81",
68
68
  label: "StyledDone"
69
- })("color:", colors.support.green, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FolderItem.tsx"],"names":[],"mappings":"AAyG+B","file":"FolderItem.tsx","sourcesContent":["/**\n * Copyright (c) 2022-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { CSSProperties, KeyboardEvent, useEffect, useMemo, useRef } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport styled from \"@emotion/styled\";\nimport { ButtonV2 as Button } from \"@ndla/button\";\nimport { colors, spacing, animations, misc, fonts } from \"@ndla/core\";\nimport { ArrowDropDownRounded } from \"@ndla/icons/common\";\nimport { FolderOutlined, FolderShared } from \"@ndla/icons/contentType\";\nimport { Done } from \"@ndla/icons/editor\";\nimport { SafeLink } from \"@ndla/safelink\";\nimport { IFolder } from \"@ndla/types-backend/myndla-api\";\nimport { arrowNavigation } from \"./arrowNavigation\";\nimport { treestructureId } from \"./helperFunctions\";\nimport { CommonFolderItemsProps } from \"./types\";\n\nconst OpenButton = styled.span`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  align-self: stretch;\n  color: ${colors.brand.tertiary};\n  ${misc.transition.default};\n  cursor: pointer;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n  svg {\n    width: 24px;\n    height: 24px;\n    transform: rotate(-90deg);\n  }\n  &[data-open=\"true\"] {\n    svg {\n      transform: rotate(0deg);\n    }\n  }\n  &[data-hide-arrow=\"true\"] {\n    visibility: hidden;\n  }\n`;\n\nconst StyledName = styled.span`\n  white-space: nowrap;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  grid-column-start: 2;\n  text-align: left;\n`;\n\nconst IconWrapper = styled.div`\n  display: flex;\n`;\n\nconst FolderIconWrapper = styled.div`\n  svg {\n    height: 24px;\n    width: 24px;\n  }\n`;\n\nconst FolderName = styled(Button)`\n  display: grid;\n  grid-template-columns: auto 1fr auto;\n  padding-left: calc(0.75 * ${spacing.normal} * var(--level));\n  gap: ${spacing.xxsmall};\n  border: none;\n  outline: none;\n  color: ${colors.text.primary};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\n\n  &:hover {\n    box-shadow: none;\n    outline: none;\n    background: ${colors.brand.lightest};\n    color: ${colors.text.primary};\n  }\n\n  &[data-focused=\"true\"] {\n    background: ${colors.brand.lightest};\n  }\n\n  &[data-selected=\"true\"] {\n    background: ${colors.brand.lighter};\n    &:hover {\n      background: ${colors.brand.light};\n    }\n  }\n\n  &[data-creating=\"true\"][data-focused=\"true\"] {\n    color: ${colors.brand.primary};\n  }\n\n  &[data-creating=\"true\"] {\n    background: none;\n  }\n`;\n\nconst StyledDone = styled(Done)`\n  color: ${colors.support.green};\n`;\n\nconst FolderNameLink = styled(SafeLink)`\n  display: grid;\n  align-items: center;\n  grid-template-columns: ${spacing.medium} 1fr auto;\n  padding: ${spacing.small} ${spacing.xxsmall};\n  padding-left: calc(0.75 * ${spacing.normal} * var(--level));\n  gap: ${spacing.xxsmall};\n  cursor: pointer;\n\n  border: none;\n  box-shadow: none;\n  color: ${colors.text.primary};\n  font-size: ${fonts.sizes(\"16px\")};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\n  &[data-selected=\"true\"] {\n    color: ${colors.brand.primary};\n    font-weight: ${fonts.weight.semibold};\n  }\n  &:hover,\n  &:focus {\n    color: ${colors.brand.primary};\n  }\n`;\n\ninterface Props extends CommonFolderItemsProps {\n  isOpen: boolean;\n  folder: IFolder;\n  isCreatingFolder?: boolean;\n  index: number;\n}\n\nconst FolderItem = ({\n  focusedFolder,\n  folder,\n  isOpen,\n  level,\n  loading,\n  selectedFolder,\n  onCloseFolder,\n  onOpenFolder,\n  setFocusedFolder,\n  setSelectedFolder,\n  targetResource,\n  visibleFolders,\n  maxLevel,\n  isCreatingFolder,\n  type,\n  closeTree,\n  index,\n}: Props) => {\n  const { t } = useTranslation();\n  const { id, name } = folder;\n  const ref = useRef<HTMLButtonElement & HTMLAnchorElement>(null);\n  const selected = selectedFolder ? selectedFolder.id === id : false;\n\n  const levelVariable = useMemo(() => ({ \"--level\": level }) as unknown as CSSProperties, [level]);\n\n  const focused = focusedFolder?.id === id;\n\n  const handleClickFolder = () => {\n    if (!selected) {\n      setSelectedFolder(folder);\n    }\n    setFocusedFolder(folder);\n    if (type === \"picker\") {\n      if (selected) {\n        closeTree();\n      }\n    }\n  };\n\n  useEffect(() => {\n    if (focusedFolder?.id === id && !isCreatingFolder) {\n      if (type === \"navigation\") {\n        ref.current?.focus();\n      }\n      if (type === \"picker\") {\n        ref.current?.scrollIntoView({\n          behavior: \"smooth\",\n          block: \"start\",\n        });\n      }\n    }\n  }, [focusedFolder, ref, id, isCreatingFolder, type]);\n\n  const linkPath = `/minndla/folders/${id}`;\n\n  const containsResource =\n    targetResource && folder.resources.some((resource) => resource.resourceId === targetResource.resourceId);\n\n  const emptyFolder = folder.subfolders.length === 0;\n  const isMaxDepth = level > maxLevel;\n  const hideArrow = isMaxDepth || emptyFolder;\n\n  const FolderIcon = folder.status === \"shared\" ? FolderShared : FolderOutlined;\n\n  const tabable = selected || focused || (!focusedFolder && !folder.parentId && index === 0);\n\n  return type === \"navigation\" ? (\n    <FolderNameLink\n      role=\"treeitem\"\n      aria-owns={folder.subfolders.length ? treestructureId(type, `subfolders-${folder.id}`) : undefined}\n      aria-expanded={isMaxDepth || emptyFolder ? undefined : isOpen}\n      aria-current={selected ? \"page\" : undefined}\n      aria-describedby={containsResource ? `alreadyAdded-${folder.id}` : undefined}\n      ref={ref}\n      style={levelVariable}\n      onKeyDown={(e: KeyboardEvent<HTMLElement>) => {\n        if (e.key === \"Enter\") {\n          setSelectedFolder(folder);\n          return;\n        }\n        arrowNavigation(e, id, visibleFolders, setFocusedFolder, onOpenFolder, onCloseFolder);\n      }}\n      to={loading ? \"\" : linkPath}\n      tabIndex={tabable ? 0 : -1}\n      data-selected={selected}\n      onFocus={() => setFocusedFolder(folder)}\n      onClick={handleClickFolder}\n    >\n      <OpenButton\n        aria-hidden\n        tabIndex={-1}\n        data-open={isOpen}\n        data-hide-arrow={hideArrow}\n        onClick={(e) => {\n          e.stopPropagation();\n          e.preventDefault();\n          ref.current?.focus();\n          if (isOpen) {\n            onCloseFolder(id);\n          } else {\n            onOpenFolder(id);\n          }\n        }}\n      >\n        <ArrowDropDownRounded />\n      </OpenButton>\n      <StyledName>{name}</StyledName>\n    </FolderNameLink>\n  ) : (\n    <FolderName\n      tabIndex={-1}\n      role=\"treeitem\"\n      id={treestructureId(type, folder.id)}\n      aria-expanded={isMaxDepth || emptyFolder ? undefined : isOpen}\n      aria-selected={selected}\n      data-focused={focusedFolder?.id === folder.id}\n      aria-describedby={containsResource ? `alreadyAdded-${folder.id}` : undefined}\n      aria-label={`${name}${folder.status === \"shared\" ? `, ${t(\"myNdla.folder.sharing.shared\")}` : \"\"}`}\n      variant=\"ghost\"\n      shape=\"sharp\"\n      fontWeight=\"normal\"\n      colorTheme=\"light\"\n      ref={ref}\n      style={levelVariable}\n      data-selected={selected}\n      disabled={loading}\n      onFocus={() => setFocusedFolder(focusedFolder || folder)}\n      onClick={handleClickFolder}\n      data-creating={isCreatingFolder}\n    >\n      <IconWrapper>\n        <OpenButton\n          aria-hidden\n          tabIndex={-1}\n          data-open={isOpen}\n          data-hide-arrow={hideArrow}\n          onClick={(e) => {\n            e.stopPropagation();\n            setFocusedFolder(folder);\n            if (isOpen) {\n              onCloseFolder(id);\n            } else {\n              onOpenFolder(id);\n            }\n          }}\n        >\n          <ArrowDropDownRounded />\n        </OpenButton>\n        <FolderIconWrapper>\n          <FolderIcon />\n        </FolderIconWrapper>\n      </IconWrapper>\n      <StyledName>{name}</StyledName>\n      {containsResource && (\n        <StyledDone\n          aria-label={t(\"myNdla.alreadyInFolder\")}\n          id={`alreadyAdded-${folder.id}`}\n          title={t(\"myNdla.alreadyInFolder\")}\n        />\n      )}\n    </FolderName>\n  );\n};\n\nexport default FolderItem;\n"]} */"));
69
+ })("color:", colors.support.green, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FolderItem.tsx"],"names":[],"mappings":"AAyG+B","file":"FolderItem.tsx","sourcesContent":["/**\n * Copyright (c) 2022-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { CSSProperties, KeyboardEvent, useEffect, useMemo, useRef } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport styled from \"@emotion/styled\";\nimport { ButtonV2 as Button } from \"@ndla/button\";\nimport { colors, spacing, animations, misc, fonts } from \"@ndla/core\";\nimport { ArrowDropDownRounded } from \"@ndla/icons/common\";\nimport { FolderOutlined, FolderShared } from \"@ndla/icons/contentType\";\nimport { Done } from \"@ndla/icons/editor\";\nimport { SafeLink } from \"@ndla/safelink\";\nimport { IFolder } from \"@ndla/types-backend/myndla-api\";\nimport { arrowNavigation } from \"./arrowNavigation\";\nimport { treestructureId } from \"./helperFunctions\";\nimport { CommonFolderItemsProps } from \"./types\";\n\nconst OpenButton = styled.span`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  align-self: stretch;\n  color: ${colors.brand.tertiary};\n  ${misc.transition.default};\n  cursor: pointer;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n  svg {\n    width: 24px;\n    height: 24px;\n    transform: rotate(-90deg);\n  }\n  &[data-open=\"true\"] {\n    svg {\n      transform: rotate(0deg);\n    }\n  }\n  &[data-hide-arrow=\"true\"] {\n    visibility: hidden;\n  }\n`;\n\nconst StyledName = styled.span`\n  white-space: nowrap;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  grid-column-start: 2;\n  text-align: left;\n`;\n\nconst IconWrapper = styled.div`\n  display: flex;\n`;\n\nconst FolderIconWrapper = styled.div`\n  svg {\n    height: 24px;\n    width: 24px;\n  }\n`;\n\nconst FolderName = styled(Button)`\n  display: grid;\n  grid-template-columns: auto 1fr auto;\n  padding-left: calc(0.75 * ${spacing.normal} * var(--level));\n  gap: ${spacing.xxsmall};\n  border: none;\n  outline: none;\n  color: ${colors.text.primary};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\n\n  &:hover {\n    box-shadow: none;\n    outline: none;\n    background: ${colors.brand.lightest};\n    color: ${colors.text.primary};\n  }\n\n  &[data-focused=\"true\"] {\n    background: ${colors.brand.lightest};\n  }\n\n  &[data-selected=\"true\"] {\n    background: ${colors.brand.lighter};\n    &:hover {\n      background: ${colors.brand.light};\n    }\n  }\n\n  &[data-creating=\"true\"][data-focused=\"true\"] {\n    color: ${colors.brand.primary};\n  }\n\n  &[data-creating=\"true\"] {\n    background: none;\n  }\n`;\n\nconst StyledDone = styled(Done)`\n  color: ${colors.support.green};\n`;\n\nconst FolderNameLink = styled(SafeLink)`\n  display: grid;\n  align-items: center;\n  grid-template-columns: ${spacing.medium} 1fr auto;\n  padding: ${spacing.small} ${spacing.xxsmall};\n  padding-left: calc(0.75 * ${spacing.normal} * var(--level));\n  gap: ${spacing.xxsmall};\n  cursor: pointer;\n\n  border: none;\n  box-shadow: none;\n  color: ${colors.text.primary};\n  ${fonts.sizes(\"16px\")};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\n  &[data-selected=\"true\"] {\n    color: ${colors.brand.primary};\n    font-weight: ${fonts.weight.semibold};\n  }\n  &:hover,\n  &:focus {\n    color: ${colors.brand.primary};\n  }\n`;\n\ninterface Props extends CommonFolderItemsProps {\n  isOpen: boolean;\n  folder: IFolder;\n  isCreatingFolder?: boolean;\n  index: number;\n}\n\nconst FolderItem = ({\n  focusedFolder,\n  folder,\n  isOpen,\n  level,\n  loading,\n  selectedFolder,\n  onCloseFolder,\n  onOpenFolder,\n  setFocusedFolder,\n  setSelectedFolder,\n  targetResource,\n  visibleFolders,\n  maxLevel,\n  isCreatingFolder,\n  type,\n  closeTree,\n  index,\n}: Props) => {\n  const { t } = useTranslation();\n  const { id, name } = folder;\n  const ref = useRef<HTMLButtonElement & HTMLAnchorElement>(null);\n  const selected = selectedFolder ? selectedFolder.id === id : false;\n\n  const levelVariable = useMemo(() => ({ \"--level\": level }) as unknown as CSSProperties, [level]);\n\n  const focused = focusedFolder?.id === id;\n\n  const handleClickFolder = () => {\n    if (!selected) {\n      setSelectedFolder(folder);\n    }\n    setFocusedFolder(folder);\n    if (type === \"picker\") {\n      if (selected) {\n        closeTree();\n      }\n    }\n  };\n\n  useEffect(() => {\n    if (focusedFolder?.id === id && !isCreatingFolder) {\n      if (type === \"navigation\") {\n        ref.current?.focus();\n      }\n      if (type === \"picker\") {\n        ref.current?.scrollIntoView({\n          behavior: \"smooth\",\n          block: \"start\",\n        });\n      }\n    }\n  }, [focusedFolder, ref, id, isCreatingFolder, type]);\n\n  const linkPath = `/minndla/folders/${id}`;\n\n  const containsResource =\n    targetResource && folder.resources.some((resource) => resource.resourceId === targetResource.resourceId);\n\n  const emptyFolder = folder.subfolders.length === 0;\n  const isMaxDepth = level > maxLevel;\n  const hideArrow = isMaxDepth || emptyFolder;\n\n  const FolderIcon = folder.status === \"shared\" ? FolderShared : FolderOutlined;\n\n  const tabable = selected || focused || (!focusedFolder && !folder.parentId && index === 0);\n\n  return type === \"navigation\" ? (\n    <FolderNameLink\n      role=\"treeitem\"\n      aria-owns={folder.subfolders.length ? treestructureId(type, `subfolders-${folder.id}`) : undefined}\n      aria-expanded={isMaxDepth || emptyFolder ? undefined : isOpen}\n      aria-current={selected ? \"page\" : undefined}\n      aria-describedby={containsResource ? `alreadyAdded-${folder.id}` : undefined}\n      ref={ref}\n      style={levelVariable}\n      onKeyDown={(e: KeyboardEvent<HTMLElement>) => {\n        if (e.key === \"Enter\") {\n          setSelectedFolder(folder);\n          return;\n        }\n        arrowNavigation(e, id, visibleFolders, setFocusedFolder, onOpenFolder, onCloseFolder);\n      }}\n      to={loading ? \"\" : linkPath}\n      tabIndex={tabable ? 0 : -1}\n      data-selected={selected}\n      onFocus={() => setFocusedFolder(folder)}\n      onClick={handleClickFolder}\n    >\n      <OpenButton\n        aria-hidden\n        tabIndex={-1}\n        data-open={isOpen}\n        data-hide-arrow={hideArrow}\n        onClick={(e) => {\n          e.stopPropagation();\n          e.preventDefault();\n          ref.current?.focus();\n          if (isOpen) {\n            onCloseFolder(id);\n          } else {\n            onOpenFolder(id);\n          }\n        }}\n      >\n        <ArrowDropDownRounded />\n      </OpenButton>\n      <StyledName>{name}</StyledName>\n    </FolderNameLink>\n  ) : (\n    <FolderName\n      tabIndex={-1}\n      role=\"treeitem\"\n      id={treestructureId(type, folder.id)}\n      aria-expanded={isMaxDepth || emptyFolder ? undefined : isOpen}\n      aria-selected={selected}\n      data-focused={focusedFolder?.id === folder.id}\n      aria-describedby={containsResource ? `alreadyAdded-${folder.id}` : undefined}\n      aria-label={`${name}${folder.status === \"shared\" ? `, ${t(\"myNdla.folder.sharing.shared\")}` : \"\"}`}\n      variant=\"ghost\"\n      shape=\"sharp\"\n      fontWeight=\"normal\"\n      colorTheme=\"light\"\n      ref={ref}\n      style={levelVariable}\n      data-selected={selected}\n      disabled={loading}\n      onFocus={() => setFocusedFolder(focusedFolder || folder)}\n      onClick={handleClickFolder}\n      data-creating={isCreatingFolder}\n    >\n      <IconWrapper>\n        <OpenButton\n          aria-hidden\n          tabIndex={-1}\n          data-open={isOpen}\n          data-hide-arrow={hideArrow}\n          onClick={(e) => {\n            e.stopPropagation();\n            setFocusedFolder(folder);\n            if (isOpen) {\n              onCloseFolder(id);\n            } else {\n              onOpenFolder(id);\n            }\n          }}\n        >\n          <ArrowDropDownRounded />\n        </OpenButton>\n        <FolderIconWrapper>\n          <FolderIcon />\n        </FolderIconWrapper>\n      </IconWrapper>\n      <StyledName>{name}</StyledName>\n      {containsResource && (\n        <StyledDone\n          aria-label={t(\"myNdla.alreadyInFolder\")}\n          id={`alreadyAdded-${folder.id}`}\n          title={t(\"myNdla.alreadyInFolder\")}\n        />\n      )}\n    </FolderName>\n  );\n};\n\nexport default FolderItem;\n"]} */"));
70
70
  const FolderNameLink = /*#__PURE__*/_styled(SafeLink, {
71
71
  target: "e11ok6h80",
72
72
  label: "FolderNameLink"
73
- })("display:grid;align-items:center;grid-template-columns:", spacing.medium, " 1fr auto;padding:", spacing.small, " ", spacing.xxsmall, ";padding-left:calc(0.75 * ", spacing.normal, " * var(--level));gap:", spacing.xxsmall, ";cursor:pointer;border:none;box-shadow:none;color:", colors.text.primary, ";font-size:", fonts.sizes("16px"), ";transition:", animations.durations.superFast, ";word-break:break-word;&[data-selected=\"true\"]{color:", colors.brand.primary, ";font-weight:", fonts.weight.semibold, ";}&:hover,&:focus{color:", colors.brand.primary, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FolderItem.tsx"],"names":[],"mappings":"AA6GuC","file":"FolderItem.tsx","sourcesContent":["/**\n * Copyright (c) 2022-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { CSSProperties, KeyboardEvent, useEffect, useMemo, useRef } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport styled from \"@emotion/styled\";\nimport { ButtonV2 as Button } from \"@ndla/button\";\nimport { colors, spacing, animations, misc, fonts } from \"@ndla/core\";\nimport { ArrowDropDownRounded } from \"@ndla/icons/common\";\nimport { FolderOutlined, FolderShared } from \"@ndla/icons/contentType\";\nimport { Done } from \"@ndla/icons/editor\";\nimport { SafeLink } from \"@ndla/safelink\";\nimport { IFolder } from \"@ndla/types-backend/myndla-api\";\nimport { arrowNavigation } from \"./arrowNavigation\";\nimport { treestructureId } from \"./helperFunctions\";\nimport { CommonFolderItemsProps } from \"./types\";\n\nconst OpenButton = styled.span`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  align-self: stretch;\n  color: ${colors.brand.tertiary};\n  ${misc.transition.default};\n  cursor: pointer;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n  svg {\n    width: 24px;\n    height: 24px;\n    transform: rotate(-90deg);\n  }\n  &[data-open=\"true\"] {\n    svg {\n      transform: rotate(0deg);\n    }\n  }\n  &[data-hide-arrow=\"true\"] {\n    visibility: hidden;\n  }\n`;\n\nconst StyledName = styled.span`\n  white-space: nowrap;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  grid-column-start: 2;\n  text-align: left;\n`;\n\nconst IconWrapper = styled.div`\n  display: flex;\n`;\n\nconst FolderIconWrapper = styled.div`\n  svg {\n    height: 24px;\n    width: 24px;\n  }\n`;\n\nconst FolderName = styled(Button)`\n  display: grid;\n  grid-template-columns: auto 1fr auto;\n  padding-left: calc(0.75 * ${spacing.normal} * var(--level));\n  gap: ${spacing.xxsmall};\n  border: none;\n  outline: none;\n  color: ${colors.text.primary};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\n\n  &:hover {\n    box-shadow: none;\n    outline: none;\n    background: ${colors.brand.lightest};\n    color: ${colors.text.primary};\n  }\n\n  &[data-focused=\"true\"] {\n    background: ${colors.brand.lightest};\n  }\n\n  &[data-selected=\"true\"] {\n    background: ${colors.brand.lighter};\n    &:hover {\n      background: ${colors.brand.light};\n    }\n  }\n\n  &[data-creating=\"true\"][data-focused=\"true\"] {\n    color: ${colors.brand.primary};\n  }\n\n  &[data-creating=\"true\"] {\n    background: none;\n  }\n`;\n\nconst StyledDone = styled(Done)`\n  color: ${colors.support.green};\n`;\n\nconst FolderNameLink = styled(SafeLink)`\n  display: grid;\n  align-items: center;\n  grid-template-columns: ${spacing.medium} 1fr auto;\n  padding: ${spacing.small} ${spacing.xxsmall};\n  padding-left: calc(0.75 * ${spacing.normal} * var(--level));\n  gap: ${spacing.xxsmall};\n  cursor: pointer;\n\n  border: none;\n  box-shadow: none;\n  color: ${colors.text.primary};\n  font-size: ${fonts.sizes(\"16px\")};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\n  &[data-selected=\"true\"] {\n    color: ${colors.brand.primary};\n    font-weight: ${fonts.weight.semibold};\n  }\n  &:hover,\n  &:focus {\n    color: ${colors.brand.primary};\n  }\n`;\n\ninterface Props extends CommonFolderItemsProps {\n  isOpen: boolean;\n  folder: IFolder;\n  isCreatingFolder?: boolean;\n  index: number;\n}\n\nconst FolderItem = ({\n  focusedFolder,\n  folder,\n  isOpen,\n  level,\n  loading,\n  selectedFolder,\n  onCloseFolder,\n  onOpenFolder,\n  setFocusedFolder,\n  setSelectedFolder,\n  targetResource,\n  visibleFolders,\n  maxLevel,\n  isCreatingFolder,\n  type,\n  closeTree,\n  index,\n}: Props) => {\n  const { t } = useTranslation();\n  const { id, name } = folder;\n  const ref = useRef<HTMLButtonElement & HTMLAnchorElement>(null);\n  const selected = selectedFolder ? selectedFolder.id === id : false;\n\n  const levelVariable = useMemo(() => ({ \"--level\": level }) as unknown as CSSProperties, [level]);\n\n  const focused = focusedFolder?.id === id;\n\n  const handleClickFolder = () => {\n    if (!selected) {\n      setSelectedFolder(folder);\n    }\n    setFocusedFolder(folder);\n    if (type === \"picker\") {\n      if (selected) {\n        closeTree();\n      }\n    }\n  };\n\n  useEffect(() => {\n    if (focusedFolder?.id === id && !isCreatingFolder) {\n      if (type === \"navigation\") {\n        ref.current?.focus();\n      }\n      if (type === \"picker\") {\n        ref.current?.scrollIntoView({\n          behavior: \"smooth\",\n          block: \"start\",\n        });\n      }\n    }\n  }, [focusedFolder, ref, id, isCreatingFolder, type]);\n\n  const linkPath = `/minndla/folders/${id}`;\n\n  const containsResource =\n    targetResource && folder.resources.some((resource) => resource.resourceId === targetResource.resourceId);\n\n  const emptyFolder = folder.subfolders.length === 0;\n  const isMaxDepth = level > maxLevel;\n  const hideArrow = isMaxDepth || emptyFolder;\n\n  const FolderIcon = folder.status === \"shared\" ? FolderShared : FolderOutlined;\n\n  const tabable = selected || focused || (!focusedFolder && !folder.parentId && index === 0);\n\n  return type === \"navigation\" ? (\n    <FolderNameLink\n      role=\"treeitem\"\n      aria-owns={folder.subfolders.length ? treestructureId(type, `subfolders-${folder.id}`) : undefined}\n      aria-expanded={isMaxDepth || emptyFolder ? undefined : isOpen}\n      aria-current={selected ? \"page\" : undefined}\n      aria-describedby={containsResource ? `alreadyAdded-${folder.id}` : undefined}\n      ref={ref}\n      style={levelVariable}\n      onKeyDown={(e: KeyboardEvent<HTMLElement>) => {\n        if (e.key === \"Enter\") {\n          setSelectedFolder(folder);\n          return;\n        }\n        arrowNavigation(e, id, visibleFolders, setFocusedFolder, onOpenFolder, onCloseFolder);\n      }}\n      to={loading ? \"\" : linkPath}\n      tabIndex={tabable ? 0 : -1}\n      data-selected={selected}\n      onFocus={() => setFocusedFolder(folder)}\n      onClick={handleClickFolder}\n    >\n      <OpenButton\n        aria-hidden\n        tabIndex={-1}\n        data-open={isOpen}\n        data-hide-arrow={hideArrow}\n        onClick={(e) => {\n          e.stopPropagation();\n          e.preventDefault();\n          ref.current?.focus();\n          if (isOpen) {\n            onCloseFolder(id);\n          } else {\n            onOpenFolder(id);\n          }\n        }}\n      >\n        <ArrowDropDownRounded />\n      </OpenButton>\n      <StyledName>{name}</StyledName>\n    </FolderNameLink>\n  ) : (\n    <FolderName\n      tabIndex={-1}\n      role=\"treeitem\"\n      id={treestructureId(type, folder.id)}\n      aria-expanded={isMaxDepth || emptyFolder ? undefined : isOpen}\n      aria-selected={selected}\n      data-focused={focusedFolder?.id === folder.id}\n      aria-describedby={containsResource ? `alreadyAdded-${folder.id}` : undefined}\n      aria-label={`${name}${folder.status === \"shared\" ? `, ${t(\"myNdla.folder.sharing.shared\")}` : \"\"}`}\n      variant=\"ghost\"\n      shape=\"sharp\"\n      fontWeight=\"normal\"\n      colorTheme=\"light\"\n      ref={ref}\n      style={levelVariable}\n      data-selected={selected}\n      disabled={loading}\n      onFocus={() => setFocusedFolder(focusedFolder || folder)}\n      onClick={handleClickFolder}\n      data-creating={isCreatingFolder}\n    >\n      <IconWrapper>\n        <OpenButton\n          aria-hidden\n          tabIndex={-1}\n          data-open={isOpen}\n          data-hide-arrow={hideArrow}\n          onClick={(e) => {\n            e.stopPropagation();\n            setFocusedFolder(folder);\n            if (isOpen) {\n              onCloseFolder(id);\n            } else {\n              onOpenFolder(id);\n            }\n          }}\n        >\n          <ArrowDropDownRounded />\n        </OpenButton>\n        <FolderIconWrapper>\n          <FolderIcon />\n        </FolderIconWrapper>\n      </IconWrapper>\n      <StyledName>{name}</StyledName>\n      {containsResource && (\n        <StyledDone\n          aria-label={t(\"myNdla.alreadyInFolder\")}\n          id={`alreadyAdded-${folder.id}`}\n          title={t(\"myNdla.alreadyInFolder\")}\n        />\n      )}\n    </FolderName>\n  );\n};\n\nexport default FolderItem;\n"]} */"));
73
+ })("display:grid;align-items:center;grid-template-columns:", spacing.medium, " 1fr auto;padding:", spacing.small, " ", spacing.xxsmall, ";padding-left:calc(0.75 * ", spacing.normal, " * var(--level));gap:", spacing.xxsmall, ";cursor:pointer;border:none;box-shadow:none;color:", colors.text.primary, ";", fonts.sizes("16px"), ";transition:", animations.durations.superFast, ";word-break:break-word;&[data-selected=\"true\"]{color:", colors.brand.primary, ";font-weight:", fonts.weight.semibold, ";}&:hover,&:focus{color:", colors.brand.primary, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FolderItem.tsx"],"names":[],"mappings":"AA6GuC","file":"FolderItem.tsx","sourcesContent":["/**\n * Copyright (c) 2022-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { CSSProperties, KeyboardEvent, useEffect, useMemo, useRef } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport styled from \"@emotion/styled\";\nimport { ButtonV2 as Button } from \"@ndla/button\";\nimport { colors, spacing, animations, misc, fonts } from \"@ndla/core\";\nimport { ArrowDropDownRounded } from \"@ndla/icons/common\";\nimport { FolderOutlined, FolderShared } from \"@ndla/icons/contentType\";\nimport { Done } from \"@ndla/icons/editor\";\nimport { SafeLink } from \"@ndla/safelink\";\nimport { IFolder } from \"@ndla/types-backend/myndla-api\";\nimport { arrowNavigation } from \"./arrowNavigation\";\nimport { treestructureId } from \"./helperFunctions\";\nimport { CommonFolderItemsProps } from \"./types\";\n\nconst OpenButton = styled.span`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  align-self: stretch;\n  color: ${colors.brand.tertiary};\n  ${misc.transition.default};\n  cursor: pointer;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n  svg {\n    width: 24px;\n    height: 24px;\n    transform: rotate(-90deg);\n  }\n  &[data-open=\"true\"] {\n    svg {\n      transform: rotate(0deg);\n    }\n  }\n  &[data-hide-arrow=\"true\"] {\n    visibility: hidden;\n  }\n`;\n\nconst StyledName = styled.span`\n  white-space: nowrap;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  grid-column-start: 2;\n  text-align: left;\n`;\n\nconst IconWrapper = styled.div`\n  display: flex;\n`;\n\nconst FolderIconWrapper = styled.div`\n  svg {\n    height: 24px;\n    width: 24px;\n  }\n`;\n\nconst FolderName = styled(Button)`\n  display: grid;\n  grid-template-columns: auto 1fr auto;\n  padding-left: calc(0.75 * ${spacing.normal} * var(--level));\n  gap: ${spacing.xxsmall};\n  border: none;\n  outline: none;\n  color: ${colors.text.primary};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\n\n  &:hover {\n    box-shadow: none;\n    outline: none;\n    background: ${colors.brand.lightest};\n    color: ${colors.text.primary};\n  }\n\n  &[data-focused=\"true\"] {\n    background: ${colors.brand.lightest};\n  }\n\n  &[data-selected=\"true\"] {\n    background: ${colors.brand.lighter};\n    &:hover {\n      background: ${colors.brand.light};\n    }\n  }\n\n  &[data-creating=\"true\"][data-focused=\"true\"] {\n    color: ${colors.brand.primary};\n  }\n\n  &[data-creating=\"true\"] {\n    background: none;\n  }\n`;\n\nconst StyledDone = styled(Done)`\n  color: ${colors.support.green};\n`;\n\nconst FolderNameLink = styled(SafeLink)`\n  display: grid;\n  align-items: center;\n  grid-template-columns: ${spacing.medium} 1fr auto;\n  padding: ${spacing.small} ${spacing.xxsmall};\n  padding-left: calc(0.75 * ${spacing.normal} * var(--level));\n  gap: ${spacing.xxsmall};\n  cursor: pointer;\n\n  border: none;\n  box-shadow: none;\n  color: ${colors.text.primary};\n  ${fonts.sizes(\"16px\")};\n  transition: ${animations.durations.superFast};\n  word-break: break-word;\n  &[data-selected=\"true\"] {\n    color: ${colors.brand.primary};\n    font-weight: ${fonts.weight.semibold};\n  }\n  &:hover,\n  &:focus {\n    color: ${colors.brand.primary};\n  }\n`;\n\ninterface Props extends CommonFolderItemsProps {\n  isOpen: boolean;\n  folder: IFolder;\n  isCreatingFolder?: boolean;\n  index: number;\n}\n\nconst FolderItem = ({\n  focusedFolder,\n  folder,\n  isOpen,\n  level,\n  loading,\n  selectedFolder,\n  onCloseFolder,\n  onOpenFolder,\n  setFocusedFolder,\n  setSelectedFolder,\n  targetResource,\n  visibleFolders,\n  maxLevel,\n  isCreatingFolder,\n  type,\n  closeTree,\n  index,\n}: Props) => {\n  const { t } = useTranslation();\n  const { id, name } = folder;\n  const ref = useRef<HTMLButtonElement & HTMLAnchorElement>(null);\n  const selected = selectedFolder ? selectedFolder.id === id : false;\n\n  const levelVariable = useMemo(() => ({ \"--level\": level }) as unknown as CSSProperties, [level]);\n\n  const focused = focusedFolder?.id === id;\n\n  const handleClickFolder = () => {\n    if (!selected) {\n      setSelectedFolder(folder);\n    }\n    setFocusedFolder(folder);\n    if (type === \"picker\") {\n      if (selected) {\n        closeTree();\n      }\n    }\n  };\n\n  useEffect(() => {\n    if (focusedFolder?.id === id && !isCreatingFolder) {\n      if (type === \"navigation\") {\n        ref.current?.focus();\n      }\n      if (type === \"picker\") {\n        ref.current?.scrollIntoView({\n          behavior: \"smooth\",\n          block: \"start\",\n        });\n      }\n    }\n  }, [focusedFolder, ref, id, isCreatingFolder, type]);\n\n  const linkPath = `/minndla/folders/${id}`;\n\n  const containsResource =\n    targetResource && folder.resources.some((resource) => resource.resourceId === targetResource.resourceId);\n\n  const emptyFolder = folder.subfolders.length === 0;\n  const isMaxDepth = level > maxLevel;\n  const hideArrow = isMaxDepth || emptyFolder;\n\n  const FolderIcon = folder.status === \"shared\" ? FolderShared : FolderOutlined;\n\n  const tabable = selected || focused || (!focusedFolder && !folder.parentId && index === 0);\n\n  return type === \"navigation\" ? (\n    <FolderNameLink\n      role=\"treeitem\"\n      aria-owns={folder.subfolders.length ? treestructureId(type, `subfolders-${folder.id}`) : undefined}\n      aria-expanded={isMaxDepth || emptyFolder ? undefined : isOpen}\n      aria-current={selected ? \"page\" : undefined}\n      aria-describedby={containsResource ? `alreadyAdded-${folder.id}` : undefined}\n      ref={ref}\n      style={levelVariable}\n      onKeyDown={(e: KeyboardEvent<HTMLElement>) => {\n        if (e.key === \"Enter\") {\n          setSelectedFolder(folder);\n          return;\n        }\n        arrowNavigation(e, id, visibleFolders, setFocusedFolder, onOpenFolder, onCloseFolder);\n      }}\n      to={loading ? \"\" : linkPath}\n      tabIndex={tabable ? 0 : -1}\n      data-selected={selected}\n      onFocus={() => setFocusedFolder(folder)}\n      onClick={handleClickFolder}\n    >\n      <OpenButton\n        aria-hidden\n        tabIndex={-1}\n        data-open={isOpen}\n        data-hide-arrow={hideArrow}\n        onClick={(e) => {\n          e.stopPropagation();\n          e.preventDefault();\n          ref.current?.focus();\n          if (isOpen) {\n            onCloseFolder(id);\n          } else {\n            onOpenFolder(id);\n          }\n        }}\n      >\n        <ArrowDropDownRounded />\n      </OpenButton>\n      <StyledName>{name}</StyledName>\n    </FolderNameLink>\n  ) : (\n    <FolderName\n      tabIndex={-1}\n      role=\"treeitem\"\n      id={treestructureId(type, folder.id)}\n      aria-expanded={isMaxDepth || emptyFolder ? undefined : isOpen}\n      aria-selected={selected}\n      data-focused={focusedFolder?.id === folder.id}\n      aria-describedby={containsResource ? `alreadyAdded-${folder.id}` : undefined}\n      aria-label={`${name}${folder.status === \"shared\" ? `, ${t(\"myNdla.folder.sharing.shared\")}` : \"\"}`}\n      variant=\"ghost\"\n      shape=\"sharp\"\n      fontWeight=\"normal\"\n      colorTheme=\"light\"\n      ref={ref}\n      style={levelVariable}\n      data-selected={selected}\n      disabled={loading}\n      onFocus={() => setFocusedFolder(focusedFolder || folder)}\n      onClick={handleClickFolder}\n      data-creating={isCreatingFolder}\n    >\n      <IconWrapper>\n        <OpenButton\n          aria-hidden\n          tabIndex={-1}\n          data-open={isOpen}\n          data-hide-arrow={hideArrow}\n          onClick={(e) => {\n            e.stopPropagation();\n            setFocusedFolder(folder);\n            if (isOpen) {\n              onCloseFolder(id);\n            } else {\n              onOpenFolder(id);\n            }\n          }}\n        >\n          <ArrowDropDownRounded />\n        </OpenButton>\n        <FolderIconWrapper>\n          <FolderIcon />\n        </FolderIconWrapper>\n      </IconWrapper>\n      <StyledName>{name}</StyledName>\n      {containsResource && (\n        <StyledDone\n          aria-label={t(\"myNdla.alreadyInFolder\")}\n          id={`alreadyAdded-${folder.id}`}\n          title={t(\"myNdla.alreadyInFolder\")}\n        />\n      )}\n    </FolderName>\n  );\n};\n\nexport default FolderItem;\n"]} */"));
74
74
  const FolderItem = _ref => {
75
75
  let {
76
76
  focusedFolder,
@@ -100,6 +100,10 @@ const messages = {
100
100
  movedResourcePage: {
101
101
  title: "The page has been moved, but you can find it here:"
102
102
  },
103
+ unpublishedResourcePage: {
104
+ title: "Resource is unpublished",
105
+ errorDescription: "The resource you are looking for has been unpublished."
106
+ },
103
107
  lti: {
104
108
  embed: "Embed",
105
109
  notSupported: "It did not work to auto-insert the content. You can copy the source code and add it to your content."
@@ -929,11 +933,15 @@ const messages = {
929
933
  sharing: {
930
934
  share: "Share folder",
931
935
  shared: "Shared",
936
+ sharedBy: "Shared by ",
937
+ sharedByAnonymous: "anonymous teacher",
932
938
  sharedFolder: "Shared folder",
933
939
  unShare: "Sharing stopped. The folder is no longer shared",
934
940
  copyLink: "Copy link to folder",
941
+ removeLink: "Remove link to folder",
935
942
  link: "Link is copied",
936
943
  savedLink: "Link to {{ name }} has been added to My folders.",
944
+ unSavedLink: "Link to {{ name }} has been removed from My folders.",
937
945
  header: {
938
946
  shared: "This folder is shared"
939
947
  },
@@ -954,7 +962,8 @@ const messages = {
954
962
  goTo: "Go to shared folder",
955
963
  unShare: "Stop sharing",
956
964
  shareLink: "Copy link",
957
- saveLink: "Save the link"
965
+ saveLink: "Save the link",
966
+ unSaveLink: "Remove the link"
958
967
  },
959
968
  save: {
960
969
  warning: "This creates a link to the folder in My folders. You can easily find the link by navigating to My Folders through the menu in My NDLA.",
@@ -1043,7 +1052,9 @@ const messages = {
1043
1052
  delete: "Delete post"
1044
1053
  },
1045
1054
  fetchMore: "Fetch more answers",
1046
- deleted: "This post has been deleted by the author."
1055
+ deleted: "This post has been deleted by the author.",
1056
+ upvote: "Upvote",
1057
+ removeUpvote: "Remove upvote"
1047
1058
  },
1048
1059
  flag: {
1049
1060
  title: "Report post / comment",
@@ -1330,7 +1341,10 @@ const messages = {
1330
1341
  loadMore: "Load more"
1331
1342
  },
1332
1343
  siteNav: {
1333
- search: "Search"
1344
+ search: "Search",
1345
+ navigate: "Navigate using the arrow keys",
1346
+ select: "Select",
1347
+ close: "Close search"
1334
1348
  },
1335
1349
  programmes: {
1336
1350
  header: "What do you want to learn today?",
@@ -100,6 +100,10 @@ const messages = {
100
100
  movedResourcePage: {
101
101
  title: "Siden har flyttet, men du kan finne den her:"
102
102
  },
103
+ unpublishedResourcePage: {
104
+ title: "Ressursen er avpublisert",
105
+ errorDescription: "Beklager, ressursen du prøvde komme til er avpublisert."
106
+ },
103
107
  lti: {
104
108
  embed: "Sett inn",
105
109
  notSupported: "Det fungerte ikke å sette inn innholdet automatisk. Kopier kildekoden under for å sette inn på din side."
@@ -929,11 +933,15 @@ const messages = {
929
933
  sharing: {
930
934
  share: "Del mappe",
931
935
  shared: "Delt",
936
+ sharedBy: "Delt av ",
937
+ sharedByAnonymous: "anonym lærer",
932
938
  sharedFolder: "Delt mappe",
933
939
  unShare: "Delingen er avsluttet. Mappen er ikke lenger delt.",
934
940
  copyLink: "Kopier lenke til mappa",
941
+ removeLink: "Fjern lenke til mappe",
935
942
  link: "Lenken er kopiert",
936
943
  savedLink: "Lenke til {{ name }} er lagt til i Mine mapper.",
944
+ unSavedLink: "Lenke til {{ name }} er fjernet fra Mine mapper.",
937
945
  header: {
938
946
  shared: "Denne mappa er delt"
939
947
  },
@@ -954,7 +962,8 @@ const messages = {
954
962
  goTo: "Gå til delt mappe",
955
963
  unShare: "Avslutt deling",
956
964
  shareLink: "Kopier lenke",
957
- saveLink: "Lagre lenken"
965
+ saveLink: "Lagre lenken",
966
+ unSaveLink: "Fjern lenken"
958
967
  },
959
968
  save: {
960
969
  warning: "Dette lager en lenke til mappen i Mine mapper. Du kan enkelt finne den igjen ved å gå til Mine mapper i menyen i Min NDLA.",
@@ -1043,7 +1052,9 @@ const messages = {
1043
1052
  delete: "Slett innlegget"
1044
1053
  },
1045
1054
  fetchMore: "Hent flere svar",
1046
- deleted: "Dette innlegget er slettet av forfatteren."
1055
+ deleted: "Dette innlegget er slettet av forfatteren.",
1056
+ upvote: "Stem opp",
1057
+ removeUpvote: "Fjern stemme"
1047
1058
  },
1048
1059
  flag: {
1049
1060
  title: "Rapporter innlegg / kommentar",
@@ -1330,7 +1341,10 @@ const messages = {
1330
1341
  loadMore: "Last mer"
1331
1342
  },
1332
1343
  siteNav: {
1333
- search: "Søk"
1344
+ search: "Søk",
1345
+ navigate: "Naviger med piltastene",
1346
+ select: "Velg",
1347
+ close: "Lukk søk"
1334
1348
  },
1335
1349
  programmes: {
1336
1350
  header: "Hva vil du lære om i dag?",
@@ -100,6 +100,10 @@ const messages = {
100
100
  movedResourcePage: {
101
101
  title: "Sida har flytta, men du kan finne den her:"
102
102
  },
103
+ unpublishedResourcePage: {
104
+ title: "Ressursen er avpublisert",
105
+ errorDescription: "Orsak, ressursen du prøvde komme til er avpublisert."
106
+ },
103
107
  lti: {
104
108
  embed: "Sett inn",
105
109
  notSupported: "Det fungerte ikkje å setje inn innhaldet automatisk. Kopier kjeldekoden under for å setje han inn på sida di."
@@ -929,11 +933,15 @@ const messages = {
929
933
  sharing: {
930
934
  share: "Del mappe",
931
935
  shared: "Delt",
936
+ sharedBy: "Delt av ",
937
+ sharedByAnonymous: "anonym lærar",
932
938
  sharedFolder: "Delt mappe",
933
939
  unShare: "Delinga er avslutta. Mappa er ikkje lenger delt",
934
940
  link: "Lenka er kopiert",
935
- savedLink: "Lenka til {{ name }} er lagt til i Mine mapper.",
936
941
  copyLink: "Kopier lenke til mappa",
942
+ removeLink: "Fjern lenke til mappe",
943
+ savedLink: "Lenka til {{ name }} er lagt til i Mine mapper.",
944
+ unSavedLink: "Lenka til {{ name }} er fjernet fra Mine mapper.",
937
945
  header: {
938
946
  shared: "Denne mappa er delt"
939
947
  },
@@ -954,7 +962,8 @@ const messages = {
954
962
  goTo: "Gå til delt mappe",
955
963
  unShare: "Avslutt deling",
956
964
  shareLink: "Kopier lenke",
957
- saveLink: "Lagre lenka"
965
+ saveLink: "Lagre lenka",
966
+ unSaveLink: "Fjern lenken"
958
967
  },
959
968
  save: {
960
969
  warning: "Dette lagar ei lenke til mappa i Mine mapper. Du kan enkelt finne ho att ved å gå til Mine mapper i menyen i Min NDLA.",
@@ -1043,7 +1052,9 @@ const messages = {
1043
1052
  delete: "Slett innlegget"
1044
1053
  },
1045
1054
  fetchMore: "Hent fleire svar",
1046
- deleted: "Dette innlegget er sletta av forfatteren."
1055
+ deleted: "Dette innlegget er sletta av forfatteren.",
1056
+ upvote: "Stem opp",
1057
+ removeUpvote: "Fjern stemme"
1047
1058
  },
1048
1059
  flag: {
1049
1060
  title: "Rapporter innlegg / kommentar",
@@ -1330,7 +1341,10 @@ const messages = {
1330
1341
  loadMore: "Last meir"
1331
1342
  },
1332
1343
  siteNav: {
1333
- search: "Søk"
1344
+ search: "Søk",
1345
+ navigate: "Naviger med piltastane",
1346
+ select: "Velg",
1347
+ close: "Lukk søk"
1334
1348
  },
1335
1349
  programmes: {
1336
1350
  header: "Kva vil du lære om i dag?",