@ndla/ui 25.3.0 → 26.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/es/LanguageSelector/LanguageSelector.js +12 -7
- 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 +2 -0
- package/es/locale/messages-nb.js +2 -0
- package/es/locale/messages-nn.js +2 -0
- package/es/locale/messages-se.js +2 -0
- package/es/locale/messages-sma.js +2 -0
- package/lib/LanguageSelector/LanguageSelector.js +13 -7
- 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 +2 -0
- package/lib/locale/messages-en.js +2 -0
- package/lib/locale/messages-nb.d.ts +2 -0
- package/lib/locale/messages-nb.js +2 -0
- package/lib/locale/messages-nn.d.ts +2 -0
- package/lib/locale/messages-nn.js +2 -0
- package/lib/locale/messages-se.d.ts +2 -0
- package/lib/locale/messages-se.js +2 -0
- package/lib/locale/messages-sma.d.ts +2 -0
- package/lib/locale/messages-sma.js +2 -0
- package/package.json +11 -11
- package/src/LanguageSelector/LanguageSelector.tsx +4 -1
- 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 +2 -0
- package/src/locale/messages-nb.ts +2 -0
- package/src/locale/messages-nn.ts +2 -0
- package/src/locale/messages-se.ts +2 -0
- package/src/locale/messages-sma.ts +2 -0
- 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
|
@@ -19,8 +19,6 @@ var _editor = require("@ndla/icons/editor");
|
|
|
19
19
|
|
|
20
20
|
var _button = require("@ndla/button");
|
|
21
21
|
|
|
22
|
-
var _contentType = require("@ndla/icons/contentType");
|
|
23
|
-
|
|
24
22
|
var _core = require("@ndla/core");
|
|
25
23
|
|
|
26
24
|
var _safelink = _interopRequireDefault(require("@ndla/safelink"));
|
|
@@ -35,96 +33,97 @@ function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj;
|
|
|
35
33
|
|
|
36
34
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
|
37
35
|
|
|
38
|
-
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; }
|
|
39
|
-
|
|
40
|
-
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; }
|
|
41
|
-
|
|
42
|
-
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; }
|
|
43
|
-
|
|
44
36
|
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)."; }
|
|
45
37
|
|
|
46
|
-
var OpenButton = (0, _styledBase["default"])("
|
|
38
|
+
var OpenButton = (0, _styledBase["default"])("span", {
|
|
47
39
|
target: "e11ok6h80",
|
|
48
40
|
label: "OpenButton"
|
|
49
|
-
})("
|
|
41
|
+
})("display:flex;align-items:center;justify-content:center;align-self:stretch;color:", _core.colors.brand.tertiary, ";", _core.misc.transition["default"], ";cursor:pointer;&:hover{color:", _core.colors.brand.primary, ";}svg{width:24px;height:24px;transform:rotate(", function (_ref) {
|
|
50
42
|
var isOpen = _ref.isOpen;
|
|
51
43
|
return isOpen ? '0' : '-90';
|
|
52
|
-
}, "deg);
|
|
53
|
-
|
|
54
|
-
return isOpen ? 'translateX(3px)' : 'translateY(3px)';
|
|
55
|
-
}, ";}" + (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"]} */"));
|
|
56
|
-
var FolderItemWrapper = (0, _styledBase["default"])("div", {
|
|
44
|
+
}, "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"]} */"));
|
|
45
|
+
var StyledName = (0, _styledBase["default"])("span", {
|
|
57
46
|
target: "e11ok6h81",
|
|
58
|
-
label: "
|
|
47
|
+
label: "StyledName"
|
|
59
48
|
})(process.env.NODE_ENV === "production" ? {
|
|
60
|
-
name: "
|
|
61
|
-
styles: "
|
|
49
|
+
name: "1x6liyo",
|
|
50
|
+
styles: "grid-column-start:2;text-align:left;"
|
|
62
51
|
} : {
|
|
63
|
-
name: "
|
|
64
|
-
styles: "
|
|
65
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
52
|
+
name: "1x6liyo",
|
|
53
|
+
styles: "grid-column-start:2;text-align:left;",
|
|
54
|
+
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"]} */",
|
|
66
55
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
67
56
|
});
|
|
68
57
|
var WrapperForFolderChild = (0, _styledBase["default"])("div", {
|
|
69
58
|
target: "e11ok6h82",
|
|
70
59
|
label: "WrapperForFolderChild"
|
|
71
|
-
})("display:flex;flex-direction:row;align-items:center;gap:", _core.spacing.xsmall, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
60
|
+
})("display:flex;flex-direction:row;align-items:center;gap:", _core.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"]} */"));
|
|
72
61
|
|
|
73
62
|
var shouldForwardProp = function shouldForwardProp(name) {
|
|
74
|
-
return !['selected', 'noArrow', 'fullWidth'].includes(name);
|
|
63
|
+
return !['selected', 'noArrow', 'fullWidth', 'level'].includes(name);
|
|
75
64
|
};
|
|
76
65
|
|
|
77
|
-
var FolderName = ( /*#__PURE__*/0, _styledBase["default"])(
|
|
66
|
+
var FolderName = ( /*#__PURE__*/0, _styledBase["default"])(_button.ButtonV2, {
|
|
78
67
|
shouldForwardProp: shouldForwardProp,
|
|
79
68
|
target: "e11ok6h83",
|
|
80
69
|
label: "FolderName"
|
|
81
|
-
})("
|
|
82
|
-
var
|
|
83
|
-
return
|
|
84
|
-
}, ";
|
|
85
|
-
var
|
|
86
|
-
|
|
87
|
-
|
|
70
|
+
})("display:grid;grid-template-columns:", _core.spacing.medium, " 1fr auto;padding-left:", function (_ref2) {
|
|
71
|
+
var level = _ref2.level;
|
|
72
|
+
return 0.75 * _core.spacingUnit * level;
|
|
73
|
+
}, "px;gap:", _core.spacing.xxsmall, ";border:none;outline:none;background:", function (_ref3) {
|
|
74
|
+
var selected = _ref3.selected,
|
|
75
|
+
isCreatingFolder = _ref3.isCreatingFolder;
|
|
76
|
+
return selected && !isCreatingFolder && _core.colors.brand.lighter;
|
|
77
|
+
}, ";color:", function (_ref4) {
|
|
78
|
+
var isCreatingFolder = _ref4.isCreatingFolder,
|
|
79
|
+
selected = _ref4.selected;
|
|
80
|
+
return isCreatingFolder && selected ? _core.colors.brand.primary : _core.colors.text.primary;
|
|
81
|
+
}, ";transition:", _core.animations.durations.superFast, ";line-height:1;word-break:break-word;&:hover,&:focus{box-shadow:none;outline:none;background:", function (_ref5) {
|
|
88
82
|
var selected = _ref5.selected;
|
|
89
|
-
return selected ? _core.colors.brand.lighter : 'transparent';
|
|
90
|
-
}, ";color:", _core.colors.text.primary, ";transition:", _core.animations.durations.superFast, ";text-align:left;line-height:1;word-break:break-word;&:hover,&:focus{background:", function (_ref6) {
|
|
91
|
-
var selected = _ref6.selected;
|
|
92
83
|
return selected ? _core.colors.brand.light : _core.colors.brand.lightest;
|
|
93
|
-
}, ";color:", _core.colors.
|
|
84
|
+
}, ";color:", _core.colors.text.primary, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FolderItem.tsx"],"names":[],"mappings":"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"]} */"));
|
|
94
85
|
var StyledDone = ( /*#__PURE__*/0, _styledBase["default"])(_editor.Done, {
|
|
95
86
|
target: "e11ok6h84",
|
|
96
87
|
label: "StyledDone"
|
|
97
|
-
})("color:", _core.colors.support.green, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
98
|
-
var FolderNameLink =
|
|
88
|
+
})("color:", _core.colors.support.green, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FolderItem.tsx"],"names":[],"mappings":"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"]} */"));
|
|
89
|
+
var FolderNameLink = ( /*#__PURE__*/0, _styledBase["default"])(_safelink["default"], {
|
|
90
|
+
shouldForwardProp: shouldForwardProp,
|
|
99
91
|
target: "e11ok6h85",
|
|
100
92
|
label: "FolderNameLink"
|
|
101
|
-
});
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
93
|
+
})("display:grid;align-items:center;grid-template-columns:", _core.spacing.medium, " 1fr auto;padding:", _core.spacing.small, " ", _core.spacing.xxsmall, ";margin-left:", function (_ref6) {
|
|
94
|
+
var level = _ref6.level;
|
|
95
|
+
return 0.75 * _core.spacingUnit * level;
|
|
96
|
+
}, "px;gap:", _core.spacing.xxsmall, ";cursor:pointer;border:none;box-shadow:none;color:", function (_ref7) {
|
|
97
|
+
var selected = _ref7.selected;
|
|
98
|
+
return selected ? _core.colors.brand.primary : _core.colors.text.primary;
|
|
99
|
+
}, ";font-weight:", function (_ref8) {
|
|
100
|
+
var selected = _ref8.selected;
|
|
101
|
+
return selected && _core.fonts.weight.semibold;
|
|
102
|
+
}, ";font-size:", _core.fonts.sizes('16px'), ";transition:", _core.animations.durations.superFast, ";line-height:1;word-break:break-word;&:hover,&:focus{color:", _core.colors.brand.primary, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FolderItem.tsx"],"names":[],"mappings":"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"]} */"));
|
|
103
|
+
|
|
104
|
+
var FolderItem = function FolderItem(_ref9) {
|
|
105
|
+
var focusedFolderId = _ref9.focusedFolderId,
|
|
106
|
+
folder = _ref9.folder,
|
|
107
|
+
isOpen = _ref9.isOpen,
|
|
108
|
+
level = _ref9.level,
|
|
109
|
+
loading = _ref9.loading,
|
|
110
|
+
selectedFolder = _ref9.selectedFolder,
|
|
111
|
+
onCloseFolder = _ref9.onCloseFolder,
|
|
112
|
+
onOpenFolder = _ref9.onOpenFolder,
|
|
113
|
+
onSelectFolder = _ref9.onSelectFolder,
|
|
114
|
+
openOnFolderClick = _ref9.openOnFolderClick,
|
|
115
|
+
setFocusedId = _ref9.setFocusedId,
|
|
116
|
+
setSelectedFolder = _ref9.setSelectedFolder,
|
|
117
|
+
targetResource = _ref9.targetResource,
|
|
118
|
+
visibleFolders = _ref9.visibleFolders,
|
|
119
|
+
framed = _ref9.framed,
|
|
120
|
+
maxLevel = _ref9.maxLevel,
|
|
121
|
+
isCreatingFolder = _ref9.isCreatingFolder;
|
|
122
122
|
|
|
123
123
|
var _useTranslation = (0, _reactI18next.useTranslation)(),
|
|
124
124
|
t = _useTranslation.t;
|
|
125
125
|
|
|
126
126
|
var id = folder.id,
|
|
127
|
-
icon = folder.icon,
|
|
128
127
|
name = folder.name;
|
|
129
128
|
var ref = (0, _react.useRef)(null);
|
|
130
129
|
var selected = selectedFolder && selectedFolder.id === id;
|
|
@@ -150,68 +149,84 @@ var FolderItem = function FolderItem(_ref7) {
|
|
|
150
149
|
};
|
|
151
150
|
|
|
152
151
|
(0, _react.useEffect)(function () {
|
|
153
|
-
if (focusedFolderId === id) {
|
|
152
|
+
if (focusedFolderId === id && !isCreatingFolder) {
|
|
154
153
|
var _ref$current;
|
|
155
154
|
|
|
156
155
|
(_ref$current = ref.current) === null || _ref$current === void 0 ? void 0 : _ref$current.focus();
|
|
157
156
|
}
|
|
158
|
-
}, [focusedFolderId, ref, id]);
|
|
159
|
-
var actions = menuItems === null || menuItems === void 0 ? void 0 : menuItems.map(function (item) {
|
|
160
|
-
var _onClick = item.onClick;
|
|
161
|
-
return _objectSpread(_objectSpread({}, item), {}, {
|
|
162
|
-
onClick: function onClick(e) {
|
|
163
|
-
return _onClick(e, folder);
|
|
164
|
-
}
|
|
165
|
-
});
|
|
166
|
-
});
|
|
157
|
+
}, [focusedFolderId, ref, id, isCreatingFolder]);
|
|
167
158
|
var linkPath = "/minndla".concat(level > 0 ? '/folders' : '', "/").concat(id);
|
|
168
159
|
var containsResource = targetResource && folder.resources.some(function (resource) {
|
|
169
160
|
return resource.resourceId === targetResource.resourceId;
|
|
170
161
|
});
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
fullWidth: framed,
|
|
162
|
+
var emptyFolder = folder.subfolders.length === 0;
|
|
163
|
+
var isMaxDepth = level > maxLevel;
|
|
164
|
+
var hideArrow = isMaxDepth || emptyFolder;
|
|
165
|
+
return onSelectFolder ? (0, _core2.jsx)(FolderName, {
|
|
166
|
+
variant: "ghost",
|
|
167
|
+
shape: "sharp",
|
|
168
|
+
fontWeight: "normal",
|
|
169
|
+
colorTheme: "light",
|
|
180
170
|
ref: ref,
|
|
171
|
+
level: level,
|
|
172
|
+
fullWidth: framed,
|
|
181
173
|
onKeyDown: function onKeyDown(e) {
|
|
182
174
|
return (0, _arrowNavigation.arrowNavigation)(e, id, visibleFolders, setFocusedId, onOpenFolder, onCloseFolder);
|
|
183
175
|
},
|
|
184
|
-
noArrow: hideArrow
|
|
176
|
+
noArrow: hideArrow,
|
|
185
177
|
tabIndex: selected || focused ? 0 : -1,
|
|
186
178
|
selected: selected,
|
|
187
179
|
disabled: loading,
|
|
188
180
|
onFocus: function onFocus() {
|
|
189
181
|
return setFocusedId(id);
|
|
190
182
|
},
|
|
191
|
-
onClick: handleClickFolder
|
|
192
|
-
|
|
183
|
+
onClick: handleClickFolder,
|
|
184
|
+
isCreatingFolder: isCreatingFolder
|
|
185
|
+
}, !hideArrow && (0, _core2.jsx)(OpenButton, {
|
|
186
|
+
tabIndex: -1,
|
|
187
|
+
isOpen: isOpen,
|
|
188
|
+
onClick: function onClick() {
|
|
189
|
+
var _ref$current2;
|
|
190
|
+
|
|
191
|
+
(_ref$current2 = ref.current) === null || _ref$current2 === void 0 ? void 0 : _ref$current2.focus();
|
|
192
|
+
|
|
193
|
+
if (isOpen) {
|
|
194
|
+
onCloseFolder(id);
|
|
195
|
+
} else {
|
|
196
|
+
onOpenFolder(id);
|
|
197
|
+
}
|
|
198
|
+
}
|
|
199
|
+
}, (0, _core2.jsx)(_common.ArrowDropDownRounded, null)), (0, _core2.jsx)(StyledName, null, name), (0, _core2.jsx)(WrapperForFolderChild, null, containsResource && (0, _core2.jsx)(StyledDone, {
|
|
193
200
|
title: t('myNdla.alreadyInFolder')
|
|
194
|
-
})
|
|
195
|
-
onClick: function onClick(e) {
|
|
196
|
-
return e.stopPropagation();
|
|
197
|
-
},
|
|
198
|
-
size: "xsmall",
|
|
199
|
-
menuItems: actions,
|
|
200
|
-
tabIndex: selected || id === focusedFolderId ? 0 : -1
|
|
201
|
-
})))) : (0, _core2.jsx)(FolderNameLink, {
|
|
201
|
+
}))) : (0, _core2.jsx)(FolderNameLink, {
|
|
202
202
|
ref: ref,
|
|
203
|
+
level: level,
|
|
203
204
|
onKeyDown: function onKeyDown(e) {
|
|
204
205
|
return (0, _arrowNavigation.arrowNavigation)(e, id, visibleFolders, setFocusedId, onOpenFolder, onCloseFolder);
|
|
205
206
|
},
|
|
206
|
-
noArrow:
|
|
207
|
+
noArrow: !isMaxDepth,
|
|
207
208
|
to: loading ? '' : linkPath,
|
|
208
|
-
tabIndex: selected || focused
|
|
209
|
+
tabIndex: selected || focused ? 0 : -1,
|
|
209
210
|
selected: selected,
|
|
210
211
|
onFocus: function onFocus() {
|
|
211
212
|
return setFocusedId(id);
|
|
212
213
|
},
|
|
213
214
|
onClick: handleClickFolder
|
|
214
|
-
},
|
|
215
|
+
}, (!hideArrow || level === 0) && (0, _core2.jsx)(OpenButton, {
|
|
216
|
+
tabIndex: -1,
|
|
217
|
+
isOpen: isOpen,
|
|
218
|
+
onClick: function onClick() {
|
|
219
|
+
var _ref$current3;
|
|
220
|
+
|
|
221
|
+
(_ref$current3 = ref.current) === null || _ref$current3 === void 0 ? void 0 : _ref$current3.focus();
|
|
222
|
+
|
|
223
|
+
if (isOpen) {
|
|
224
|
+
onCloseFolder(id);
|
|
225
|
+
} else {
|
|
226
|
+
onOpenFolder(id);
|
|
227
|
+
}
|
|
228
|
+
}
|
|
229
|
+
}, (0, _core2.jsx)(_common.ArrowDropDownRounded, null)), (0, _core2.jsx)(StyledName, null, name));
|
|
215
230
|
};
|
|
216
231
|
|
|
217
232
|
var _default = FolderItem;
|
|
@@ -9,12 +9,10 @@
|
|
|
9
9
|
import { CommonFolderItemsProps, FolderType } from './types';
|
|
10
10
|
export interface FolderItemsProps extends CommonFolderItemsProps {
|
|
11
11
|
folders: FolderType[];
|
|
12
|
-
editable?: boolean;
|
|
13
|
-
maximumLevelsOfFoldersAllowed: number;
|
|
14
12
|
newFolderParentId: string | undefined;
|
|
15
13
|
onCancelNewFolder: () => void;
|
|
16
14
|
onSaveNewFolder: (name: string, parentId: string) => void;
|
|
17
15
|
openFolders: string[];
|
|
18
16
|
}
|
|
19
|
-
declare const FolderItems: ({
|
|
17
|
+
declare const FolderItems: ({ folders, level, loading, newFolderParentId, onCancelNewFolder, onSaveNewFolder, openFolders, type, ...rest }: FolderItemsProps) => JSX.Element;
|
|
20
18
|
export default FolderItems;
|