import { observer } from "mobx-react"; import { PlusIcon } from "outline-icons"; import * as React from "react"; import { useTranslation } from "react-i18next"; import { Link } from "react-router-dom"; import { MenuButton, useMenuState } from "reakit/Menu"; import styled from "styled-components"; import Button from "~/components/Button"; import CollectionIcon from "~/components/CollectionIcon"; import ContextMenu from "~/components/ContextMenu"; import Header from "~/components/ContextMenu/Header"; import Template from "~/components/ContextMenu/Template"; import useCurrentTeam from "~/hooks/useCurrentTeam"; import useStores from "~/hooks/useStores"; import { MenuItem } from "~/types"; import { newDocumentPath } from "~/utils/routeHelpers"; function NewDocumentMenu() { const menu = useMenuState({ modal: true, }); const { t } = useTranslation(); const team = useCurrentTeam(); const { collections, policies } = useStores(); const can = policies.abilities(team.id); const items = React.useMemo( () => collections.orderedData.reduce((filtered, collection) => { const can = policies.abilities(collection.id); if (can.update) { filtered.push({ type: "route", to: newDocumentPath(collection.id), title: {collection.name}, icon: , }); } return filtered; }, []), [collections.orderedData, policies] ); if (!can.createDocument || items.length === 0) { return null; } if (items.length === 1) { return ( ); } return ( <> {(props) => ( )}
{t("Choose a collection")}