@ndla/ui 21.0.0 → 22.0.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/es/Breadcrumb/ActionBreadcrumb.js +4 -4
- package/es/ContentLoader/index.js +8 -3
- package/es/MyNdla/Resource/Folder.js +7 -6
- package/es/Resource/BlockResource.js +106 -18
- package/es/Resource/ListResource.js +125 -26
- 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/SnackBar/DefaultSnackbar.js +56 -0
- package/es/SnackBar/SnackbarProvider.js +179 -0
- package/es/SnackBar/index.js +2 -2
- package/es/TopicMenu/TopicMenuButton.js +4 -2
- package/es/TreeStructure/FolderItem.js +64 -44
- package/es/TreeStructure/FolderItems.js +4 -4
- package/es/TreeStructure/TreeStructure.js +16 -9
- package/es/index.js +1 -1
- package/es/locale/messages-en.js +17 -2
- package/es/locale/messages-nb.js +17 -2
- package/es/locale/messages-nn.js +17 -2
- package/es/locale/messages-se.js +17 -2
- package/es/locale/messages-sma.js +17 -2
- package/lib/Breadcrumb/ActionBreadcrumb.js +4 -4
- package/lib/ContentLoader/index.d.ts +4 -8
- package/lib/ContentLoader/index.js +8 -3
- package/lib/MyNdla/Resource/Folder.js +7 -6
- package/lib/Resource/BlockResource.d.ts +2 -1
- package/lib/Resource/BlockResource.js +107 -18
- package/lib/Resource/ListResource.d.ts +2 -1
- package/lib/Resource/ListResource.js +126 -26
- 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/SnackBar/DefaultSnackbar.d.ts +11 -0
- package/lib/SnackBar/DefaultSnackbar.js +70 -0
- package/lib/SnackBar/SnackbarProvider.d.ts +32 -0
- package/lib/SnackBar/SnackbarProvider.js +197 -0
- package/lib/SnackBar/index.d.ts +3 -3
- package/lib/SnackBar/index.js +23 -3
- package/lib/TopicMenu/TopicMenuButton.js +3 -1
- package/lib/TreeStructure/FolderItem.d.ts +1 -1
- package/lib/TreeStructure/FolderItem.js +65 -44
- package/lib/TreeStructure/FolderItems.js +4 -4
- package/lib/TreeStructure/TreeStructure.d.ts +2 -2
- package/lib/TreeStructure/TreeStructure.js +16 -9
- package/lib/TreeStructure/types.d.ts +2 -1
- package/lib/index.d.ts +2 -2
- package/lib/index.js +24 -3
- package/lib/locale/messages-en.d.ts +15 -0
- package/lib/locale/messages-en.js +17 -2
- package/lib/locale/messages-nb.d.ts +15 -0
- package/lib/locale/messages-nb.js +17 -2
- package/lib/locale/messages-nn.d.ts +15 -0
- package/lib/locale/messages-nn.js +17 -2
- package/lib/locale/messages-se.d.ts +15 -0
- package/lib/locale/messages-se.js +17 -2
- package/lib/locale/messages-sma.d.ts +15 -0
- package/lib/locale/messages-sma.js +17 -2
- package/package.json +14 -14
- package/src/.DS_Store +0 -0
- package/src/Breadcrumb/ActionBreadcrumb.tsx +1 -1
- package/src/ContentLoader/index.tsx +9 -9
- package/src/MyNdla/Resource/Folder.tsx +1 -1
- package/src/Resource/BlockResource.tsx +66 -5
- package/src/Resource/ListResource.tsx +86 -11
- 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/SnackBar/DefaultSnackbar.tsx +70 -0
- package/src/SnackBar/SnackbarProvider.tsx +147 -0
- package/src/SnackBar/index.ts +3 -5
- package/src/TopicMenu/TopicMenuButton.jsx +5 -1
- package/src/TreeStructure/FolderItem.tsx +56 -37
- package/src/TreeStructure/FolderItems.tsx +3 -2
- package/src/TreeStructure/TreeStructure.tsx +11 -6
- package/src/TreeStructure/types.ts +2 -1
- package/src/index.ts +2 -2
- package/src/locale/messages-en.ts +15 -0
- package/src/locale/messages-nb.ts +15 -0
- package/src/locale/messages-nn.ts +15 -0
- package/src/locale/messages-se.ts +15 -0
- package/src/locale/messages-sma.ts +15 -0
- package/es/SnackBar/SnackBar.js +0 -117
- package/lib/SnackBar/SnackBar.d.ts +0 -23
- package/lib/SnackBar/SnackBar.js +0 -127
- package/src/SnackBar/SnackBar.tsx +0 -183
|
@@ -11,8 +11,12 @@ 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
|
+
|
|
16
20
|
var _button = require("@ndla/button");
|
|
17
21
|
|
|
18
22
|
var _contentType = require("@ndla/icons/contentType");
|
|
@@ -48,7 +52,7 @@ var OpenButton = (0, _styledBase["default"])("button", {
|
|
|
48
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) {
|
|
49
53
|
var isOpen = _ref2.isOpen;
|
|
50
54
|
return isOpen ? 'translateX(3px)' : 'translateY(3px)';
|
|
51
|
-
}, ";}" + (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"]} */"));
|
|
52
56
|
var FolderItemWrapper = (0, _styledBase["default"])("div", {
|
|
53
57
|
target: "e11ok6h81",
|
|
54
58
|
label: "FolderItemWrapper"
|
|
@@ -58,16 +62,13 @@ var FolderItemWrapper = (0, _styledBase["default"])("div", {
|
|
|
58
62
|
} : {
|
|
59
63
|
name: "70qvj9",
|
|
60
64
|
styles: "display:flex;align-items:center;",
|
|
61
|
-
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"]} */",
|
|
62
66
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
63
67
|
});
|
|
64
68
|
var WrapperForFolderChild = (0, _styledBase["default"])("div", {
|
|
65
69
|
target: "e11ok6h82",
|
|
66
70
|
label: "WrapperForFolderChild"
|
|
67
|
-
})("
|
|
68
|
-
var selected = _ref3.selected;
|
|
69
|
-
return selected ? 1 : 0.25;
|
|
70
|
-
}, ";&:hover,&:focus,&:focus-within{opacity:1;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZvbGRlckl0ZW0udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTBDZ0UiLCJmaWxlIjoiRm9sZGVySXRlbS50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMi1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCwgeyBLZXlib2FyZEV2ZW50LCBNb3VzZUV2ZW50LCB1c2VFZmZlY3QsIHVzZVJlZiB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IEFycm93RHJvcERvd24gfSBmcm9tICdAbmRsYS9pY29ucy9jb21tb24nO1xuaW1wb3J0IHsgTWVudUJ1dHRvbiB9IGZyb20gJ0BuZGxhL2J1dHRvbic7XG5pbXBvcnQgeyBGb2xkZXJPdXRsaW5lZCB9IGZyb20gJ0BuZGxhL2ljb25zL2NvbnRlbnRUeXBlJztcbmltcG9ydCB7IGNvbG9ycywgc3BhY2luZywgbWlzYywgYW5pbWF0aW9ucyB9IGZyb20gJ0BuZGxhL2NvcmUnO1xuaW1wb3J0IFNhZmVMaW5rIGZyb20gJ0BuZGxhL3NhZmVsaW5rJztcbmltcG9ydCB7IENvbW1vbkZvbGRlckl0ZW1zUHJvcHMsIEZvbGRlclR5cGUgfSBmcm9tICcuL3R5cGVzJztcbmltcG9ydCB7IGFycm93TmF2aWdhdGlvbiB9IGZyb20gJy4vYXJyb3dOYXZpZ2F0aW9uJztcblxuY29uc3QgT3BlbkJ1dHRvbiA9IHN0eWxlZC5idXR0b248eyBpc09wZW46IGJvb2xlYW4gfT5gXG4gIGJhY2tncm91bmQ6IHRyYW5zcGFyZW50O1xuICBib3JkZXI6IDA7XG4gIHRyYW5zZm9ybTogcm90YXRlKCR7KHsgaXNPcGVuIH0pID0+IChpc09wZW4gPyAnMCcgOiAnLTkwJyl9ZGVnKTtcbiAgcGFkZGluZzogJHtzcGFjaW5nLnhzbWFsbH07XG4gIGRpc3BsYXk6IGZsZXg7XG4gIG1hcmdpbjogMDtcbiAgY29sb3I6ICR7Y29sb3JzLmJyYW5kLnNlY29uZGFyeX07XG4gIGN1cnNvcjogcG9pbnRlcjtcbiAgJjpob3ZlciB7XG4gICAgY29sb3I6ICR7Y29sb3JzLmJyYW5kLnByaW1hcnl9O1xuICB9XG4gIHN2ZyB7XG4gICAgd2lkdGg6IDE2cHg7XG4gICAgaGVpZ2h0OiAxNnB4O1xuICAgIHRyYW5zZm9ybTogJHsoeyBpc09wZW4gfSkgPT4gKGlzT3BlbiA/ICd0cmFuc2xhdGVYKDNweCknIDogJ3RyYW5zbGF0ZVkoM3B4KScpfTtcbiAgfVxuYDtcblxuY29uc3QgRm9sZGVySXRlbVdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuYDtcblxuY29uc3QgV3JhcHBlckZvckZvbGRlckNoaWxkID0gc3R5bGVkLmRpdjx7IHNlbGVjdGVkPzogYm9vbGVhbiB9PmBcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICByaWdodDogJHtzcGFjaW5nLnhzbWFsbH07XG4gIG9wYWNpdHk6ICR7KHsgc2VsZWN0ZWQgfSkgPT4gKHNlbGVjdGVkID8gMSA6IDAuMjUpfTtcbiAgJjpob3ZlcixcbiAgJjpmb2N1cyxcbiAgJjpmb2N1cy13aXRoaW4ge1xuICAgIG9wYWNpdHk6IDE7XG4gIH1cbmA7XG5cbmNvbnN0IHNob3VsZEZvcndhcmRQcm9wID0gKG5hbWU6IHN0cmluZykgPT4gIVsnc2VsZWN0ZWQnLCAnbm9BcnJvdyddLmluY2x1ZGVzKG5hbWUpO1xuXG5pbnRlcmZhY2UgRm9sZGVyTmFtZVByb3BzIHtcbiAgc2VsZWN0ZWQ/OiBib29sZWFuO1xuICBub0Fycm93PzogYm9vbGVhbjtcbn1cblxuY29uc3QgRm9sZGVyTmFtZSA9IHN0eWxlZCgnYnV0dG9uJywgeyBzaG91bGRGb3J3YXJkUHJvcCB9KTxGb2xkZXJOYW1lUHJvcHM+YFxuICBsaW5lLWhlaWdodDogMTtcbiAgYmFja2dyb3VuZDogJHsoeyBzZWxlY3RlZCB9KSA9PiAoc2VsZWN0ZWQgPyBjb2xvcnMuYnJhbmQubGlnaHRlciA6ICd0cmFuc3BhcmVudCcpfTtcbiAgY29sb3I6ICR7Y29sb3JzLnRleHQucHJpbWFyeX07XG4gICY6aG92ZXIsXG4gICY6Zm9jdXMge1xuICAgIGJhY2tncm91bmQ6ICR7KHsgc2VsZWN0ZWQgfSkgPT4gKHNlbGVjdGVkID8gY29sb3JzLmJyYW5kLmxpZ2h0IDogY29sb3JzLmJyYW5kLmxpZ2h0ZXN0KX07XG4gICAgY29sb3I6ICR7Y29sb3JzLmJyYW5kLnByaW1hcnl9O1xuICAgICsgJHtXcmFwcGVyRm9yRm9sZGVyQ2hpbGR9IHtcbiAgICAgIG9wYWNpdHk6IDE7XG4gICAgfVxuICB9XG4gIHRyYW5zaXRpb246ICR7YW5pbWF0aW9ucy5kdXJhdGlvbnMuc3VwZXJGYXN0fTtcbiAgYm9yZGVyOiAwO1xuICBib3JkZXItcmFkaXVzOiAke21pc2MuYm9yZGVyUmFkaXVzfTtcbiAgZGlzcGxheTogZmxleDtcbiAgZ2FwOiAke3NwYWNpbmcueHhzbWFsbH07XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGN1cnNvcjogcG9pbnRlcjtcbiAgcGFkZGluZzogJHtzcGFjaW5nLnhzbWFsbH07XG4gIG1hcmdpbjogMDtcbiAgbWFyZ2luLWxlZnQ6ICR7KHsgbm9BcnJvdyB9KSA9PiAobm9BcnJvdyA/IGAyOXB4YCA6IGAwcHhgKX07XG4gIGZsZXgtZ3JvdzogMTtcbiAgYm94LXNoYWRvdzogbm9uZTtcbiAgdGV4dC1hbGlnbjogbGVmdDtcbmA7XG5cbmNvbnN0IEZvbGRlck5hbWVMaW5rID0gRm9sZGVyTmFtZS53aXRoQ29tcG9uZW50KFNhZmVMaW5rKTtcblxuaW50ZXJmYWNlIFByb3BzIGV4dGVuZHMgQ29tbW9uRm9sZGVySXRlbXNQcm9wcyB7XG4gIGhpZGVBcnJvdz86IGJvb2xlYW47XG4gIGlzT3BlbjogYm9vbGVhbjtcbiAgZm9sZGVyOiBGb2xkZXJUeXBlO1xuICBub1BhZGRpbmdXaGVuQXJyb3dJc0hpZGRlbj86IGJvb2xlYW47XG59XG5cbmNvbnN0IEZvbGRlckl0ZW0gPSAoe1xuICBmb2N1c2VkRm9sZGVySWQsXG4gIG1lbnVJdGVtcyxcbiAgaGlkZUFycm93LFxuICBmb2xkZXIsXG4gIGlzT3BlbixcbiAgbGV2ZWwsXG4gIGxvYWRpbmcsXG4gIHNlbGVjdGVkRm9sZGVyLFxuICBub1BhZGRpbmdXaGVuQXJyb3dJc0hpZGRlbixcbiAgb25DbG9zZUZvbGRlcixcbiAgb25PcGVuRm9sZGVyLFxuICBvblNlbGVjdEZvbGRlcixcbiAgb3Blbk9uRm9sZGVyQ2xpY2ssXG4gIHNldEZvY3VzZWRJZCxcbiAgc2V0U2VsZWN0ZWRGb2xkZXIsXG4gIHZpc2libGVGb2xkZXJzLFxufTogUHJvcHMpID0+IHtcbiAgY29uc3QgeyBpZCwgaWNvbiwgbmFtZSB9ID0gZm9sZGVyO1xuICBjb25zdCByZWYgPSB1c2VSZWY8SFRNTEJ1dHRvbkVsZW1lbnQgJiBIVE1MQW5jaG9yRWxlbWVudD4obnVsbCk7XG4gIGNvbnN0IHNlbGVjdGVkID0gc2VsZWN0ZWRGb2xkZXIgJiYgc2VsZWN0ZWRGb2xkZXIuaWQgPT09IGlkO1xuICBjb25zdCBmb2N1c2VkID0gZm9jdXNlZEZvbGRlcklkID09PSBpZDtcblxuICBjb25zdCBoYW5kbGVDbGlja0ZvbGRlciA9ICgpID0+IHtcbiAgICBzZXRTZWxlY3RlZEZvbGRlcihmb2xkZXIpO1xuICAgIHNldEZvY3VzZWRJZChpZCk7XG4gICAgb25TZWxlY3RGb2xkZXI/LihpZCk7XG4gICAgaWYgKG9wZW5PbkZvbGRlckNsaWNrKSB7XG4gICAgICBpZiAoaXNPcGVuKSB7XG4gICAgICAgIG9uQ2xvc2VGb2xkZXIoaWQpO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgb25PcGVuRm9sZGVyKGlkKTtcbiAgICAgIH1cbiAgICB9XG4gIH07XG5cbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBpZiAoZm9jdXNlZEZvbGRlcklkID09PSBpZCkge1xuICAgICAgcmVmLmN1cnJlbnQ/LmZvY3VzKCk7XG4gICAgfVxuICB9LCBbZm9jdXNlZEZvbGRlcklkLCByZWYsIGlkXSk7XG5cbiAgY29uc3QgYWN0aW9ucyA9IG1lbnVJdGVtcz8ubWFwKChpdGVtKSA9PiB7XG4gICAgY29uc3QgeyBvbkNsaWNrIH0gPSBpdGVtO1xuICAgIHJldHVybiB7XG4gICAgICAuLi5pdGVtLFxuICAgICAgb25DbGljazogKGU/OiBNb3VzZUV2ZW50PEhUTUxEaXZFbGVtZW50PikgPT4gb25DbGljayhlLCBmb2xkZXIpLFxuICAgIH07XG4gIH0pO1xuXG4gIGNvbnN0IGxpbmtQYXRoID0gYC9taW5uZGxhJHtsZXZlbCA+IDEgPyAnL2ZvbGRlcnMnIDogJyd9LyR7aWR9YDtcblxuICByZXR1cm4gKFxuICAgIDxGb2xkZXJJdGVtV3JhcHBlcj5cbiAgICAgIHshaGlkZUFycm93ICYmIChcbiAgICAgICAgPE9wZW5CdXR0b25cbiAgICAgICAgICB0YWJJbmRleD17LTF9XG4gICAgICAgICAgaXNPcGVuPXtpc09wZW59XG4gICAgICAgICAgZGlzYWJsZWQ9e2xvYWRpbmd9XG4gICAgICAgICAgb25DbGljaz17KCkgPT4gKGlzT3BlbiA/IG9uQ2xvc2VGb2xkZXIoaWQpIDogb25PcGVuRm9sZGVyKGlkKSl9PlxuICAgICAgICAgIDxBcnJvd0Ryb3BEb3duIC8+XG4gICAgICAgIDwvT3BlbkJ1dHRvbj5cbiAgICAgICl9XG4gICAgICB7b25TZWxlY3RGb2xkZXIgPyAoXG4gICAgICAgIDw+XG4gICAgICAgICAgPEZvbGRlck5hbWVcbiAgICAgICAgICAgIHJlZj17cmVmfVxuICAgICAgICAgICAgb25LZXlEb3duPXsoZSkgPT4gYXJyb3dOYXZpZ2F0aW9uKGUsIGlkLCB2aXNpYmxlRm9sZGVycywgc2V0Rm9jdXNlZElkLCBvbk9wZW5Gb2xkZXIsIG9uQ2xvc2VGb2xkZXIpfVxuICAgICAgICAgICAgbm9BcnJvdz17aGlkZUFycm93ICYmICFub1BhZGRpbmdXaGVuQXJyb3dJc0hpZGRlbn1cbiAgICAgICAgICAgIHRhYkluZGV4PXtzZWxlY3RlZCB8fCBmb2N1c2VkID8gMCA6IC0xfVxuICAgICAgICAgICAgc2VsZWN0ZWQ9e3NlbGVjdGVkfVxuICAgICAgICAgICAgZGlzYWJsZWQ9e2xvYWRpbmd9XG4gICAgICAgICAgICBvbkZvY3VzPXsoKSA9PiBzZXRGb2N1c2VkSWQoaWQpfVxuICAgICAgICAgICAgb25DbGljaz17aGFuZGxlQ2xpY2tGb2xkZXJ9PlxuICAgICAgICAgICAge2ljb24gfHwgPEZvbGRlck91dGxpbmVkIC8+fVxuICAgICAgICAgICAge25hbWV9XG4gICAgICAgICAgPC9Gb2xkZXJOYW1lPlxuICAgICAgICAgIHthY3Rpb25zICYmIChcbiAgICAgICAgICAgIDxXcmFwcGVyRm9yRm9sZGVyQ2hpbGQgc2VsZWN0ZWQ9e3NlbGVjdGVkfT5cbiAgICAgICAgICAgICAgPE1lbnVCdXR0b24gc2l6ZT1cInhzbWFsbFwiIG1lbnVJdGVtcz17YWN0aW9uc30gdGFiSW5kZXg9e3NlbGVjdGVkIHx8IGlkID09PSBmb2N1c2VkRm9sZGVySWQgPyAwIDogLTF9IC8+XG4gICAgICAgICAgICA8L1dyYXBwZXJGb3JGb2xkZXJDaGlsZD5cbiAgICAgICAgICApfVxuICAgICAgICA8Lz5cbiAgICAgICkgOiAoXG4gICAgICAgIDxGb2xkZXJOYW1lTGlua1xuICAgICAgICAgIHJlZj17cmVmfVxuICAgICAgICAgIG9uS2V5RG93bj17KGU6IEtleWJvYXJkRXZlbnQ8SFRNTEVsZW1lbnQ+KSA9PlxuICAgICAgICAgICAgYXJyb3dOYXZpZ2F0aW9uKGUsIGlkLCB2aXNpYmxlRm9sZGVycywgc2V0Rm9jdXNlZElkLCBvbk9wZW5Gb2xkZXIsIG9uQ2xvc2VGb2xkZXIpXG4gICAgICAgICAgfVxuICAgICAgICAgIG5vQXJyb3c9e2hpZGVBcnJvd31cbiAgICAgICAgICB0bz17bG9hZGluZyA/ICcnIDogbGlua1BhdGh9XG4gICAgICAgICAgdGFiSW5kZXg9e3NlbGVjdGVkIHx8IGZvY3VzZWQgfHwgbGV2ZWwgPT09IDEgPyAwIDogLTF9XG4gICAgICAgICAgc2VsZWN0ZWQ9e3NlbGVjdGVkfVxuICAgICAgICAgIG9uRm9jdXM9eygpID0+IHNldEZvY3VzZWRJZChpZCl9XG4gICAgICAgICAgb25DbGljaz17aGFuZGxlQ2xpY2tGb2xkZXJ9PlxuICAgICAgICAgIHtpY29uIHx8IDxGb2xkZXJPdXRsaW5lZCAvPn1cbiAgICAgICAgICB7bmFtZX1cbiAgICAgICAgPC9Gb2xkZXJOYW1lTGluaz5cbiAgICAgICl9XG4gICAgPC9Gb2xkZXJJdGVtV3JhcHBlcj5cbiAgKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IEZvbGRlckl0ZW07XG4iXX0= */"));
|
|
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"]} */"));
|
|
71
72
|
|
|
72
73
|
var shouldForwardProp = function shouldForwardProp(name) {
|
|
73
74
|
return !['selected', 'noArrow'].includes(name);
|
|
@@ -77,38 +78,47 @@ var FolderName = ( /*#__PURE__*/0, _styledBase["default"])('button', {
|
|
|
77
78
|
shouldForwardProp: shouldForwardProp,
|
|
78
79
|
target: "e11ok6h83",
|
|
79
80
|
label: "FolderName"
|
|
80
|
-
})("
|
|
81
|
+
})("cursor:pointer;padding:", _core.spacing.xsmall, ";margin:0;margin-left:", function (_ref3) {
|
|
82
|
+
var noArrow = _ref3.noArrow;
|
|
83
|
+
return noArrow ? "29px" : "0px";
|
|
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) {
|
|
81
85
|
var selected = _ref4.selected;
|
|
82
86
|
return selected ? _core.colors.brand.lighter : 'transparent';
|
|
83
|
-
}, ";color:", _core.colors.text.primary, ";&:hover,&:focus{background:", function (_ref5) {
|
|
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) {
|
|
84
88
|
var selected = _ref5.selected;
|
|
85
89
|
return selected ? _core.colors.brand.light : _core.colors.brand.lightest;
|
|
86
|
-
}, ";color:", _core.colors.brand.primary, ";+ ", WrapperForFolderChild, "{opacity:1;}}
|
|
87
|
-
|
|
88
|
-
return noArrow ? "29px" : "0px";
|
|
89
|
-
}, ";flex-grow:1;box-shadow:none;text-align:left;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZvbGRlckl0ZW0udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTREMkUiLCJmaWxlIjoiRm9sZGVySXRlbS50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMi1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCwgeyBLZXlib2FyZEV2ZW50LCBNb3VzZUV2ZW50LCB1c2VFZmZlY3QsIHVzZVJlZiB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IEFycm93RHJvcERvd24gfSBmcm9tICdAbmRsYS9pY29ucy9jb21tb24nO1xuaW1wb3J0IHsgTWVudUJ1dHRvbiB9IGZyb20gJ0BuZGxhL2J1dHRvbic7XG5pbXBvcnQgeyBGb2xkZXJPdXRsaW5lZCB9IGZyb20gJ0BuZGxhL2ljb25zL2NvbnRlbnRUeXBlJztcbmltcG9ydCB7IGNvbG9ycywgc3BhY2luZywgbWlzYywgYW5pbWF0aW9ucyB9IGZyb20gJ0BuZGxhL2NvcmUnO1xuaW1wb3J0IFNhZmVMaW5rIGZyb20gJ0BuZGxhL3NhZmVsaW5rJztcbmltcG9ydCB7IENvbW1vbkZvbGRlckl0ZW1zUHJvcHMsIEZvbGRlclR5cGUgfSBmcm9tICcuL3R5cGVzJztcbmltcG9ydCB7IGFycm93TmF2aWdhdGlvbiB9IGZyb20gJy4vYXJyb3dOYXZpZ2F0aW9uJztcblxuY29uc3QgT3BlbkJ1dHRvbiA9IHN0eWxlZC5idXR0b248eyBpc09wZW46IGJvb2xlYW4gfT5gXG4gIGJhY2tncm91bmQ6IHRyYW5zcGFyZW50O1xuICBib3JkZXI6IDA7XG4gIHRyYW5zZm9ybTogcm90YXRlKCR7KHsgaXNPcGVuIH0pID0+IChpc09wZW4gPyAnMCcgOiAnLTkwJyl9ZGVnKTtcbiAgcGFkZGluZzogJHtzcGFjaW5nLnhzbWFsbH07XG4gIGRpc3BsYXk6IGZsZXg7XG4gIG1hcmdpbjogMDtcbiAgY29sb3I6ICR7Y29sb3JzLmJyYW5kLnNlY29uZGFyeX07XG4gIGN1cnNvcjogcG9pbnRlcjtcbiAgJjpob3ZlciB7XG4gICAgY29sb3I6ICR7Y29sb3JzLmJyYW5kLnByaW1hcnl9O1xuICB9XG4gIHN2ZyB7XG4gICAgd2lkdGg6IDE2cHg7XG4gICAgaGVpZ2h0OiAxNnB4O1xuICAgIHRyYW5zZm9ybTogJHsoeyBpc09wZW4gfSkgPT4gKGlzT3BlbiA/ICd0cmFuc2xhdGVYKDNweCknIDogJ3RyYW5zbGF0ZVkoM3B4KScpfTtcbiAgfVxuYDtcblxuY29uc3QgRm9sZGVySXRlbVdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuYDtcblxuY29uc3QgV3JhcHBlckZvckZvbGRlckNoaWxkID0gc3R5bGVkLmRpdjx7IHNlbGVjdGVkPzogYm9vbGVhbiB9PmBcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICByaWdodDogJHtzcGFjaW5nLnhzbWFsbH07XG4gIG9wYWNpdHk6ICR7KHsgc2VsZWN0ZWQgfSkgPT4gKHNlbGVjdGVkID8gMSA6IDAuMjUpfTtcbiAgJjpob3ZlcixcbiAgJjpmb2N1cyxcbiAgJjpmb2N1cy13aXRoaW4ge1xuICAgIG9wYWNpdHk6IDE7XG4gIH1cbmA7XG5cbmNvbnN0IHNob3VsZEZvcndhcmRQcm9wID0gKG5hbWU6IHN0cmluZykgPT4gIVsnc2VsZWN0ZWQnLCAnbm9BcnJvdyddLmluY2x1ZGVzKG5hbWUpO1xuXG5pbnRlcmZhY2UgRm9sZGVyTmFtZVByb3BzIHtcbiAgc2VsZWN0ZWQ/OiBib29sZWFuO1xuICBub0Fycm93PzogYm9vbGVhbjtcbn1cblxuY29uc3QgRm9sZGVyTmFtZSA9IHN0eWxlZCgnYnV0dG9uJywgeyBzaG91bGRGb3J3YXJkUHJvcCB9KTxGb2xkZXJOYW1lUHJvcHM+YFxuICBsaW5lLWhlaWdodDogMTtcbiAgYmFja2dyb3VuZDogJHsoeyBzZWxlY3RlZCB9KSA9PiAoc2VsZWN0ZWQgPyBjb2xvcnMuYnJhbmQubGlnaHRlciA6ICd0cmFuc3BhcmVudCcpfTtcbiAgY29sb3I6ICR7Y29sb3JzLnRleHQucHJpbWFyeX07XG4gICY6aG92ZXIsXG4gICY6Zm9jdXMge1xuICAgIGJhY2tncm91bmQ6ICR7KHsgc2VsZWN0ZWQgfSkgPT4gKHNlbGVjdGVkID8gY29sb3JzLmJyYW5kLmxpZ2h0IDogY29sb3JzLmJyYW5kLmxpZ2h0ZXN0KX07XG4gICAgY29sb3I6ICR7Y29sb3JzLmJyYW5kLnByaW1hcnl9O1xuICAgICsgJHtXcmFwcGVyRm9yRm9sZGVyQ2hpbGR9IHtcbiAgICAgIG9wYWNpdHk6IDE7XG4gICAgfVxuICB9XG4gIHRyYW5zaXRpb246ICR7YW5pbWF0aW9ucy5kdXJhdGlvbnMuc3VwZXJGYXN0fTtcbiAgYm9yZGVyOiAwO1xuICBib3JkZXItcmFkaXVzOiAke21pc2MuYm9yZGVyUmFkaXVzfTtcbiAgZGlzcGxheTogZmxleDtcbiAgZ2FwOiAke3NwYWNpbmcueHhzbWFsbH07XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGN1cnNvcjogcG9pbnRlcjtcbiAgcGFkZGluZzogJHtzcGFjaW5nLnhzbWFsbH07XG4gIG1hcmdpbjogMDtcbiAgbWFyZ2luLWxlZnQ6ICR7KHsgbm9BcnJvdyB9KSA9PiAobm9BcnJvdyA/IGAyOXB4YCA6IGAwcHhgKX07XG4gIGZsZXgtZ3JvdzogMTtcbiAgYm94LXNoYWRvdzogbm9uZTtcbiAgdGV4dC1hbGlnbjogbGVmdDtcbmA7XG5cbmNvbnN0IEZvbGRlck5hbWVMaW5rID0gRm9sZGVyTmFtZS53aXRoQ29tcG9uZW50KFNhZmVMaW5rKTtcblxuaW50ZXJmYWNlIFByb3BzIGV4dGVuZHMgQ29tbW9uRm9sZGVySXRlbXNQcm9wcyB7XG4gIGhpZGVBcnJvdz86IGJvb2xlYW47XG4gIGlzT3BlbjogYm9vbGVhbjtcbiAgZm9sZGVyOiBGb2xkZXJUeXBlO1xuICBub1BhZGRpbmdXaGVuQXJyb3dJc0hpZGRlbj86IGJvb2xlYW47XG59XG5cbmNvbnN0IEZvbGRlckl0ZW0gPSAoe1xuICBmb2N1c2VkRm9sZGVySWQsXG4gIG1lbnVJdGVtcyxcbiAgaGlkZUFycm93LFxuICBmb2xkZXIsXG4gIGlzT3BlbixcbiAgbGV2ZWwsXG4gIGxvYWRpbmcsXG4gIHNlbGVjdGVkRm9sZGVyLFxuICBub1BhZGRpbmdXaGVuQXJyb3dJc0hpZGRlbixcbiAgb25DbG9zZUZvbGRlcixcbiAgb25PcGVuRm9sZGVyLFxuICBvblNlbGVjdEZvbGRlcixcbiAgb3Blbk9uRm9sZGVyQ2xpY2ssXG4gIHNldEZvY3VzZWRJZCxcbiAgc2V0U2VsZWN0ZWRGb2xkZXIsXG4gIHZpc2libGVGb2xkZXJzLFxufTogUHJvcHMpID0+IHtcbiAgY29uc3QgeyBpZCwgaWNvbiwgbmFtZSB9ID0gZm9sZGVyO1xuICBjb25zdCByZWYgPSB1c2VSZWY8SFRNTEJ1dHRvbkVsZW1lbnQgJiBIVE1MQW5jaG9yRWxlbWVudD4obnVsbCk7XG4gIGNvbnN0IHNlbGVjdGVkID0gc2VsZWN0ZWRGb2xkZXIgJiYgc2VsZWN0ZWRGb2xkZXIuaWQgPT09IGlkO1xuICBjb25zdCBmb2N1c2VkID0gZm9jdXNlZEZvbGRlcklkID09PSBpZDtcblxuICBjb25zdCBoYW5kbGVDbGlja0ZvbGRlciA9ICgpID0+IHtcbiAgICBzZXRTZWxlY3RlZEZvbGRlcihmb2xkZXIpO1xuICAgIHNldEZvY3VzZWRJZChpZCk7XG4gICAgb25TZWxlY3RGb2xkZXI/LihpZCk7XG4gICAgaWYgKG9wZW5PbkZvbGRlckNsaWNrKSB7XG4gICAgICBpZiAoaXNPcGVuKSB7XG4gICAgICAgIG9uQ2xvc2VGb2xkZXIoaWQpO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgb25PcGVuRm9sZGVyKGlkKTtcbiAgICAgIH1cbiAgICB9XG4gIH07XG5cbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBpZiAoZm9jdXNlZEZvbGRlcklkID09PSBpZCkge1xuICAgICAgcmVmLmN1cnJlbnQ/LmZvY3VzKCk7XG4gICAgfVxuICB9LCBbZm9jdXNlZEZvbGRlcklkLCByZWYsIGlkXSk7XG5cbiAgY29uc3QgYWN0aW9ucyA9IG1lbnVJdGVtcz8ubWFwKChpdGVtKSA9PiB7XG4gICAgY29uc3QgeyBvbkNsaWNrIH0gPSBpdGVtO1xuICAgIHJldHVybiB7XG4gICAgICAuLi5pdGVtLFxuICAgICAgb25DbGljazogKGU/OiBNb3VzZUV2ZW50PEhUTUxEaXZFbGVtZW50PikgPT4gb25DbGljayhlLCBmb2xkZXIpLFxuICAgIH07XG4gIH0pO1xuXG4gIGNvbnN0IGxpbmtQYXRoID0gYC9taW5uZGxhJHtsZXZlbCA+IDEgPyAnL2ZvbGRlcnMnIDogJyd9LyR7aWR9YDtcblxuICByZXR1cm4gKFxuICAgIDxGb2xkZXJJdGVtV3JhcHBlcj5cbiAgICAgIHshaGlkZUFycm93ICYmIChcbiAgICAgICAgPE9wZW5CdXR0b25cbiAgICAgICAgICB0YWJJbmRleD17LTF9XG4gICAgICAgICAgaXNPcGVuPXtpc09wZW59XG4gICAgICAgICAgZGlzYWJsZWQ9e2xvYWRpbmd9XG4gICAgICAgICAgb25DbGljaz17KCkgPT4gKGlzT3BlbiA/IG9uQ2xvc2VGb2xkZXIoaWQpIDogb25PcGVuRm9sZGVyKGlkKSl9PlxuICAgICAgICAgIDxBcnJvd0Ryb3BEb3duIC8+XG4gICAgICAgIDwvT3BlbkJ1dHRvbj5cbiAgICAgICl9XG4gICAgICB7b25TZWxlY3RGb2xkZXIgPyAoXG4gICAgICAgIDw+XG4gICAgICAgICAgPEZvbGRlck5hbWVcbiAgICAgICAgICAgIHJlZj17cmVmfVxuICAgICAgICAgICAgb25LZXlEb3duPXsoZSkgPT4gYXJyb3dOYXZpZ2F0aW9uKGUsIGlkLCB2aXNpYmxlRm9sZGVycywgc2V0Rm9jdXNlZElkLCBvbk9wZW5Gb2xkZXIsIG9uQ2xvc2VGb2xkZXIpfVxuICAgICAgICAgICAgbm9BcnJvdz17aGlkZUFycm93ICYmICFub1BhZGRpbmdXaGVuQXJyb3dJc0hpZGRlbn1cbiAgICAgICAgICAgIHRhYkluZGV4PXtzZWxlY3RlZCB8fCBmb2N1c2VkID8gMCA6IC0xfVxuICAgICAgICAgICAgc2VsZWN0ZWQ9e3NlbGVjdGVkfVxuICAgICAgICAgICAgZGlzYWJsZWQ9e2xvYWRpbmd9XG4gICAgICAgICAgICBvbkZvY3VzPXsoKSA9PiBzZXRGb2N1c2VkSWQoaWQpfVxuICAgICAgICAgICAgb25DbGljaz17aGFuZGxlQ2xpY2tGb2xkZXJ9PlxuICAgICAgICAgICAge2ljb24gfHwgPEZvbGRlck91dGxpbmVkIC8+fVxuICAgICAgICAgICAge25hbWV9XG4gICAgICAgICAgPC9Gb2xkZXJOYW1lPlxuICAgICAgICAgIHthY3Rpb25zICYmIChcbiAgICAgICAgICAgIDxXcmFwcGVyRm9yRm9sZGVyQ2hpbGQgc2VsZWN0ZWQ9e3NlbGVjdGVkfT5cbiAgICAgICAgICAgICAgPE1lbnVCdXR0b24gc2l6ZT1cInhzbWFsbFwiIG1lbnVJdGVtcz17YWN0aW9uc30gdGFiSW5kZXg9e3NlbGVjdGVkIHx8IGlkID09PSBmb2N1c2VkRm9sZGVySWQgPyAwIDogLTF9IC8+XG4gICAgICAgICAgICA8L1dyYXBwZXJGb3JGb2xkZXJDaGlsZD5cbiAgICAgICAgICApfVxuICAgICAgICA8Lz5cbiAgICAgICkgOiAoXG4gICAgICAgIDxGb2xkZXJOYW1lTGlua1xuICAgICAgICAgIHJlZj17cmVmfVxuICAgICAgICAgIG9uS2V5RG93bj17KGU6IEtleWJvYXJkRXZlbnQ8SFRNTEVsZW1lbnQ+KSA9PlxuICAgICAgICAgICAgYXJyb3dOYXZpZ2F0aW9uKGUsIGlkLCB2aXNpYmxlRm9sZGVycywgc2V0Rm9jdXNlZElkLCBvbk9wZW5Gb2xkZXIsIG9uQ2xvc2VGb2xkZXIpXG4gICAgICAgICAgfVxuICAgICAgICAgIG5vQXJyb3c9e2hpZGVBcnJvd31cbiAgICAgICAgICB0bz17bG9hZGluZyA/ICcnIDogbGlua1BhdGh9XG4gICAgICAgICAgdGFiSW5kZXg9e3NlbGVjdGVkIHx8IGZvY3VzZWQgfHwgbGV2ZWwgPT09IDEgPyAwIDogLTF9XG4gICAgICAgICAgc2VsZWN0ZWQ9e3NlbGVjdGVkfVxuICAgICAgICAgIG9uRm9jdXM9eygpID0+IHNldEZvY3VzZWRJZChpZCl9XG4gICAgICAgICAgb25DbGljaz17aGFuZGxlQ2xpY2tGb2xkZXJ9PlxuICAgICAgICAgIHtpY29uIHx8IDxGb2xkZXJPdXRsaW5lZCAvPn1cbiAgICAgICAgICB7bmFtZX1cbiAgICAgICAgPC9Gb2xkZXJOYW1lTGluaz5cbiAgICAgICl9XG4gICAgPC9Gb2xkZXJJdGVtV3JhcHBlcj5cbiAgKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IEZvbGRlckl0ZW07XG4iXX0= */"));
|
|
90
|
-
var FolderNameLink = FolderName.withComponent(_safelink["default"], {
|
|
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, {
|
|
91
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",
|
|
92
97
|
label: "FolderNameLink"
|
|
93
98
|
});
|
|
94
99
|
|
|
95
|
-
var FolderItem = function FolderItem(
|
|
96
|
-
var focusedFolderId =
|
|
97
|
-
menuItems =
|
|
98
|
-
hideArrow =
|
|
99
|
-
folder =
|
|
100
|
-
isOpen =
|
|
101
|
-
level =
|
|
102
|
-
loading =
|
|
103
|
-
selectedFolder =
|
|
104
|
-
noPaddingWhenArrowIsHidden =
|
|
105
|
-
onCloseFolder =
|
|
106
|
-
onOpenFolder =
|
|
107
|
-
onSelectFolder =
|
|
108
|
-
openOnFolderClick =
|
|
109
|
-
setFocusedId =
|
|
110
|
-
setSelectedFolder =
|
|
111
|
-
|
|
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
|
+
|
|
112
122
|
var id = folder.id,
|
|
113
123
|
icon = folder.icon,
|
|
114
124
|
name = folder.name;
|
|
@@ -117,17 +127,22 @@ var FolderItem = function FolderItem(_ref7) {
|
|
|
117
127
|
var focused = focusedFolderId === id;
|
|
118
128
|
|
|
119
129
|
var handleClickFolder = function handleClickFolder() {
|
|
120
|
-
setSelectedFolder(folder);
|
|
121
|
-
setFocusedId(id);
|
|
122
|
-
onSelectFolder === null || onSelectFolder === void 0 ? void 0 : onSelectFolder(id);
|
|
123
|
-
|
|
124
130
|
if (openOnFolderClick) {
|
|
125
|
-
if (
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
131
|
+
if (selected) {
|
|
132
|
+
if (isOpen) {
|
|
133
|
+
onCloseFolder(id);
|
|
134
|
+
} else {
|
|
135
|
+
onOpenFolder(id);
|
|
136
|
+
}
|
|
129
137
|
}
|
|
130
138
|
}
|
|
139
|
+
|
|
140
|
+
if (!selected) {
|
|
141
|
+
setSelectedFolder(folder);
|
|
142
|
+
setFocusedId(id);
|
|
143
|
+
}
|
|
144
|
+
|
|
145
|
+
onSelectFolder === null || onSelectFolder === void 0 ? void 0 : onSelectFolder(id);
|
|
131
146
|
};
|
|
132
147
|
|
|
133
148
|
(0, _react.useEffect)(function () {
|
|
@@ -145,7 +160,10 @@ var FolderItem = function FolderItem(_ref7) {
|
|
|
145
160
|
}
|
|
146
161
|
});
|
|
147
162
|
});
|
|
148
|
-
var linkPath = "/minndla".concat(level >
|
|
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
|
+
});
|
|
149
167
|
return (0, _core2.jsx)(FolderItemWrapper, null, !hideArrow && (0, _core2.jsx)(OpenButton, {
|
|
150
168
|
tabIndex: -1,
|
|
151
169
|
isOpen: isOpen,
|
|
@@ -166,20 +184,23 @@ var FolderItem = function FolderItem(_ref7) {
|
|
|
166
184
|
return setFocusedId(id);
|
|
167
185
|
},
|
|
168
186
|
onClick: handleClickFolder
|
|
169
|
-
}, icon || (0, _core2.jsx)(_contentType.FolderOutlined, null), name),
|
|
170
|
-
|
|
171
|
-
}, (0, _core2.jsx)(_button.MenuButton, {
|
|
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
|
+
},
|
|
172
193
|
size: "xsmall",
|
|
173
194
|
menuItems: actions,
|
|
174
195
|
tabIndex: selected || id === focusedFolderId ? 0 : -1
|
|
175
|
-
}))) : (0, _core2.jsx)(FolderNameLink, {
|
|
196
|
+
})))) : (0, _core2.jsx)(FolderNameLink, {
|
|
176
197
|
ref: ref,
|
|
177
198
|
onKeyDown: function onKeyDown(e) {
|
|
178
199
|
return (0, _arrowNavigation.arrowNavigation)(e, id, visibleFolders, setFocusedId, onOpenFolder, onCloseFolder);
|
|
179
200
|
},
|
|
180
201
|
noArrow: hideArrow,
|
|
181
202
|
to: loading ? '' : linkPath,
|
|
182
|
-
tabIndex: selected || focused || level ===
|
|
203
|
+
tabIndex: selected || focused || level === 0 ? 0 : -1,
|
|
183
204
|
selected: selected,
|
|
184
205
|
onFocus: function onFocus() {
|
|
185
206
|
return setFocusedId(id);
|
|
@@ -33,7 +33,7 @@ var StyledUL = (0, _styledBase["default"])("ul", {
|
|
|
33
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) {
|
|
34
34
|
var firstLevel = _ref.firstLevel;
|
|
35
35
|
return firstLevel ? "-".concat(_core.spacing.xsmall) : _core.spacing.normal;
|
|
36
|
-
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZvbGRlckl0ZW1zLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFlb0QiLCJmaWxlIjoiRm9sZGVySXRlbXMudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjItcHJlc2VudCwgTkRMQS5cbiAqXG4gKiBUaGlzIHNvdXJjZSBjb2RlIGlzIGxpY2Vuc2VkIHVuZGVyIHRoZSBHUEx2MyBsaWNlbnNlIGZvdW5kIGluIHRoZVxuICogTElDRU5TRSBmaWxlIGluIHRoZSByb290IGRpcmVjdG9yeSBvZiB0aGlzIHNvdXJjZSB0cmVlLlxuICpcbiAqL1xuXG5pbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgYW5pbWF0aW9ucywgc3BhY2luZyB9IGZyb20gJ0BuZGxhL2NvcmUnO1xuaW1wb3J0IEZvbGRlckl0ZW0gZnJvbSAnLi9Gb2xkZXJJdGVtJztcbmltcG9ydCBGb2xkZXJOYW1lSW5wdXQgZnJvbSAnLi9Gb2xkZXJOYW1lSW5wdXQnO1xuaW1wb3J0IHsgQ29tbW9uRm9sZGVySXRlbXNQcm9wcywgRm9sZGVyVHlwZSB9IGZyb20gJy4vdHlwZXMnO1xuXG5jb25zdCBTdHlsZWRVTCA9IHN0eWxlZC51bDx7IGZpcnN0TGV2ZWw/OiBib29sZWFuIH0+YFxuICAke2FuaW1hdGlvbnMuZmFkZUluTGVmdChhbmltYXRpb25zLmR1cmF0aW9ucy5mYXN0KX07XG4gIGFuaW1hdGlvbi1maWxsLW1vZGU6IGZvcndhcmRzO1xuICBAbWVkaWEgKHByZWZlcnMtcmVkdWNlZC1tb3Rpb246IHJlZHVjZSkge1xuICAgIGFuaW1hdGlvbjogbm9uZTtcbiAgfVxuICBsaXN0LXN0eWxlOiBub25lO1xuICBtYXJnaW46IDA7XG4gIHBhZGRpbmc6IDA7XG4gIG1hcmdpbi1sZWZ0OiAkeyh7IGZpcnN0TGV2ZWwgfSkgPT4gKGZpcnN0TGV2ZWwgPyBgLSR7c3BhY2luZy54c21hbGx9YCA6IHNwYWNpbmcubm9ybWFsKX07XG5gO1xuXG5jb25zdCBTdHlsZWRMSSA9IHN0eWxlZC5saWBcbiAgbWFyZ2luOiAwO1xuICBwYWRkaW5nOiAwO1xuYDtcblxuZXhwb3J0IGludGVyZmFjZSBGb2xkZXJJdGVtc1Byb3BzIGV4dGVuZHMgQ29tbW9uRm9sZGVySXRlbXNQcm9wcyB7XG4gIGZvbGRlcnM6IEZvbGRlclR5cGVbXTtcbiAgZWRpdGFibGU/
|
|
36
|
+
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZvbGRlckl0ZW1zLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFlb0QiLCJmaWxlIjoiRm9sZGVySXRlbXMudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjItcHJlc2VudCwgTkRMQS5cbiAqXG4gKiBUaGlzIHNvdXJjZSBjb2RlIGlzIGxpY2Vuc2VkIHVuZGVyIHRoZSBHUEx2MyBsaWNlbnNlIGZvdW5kIGluIHRoZVxuICogTElDRU5TRSBmaWxlIGluIHRoZSByb290IGRpcmVjdG9yeSBvZiB0aGlzIHNvdXJjZSB0cmVlLlxuICpcbiAqL1xuXG5pbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgYW5pbWF0aW9ucywgc3BhY2luZyB9IGZyb20gJ0BuZGxhL2NvcmUnO1xuaW1wb3J0IEZvbGRlckl0ZW0gZnJvbSAnLi9Gb2xkZXJJdGVtJztcbmltcG9ydCBGb2xkZXJOYW1lSW5wdXQgZnJvbSAnLi9Gb2xkZXJOYW1lSW5wdXQnO1xuaW1wb3J0IHsgQ29tbW9uRm9sZGVySXRlbXNQcm9wcywgRm9sZGVyVHlwZSB9IGZyb20gJy4vdHlwZXMnO1xuXG5jb25zdCBTdHlsZWRVTCA9IHN0eWxlZC51bDx7IGZpcnN0TGV2ZWw/OiBib29sZWFuIH0+YFxuICAke2FuaW1hdGlvbnMuZmFkZUluTGVmdChhbmltYXRpb25zLmR1cmF0aW9ucy5mYXN0KX07XG4gIGFuaW1hdGlvbi1maWxsLW1vZGU6IGZvcndhcmRzO1xuICBAbWVkaWEgKHByZWZlcnMtcmVkdWNlZC1tb3Rpb246IHJlZHVjZSkge1xuICAgIGFuaW1hdGlvbjogbm9uZTtcbiAgfVxuICBsaXN0LXN0eWxlOiBub25lO1xuICBtYXJnaW46IDA7XG4gIHBhZGRpbmc6IDA7XG4gIG1hcmdpbi1sZWZ0OiAkeyh7IGZpcnN0TGV2ZWwgfSkgPT4gKGZpcnN0TGV2ZWwgPyBgLSR7c3BhY2luZy54c21hbGx9YCA6IHNwYWNpbmcubm9ybWFsKX07XG5gO1xuXG5jb25zdCBTdHlsZWRMSSA9IHN0eWxlZC5saWBcbiAgbWFyZ2luOiAwO1xuICBwYWRkaW5nOiAwO1xuYDtcblxuZXhwb3J0IGludGVyZmFjZSBGb2xkZXJJdGVtc1Byb3BzIGV4dGVuZHMgQ29tbW9uRm9sZGVySXRlbXNQcm9wcyB7XG4gIGZvbGRlcnM6IEZvbGRlclR5cGVbXTtcbiAgZWRpdGFibGU/OiBib29sZWFuO1xuICBtYXhpbXVtTGV2ZWxzT2ZGb2xkZXJzQWxsb3dlZDogbnVtYmVyO1xuICBuZXdGb2xkZXJQYXJlbnRJZDogc3RyaW5nIHwgdW5kZWZpbmVkO1xuICBvbkNhbmNlbE5ld0ZvbGRlcjogKCkgPT4gdm9pZDtcbiAgb25TYXZlTmV3Rm9sZGVyOiAobmFtZTogc3RyaW5nLCBwYXJlbnRJZDogc3RyaW5nKSA9PiB2b2lkO1xuICBvcGVuRm9sZGVyczogc3RyaW5nW107XG59XG5cbmNvbnN0IEZvbGRlckl0ZW1zID0gKHtcbiAgZWRpdGFibGUsXG4gIGZvbGRlcnMsXG4gIGxldmVsLFxuICBsb2FkaW5nLFxuICBtYXhpbXVtTGV2ZWxzT2ZGb2xkZXJzQWxsb3dlZCxcbiAgbmV3Rm9sZGVyUGFyZW50SWQsXG4gIG9uQ2FuY2VsTmV3Rm9sZGVyLFxuICBvblNhdmVOZXdGb2xkZXIsXG4gIG9wZW5Gb2xkZXJzLFxuICAuLi5yZXN0XG59OiBGb2xkZXJJdGVtc1Byb3BzKSA9PiAoXG4gIDxTdHlsZWRVTCByb2xlPVwiZ3JvdXBcIiBmaXJzdExldmVsPXtsZXZlbCA9PT0gMH0+XG4gICAge2ZvbGRlcnMubWFwKChmb2xkZXIpID0+IHtcbiAgICAgIGNvbnN0IHsgc3ViZm9sZGVycywgaWQgfSA9IGZvbGRlcjtcbiAgICAgIGNvbnN0IGlzT3BlbiA9IG9wZW5Gb2xkZXJzPy5pbmNsdWRlcyhpZCk7XG5cbiAgICAgIHJldHVybiAoXG4gICAgICAgIDxTdHlsZWRMSSBrZXk9e2lkfSByb2xlPVwidHJlZWl0ZW1cIj5cbiAgICAgICAgICA8ZGl2PlxuICAgICAgICAgICAgPEZvbGRlckl0ZW1cbiAgICAgICAgICAgICAgaGlkZUFycm93PXtzdWJmb2xkZXJzPy5sZW5ndGggPT09IDAgfHwgbGV2ZWwgPiBtYXhpbXVtTGV2ZWxzT2ZGb2xkZXJzQWxsb3dlZH1cbiAgICAgICAgICAgICAgZm9sZGVyPXtmb2xkZXJ9XG4gICAgICAgICAgICAgIGlzT3Blbj17aXNPcGVufVxuICAgICAgICAgICAgICBsZXZlbD17bGV2ZWx9XG4gICAgICAgICAgICAgIGxvYWRpbmc9e2xvYWRpbmd9XG4gICAgICAgICAgICAgIG5vUGFkZGluZ1doZW5BcnJvd0lzSGlkZGVuPXtlZGl0YWJsZSAmJiBsZXZlbCA9PT0gMCAmJiBzdWJmb2xkZXJzPy5sZW5ndGggPT09IDB9XG4gICAgICAgICAgICAgIHsuLi5yZXN0fVxuICAgICAgICAgICAgLz5cbiAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICB7bmV3Rm9sZGVyUGFyZW50SWQgPT09IGlkICYmIChcbiAgICAgICAgICAgIDxGb2xkZXJOYW1lSW5wdXRcbiAgICAgICAgICAgICAgbG9hZGluZz17bG9hZGluZ31cbiAgICAgICAgICAgICAgb25DYW5jZWxOZXdGb2xkZXI9e29uQ2FuY2VsTmV3Rm9sZGVyfVxuICAgICAgICAgICAgICBvblNhdmVOZXdGb2xkZXI9e29uU2F2ZU5ld0ZvbGRlcn1cbiAgICAgICAgICAgICAgcGFyZW50SWQ9e25ld0ZvbGRlclBhcmVudElkfVxuICAgICAgICAgICAgLz5cbiAgICAgICAgICApfVxuICAgICAgICAgIHtzdWJmb2xkZXJzICYmIGlzT3BlbiAmJiAoXG4gICAgICAgICAgICA8Rm9sZGVySXRlbXNcbiAgICAgICAgICAgICAgZWRpdGFibGU9e2VkaXRhYmxlfVxuICAgICAgICAgICAgICBmb2xkZXJzPXtzdWJmb2xkZXJzfVxuICAgICAgICAgICAgICBsZXZlbD17bGV2ZWwgKyAxfVxuICAgICAgICAgICAgICBsb2FkaW5nPXtsb2FkaW5nfVxuICAgICAgICAgICAgICBtYXhpbXVtTGV2ZWxzT2ZGb2xkZXJzQWxsb3dlZD17bWF4aW11bUxldmVsc09mRm9sZGVyc0FsbG93ZWR9XG4gICAgICAgICAgICAgIG5ld0ZvbGRlclBhcmVudElkPXtuZXdGb2xkZXJQYXJlbnRJZH1cbiAgICAgICAgICAgICAgb25DYW5jZWxOZXdGb2xkZXI9e29uQ2FuY2VsTmV3Rm9sZGVyfVxuICAgICAgICAgICAgICBvblNhdmVOZXdGb2xkZXI9e29uU2F2ZU5ld0ZvbGRlcn1cbiAgICAgICAgICAgICAgb3BlbkZvbGRlcnM9e29wZW5Gb2xkZXJzfVxuICAgICAgICAgICAgICB7Li4ucmVzdH1cbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgKX1cbiAgICAgICAgPC9TdHlsZWRMST5cbiAgICAgICk7XG4gICAgfSl9XG4gIDwvU3R5bGVkVUw+XG4pO1xuXG5leHBvcnQgZGVmYXVsdCBGb2xkZXJJdGVtcztcbiJdfQ== */"));
|
|
37
37
|
var StyledLI = (0, _styledBase["default"])("li", {
|
|
38
38
|
target: "ef48q151",
|
|
39
39
|
label: "StyledLI"
|
|
@@ -43,7 +43,7 @@ var StyledLI = (0, _styledBase["default"])("li", {
|
|
|
43
43
|
} : {
|
|
44
44
|
name: "1l95nvm",
|
|
45
45
|
styles: "margin:0;padding:0;",
|
|
46
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZvbGRlckl0ZW1zLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEyQjBCIiwiZmlsZSI6IkZvbGRlckl0ZW1zLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDIyLXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGFuaW1hdGlvbnMsIHNwYWNpbmcgfSBmcm9tICdAbmRsYS9jb3JlJztcbmltcG9ydCBGb2xkZXJJdGVtIGZyb20gJy4vRm9sZGVySXRlbSc7XG5pbXBvcnQgRm9sZGVyTmFtZUlucHV0IGZyb20gJy4vRm9sZGVyTmFtZUlucHV0JztcbmltcG9ydCB7IENvbW1vbkZvbGRlckl0ZW1zUHJvcHMsIEZvbGRlclR5cGUgfSBmcm9tICcuL3R5cGVzJztcblxuY29uc3QgU3R5bGVkVUwgPSBzdHlsZWQudWw8eyBmaXJzdExldmVsPzogYm9vbGVhbiB9PmBcbiAgJHthbmltYXRpb25zLmZhZGVJbkxlZnQoYW5pbWF0aW9ucy5kdXJhdGlvbnMuZmFzdCl9O1xuICBhbmltYXRpb24tZmlsbC1tb2RlOiBmb3J3YXJkcztcbiAgQG1lZGlhIChwcmVmZXJzLXJlZHVjZWQtbW90aW9uOiByZWR1Y2UpIHtcbiAgICBhbmltYXRpb246IG5vbmU7XG4gIH1cbiAgbGlzdC1zdHlsZTogbm9uZTtcbiAgbWFyZ2luOiAwO1xuICBwYWRkaW5nOiAwO1xuICBtYXJnaW4tbGVmdDogJHsoeyBmaXJzdExldmVsIH0pID0+IChmaXJzdExldmVsID8gYC0ke3NwYWNpbmcueHNtYWxsfWAgOiBzcGFjaW5nLm5vcm1hbCl9O1xuYDtcblxuY29uc3QgU3R5bGVkTEkgPSBzdHlsZWQubGlgXG4gIG1hcmdpbjogMDtcbiAgcGFkZGluZzogMDtcbmA7XG5cbmV4cG9ydCBpbnRlcmZhY2UgRm9sZGVySXRlbXNQcm9wcyBleHRlbmRzIENvbW1vbkZvbGRlckl0ZW1zUHJvcHMge1xuICBmb2xkZXJzOiBGb2xkZXJUeXBlW107XG4gIGVkaXRhYmxlPzogYm9vbGVhbjtcbiAgbWF4aW11bUxldmVsc09mRm9sZGVyc0FsbG93ZWQ6IG51bWJlcjtcbiAgbmV3Rm9sZGVyUGFyZW50SWQ6IHN0cmluZyB8IHVuZGVmaW5lZDtcbiAgb25DYW5jZWxOZXdGb2xkZXI6ICgpID0+
|
|
46
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZvbGRlckl0ZW1zLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEyQjBCIiwiZmlsZSI6IkZvbGRlckl0ZW1zLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDIyLXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGFuaW1hdGlvbnMsIHNwYWNpbmcgfSBmcm9tICdAbmRsYS9jb3JlJztcbmltcG9ydCBGb2xkZXJJdGVtIGZyb20gJy4vRm9sZGVySXRlbSc7XG5pbXBvcnQgRm9sZGVyTmFtZUlucHV0IGZyb20gJy4vRm9sZGVyTmFtZUlucHV0JztcbmltcG9ydCB7IENvbW1vbkZvbGRlckl0ZW1zUHJvcHMsIEZvbGRlclR5cGUgfSBmcm9tICcuL3R5cGVzJztcblxuY29uc3QgU3R5bGVkVUwgPSBzdHlsZWQudWw8eyBmaXJzdExldmVsPzogYm9vbGVhbiB9PmBcbiAgJHthbmltYXRpb25zLmZhZGVJbkxlZnQoYW5pbWF0aW9ucy5kdXJhdGlvbnMuZmFzdCl9O1xuICBhbmltYXRpb24tZmlsbC1tb2RlOiBmb3J3YXJkcztcbiAgQG1lZGlhIChwcmVmZXJzLXJlZHVjZWQtbW90aW9uOiByZWR1Y2UpIHtcbiAgICBhbmltYXRpb246IG5vbmU7XG4gIH1cbiAgbGlzdC1zdHlsZTogbm9uZTtcbiAgbWFyZ2luOiAwO1xuICBwYWRkaW5nOiAwO1xuICBtYXJnaW4tbGVmdDogJHsoeyBmaXJzdExldmVsIH0pID0+IChmaXJzdExldmVsID8gYC0ke3NwYWNpbmcueHNtYWxsfWAgOiBzcGFjaW5nLm5vcm1hbCl9O1xuYDtcblxuY29uc3QgU3R5bGVkTEkgPSBzdHlsZWQubGlgXG4gIG1hcmdpbjogMDtcbiAgcGFkZGluZzogMDtcbmA7XG5cbmV4cG9ydCBpbnRlcmZhY2UgRm9sZGVySXRlbXNQcm9wcyBleHRlbmRzIENvbW1vbkZvbGRlckl0ZW1zUHJvcHMge1xuICBmb2xkZXJzOiBGb2xkZXJUeXBlW107XG4gIGVkaXRhYmxlPzogYm9vbGVhbjtcbiAgbWF4aW11bUxldmVsc09mRm9sZGVyc0FsbG93ZWQ6IG51bWJlcjtcbiAgbmV3Rm9sZGVyUGFyZW50SWQ6IHN0cmluZyB8IHVuZGVmaW5lZDtcbiAgb25DYW5jZWxOZXdGb2xkZXI6ICgpID0+IHZvaWQ7XG4gIG9uU2F2ZU5ld0ZvbGRlcjogKG5hbWU6IHN0cmluZywgcGFyZW50SWQ6IHN0cmluZykgPT4gdm9pZDtcbiAgb3BlbkZvbGRlcnM6IHN0cmluZ1tdO1xufVxuXG5jb25zdCBGb2xkZXJJdGVtcyA9ICh7XG4gIGVkaXRhYmxlLFxuICBmb2xkZXJzLFxuICBsZXZlbCxcbiAgbG9hZGluZyxcbiAgbWF4aW11bUxldmVsc09mRm9sZGVyc0FsbG93ZWQsXG4gIG5ld0ZvbGRlclBhcmVudElkLFxuICBvbkNhbmNlbE5ld0ZvbGRlcixcbiAgb25TYXZlTmV3Rm9sZGVyLFxuICBvcGVuRm9sZGVycyxcbiAgLi4ucmVzdFxufTogRm9sZGVySXRlbXNQcm9wcykgPT4gKFxuICA8U3R5bGVkVUwgcm9sZT1cImdyb3VwXCIgZmlyc3RMZXZlbD17bGV2ZWwgPT09IDB9PlxuICAgIHtmb2xkZXJzLm1hcCgoZm9sZGVyKSA9PiB7XG4gICAgICBjb25zdCB7IHN1YmZvbGRlcnMsIGlkIH0gPSBmb2xkZXI7XG4gICAgICBjb25zdCBpc09wZW4gPSBvcGVuRm9sZGVycz8uaW5jbHVkZXMoaWQpO1xuXG4gICAgICByZXR1cm4gKFxuICAgICAgICA8U3R5bGVkTEkga2V5PXtpZH0gcm9sZT1cInRyZWVpdGVtXCI+XG4gICAgICAgICAgPGRpdj5cbiAgICAgICAgICAgIDxGb2xkZXJJdGVtXG4gICAgICAgICAgICAgIGhpZGVBcnJvdz17c3ViZm9sZGVycz8ubGVuZ3RoID09PSAwIHx8IGxldmVsID4gbWF4aW11bUxldmVsc09mRm9sZGVyc0FsbG93ZWR9XG4gICAgICAgICAgICAgIGZvbGRlcj17Zm9sZGVyfVxuICAgICAgICAgICAgICBpc09wZW49e2lzT3Blbn1cbiAgICAgICAgICAgICAgbGV2ZWw9e2xldmVsfVxuICAgICAgICAgICAgICBsb2FkaW5nPXtsb2FkaW5nfVxuICAgICAgICAgICAgICBub1BhZGRpbmdXaGVuQXJyb3dJc0hpZGRlbj17ZWRpdGFibGUgJiYgbGV2ZWwgPT09IDAgJiYgc3ViZm9sZGVycz8ubGVuZ3RoID09PSAwfVxuICAgICAgICAgICAgICB7Li4ucmVzdH1cbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgPC9kaXY+XG4gICAgICAgICAge25ld0ZvbGRlclBhcmVudElkID09PSBpZCAmJiAoXG4gICAgICAgICAgICA8Rm9sZGVyTmFtZUlucHV0XG4gICAgICAgICAgICAgIGxvYWRpbmc9e2xvYWRpbmd9XG4gICAgICAgICAgICAgIG9uQ2FuY2VsTmV3Rm9sZGVyPXtvbkNhbmNlbE5ld0ZvbGRlcn1cbiAgICAgICAgICAgICAgb25TYXZlTmV3Rm9sZGVyPXtvblNhdmVOZXdGb2xkZXJ9XG4gICAgICAgICAgICAgIHBhcmVudElkPXtuZXdGb2xkZXJQYXJlbnRJZH1cbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgKX1cbiAgICAgICAgICB7c3ViZm9sZGVycyAmJiBpc09wZW4gJiYgKFxuICAgICAgICAgICAgPEZvbGRlckl0ZW1zXG4gICAgICAgICAgICAgIGVkaXRhYmxlPXtlZGl0YWJsZX1cbiAgICAgICAgICAgICAgZm9sZGVycz17c3ViZm9sZGVyc31cbiAgICAgICAgICAgICAgbGV2ZWw9e2xldmVsICsgMX1cbiAgICAgICAgICAgICAgbG9hZGluZz17bG9hZGluZ31cbiAgICAgICAgICAgICAgbWF4aW11bUxldmVsc09mRm9sZGVyc0FsbG93ZWQ9e21heGltdW1MZXZlbHNPZkZvbGRlcnNBbGxvd2VkfVxuICAgICAgICAgICAgICBuZXdGb2xkZXJQYXJlbnRJZD17bmV3Rm9sZGVyUGFyZW50SWR9XG4gICAgICAgICAgICAgIG9uQ2FuY2VsTmV3Rm9sZGVyPXtvbkNhbmNlbE5ld0ZvbGRlcn1cbiAgICAgICAgICAgICAgb25TYXZlTmV3Rm9sZGVyPXtvblNhdmVOZXdGb2xkZXJ9XG4gICAgICAgICAgICAgIG9wZW5Gb2xkZXJzPXtvcGVuRm9sZGVyc31cbiAgICAgICAgICAgICAgey4uLnJlc3R9XG4gICAgICAgICAgICAvPlxuICAgICAgICAgICl9XG4gICAgICAgIDwvU3R5bGVkTEk+XG4gICAgICApO1xuICAgIH0pfVxuICA8L1N0eWxlZFVMPlxuKTtcblxuZXhwb3J0IGRlZmF1bHQgRm9sZGVySXRlbXM7XG4iXX0= */",
|
|
47
47
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
48
48
|
});
|
|
49
49
|
|
|
@@ -61,7 +61,7 @@ var FolderItems = function FolderItems(_ref2) {
|
|
|
61
61
|
|
|
62
62
|
return (0, _core2.jsx)(StyledUL, {
|
|
63
63
|
role: "group",
|
|
64
|
-
firstLevel: level ===
|
|
64
|
+
firstLevel: level === 0
|
|
65
65
|
}, folders.map(function (folder) {
|
|
66
66
|
var subfolders = folder.subfolders,
|
|
67
67
|
id = folder.id;
|
|
@@ -75,7 +75,7 @@ var FolderItems = function FolderItems(_ref2) {
|
|
|
75
75
|
isOpen: isOpen,
|
|
76
76
|
level: level,
|
|
77
77
|
loading: loading,
|
|
78
|
-
noPaddingWhenArrowIsHidden: editable && level ===
|
|
78
|
+
noPaddingWhenArrowIsHidden: editable && level === 0 && (subfolders === null || subfolders === void 0 ? void 0 : subfolders.length) === 0
|
|
79
79
|
}, rest))), newFolderParentId === id && (0, _core2.jsx)(_FolderNameInput["default"], {
|
|
80
80
|
loading: loading,
|
|
81
81
|
onCancelNewFolder: onCancelNewFolder,
|
|
@@ -16,7 +16,7 @@ export interface TreeStructureProps extends CommonTreeStructureProps {
|
|
|
16
16
|
framed?: boolean;
|
|
17
17
|
label?: string;
|
|
18
18
|
maximumLevelsOfFoldersAllowed?: number;
|
|
19
|
-
onNewFolder
|
|
19
|
+
onNewFolder?: (name: string, parentId: string) => Promise<IFolder>;
|
|
20
20
|
}
|
|
21
|
-
declare const TreeStructure: ({ defaultOpenFolders, editable, menuItems, folders, framed, label, loading, maximumLevelsOfFoldersAllowed, onNewFolder, onSelectFolder, openOnFolderClick, }: TreeStructureProps) => JSX.Element;
|
|
21
|
+
declare const TreeStructure: ({ defaultOpenFolders, editable, menuItems, folders, framed, label, loading, maximumLevelsOfFoldersAllowed, onNewFolder, onSelectFolder, openOnFolderClick, targetResource, }: TreeStructureProps) => JSX.Element;
|
|
22
22
|
export default TreeStructure;
|
|
@@ -52,11 +52,11 @@ exports.MAX_LEVEL_FOR_FOLDERS = MAX_LEVEL_FOR_FOLDERS;
|
|
|
52
52
|
var StyledLabel = (0, _styledBase["default"])("label", {
|
|
53
53
|
target: "e1dg1gdn0",
|
|
54
54
|
label: "StyledLabel"
|
|
55
|
-
})("font-weight:", _core.fonts.weight.semibold, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlRyZWVTdHJ1Y3R1cmUudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXVCZ0MiLCJmaWxlIjoiVHJlZVN0cnVjdHVyZS50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMi1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCwgeyB1c2VFZmZlY3QsIHVzZVN0YXRlLCB1c2VNZW1vIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgQWRkQnV0dG9uIH0gZnJvbSAnQG5kbGEvYnV0dG9uJztcbmltcG9ydCBUb29sdGlwIGZyb20gJ0BuZGxhL3Rvb2x0aXAnO1xuaW1wb3J0IHsgdXNlVHJhbnNsYXRpb24gfSBmcm9tICdyZWFjdC1pMThuZXh0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IHNwYWNpbmcsIGZvbnRzIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgeyB1bmlxIH0gZnJvbSAnbG9kYXNoJztcbmltcG9ydCB7IElGb2xkZXIgfSBmcm9tICdAbmRsYS90eXBlcy1sZWFybmluZ3BhdGgtYXBpJztcbmltcG9ydCBUcmVlU3RydWN0dXJlU3R5bGVkV3JhcHBlciBmcm9tICcuL1RyZWVTdHJ1Y3R1cmVXcmFwcGVyJztcbmltcG9ydCBGb2xkZXJJdGVtcyBmcm9tICcuL0ZvbGRlckl0ZW1zJztcbmltcG9ydCB7IGZsYXR0ZW5Gb2xkZXJzIH0gZnJvbSAnLi9oZWxwZXJGdW5jdGlvbnMnO1xuaW1wb3J0IHsgQ29tbW9uVHJlZVN0cnVjdHVyZVByb3BzLCBGb2xkZXJUeXBlIH0gZnJvbSAnLi90eXBlcyc7XG5cbmV4cG9ydCBjb25zdCBNQVhfTEVWRUxfRk9SX0ZPTERFUlMgPSA0O1xuXG5jb25zdCBTdHlsZWRMYWJlbCA9IHN0eWxlZC5sYWJlbGBcbiAgZm9udC13ZWlnaHQ6ICR7Zm9udHMud2VpZ2h0LnNlbWlib2xkfTtcbmA7XG5cbmNvbnN0IEFkZEZvbGRlcldyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBmbGV4O1xuICBtYXJnaW4tdG9wOiAke3NwYWNpbmcueHNtYWxsfTtcbmA7XG5cbmV4cG9ydCBpbnRlcmZhY2UgVHJlZVN0cnVjdHVyZVByb3BzIGV4dGVuZHMgQ29tbW9uVHJlZVN0cnVjdHVyZVByb3BzIHtcbiAgZGVmYXVsdE9wZW5Gb2xkZXJzPzogc3RyaW5nW107XG4gIGZvbGRlcnM6IEZvbGRlclR5cGVbXTtcbiAgZWRpdGFibGU/OiBib29sZWFuO1xuICBmcmFtZWQ/OiBib29sZWFuO1xuICBsYWJlbD86IHN0cmluZztcbiAgbWF4aW11bUxldmVsc09mRm9sZGVyc0FsbG93ZWQ/
|
|
55
|
+
})("font-weight:", _core.fonts.weight.semibold, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["TreeStructure.tsx"],"names":[],"mappings":"AAuBgC","file":"TreeStructure.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, { useEffect, useState, useMemo } from 'react';\nimport { AddButton } from '@ndla/button';\nimport Tooltip from '@ndla/tooltip';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { spacing, fonts } from '@ndla/core';\nimport { uniq } from 'lodash';\nimport { IFolder } from '@ndla/types-learningpath-api';\nimport TreeStructureStyledWrapper from './TreeStructureWrapper';\nimport FolderItems from './FolderItems';\nimport { flattenFolders } from './helperFunctions';\nimport { CommonTreeStructureProps, FolderType } from './types';\n\nexport const MAX_LEVEL_FOR_FOLDERS = 4;\n\nconst StyledLabel = styled.label`\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst AddFolderWrapper = styled.div`\n  display: flex;\n  margin-top: ${spacing.xsmall};\n`;\n\nexport interface TreeStructureProps extends CommonTreeStructureProps {\n  defaultOpenFolders?: string[];\n  folders: FolderType[];\n  editable?: boolean;\n  framed?: boolean;\n  label?: string;\n  maximumLevelsOfFoldersAllowed?: number;\n  onNewFolder?: (name: string, parentId: string) => Promise<IFolder>;\n}\n\nconst TreeStructure = ({\n  defaultOpenFolders,\n  editable,\n  menuItems,\n  folders,\n  framed,\n  label,\n  loading,\n  maximumLevelsOfFoldersAllowed = MAX_LEVEL_FOR_FOLDERS,\n  onNewFolder,\n  onSelectFolder,\n  openOnFolderClick,\n  targetResource,\n}: TreeStructureProps) => {\n  const { t } = useTranslation();\n\n  const defaultSelectedFolderId = defaultOpenFolders && defaultOpenFolders[defaultOpenFolders.length - 1];\n\n  const [openFolders, setOpenFolders] = useState<string[]>(defaultOpenFolders || []);\n\n  const [newFolderParentId, setNewFolderParentId] = useState<string | undefined>();\n  const [focusedId, setFocusedId] = useState<string | undefined>();\n  const [selectedFolder, setSelectedFolder] = useState<FolderType | undefined>();\n\n  const flattenedFolders = useMemo(() => flattenFolders(folders, openFolders), [folders, openFolders]);\n  const visibleFolderIds = flattenedFolders.map((folder) => folder.id);\n\n  useEffect(() => {\n    if (defaultOpenFolders) {\n      if (!defaultOpenFolders.every((element) => openFolders.includes(element))) {\n        setOpenFolders((prev) => {\n          return uniq(defaultOpenFolders.concat(prev));\n        });\n      }\n    }\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, [defaultOpenFolders]);\n\n  useEffect(() => {\n    if (defaultSelectedFolderId !== undefined) {\n      const selected = flattenFolders(folders).find((folder) => folder.id === defaultSelectedFolderId);\n      if (selected) {\n        setSelectedFolder(selected);\n      }\n    }\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, [defaultSelectedFolderId]);\n\n  useEffect(() => {\n    if (!loading) {\n      setNewFolderParentId(undefined);\n    }\n  }, [loading]);\n\n  const onCloseFolder = (id: string) => {\n    const closedFolder = flattenedFolders.find((folder) => folder.id === id);\n\n    if (closedFolder) {\n      const subFolders = closedFolder.subfolders && flattenFolders(closedFolder.subfolders);\n      if (subFolders.some((folder) => folder.id === selectedFolder?.id)) {\n        if (onSelectFolder) {\n          setSelectedFolder(closedFolder);\n          onSelectFolder(closedFolder.id);\n        }\n        setFocusedId(closedFolder.id);\n      }\n    }\n    setOpenFolders(openFolders.filter((folderId) => folderId !== id));\n  };\n\n  const onOpenFolder = (id: string) => {\n    setOpenFolders(uniq(openFolders.concat(id)));\n  };\n\n  const onSaveNewFolder = (name: string, parentId: string) => {\n    onNewFolder?.(name, parentId).then((newFolder) => {\n      if (newFolder) {\n        setSelectedFolder(newFolder);\n        setFocusedId(newFolder.id);\n        setOpenFolders(uniq(openFolders.concat(parentId)));\n      }\n    });\n  };\n\n  const onCancelNewFolder = () => {\n    setNewFolderParentId(undefined);\n  };\n\n  const canAddFolder =\n    editable && selectedFolder && selectedFolder?.breadcrumbs.length < (maximumLevelsOfFoldersAllowed || 1);\n\n  return (\n    <div>\n      {label && <StyledLabel>{label}</StyledLabel>}\n      <TreeStructureStyledWrapper aria-label=\"Menu tree\" role=\"tree\" framed={framed}>\n        <FolderItems\n          editable={editable}\n          focusedFolderId={focusedId}\n          menuItems={menuItems}\n          folders={folders}\n          level={0}\n          loading={loading}\n          selectedFolder={selectedFolder}\n          maximumLevelsOfFoldersAllowed={maximumLevelsOfFoldersAllowed}\n          newFolderParentId={newFolderParentId}\n          onCancelNewFolder={onCancelNewFolder}\n          onCloseFolder={onCloseFolder}\n          onOpenFolder={onOpenFolder}\n          onSaveNewFolder={onSaveNewFolder}\n          onSelectFolder={onSelectFolder}\n          openFolders={openFolders}\n          openOnFolderClick={openOnFolderClick}\n          setFocusedId={setFocusedId}\n          setSelectedFolder={setSelectedFolder}\n          targetResource={targetResource}\n          visibleFolders={visibleFolderIds}\n        />\n      </TreeStructureStyledWrapper>\n      {editable && (\n        <AddFolderWrapper>\n          <Tooltip\n            tooltip={\n              canAddFolder\n                ? t('myNdla.newFolderUnder', {\n                    folderName: selectedFolder?.name,\n                  })\n                : t('treeStructure.maxFoldersAlreadyAdded')\n            }>\n            <AddButton\n              disabled={!canAddFolder}\n              aria-label={t('myNdla.newFolder')}\n              onClick={() => setNewFolderParentId(selectedFolder?.id)}>\n              {t('myNdla.newFolder')}\n            </AddButton>\n          </Tooltip>\n        </AddFolderWrapper>\n      )}\n    </div>\n  );\n};\n\nexport default TreeStructure;\n"]} */"));
|
|
56
56
|
var AddFolderWrapper = (0, _styledBase["default"])("div", {
|
|
57
57
|
target: "e1dg1gdn1",
|
|
58
58
|
label: "AddFolderWrapper"
|
|
59
|
-
})("display:flex;margin-top:", _core.spacing.xsmall, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlRyZWVTdHJ1Y3R1cmUudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTJCbUMiLCJmaWxlIjoiVHJlZVN0cnVjdHVyZS50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMi1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCwgeyB1c2VFZmZlY3QsIHVzZVN0YXRlLCB1c2VNZW1vIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgQWRkQnV0dG9uIH0gZnJvbSAnQG5kbGEvYnV0dG9uJztcbmltcG9ydCBUb29sdGlwIGZyb20gJ0BuZGxhL3Rvb2x0aXAnO1xuaW1wb3J0IHsgdXNlVHJhbnNsYXRpb24gfSBmcm9tICdyZWFjdC1pMThuZXh0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IHNwYWNpbmcsIGZvbnRzIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgeyB1bmlxIH0gZnJvbSAnbG9kYXNoJztcbmltcG9ydCB7IElGb2xkZXIgfSBmcm9tICdAbmRsYS90eXBlcy1sZWFybmluZ3BhdGgtYXBpJztcbmltcG9ydCBUcmVlU3RydWN0dXJlU3R5bGVkV3JhcHBlciBmcm9tICcuL1RyZWVTdHJ1Y3R1cmVXcmFwcGVyJztcbmltcG9ydCBGb2xkZXJJdGVtcyBmcm9tICcuL0ZvbGRlckl0ZW1zJztcbmltcG9ydCB7IGZsYXR0ZW5Gb2xkZXJzIH0gZnJvbSAnLi9oZWxwZXJGdW5jdGlvbnMnO1xuaW1wb3J0IHsgQ29tbW9uVHJlZVN0cnVjdHVyZVByb3BzLCBGb2xkZXJUeXBlIH0gZnJvbSAnLi90eXBlcyc7XG5cbmV4cG9ydCBjb25zdCBNQVhfTEVWRUxfRk9SX0ZPTERFUlMgPSA0O1xuXG5jb25zdCBTdHlsZWRMYWJlbCA9IHN0eWxlZC5sYWJlbGBcbiAgZm9udC13ZWlnaHQ6ICR7Zm9udHMud2VpZ2h0LnNlbWlib2xkfTtcbmA7XG5cbmNvbnN0IEFkZEZvbGRlcldyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBmbGV4O1xuICBtYXJnaW4tdG9wOiAke3NwYWNpbmcueHNtYWxsfTtcbmA7XG5cbmV4cG9ydCBpbnRlcmZhY2UgVHJlZVN0cnVjdHVyZVByb3BzIGV4dGVuZHMgQ29tbW9uVHJlZVN0cnVjdHVyZVByb3BzIHtcbiAgZGVmYXVsdE9wZW5Gb2xkZXJzPzogc3RyaW5nW107XG4gIGZvbGRlcnM6IEZvbGRlclR5cGVbXTtcbiAgZWRpdGFibGU/OiBib29sZWFuO1xuICBmcmFtZWQ/OiBib29sZWFuO1xuICBsYWJlbD86IHN0cmluZztcbiAgbWF4aW11bUxldmVsc09mRm9sZGVyc0FsbG93ZWQ/
|
|
59
|
+
})("display:flex;margin-top:", _core.spacing.xsmall, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["TreeStructure.tsx"],"names":[],"mappings":"AA2BmC","file":"TreeStructure.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, { useEffect, useState, useMemo } from 'react';\nimport { AddButton } from '@ndla/button';\nimport Tooltip from '@ndla/tooltip';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { spacing, fonts } from '@ndla/core';\nimport { uniq } from 'lodash';\nimport { IFolder } from '@ndla/types-learningpath-api';\nimport TreeStructureStyledWrapper from './TreeStructureWrapper';\nimport FolderItems from './FolderItems';\nimport { flattenFolders } from './helperFunctions';\nimport { CommonTreeStructureProps, FolderType } from './types';\n\nexport const MAX_LEVEL_FOR_FOLDERS = 4;\n\nconst StyledLabel = styled.label`\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst AddFolderWrapper = styled.div`\n  display: flex;\n  margin-top: ${spacing.xsmall};\n`;\n\nexport interface TreeStructureProps extends CommonTreeStructureProps {\n  defaultOpenFolders?: string[];\n  folders: FolderType[];\n  editable?: boolean;\n  framed?: boolean;\n  label?: string;\n  maximumLevelsOfFoldersAllowed?: number;\n  onNewFolder?: (name: string, parentId: string) => Promise<IFolder>;\n}\n\nconst TreeStructure = ({\n  defaultOpenFolders,\n  editable,\n  menuItems,\n  folders,\n  framed,\n  label,\n  loading,\n  maximumLevelsOfFoldersAllowed = MAX_LEVEL_FOR_FOLDERS,\n  onNewFolder,\n  onSelectFolder,\n  openOnFolderClick,\n  targetResource,\n}: TreeStructureProps) => {\n  const { t } = useTranslation();\n\n  const defaultSelectedFolderId = defaultOpenFolders && defaultOpenFolders[defaultOpenFolders.length - 1];\n\n  const [openFolders, setOpenFolders] = useState<string[]>(defaultOpenFolders || []);\n\n  const [newFolderParentId, setNewFolderParentId] = useState<string | undefined>();\n  const [focusedId, setFocusedId] = useState<string | undefined>();\n  const [selectedFolder, setSelectedFolder] = useState<FolderType | undefined>();\n\n  const flattenedFolders = useMemo(() => flattenFolders(folders, openFolders), [folders, openFolders]);\n  const visibleFolderIds = flattenedFolders.map((folder) => folder.id);\n\n  useEffect(() => {\n    if (defaultOpenFolders) {\n      if (!defaultOpenFolders.every((element) => openFolders.includes(element))) {\n        setOpenFolders((prev) => {\n          return uniq(defaultOpenFolders.concat(prev));\n        });\n      }\n    }\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, [defaultOpenFolders]);\n\n  useEffect(() => {\n    if (defaultSelectedFolderId !== undefined) {\n      const selected = flattenFolders(folders).find((folder) => folder.id === defaultSelectedFolderId);\n      if (selected) {\n        setSelectedFolder(selected);\n      }\n    }\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, [defaultSelectedFolderId]);\n\n  useEffect(() => {\n    if (!loading) {\n      setNewFolderParentId(undefined);\n    }\n  }, [loading]);\n\n  const onCloseFolder = (id: string) => {\n    const closedFolder = flattenedFolders.find((folder) => folder.id === id);\n\n    if (closedFolder) {\n      const subFolders = closedFolder.subfolders && flattenFolders(closedFolder.subfolders);\n      if (subFolders.some((folder) => folder.id === selectedFolder?.id)) {\n        if (onSelectFolder) {\n          setSelectedFolder(closedFolder);\n          onSelectFolder(closedFolder.id);\n        }\n        setFocusedId(closedFolder.id);\n      }\n    }\n    setOpenFolders(openFolders.filter((folderId) => folderId !== id));\n  };\n\n  const onOpenFolder = (id: string) => {\n    setOpenFolders(uniq(openFolders.concat(id)));\n  };\n\n  const onSaveNewFolder = (name: string, parentId: string) => {\n    onNewFolder?.(name, parentId).then((newFolder) => {\n      if (newFolder) {\n        setSelectedFolder(newFolder);\n        setFocusedId(newFolder.id);\n        setOpenFolders(uniq(openFolders.concat(parentId)));\n      }\n    });\n  };\n\n  const onCancelNewFolder = () => {\n    setNewFolderParentId(undefined);\n  };\n\n  const canAddFolder =\n    editable && selectedFolder && selectedFolder?.breadcrumbs.length < (maximumLevelsOfFoldersAllowed || 1);\n\n  return (\n    <div>\n      {label && <StyledLabel>{label}</StyledLabel>}\n      <TreeStructureStyledWrapper aria-label=\"Menu tree\" role=\"tree\" framed={framed}>\n        <FolderItems\n          editable={editable}\n          focusedFolderId={focusedId}\n          menuItems={menuItems}\n          folders={folders}\n          level={0}\n          loading={loading}\n          selectedFolder={selectedFolder}\n          maximumLevelsOfFoldersAllowed={maximumLevelsOfFoldersAllowed}\n          newFolderParentId={newFolderParentId}\n          onCancelNewFolder={onCancelNewFolder}\n          onCloseFolder={onCloseFolder}\n          onOpenFolder={onOpenFolder}\n          onSaveNewFolder={onSaveNewFolder}\n          onSelectFolder={onSelectFolder}\n          openFolders={openFolders}\n          openOnFolderClick={openOnFolderClick}\n          setFocusedId={setFocusedId}\n          setSelectedFolder={setSelectedFolder}\n          targetResource={targetResource}\n          visibleFolders={visibleFolderIds}\n        />\n      </TreeStructureStyledWrapper>\n      {editable && (\n        <AddFolderWrapper>\n          <Tooltip\n            tooltip={\n              canAddFolder\n                ? t('myNdla.newFolderUnder', {\n                    folderName: selectedFolder?.name,\n                  })\n                : t('treeStructure.maxFoldersAlreadyAdded')\n            }>\n            <AddButton\n              disabled={!canAddFolder}\n              aria-label={t('myNdla.newFolder')}\n              onClick={() => setNewFolderParentId(selectedFolder?.id)}>\n              {t('myNdla.newFolder')}\n            </AddButton>\n          </Tooltip>\n        </AddFolderWrapper>\n      )}\n    </div>\n  );\n};\n\nexport default TreeStructure;\n"]} */"));
|
|
60
60
|
|
|
61
61
|
var TreeStructure = function TreeStructure(_ref) {
|
|
62
62
|
var defaultOpenFolders = _ref.defaultOpenFolders,
|
|
@@ -70,7 +70,8 @@ var TreeStructure = function TreeStructure(_ref) {
|
|
|
70
70
|
maximumLevelsOfFoldersAllowed = _ref$maximumLevelsOfF === void 0 ? MAX_LEVEL_FOR_FOLDERS : _ref$maximumLevelsOfF,
|
|
71
71
|
onNewFolder = _ref.onNewFolder,
|
|
72
72
|
onSelectFolder = _ref.onSelectFolder,
|
|
73
|
-
openOnFolderClick = _ref.openOnFolderClick
|
|
73
|
+
openOnFolderClick = _ref.openOnFolderClick,
|
|
74
|
+
targetResource = _ref.targetResource;
|
|
74
75
|
|
|
75
76
|
var _useTranslation = (0, _reactI18next.useTranslation)(),
|
|
76
77
|
t = _useTranslation.t;
|
|
@@ -105,10 +106,15 @@ var TreeStructure = function TreeStructure(_ref) {
|
|
|
105
106
|
});
|
|
106
107
|
(0, _react.useEffect)(function () {
|
|
107
108
|
if (defaultOpenFolders) {
|
|
108
|
-
|
|
109
|
-
return
|
|
110
|
-
})
|
|
111
|
-
|
|
109
|
+
if (!defaultOpenFolders.every(function (element) {
|
|
110
|
+
return openFolders.includes(element);
|
|
111
|
+
})) {
|
|
112
|
+
setOpenFolders(function (prev) {
|
|
113
|
+
return (0, _lodash.uniq)(defaultOpenFolders.concat(prev));
|
|
114
|
+
});
|
|
115
|
+
}
|
|
116
|
+
} // eslint-disable-next-line react-hooks/exhaustive-deps
|
|
117
|
+
|
|
112
118
|
}, [defaultOpenFolders]);
|
|
113
119
|
(0, _react.useEffect)(function () {
|
|
114
120
|
if (defaultSelectedFolderId !== undefined) {
|
|
@@ -158,7 +164,7 @@ var TreeStructure = function TreeStructure(_ref) {
|
|
|
158
164
|
};
|
|
159
165
|
|
|
160
166
|
var onSaveNewFolder = function onSaveNewFolder(name, parentId) {
|
|
161
|
-
onNewFolder(name, parentId).then(function (newFolder) {
|
|
167
|
+
onNewFolder === null || onNewFolder === void 0 ? void 0 : onNewFolder(name, parentId).then(function (newFolder) {
|
|
162
168
|
if (newFolder) {
|
|
163
169
|
setSelectedFolder(newFolder);
|
|
164
170
|
setFocusedId(newFolder.id);
|
|
@@ -181,7 +187,7 @@ var TreeStructure = function TreeStructure(_ref) {
|
|
|
181
187
|
focusedFolderId: focusedId,
|
|
182
188
|
menuItems: menuItems,
|
|
183
189
|
folders: folders,
|
|
184
|
-
level:
|
|
190
|
+
level: 0,
|
|
185
191
|
loading: loading,
|
|
186
192
|
selectedFolder: selectedFolder,
|
|
187
193
|
maximumLevelsOfFoldersAllowed: maximumLevelsOfFoldersAllowed,
|
|
@@ -195,6 +201,7 @@ var TreeStructure = function TreeStructure(_ref) {
|
|
|
195
201
|
openOnFolderClick: openOnFolderClick,
|
|
196
202
|
setFocusedId: setFocusedId,
|
|
197
203
|
setSelectedFolder: setSelectedFolder,
|
|
204
|
+
targetResource: targetResource,
|
|
198
205
|
visibleFolders: visibleFolderIds
|
|
199
206
|
})), editable && (0, _core2.jsx)(AddFolderWrapper, null, (0, _core2.jsx)(_tooltip["default"], {
|
|
200
207
|
tooltip: canAddFolder ? t('myNdla.newFolderUnder', {
|
|
@@ -6,7 +6,7 @@
|
|
|
6
6
|
*
|
|
7
7
|
*/
|
|
8
8
|
import { MouseEvent, ReactNode } from 'react';
|
|
9
|
-
import { IFolder } from '@ndla/types-learningpath-api';
|
|
9
|
+
import { IFolder, IResource } from '@ndla/types-learningpath-api';
|
|
10
10
|
import { MenuItemProps } from '@ndla/button/src';
|
|
11
11
|
export interface FolderType extends IFolder {
|
|
12
12
|
icon?: ReactNode;
|
|
@@ -19,6 +19,7 @@ export interface CommonTreeStructureProps {
|
|
|
19
19
|
onSelectFolder?: (id: string) => void;
|
|
20
20
|
openOnFolderClick?: boolean;
|
|
21
21
|
menuItems?: TreeStructureMenuProps[];
|
|
22
|
+
targetResource?: IResource;
|
|
22
23
|
}
|
|
23
24
|
export interface CommonFolderItemsProps extends CommonTreeStructureProps {
|
|
24
25
|
focusedFolderId?: string;
|
package/lib/index.d.ts
CHANGED
|
@@ -84,8 +84,8 @@ export { ListResource, BlockResource } from './Resource';
|
|
|
84
84
|
export type { ListResourceProps } from './Resource';
|
|
85
85
|
export type { TagType } from './TagSelector';
|
|
86
86
|
export { TagSelector } from './TagSelector';
|
|
87
|
-
export
|
|
88
|
-
export {
|
|
87
|
+
export { SnackbarProvider, useSnack, BaseSnack, DefaultSnackbar } from './SnackBar';
|
|
88
|
+
export type { Snack, SnackContext } from './SnackBar';
|
|
89
89
|
export { InfoBlock } from './InfoBlock';
|
|
90
90
|
export { TreeStructure } from './TreeStructure';
|
|
91
91
|
export type { FolderType, TreeStructureProps, TreeStructureMenuProps } from './TreeStructure';
|