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