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