@ndla/ui 20.0.3 → 22.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/es/Breadcrumb/ActionBreadcrumb.js +4 -4
- package/es/LearningPaths/LearningPathInformation.js +21 -3
- package/es/LearningPaths/LearningPathMenuAsideCopyright.js +17 -4
- package/es/MyNdla/Resource/Folder.js +7 -6
- package/es/Resource/BlockResource.js +6 -5
- package/es/Resource/ListResource.js +7 -6
- package/es/ResourceGroup/ResourceGroup.js +3 -3
- package/es/ResourceGroup/ResourceItem.js +12 -12
- package/es/ResourceGroup/ResourceList.js +2 -2
- package/es/Search/ContentTypeResult.js +1 -2
- package/es/SearchTypeResult/SearchItem.js +8 -8
- package/es/TopicMenu/TopicMenuButton.js +4 -2
- package/es/TreeStructure/FolderItem.js +109 -68
- package/es/TreeStructure/FolderItems.js +34 -62
- package/es/TreeStructure/FolderNameInput.js +14 -13
- package/es/TreeStructure/TreeStructure.js +89 -98
- package/es/TreeStructure/helperFunctions.js +4 -73
- package/es/TreeStructure/{TreeStructure.types.js → types.js} +0 -0
- package/es/locale/messages-en.js +8 -0
- package/es/locale/messages-nb.js +8 -0
- package/es/locale/messages-nn.js +8 -0
- package/es/locale/messages-se.js +8 -0
- package/es/locale/messages-sma.js +8 -0
- package/lib/Breadcrumb/ActionBreadcrumb.js +4 -4
- package/lib/LearningPaths/LearningPathInformation.js +19 -2
- package/lib/LearningPaths/LearningPathMenuAsideCopyright.js +16 -3
- package/lib/MyNdla/Resource/Folder.js +7 -6
- package/lib/Resource/BlockResource.js +6 -5
- package/lib/Resource/ListResource.js +7 -6
- package/lib/ResourceGroup/ResourceGroup.d.ts +1 -1
- package/lib/ResourceGroup/ResourceGroup.js +3 -3
- package/lib/ResourceGroup/ResourceItem.d.ts +1 -1
- package/lib/ResourceGroup/ResourceItem.js +12 -12
- package/lib/ResourceGroup/ResourceList.d.ts +1 -1
- package/lib/ResourceGroup/ResourceList.js +2 -2
- package/lib/Search/ContentTypeResult.js +1 -2
- package/lib/SearchTypeResult/SearchItem.js +8 -8
- package/lib/TopicMenu/TopicMenuButton.js +3 -1
- package/lib/TreeStructure/FolderItem.d.ts +6 -20
- package/lib/TreeStructure/FolderItem.js +112 -68
- package/lib/TreeStructure/FolderItems.d.ts +11 -2
- package/lib/TreeStructure/FolderItems.js +34 -62
- package/lib/TreeStructure/FolderNameInput.js +14 -13
- package/lib/TreeStructure/TreeStructure.d.ts +12 -2
- package/lib/TreeStructure/TreeStructure.js +87 -96
- package/lib/TreeStructure/helperFunctions.d.ts +2 -4
- package/lib/TreeStructure/helperFunctions.js +5 -80
- package/lib/TreeStructure/index.d.ts +2 -1
- package/lib/TreeStructure/types.d.ts +33 -0
- package/lib/TreeStructure/{TreeStructure.types.js → types.js} +0 -0
- package/lib/index.d.ts +1 -1
- package/lib/locale/messages-en.d.ts +8 -0
- package/lib/locale/messages-en.js +8 -0
- package/lib/locale/messages-nb.d.ts +8 -0
- package/lib/locale/messages-nb.js +8 -0
- package/lib/locale/messages-nn.d.ts +8 -0
- package/lib/locale/messages-nn.js +8 -0
- package/lib/locale/messages-se.d.ts +8 -0
- package/lib/locale/messages-se.js +8 -0
- package/lib/locale/messages-sma.d.ts +8 -0
- package/lib/locale/messages-sma.js +8 -0
- package/package.json +15 -14
- package/src/.DS_Store +0 -0
- package/src/Breadcrumb/ActionBreadcrumb.tsx +1 -1
- package/src/LearningPaths/LearningPathInformation.tsx +27 -12
- package/src/LearningPaths/LearningPathMenuAsideCopyright.tsx +22 -20
- package/src/MyNdla/Resource/Folder.tsx +1 -1
- package/src/Resource/BlockResource.tsx +1 -1
- package/src/Resource/ListResource.tsx +1 -1
- package/src/ResourceGroup/ResourceGroup.tsx +1 -1
- package/src/ResourceGroup/ResourceItem.tsx +2 -2
- package/src/ResourceGroup/ResourceList.tsx +1 -1
- package/src/Search/ContentTypeResult.tsx +0 -1
- package/src/SearchTypeResult/SearchItem.tsx +0 -1
- package/src/TopicMenu/TopicMenuButton.jsx +5 -1
- package/src/TreeStructure/FolderItem.tsx +105 -94
- package/src/TreeStructure/FolderItems.tsx +33 -52
- package/src/TreeStructure/FolderNameInput.tsx +6 -11
- package/src/TreeStructure/TreeStructure.tsx +80 -73
- package/src/TreeStructure/helperFunctions.ts +3 -37
- package/src/TreeStructure/index.ts +2 -1
- package/src/TreeStructure/types.ts +38 -0
- package/src/index.ts +1 -1
- package/src/locale/messages-en.ts +8 -0
- package/src/locale/messages-nb.ts +8 -0
- package/src/locale/messages-nn.ts +8 -0
- package/src/locale/messages-se.ts +8 -0
- package/src/locale/messages-sma.ts +8 -0
- package/lib/TreeStructure/TreeStructure.types.d.ts +0 -61
- package/src/TreeStructure/TreeStructure.types.ts +0 -71
|
@@ -11,8 +11,14 @@ var _styledBase = _interopRequireDefault(require("@emotion/styled-base"));
|
|
|
11
11
|
|
|
12
12
|
var _react = _interopRequireWildcard(require("react"));
|
|
13
13
|
|
|
14
|
+
var _reactI18next = require("react-i18next");
|
|
15
|
+
|
|
14
16
|
var _common = require("@ndla/icons/common");
|
|
15
17
|
|
|
18
|
+
var _editor = require("@ndla/icons/editor");
|
|
19
|
+
|
|
20
|
+
var _button = require("@ndla/button");
|
|
21
|
+
|
|
16
22
|
var _contentType = require("@ndla/icons/contentType");
|
|
17
23
|
|
|
18
24
|
var _core = require("@ndla/core");
|
|
@@ -29,6 +35,12 @@ function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj;
|
|
|
29
35
|
|
|
30
36
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
|
31
37
|
|
|
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
|
+
|
|
32
44
|
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)."; }
|
|
33
45
|
|
|
34
46
|
var OpenButton = (0, _styledBase["default"])("button", {
|
|
@@ -40,7 +52,7 @@ var OpenButton = (0, _styledBase["default"])("button", {
|
|
|
40
52
|
}, "deg);padding:", _core.spacing.xsmall, ";display:flex;margin:0;color:", _core.colors.brand.secondary, ";cursor:pointer;&:hover{color:", _core.colors.brand.primary, ";}svg{width:16px;height:16px;transform:", function (_ref2) {
|
|
41
53
|
var isOpen = _ref2.isOpen;
|
|
42
54
|
return isOpen ? 'translateX(3px)' : 'translateY(3px)';
|
|
43
|
-
}, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
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'].includes(name);\n\ninterface FolderNameProps {\n  selected?: boolean;\n  noArrow?: boolean;\n}\n\nconst FolderName = styled('button', { shouldForwardProp })<FolderNameProps>`\n  cursor: pointer;\n  padding: ${spacing.xsmall};\n  margin: 0;\n  margin-left: ${({ noArrow }) => (noArrow ? `29px` : `0px`)};\n  flex-grow: 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}: 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            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"]} */"));
|
|
44
56
|
var FolderItemWrapper = (0, _styledBase["default"])("div", {
|
|
45
57
|
target: "e11ok6h81",
|
|
46
58
|
label: "FolderItemWrapper"
|
|
@@ -50,78 +62,108 @@ var FolderItemWrapper = (0, _styledBase["default"])("div", {
|
|
|
50
62
|
} : {
|
|
51
63
|
name: "70qvj9",
|
|
52
64
|
styles: "display:flex;align-items:center;",
|
|
53
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
65
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FolderItem.tsx"],"names":[],"mappings":"AAuCoC","file":"FolderItem.tsx","sourcesContent":["/**\n * Copyright (c) 2022-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { KeyboardEvent, MouseEvent, useEffect, useRef } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { ArrowDropDown } from '@ndla/icons/common';\nimport { Done } from '@ndla/icons/editor';\nimport { MenuButton } from '@ndla/button';\nimport { FolderOutlined } from '@ndla/icons/contentType';\nimport { colors, spacing, misc, animations } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\nimport { CommonFolderItemsProps, FolderType } from './types';\nimport { arrowNavigation } from './arrowNavigation';\n\nconst OpenButton = styled.button<{ isOpen: boolean }>`\n  background: transparent;\n  border: 0;\n  transform: rotate(${({ isOpen }) => (isOpen ? '0' : '-90')}deg);\n  padding: ${spacing.xsmall};\n  display: flex;\n  margin: 0;\n  color: ${colors.brand.secondary};\n  cursor: pointer;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n  svg {\n    width: 16px;\n    height: 16px;\n    transform: ${({ isOpen }) => (isOpen ? 'translateX(3px)' : 'translateY(3px)')};\n  }\n`;\n\nconst FolderItemWrapper = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst WrapperForFolderChild = styled.div`\n  display: flex;\n  flex-direction: row;\n  align-items: center;\n  gap: ${spacing.xsmall};\n`;\n\nconst shouldForwardProp = (name: string) => !['selected', 'noArrow'].includes(name);\n\ninterface FolderNameProps {\n  selected?: boolean;\n  noArrow?: boolean;\n}\n\nconst FolderName = styled('button', { shouldForwardProp })<FolderNameProps>`\n  cursor: pointer;\n  padding: ${spacing.xsmall};\n  margin: 0;\n  margin-left: ${({ noArrow }) => (noArrow ? `29px` : `0px`)};\n  flex-grow: 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}: 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            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"]} */",
|
|
54
66
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
55
67
|
});
|
|
56
68
|
var WrapperForFolderChild = (0, _styledBase["default"])("div", {
|
|
57
69
|
target: "e11ok6h82",
|
|
58
70
|
label: "WrapperForFolderChild"
|
|
59
|
-
})("
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
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,{"version":3,"sources":["FolderItem.tsx"],"names":[],"mappings":"AA4CwC","file":"FolderItem.tsx","sourcesContent":["/**\n * Copyright (c) 2022-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { KeyboardEvent, MouseEvent, useEffect, useRef } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { ArrowDropDown } from '@ndla/icons/common';\nimport { Done } from '@ndla/icons/editor';\nimport { MenuButton } from '@ndla/button';\nimport { FolderOutlined } from '@ndla/icons/contentType';\nimport { colors, spacing, misc, animations } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\nimport { CommonFolderItemsProps, FolderType } from './types';\nimport { arrowNavigation } from './arrowNavigation';\n\nconst OpenButton = styled.button<{ isOpen: boolean }>`\n  background: transparent;\n  border: 0;\n  transform: rotate(${({ isOpen }) => (isOpen ? '0' : '-90')}deg);\n  padding: ${spacing.xsmall};\n  display: flex;\n  margin: 0;\n  color: ${colors.brand.secondary};\n  cursor: pointer;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n  svg {\n    width: 16px;\n    height: 16px;\n    transform: ${({ isOpen }) => (isOpen ? 'translateX(3px)' : 'translateY(3px)')};\n  }\n`;\n\nconst FolderItemWrapper = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst WrapperForFolderChild = styled.div`\n  display: flex;\n  flex-direction: row;\n  align-items: center;\n  gap: ${spacing.xsmall};\n`;\n\nconst shouldForwardProp = (name: string) => !['selected', 'noArrow'].includes(name);\n\ninterface FolderNameProps {\n  selected?: boolean;\n  noArrow?: boolean;\n}\n\nconst FolderName = styled('button', { shouldForwardProp })<FolderNameProps>`\n  cursor: pointer;\n  padding: ${spacing.xsmall};\n  margin: 0;\n  margin-left: ${({ noArrow }) => (noArrow ? `29px` : `0px`)};\n  flex-grow: 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}: 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            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"]} */"));
|
|
72
|
+
|
|
73
|
+
var shouldForwardProp = function shouldForwardProp(name) {
|
|
74
|
+
return !['selected', 'noArrow'].includes(name);
|
|
75
|
+
};
|
|
76
|
+
|
|
63
77
|
var FolderName = ( /*#__PURE__*/0, _styledBase["default"])('button', {
|
|
64
|
-
shouldForwardProp:
|
|
65
|
-
return !['marked', 'noArrow'].includes(name);
|
|
66
|
-
},
|
|
78
|
+
shouldForwardProp: shouldForwardProp,
|
|
67
79
|
target: "e11ok6h83",
|
|
68
80
|
label: "FolderName"
|
|
69
|
-
})("
|
|
70
|
-
var
|
|
71
|
-
return marked ? _core.colors.brand.lighter : 'transparent';
|
|
72
|
-
}, ";color:", _core.colors.text.primary, ";&:hover,&:focus{background:", function (_ref5) {
|
|
73
|
-
var marked = _ref5.marked;
|
|
74
|
-
return marked ? _core.colors.brand.light : _core.colors.brand.lightest;
|
|
75
|
-
}, ";color:", _core.colors.brand.primary, ";+ ", WrapperForFolderChild, "{opacity:1;}}transition:", _core.animations.durations.superFast, ";border:0;border-radius:", _core.misc.borderRadius, ";display:flex;gap:", _core.spacing.xxsmall, ";align-items:center;cursor:pointer;padding:", _core.spacing.xsmall, ";margin:0;margin-left:", function (_ref6) {
|
|
76
|
-
var noArrow = _ref6.noArrow;
|
|
81
|
+
})("cursor:pointer;padding:", _core.spacing.xsmall, ";margin:0;margin-left:", function (_ref3) {
|
|
82
|
+
var noArrow = _ref3.noArrow;
|
|
77
83
|
return noArrow ? "29px" : "0px";
|
|
78
|
-
}, ";flex-grow:1;
|
|
79
|
-
var
|
|
84
|
+
}, ";flex-grow:1;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:", _core.spacing.xxsmall, ";border:0;border-radius:", _core.misc.borderRadius, ";box-shadow:none;background:", function (_ref4) {
|
|
85
|
+
var selected = _ref4.selected;
|
|
86
|
+
return selected ? _core.colors.brand.lighter : 'transparent';
|
|
87
|
+
}, ";color:", _core.colors.text.primary, ";transition:", _core.animations.durations.superFast, ";text-align:left;line-height:1;word-break:break-word;&:hover,&:focus{background:", function (_ref5) {
|
|
88
|
+
var selected = _ref5.selected;
|
|
89
|
+
return selected ? _core.colors.brand.light : _core.colors.brand.lightest;
|
|
90
|
+
}, ";color:", _core.colors.brand.primary, ";+ ", WrapperForFolderChild, "{opacity:1;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FolderItem.tsx"],"names":[],"mappings":"AA0D2E","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'].includes(name);\n\ninterface FolderNameProps {\n  selected?: boolean;\n  noArrow?: boolean;\n}\n\nconst FolderName = styled('button', { shouldForwardProp })<FolderNameProps>`\n  cursor: pointer;\n  padding: ${spacing.xsmall};\n  margin: 0;\n  margin-left: ${({ noArrow }) => (noArrow ? `29px` : `0px`)};\n  flex-grow: 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}: 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            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"]} */"));
|
|
91
|
+
var StyledDone = ( /*#__PURE__*/0, _styledBase["default"])(_editor.Done, {
|
|
80
92
|
target: "e11ok6h84",
|
|
93
|
+
label: "StyledDone"
|
|
94
|
+
})("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":"AAuF+B","file":"FolderItem.tsx","sourcesContent":["/**\n * Copyright (c) 2022-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { KeyboardEvent, MouseEvent, useEffect, useRef } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { ArrowDropDown } from '@ndla/icons/common';\nimport { Done } from '@ndla/icons/editor';\nimport { MenuButton } from '@ndla/button';\nimport { FolderOutlined } from '@ndla/icons/contentType';\nimport { colors, spacing, misc, animations } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\nimport { CommonFolderItemsProps, FolderType } from './types';\nimport { arrowNavigation } from './arrowNavigation';\n\nconst OpenButton = styled.button<{ isOpen: boolean }>`\n  background: transparent;\n  border: 0;\n  transform: rotate(${({ isOpen }) => (isOpen ? '0' : '-90')}deg);\n  padding: ${spacing.xsmall};\n  display: flex;\n  margin: 0;\n  color: ${colors.brand.secondary};\n  cursor: pointer;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n  svg {\n    width: 16px;\n    height: 16px;\n    transform: ${({ isOpen }) => (isOpen ? 'translateX(3px)' : 'translateY(3px)')};\n  }\n`;\n\nconst FolderItemWrapper = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst WrapperForFolderChild = styled.div`\n  display: flex;\n  flex-direction: row;\n  align-items: center;\n  gap: ${spacing.xsmall};\n`;\n\nconst shouldForwardProp = (name: string) => !['selected', 'noArrow'].includes(name);\n\ninterface FolderNameProps {\n  selected?: boolean;\n  noArrow?: boolean;\n}\n\nconst FolderName = styled('button', { shouldForwardProp })<FolderNameProps>`\n  cursor: pointer;\n  padding: ${spacing.xsmall};\n  margin: 0;\n  margin-left: ${({ noArrow }) => (noArrow ? `29px` : `0px`)};\n  flex-grow: 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}: 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            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"]} */"));
|
|
95
|
+
var FolderNameLink = FolderName.withComponent(_safelink["default"], {
|
|
96
|
+
target: "e11ok6h85",
|
|
81
97
|
label: "FolderNameLink"
|
|
82
98
|
});
|
|
83
99
|
|
|
84
|
-
var FolderItem = function FolderItem(
|
|
85
|
-
var
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
100
|
+
var FolderItem = function FolderItem(_ref6) {
|
|
101
|
+
var focusedFolderId = _ref6.focusedFolderId,
|
|
102
|
+
menuItems = _ref6.menuItems,
|
|
103
|
+
hideArrow = _ref6.hideArrow,
|
|
104
|
+
folder = _ref6.folder,
|
|
105
|
+
isOpen = _ref6.isOpen,
|
|
106
|
+
level = _ref6.level,
|
|
107
|
+
loading = _ref6.loading,
|
|
108
|
+
selectedFolder = _ref6.selectedFolder,
|
|
109
|
+
noPaddingWhenArrowIsHidden = _ref6.noPaddingWhenArrowIsHidden,
|
|
110
|
+
onCloseFolder = _ref6.onCloseFolder,
|
|
111
|
+
onOpenFolder = _ref6.onOpenFolder,
|
|
112
|
+
onSelectFolder = _ref6.onSelectFolder,
|
|
113
|
+
openOnFolderClick = _ref6.openOnFolderClick,
|
|
114
|
+
setFocusedId = _ref6.setFocusedId,
|
|
115
|
+
setSelectedFolder = _ref6.setSelectedFolder,
|
|
116
|
+
targetResource = _ref6.targetResource,
|
|
117
|
+
visibleFolders = _ref6.visibleFolders;
|
|
118
|
+
|
|
119
|
+
var _useTranslation = (0, _reactI18next.useTranslation)(),
|
|
120
|
+
t = _useTranslation.t;
|
|
121
|
+
|
|
122
|
+
var id = folder.id,
|
|
123
|
+
icon = folder.icon,
|
|
124
|
+
name = folder.name;
|
|
103
125
|
var ref = (0, _react.useRef)(null);
|
|
104
|
-
var
|
|
105
|
-
|
|
106
|
-
var handleMarkFolder = function handleMarkFolder() {
|
|
107
|
-
onMarkFolder(id);
|
|
126
|
+
var selected = selectedFolder && selectedFolder.id === id;
|
|
127
|
+
var focused = focusedFolderId === id;
|
|
108
128
|
|
|
129
|
+
var handleClickFolder = function handleClickFolder() {
|
|
109
130
|
if (openOnFolderClick) {
|
|
110
|
-
if (
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
131
|
+
if (selected) {
|
|
132
|
+
if (isOpen) {
|
|
133
|
+
onCloseFolder(id);
|
|
134
|
+
} else {
|
|
135
|
+
onOpenFolder(id);
|
|
136
|
+
}
|
|
114
137
|
}
|
|
115
138
|
}
|
|
139
|
+
|
|
140
|
+
if (!selected) {
|
|
141
|
+
setSelectedFolder(folder);
|
|
142
|
+
setFocusedId(id);
|
|
143
|
+
}
|
|
144
|
+
|
|
145
|
+
onSelectFolder === null || onSelectFolder === void 0 ? void 0 : onSelectFolder(id);
|
|
116
146
|
};
|
|
117
147
|
|
|
118
148
|
(0, _react.useEffect)(function () {
|
|
119
149
|
if (focusedFolderId === id) {
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
150
|
+
var _ref$current;
|
|
151
|
+
|
|
152
|
+
(_ref$current = ref.current) === null || _ref$current === void 0 ? void 0 : _ref$current.focus();
|
|
123
153
|
}
|
|
124
154
|
}, [focusedFolderId, ref, id]);
|
|
155
|
+
var actions = menuItems === null || menuItems === void 0 ? void 0 : menuItems.map(function (item) {
|
|
156
|
+
var _onClick = item.onClick;
|
|
157
|
+
return _objectSpread(_objectSpread({}, item), {}, {
|
|
158
|
+
onClick: function onClick(e) {
|
|
159
|
+
return _onClick(e, folder);
|
|
160
|
+
}
|
|
161
|
+
});
|
|
162
|
+
});
|
|
163
|
+
var linkPath = "/minndla".concat(level > 0 ? '/folders' : '', "/").concat(id);
|
|
164
|
+
var containsResource = targetResource && folder.resources.some(function (resource) {
|
|
165
|
+
return resource.resourceId === targetResource.resourceId;
|
|
166
|
+
});
|
|
125
167
|
return (0, _core2.jsx)(FolderItemWrapper, null, !hideArrow && (0, _core2.jsx)(OpenButton, {
|
|
126
168
|
tabIndex: -1,
|
|
127
169
|
isOpen: isOpen,
|
|
@@ -132,36 +174,38 @@ var FolderItem = function FolderItem(_ref7) {
|
|
|
132
174
|
}, (0, _core2.jsx)(_common.ArrowDropDown, null)), onSelectFolder ? (0, _core2.jsx)(_react["default"].Fragment, null, (0, _core2.jsx)(FolderName, {
|
|
133
175
|
ref: ref,
|
|
134
176
|
onKeyDown: function onKeyDown(e) {
|
|
135
|
-
return (0, _arrowNavigation.arrowNavigation)(e, id, visibleFolders,
|
|
177
|
+
return (0, _arrowNavigation.arrowNavigation)(e, id, visibleFolders, setFocusedId, onOpenFolder, onCloseFolder);
|
|
136
178
|
},
|
|
137
179
|
noArrow: hideArrow && !noPaddingWhenArrowIsHidden,
|
|
138
|
-
tabIndex:
|
|
139
|
-
|
|
180
|
+
tabIndex: selected || focused ? 0 : -1,
|
|
181
|
+
selected: selected,
|
|
140
182
|
disabled: loading,
|
|
141
183
|
onFocus: function onFocus() {
|
|
142
|
-
|
|
184
|
+
return setFocusedId(id);
|
|
143
185
|
},
|
|
144
|
-
onClick:
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
186
|
+
onClick: handleClickFolder
|
|
187
|
+
}, icon || (0, _core2.jsx)(_contentType.FolderOutlined, null), name, (0, _core2.jsx)(WrapperForFolderChild, null, containsResource && (0, _core2.jsx)(StyledDone, {
|
|
188
|
+
title: t('myNdla.alreadyInFolder')
|
|
189
|
+
}), actions && (0, _core2.jsx)(_button.MenuButton, {
|
|
190
|
+
onClick: function onClick(e) {
|
|
191
|
+
return e.stopPropagation();
|
|
192
|
+
},
|
|
193
|
+
size: "xsmall",
|
|
194
|
+
menuItems: actions,
|
|
195
|
+
tabIndex: selected || id === focusedFolderId ? 0 : -1
|
|
196
|
+
})))) : (0, _core2.jsx)(FolderNameLink, {
|
|
151
197
|
ref: ref,
|
|
152
198
|
onKeyDown: function onKeyDown(e) {
|
|
153
|
-
return (0, _arrowNavigation.arrowNavigation)(e, id, visibleFolders,
|
|
199
|
+
return (0, _arrowNavigation.arrowNavigation)(e, id, visibleFolders, setFocusedId, onOpenFolder, onCloseFolder);
|
|
154
200
|
},
|
|
155
201
|
noArrow: hideArrow,
|
|
156
|
-
to: loading ? '' :
|
|
157
|
-
tabIndex:
|
|
158
|
-
|
|
202
|
+
to: loading ? '' : linkPath,
|
|
203
|
+
tabIndex: selected || focused || level === 0 ? 0 : -1,
|
|
204
|
+
selected: selected,
|
|
159
205
|
onFocus: function onFocus() {
|
|
160
|
-
|
|
206
|
+
return setFocusedId(id);
|
|
161
207
|
},
|
|
162
|
-
onClick:
|
|
163
|
-
handleMarkFolder();
|
|
164
|
-
}
|
|
208
|
+
onClick: handleClickFolder
|
|
165
209
|
}, icon || (0, _core2.jsx)(_contentType.FolderOutlined, null), name));
|
|
166
210
|
};
|
|
167
211
|
|
|
@@ -6,6 +6,15 @@
|
|
|
6
6
|
*
|
|
7
7
|
*/
|
|
8
8
|
/// <reference types="react" />
|
|
9
|
-
import {
|
|
10
|
-
|
|
9
|
+
import { CommonFolderItemsProps, FolderType } from './types';
|
|
10
|
+
export interface FolderItemsProps extends CommonFolderItemsProps {
|
|
11
|
+
folders: FolderType[];
|
|
12
|
+
editable?: boolean;
|
|
13
|
+
maximumLevelsOfFoldersAllowed: number;
|
|
14
|
+
newFolderParentId: string | undefined;
|
|
15
|
+
onCancelNewFolder: () => void;
|
|
16
|
+
onSaveNewFolder: (name: string, parentId: string) => void;
|
|
17
|
+
openFolders: string[];
|
|
18
|
+
}
|
|
19
|
+
declare const FolderItems: ({ editable, folders, level, loading, maximumLevelsOfFoldersAllowed, newFolderParentId, onCancelNewFolder, onSaveNewFolder, openFolders, ...rest }: FolderItemsProps) => JSX.Element;
|
|
11
20
|
export default FolderItems;
|
|
@@ -19,6 +19,12 @@ var _core2 = require("@emotion/core");
|
|
|
19
19
|
|
|
20
20
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
|
21
21
|
|
|
22
|
+
function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
|
|
23
|
+
|
|
24
|
+
function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }
|
|
25
|
+
|
|
26
|
+
function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }
|
|
27
|
+
|
|
22
28
|
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)."; }
|
|
23
29
|
|
|
24
30
|
var StyledUL = (0, _styledBase["default"])("ul", {
|
|
@@ -27,7 +33,7 @@ var StyledUL = (0, _styledBase["default"])("ul", {
|
|
|
27
33
|
})(_core.animations.fadeInLeft(_core.animations.durations.fast), ";animation-fill-mode:forwards;@media (prefers-reduced-motion:reduce){animation:none;}list-style:none;margin:0;padding:0;margin-left:", function (_ref) {
|
|
28
34
|
var firstLevel = _ref.firstLevel;
|
|
29
35
|
return firstLevel ? "-".concat(_core.spacing.xsmall) : _core.spacing.normal;
|
|
30
|
-
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
36
|
+
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZvbGRlckl0ZW1zLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFlb0QiLCJmaWxlIjoiRm9sZGVySXRlbXMudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjItcHJlc2VudCwgTkRMQS5cbiAqXG4gKiBUaGlzIHNvdXJjZSBjb2RlIGlzIGxpY2Vuc2VkIHVuZGVyIHRoZSBHUEx2MyBsaWNlbnNlIGZvdW5kIGluIHRoZVxuICogTElDRU5TRSBmaWxlIGluIHRoZSByb290IGRpcmVjdG9yeSBvZiB0aGlzIHNvdXJjZSB0cmVlLlxuICpcbiAqL1xuXG5pbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgYW5pbWF0aW9ucywgc3BhY2luZyB9IGZyb20gJ0BuZGxhL2NvcmUnO1xuaW1wb3J0IEZvbGRlckl0ZW0gZnJvbSAnLi9Gb2xkZXJJdGVtJztcbmltcG9ydCBGb2xkZXJOYW1lSW5wdXQgZnJvbSAnLi9Gb2xkZXJOYW1lSW5wdXQnO1xuaW1wb3J0IHsgQ29tbW9uRm9sZGVySXRlbXNQcm9wcywgRm9sZGVyVHlwZSB9IGZyb20gJy4vdHlwZXMnO1xuXG5jb25zdCBTdHlsZWRVTCA9IHN0eWxlZC51bDx7IGZpcnN0TGV2ZWw/OiBib29sZWFuIH0+YFxuICAke2FuaW1hdGlvbnMuZmFkZUluTGVmdChhbmltYXRpb25zLmR1cmF0aW9ucy5mYXN0KX07XG4gIGFuaW1hdGlvbi1maWxsLW1vZGU6IGZvcndhcmRzO1xuICBAbWVkaWEgKHByZWZlcnMtcmVkdWNlZC1tb3Rpb246IHJlZHVjZSkge1xuICAgIGFuaW1hdGlvbjogbm9uZTtcbiAgfVxuICBsaXN0LXN0eWxlOiBub25lO1xuICBtYXJnaW46IDA7XG4gIHBhZGRpbmc6IDA7XG4gIG1hcmdpbi1sZWZ0OiAkeyh7IGZpcnN0TGV2ZWwgfSkgPT4gKGZpcnN0TGV2ZWwgPyBgLSR7c3BhY2luZy54c21hbGx9YCA6IHNwYWNpbmcubm9ybWFsKX07XG5gO1xuXG5jb25zdCBTdHlsZWRMSSA9IHN0eWxlZC5saWBcbiAgbWFyZ2luOiAwO1xuICBwYWRkaW5nOiAwO1xuYDtcblxuZXhwb3J0IGludGVyZmFjZSBGb2xkZXJJdGVtc1Byb3BzIGV4dGVuZHMgQ29tbW9uRm9sZGVySXRlbXNQcm9wcyB7XG4gIGZvbGRlcnM6IEZvbGRlclR5cGVbXTtcbiAgZWRpdGFibGU/OiBib29sZWFuO1xuICBtYXhpbXVtTGV2ZWxzT2ZGb2xkZXJzQWxsb3dlZDogbnVtYmVyO1xuICBuZXdGb2xkZXJQYXJlbnRJZDogc3RyaW5nIHwgdW5kZWZpbmVkO1xuICBvbkNhbmNlbE5ld0ZvbGRlcjogKCkgPT4gdm9pZDtcbiAgb25TYXZlTmV3Rm9sZGVyOiAobmFtZTogc3RyaW5nLCBwYXJlbnRJZDogc3RyaW5nKSA9PiB2b2lkO1xuICBvcGVuRm9sZGVyczogc3RyaW5nW107XG59XG5cbmNvbnN0IEZvbGRlckl0ZW1zID0gKHtcbiAgZWRpdGFibGUsXG4gIGZvbGRlcnMsXG4gIGxldmVsLFxuICBsb2FkaW5nLFxuICBtYXhpbXVtTGV2ZWxzT2ZGb2xkZXJzQWxsb3dlZCxcbiAgbmV3Rm9sZGVyUGFyZW50SWQsXG4gIG9uQ2FuY2VsTmV3Rm9sZGVyLFxuICBvblNhdmVOZXdGb2xkZXIsXG4gIG9wZW5Gb2xkZXJzLFxuICAuLi5yZXN0XG59OiBGb2xkZXJJdGVtc1Byb3BzKSA9PiAoXG4gIDxTdHlsZWRVTCByb2xlPVwiZ3JvdXBcIiBmaXJzdExldmVsPXtsZXZlbCA9PT0gMH0+XG4gICAge2ZvbGRlcnMubWFwKChmb2xkZXIpID0+IHtcbiAgICAgIGNvbnN0IHsgc3ViZm9sZGVycywgaWQgfSA9IGZvbGRlcjtcbiAgICAgIGNvbnN0IGlzT3BlbiA9IG9wZW5Gb2xkZXJzPy5pbmNsdWRlcyhpZCk7XG5cbiAgICAgIHJldHVybiAoXG4gICAgICAgIDxTdHlsZWRMSSBrZXk9e2lkfSByb2xlPVwidHJlZWl0ZW1cIj5cbiAgICAgICAgICA8ZGl2PlxuICAgICAgICAgICAgPEZvbGRlckl0ZW1cbiAgICAgICAgICAgICAgaGlkZUFycm93PXtzdWJmb2xkZXJzPy5sZW5ndGggPT09IDAgfHwgbGV2ZWwgPiBtYXhpbXVtTGV2ZWxzT2ZGb2xkZXJzQWxsb3dlZH1cbiAgICAgICAgICAgICAgZm9sZGVyPXtmb2xkZXJ9XG4gICAgICAgICAgICAgIGlzT3Blbj17aXNPcGVufVxuICAgICAgICAgICAgICBsZXZlbD17bGV2ZWx9XG4gICAgICAgICAgICAgIGxvYWRpbmc9e2xvYWRpbmd9XG4gICAgICAgICAgICAgIG5vUGFkZGluZ1doZW5BcnJvd0lzSGlkZGVuPXtlZGl0YWJsZSAmJiBsZXZlbCA9PT0gMCAmJiBzdWJmb2xkZXJzPy5sZW5ndGggPT09IDB9XG4gICAgICAgICAgICAgIHsuLi5yZXN0fVxuICAgICAgICAgICAgLz5cbiAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICB7bmV3Rm9sZGVyUGFyZW50SWQgPT09IGlkICYmIChcbiAgICAgICAgICAgIDxGb2xkZXJOYW1lSW5wdXRcbiAgICAgICAgICAgICAgbG9hZGluZz17bG9hZGluZ31cbiAgICAgICAgICAgICAgb25DYW5jZWxOZXdGb2xkZXI9e29uQ2FuY2VsTmV3Rm9sZGVyfVxuICAgICAgICAgICAgICBvblNhdmVOZXdGb2xkZXI9e29uU2F2ZU5ld0ZvbGRlcn1cbiAgICAgICAgICAgICAgcGFyZW50SWQ9e25ld0ZvbGRlclBhcmVudElkfVxuICAgICAgICAgICAgLz5cbiAgICAgICAgICApfVxuICAgICAgICAgIHtzdWJmb2xkZXJzICYmIGlzT3BlbiAmJiAoXG4gICAgICAgICAgICA8Rm9sZGVySXRlbXNcbiAgICAgICAgICAgICAgZWRpdGFibGU9e2VkaXRhYmxlfVxuICAgICAgICAgICAgICBmb2xkZXJzPXtzdWJmb2xkZXJzfVxuICAgICAgICAgICAgICBsZXZlbD17bGV2ZWwgKyAxfVxuICAgICAgICAgICAgICBsb2FkaW5nPXtsb2FkaW5nfVxuICAgICAgICAgICAgICBtYXhpbXVtTGV2ZWxzT2ZGb2xkZXJzQWxsb3dlZD17bWF4aW11bUxldmVsc09mRm9sZGVyc0FsbG93ZWR9XG4gICAgICAgICAgICAgIG5ld0ZvbGRlclBhcmVudElkPXtuZXdGb2xkZXJQYXJlbnRJZH1cbiAgICAgICAgICAgICAgb25DYW5jZWxOZXdGb2xkZXI9e29uQ2FuY2VsTmV3Rm9sZGVyfVxuICAgICAgICAgICAgICBvblNhdmVOZXdGb2xkZXI9e29uU2F2ZU5ld0ZvbGRlcn1cbiAgICAgICAgICAgICAgb3BlbkZvbGRlcnM9e29wZW5Gb2xkZXJzfVxuICAgICAgICAgICAgICB7Li4ucmVzdH1cbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgKX1cbiAgICAgICAgPC9TdHlsZWRMST5cbiAgICAgICk7XG4gICAgfSl9XG4gIDwvU3R5bGVkVUw+XG4pO1xuXG5leHBvcnQgZGVmYXVsdCBGb2xkZXJJdGVtcztcbiJdfQ== */"));
|
|
31
37
|
var StyledLI = (0, _styledBase["default"])("li", {
|
|
32
38
|
target: "ef48q151",
|
|
33
39
|
label: "StyledLI"
|
|
@@ -37,89 +43,55 @@ var StyledLI = (0, _styledBase["default"])("li", {
|
|
|
37
43
|
} : {
|
|
38
44
|
name: "1l95nvm",
|
|
39
45
|
styles: "margin:0;padding:0;",
|
|
40
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
46
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZvbGRlckl0ZW1zLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEyQjBCIiwiZmlsZSI6IkZvbGRlckl0ZW1zLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDIyLXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGFuaW1hdGlvbnMsIHNwYWNpbmcgfSBmcm9tICdAbmRsYS9jb3JlJztcbmltcG9ydCBGb2xkZXJJdGVtIGZyb20gJy4vRm9sZGVySXRlbSc7XG5pbXBvcnQgRm9sZGVyTmFtZUlucHV0IGZyb20gJy4vRm9sZGVyTmFtZUlucHV0JztcbmltcG9ydCB7IENvbW1vbkZvbGRlckl0ZW1zUHJvcHMsIEZvbGRlclR5cGUgfSBmcm9tICcuL3R5cGVzJztcblxuY29uc3QgU3R5bGVkVUwgPSBzdHlsZWQudWw8eyBmaXJzdExldmVsPzogYm9vbGVhbiB9PmBcbiAgJHthbmltYXRpb25zLmZhZGVJbkxlZnQoYW5pbWF0aW9ucy5kdXJhdGlvbnMuZmFzdCl9O1xuICBhbmltYXRpb24tZmlsbC1tb2RlOiBmb3J3YXJkcztcbiAgQG1lZGlhIChwcmVmZXJzLXJlZHVjZWQtbW90aW9uOiByZWR1Y2UpIHtcbiAgICBhbmltYXRpb246IG5vbmU7XG4gIH1cbiAgbGlzdC1zdHlsZTogbm9uZTtcbiAgbWFyZ2luOiAwO1xuICBwYWRkaW5nOiAwO1xuICBtYXJnaW4tbGVmdDogJHsoeyBmaXJzdExldmVsIH0pID0+IChmaXJzdExldmVsID8gYC0ke3NwYWNpbmcueHNtYWxsfWAgOiBzcGFjaW5nLm5vcm1hbCl9O1xuYDtcblxuY29uc3QgU3R5bGVkTEkgPSBzdHlsZWQubGlgXG4gIG1hcmdpbjogMDtcbiAgcGFkZGluZzogMDtcbmA7XG5cbmV4cG9ydCBpbnRlcmZhY2UgRm9sZGVySXRlbXNQcm9wcyBleHRlbmRzIENvbW1vbkZvbGRlckl0ZW1zUHJvcHMge1xuICBmb2xkZXJzOiBGb2xkZXJUeXBlW107XG4gIGVkaXRhYmxlPzogYm9vbGVhbjtcbiAgbWF4aW11bUxldmVsc09mRm9sZGVyc0FsbG93ZWQ6IG51bWJlcjtcbiAgbmV3Rm9sZGVyUGFyZW50SWQ6IHN0cmluZyB8IHVuZGVmaW5lZDtcbiAgb25DYW5jZWxOZXdGb2xkZXI6ICgpID0+IHZvaWQ7XG4gIG9uU2F2ZU5ld0ZvbGRlcjogKG5hbWU6IHN0cmluZywgcGFyZW50SWQ6IHN0cmluZykgPT4gdm9pZDtcbiAgb3BlbkZvbGRlcnM6IHN0cmluZ1tdO1xufVxuXG5jb25zdCBGb2xkZXJJdGVtcyA9ICh7XG4gIGVkaXRhYmxlLFxuICBmb2xkZXJzLFxuICBsZXZlbCxcbiAgbG9hZGluZyxcbiAgbWF4aW11bUxldmVsc09mRm9sZGVyc0FsbG93ZWQsXG4gIG5ld0ZvbGRlclBhcmVudElkLFxuICBvbkNhbmNlbE5ld0ZvbGRlcixcbiAgb25TYXZlTmV3Rm9sZGVyLFxuICBvcGVuRm9sZGVycyxcbiAgLi4ucmVzdFxufTogRm9sZGVySXRlbXNQcm9wcykgPT4gKFxuICA8U3R5bGVkVUwgcm9sZT1cImdyb3VwXCIgZmlyc3RMZXZlbD17bGV2ZWwgPT09IDB9PlxuICAgIHtmb2xkZXJzLm1hcCgoZm9sZGVyKSA9PiB7XG4gICAgICBjb25zdCB7IHN1YmZvbGRlcnMsIGlkIH0gPSBmb2xkZXI7XG4gICAgICBjb25zdCBpc09wZW4gPSBvcGVuRm9sZGVycz8uaW5jbHVkZXMoaWQpO1xuXG4gICAgICByZXR1cm4gKFxuICAgICAgICA8U3R5bGVkTEkga2V5PXtpZH0gcm9sZT1cInRyZWVpdGVtXCI+XG4gICAgICAgICAgPGRpdj5cbiAgICAgICAgICAgIDxGb2xkZXJJdGVtXG4gICAgICAgICAgICAgIGhpZGVBcnJvdz17c3ViZm9sZGVycz8ubGVuZ3RoID09PSAwIHx8IGxldmVsID4gbWF4aW11bUxldmVsc09mRm9sZGVyc0FsbG93ZWR9XG4gICAgICAgICAgICAgIGZvbGRlcj17Zm9sZGVyfVxuICAgICAgICAgICAgICBpc09wZW49e2lzT3Blbn1cbiAgICAgICAgICAgICAgbGV2ZWw9e2xldmVsfVxuICAgICAgICAgICAgICBsb2FkaW5nPXtsb2FkaW5nfVxuICAgICAgICAgICAgICBub1BhZGRpbmdXaGVuQXJyb3dJc0hpZGRlbj17ZWRpdGFibGUgJiYgbGV2ZWwgPT09IDAgJiYgc3ViZm9sZGVycz8ubGVuZ3RoID09PSAwfVxuICAgICAgICAgICAgICB7Li4ucmVzdH1cbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgPC9kaXY+XG4gICAgICAgICAge25ld0ZvbGRlclBhcmVudElkID09PSBpZCAmJiAoXG4gICAgICAgICAgICA8Rm9sZGVyTmFtZUlucHV0XG4gICAgICAgICAgICAgIGxvYWRpbmc9e2xvYWRpbmd9XG4gICAgICAgICAgICAgIG9uQ2FuY2VsTmV3Rm9sZGVyPXtvbkNhbmNlbE5ld0ZvbGRlcn1cbiAgICAgICAgICAgICAgb25TYXZlTmV3Rm9sZGVyPXtvblNhdmVOZXdGb2xkZXJ9XG4gICAgICAgICAgICAgIHBhcmVudElkPXtuZXdGb2xkZXJQYXJlbnRJZH1cbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgKX1cbiAgICAgICAgICB7c3ViZm9sZGVycyAmJiBpc09wZW4gJiYgKFxuICAgICAgICAgICAgPEZvbGRlckl0ZW1zXG4gICAgICAgICAgICAgIGVkaXRhYmxlPXtlZGl0YWJsZX1cbiAgICAgICAgICAgICAgZm9sZGVycz17c3ViZm9sZGVyc31cbiAgICAgICAgICAgICAgbGV2ZWw9e2xldmVsICsgMX1cbiAgICAgICAgICAgICAgbG9hZGluZz17bG9hZGluZ31cbiAgICAgICAgICAgICAgbWF4aW11bUxldmVsc09mRm9sZGVyc0FsbG93ZWQ9e21heGltdW1MZXZlbHNPZkZvbGRlcnNBbGxvd2VkfVxuICAgICAgICAgICAgICBuZXdGb2xkZXJQYXJlbnRJZD17bmV3Rm9sZGVyUGFyZW50SWR9XG4gICAgICAgICAgICAgIG9uQ2FuY2VsTmV3Rm9sZGVyPXtvbkNhbmNlbE5ld0ZvbGRlcn1cbiAgICAgICAgICAgICAgb25TYXZlTmV3Rm9sZGVyPXtvblNhdmVOZXdGb2xkZXJ9XG4gICAgICAgICAgICAgIG9wZW5Gb2xkZXJzPXtvcGVuRm9sZGVyc31cbiAgICAgICAgICAgICAgey4uLnJlc3R9XG4gICAgICAgICAgICAvPlxuICAgICAgICAgICl9XG4gICAgICAgIDwvU3R5bGVkTEk+XG4gICAgICApO1xuICAgIH0pfVxuICA8L1N0eWxlZFVMPlxuKTtcblxuZXhwb3J0IGRlZmF1bHQgRm9sZGVySXRlbXM7XG4iXX0= */",
|
|
41
47
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
42
48
|
});
|
|
43
49
|
|
|
44
50
|
var FolderItems = function FolderItems(_ref2) {
|
|
45
|
-
var
|
|
51
|
+
var editable = _ref2.editable,
|
|
46
52
|
folders = _ref2.folders,
|
|
47
53
|
level = _ref2.level,
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
onOpenFolder = _ref2.onOpenFolder,
|
|
52
|
-
onCreateNewFolder = _ref2.onCreateNewFolder,
|
|
54
|
+
loading = _ref2.loading,
|
|
55
|
+
maximumLevelsOfFoldersAllowed = _ref2.maximumLevelsOfFoldersAllowed,
|
|
56
|
+
newFolderParentId = _ref2.newFolderParentId,
|
|
53
57
|
onCancelNewFolder = _ref2.onCancelNewFolder,
|
|
54
58
|
onSaveNewFolder = _ref2.onSaveNewFolder,
|
|
55
|
-
newFolderParentId = _ref2.newFolderParentId,
|
|
56
|
-
visibleFolders = _ref2.visibleFolders,
|
|
57
59
|
openFolders = _ref2.openFolders,
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
openOnFolderClick = _ref2.openOnFolderClick,
|
|
61
|
-
focusedFolderId = _ref2.focusedFolderId,
|
|
62
|
-
setFocusedFolderId = _ref2.setFocusedFolderId,
|
|
63
|
-
folderChild = _ref2.folderChild,
|
|
64
|
-
maximumLevelsOfFoldersAllowed = _ref2.maximumLevelsOfFoldersAllowed;
|
|
60
|
+
rest = _objectWithoutProperties(_ref2, ["editable", "folders", "level", "loading", "maximumLevelsOfFoldersAllowed", "newFolderParentId", "onCancelNewFolder", "onSaveNewFolder", "openFolders"]);
|
|
61
|
+
|
|
65
62
|
return (0, _core2.jsx)(StyledUL, {
|
|
66
63
|
role: "group",
|
|
67
|
-
firstLevel: level ===
|
|
68
|
-
}, folders.map(function (
|
|
69
|
-
var
|
|
70
|
-
|
|
71
|
-
id = _ref3.id,
|
|
72
|
-
icon = _ref3.icon;
|
|
64
|
+
firstLevel: level === 0
|
|
65
|
+
}, folders.map(function (folder) {
|
|
66
|
+
var subfolders = folder.subfolders,
|
|
67
|
+
id = folder.id;
|
|
73
68
|
var isOpen = openFolders === null || openFolders === void 0 ? void 0 : openFolders.includes(id);
|
|
74
69
|
return (0, _core2.jsx)(StyledLI, {
|
|
75
70
|
key: id,
|
|
76
71
|
role: "treeitem"
|
|
77
|
-
}, (0, _core2.jsx)("div", null, (0, _core2.jsx)(_FolderItem["default"], {
|
|
72
|
+
}, (0, _core2.jsx)("div", null, (0, _core2.jsx)(_FolderItem["default"], _extends({
|
|
73
|
+
hideArrow: (subfolders === null || subfolders === void 0 ? void 0 : subfolders.length) === 0 || level > maximumLevelsOfFoldersAllowed,
|
|
74
|
+
folder: folder,
|
|
75
|
+
isOpen: isOpen,
|
|
78
76
|
level: level,
|
|
79
|
-
icon: icon,
|
|
80
|
-
onSelectFolder: onSelectFolder,
|
|
81
|
-
openOnFolderClick: openOnFolderClick,
|
|
82
77
|
loading: loading,
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
visibleFolders: visibleFolders,
|
|
86
|
-
name: name,
|
|
87
|
-
markedFolderId: markedFolderId,
|
|
88
|
-
focusedFolderId: focusedFolderId,
|
|
89
|
-
onMarkFolder: onMarkFolder,
|
|
90
|
-
onCloseFolder: onCloseFolder,
|
|
91
|
-
onOpenFolder: onOpenFolder,
|
|
92
|
-
hideArrow: (subfolders === null || subfolders === void 0 ? void 0 : subfolders.length) === 0 || level > maximumLevelsOfFoldersAllowed,
|
|
93
|
-
noPaddingWhenArrowIsHidden: editable && level === 1 && (subfolders === null || subfolders === void 0 ? void 0 : subfolders.length) === 0,
|
|
94
|
-
setFocusedFolderId: setFocusedFolderId,
|
|
95
|
-
folderChild: folderChild
|
|
96
|
-
})), newFolderParentId === id && (0, _core2.jsx)(_FolderNameInput["default"], {
|
|
97
|
-
parentId: newFolderParentId,
|
|
78
|
+
noPaddingWhenArrowIsHidden: editable && level === 0 && (subfolders === null || subfolders === void 0 ? void 0 : subfolders.length) === 0
|
|
79
|
+
}, rest))), newFolderParentId === id && (0, _core2.jsx)(_FolderNameInput["default"], {
|
|
98
80
|
loading: loading,
|
|
99
81
|
onCancelNewFolder: onCancelNewFolder,
|
|
100
|
-
onSaveNewFolder: onSaveNewFolder
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
loading: loading,
|
|
104
|
-
newFolderParentId: newFolderParentId,
|
|
105
|
-
visibleFolders: visibleFolders,
|
|
106
|
-
openFolders: openFolders,
|
|
107
|
-
level: level + 1,
|
|
82
|
+
onSaveNewFolder: onSaveNewFolder,
|
|
83
|
+
parentId: newFolderParentId
|
|
84
|
+
}), subfolders && isOpen && (0, _core2.jsx)(FolderItems, _extends({
|
|
108
85
|
editable: editable,
|
|
109
86
|
folders: subfolders,
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
87
|
+
level: level + 1,
|
|
88
|
+
loading: loading,
|
|
89
|
+
maximumLevelsOfFoldersAllowed: maximumLevelsOfFoldersAllowed,
|
|
90
|
+
newFolderParentId: newFolderParentId,
|
|
114
91
|
onCancelNewFolder: onCancelNewFolder,
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
focusedFolderId: focusedFolderId,
|
|
119
|
-
setFocusedFolderId: setFocusedFolderId,
|
|
120
|
-
folderChild: folderChild,
|
|
121
|
-
maximumLevelsOfFoldersAllowed: maximumLevelsOfFoldersAllowed
|
|
122
|
-
}));
|
|
92
|
+
onSaveNewFolder: onSaveNewFolder,
|
|
93
|
+
openFolders: openFolders
|
|
94
|
+
}, rest)));
|
|
123
95
|
}));
|
|
124
96
|
};
|
|
125
97
|
|