import { observer } from "mobx-react"; import { CodeIcon } from "outline-icons"; import * as React from "react"; import { useTranslation, Trans } from "react-i18next"; import ApiKey from "~/models/ApiKey"; import APITokenNew from "~/scenes/APITokenNew"; import { Action } from "~/components/Actions"; import Button from "~/components/Button"; import Heading from "~/components/Heading"; import Modal from "~/components/Modal"; import PaginatedList from "~/components/PaginatedList"; import Scene from "~/components/Scene"; import Text from "~/components/Text"; import useBoolean from "~/hooks/useBoolean"; import useCurrentTeam from "~/hooks/useCurrentTeam"; import usePolicy from "~/hooks/usePolicy"; import useStores from "~/hooks/useStores"; import TokenListItem from "./components/TokenListItem"; function Tokens() { const team = useCurrentTeam(); const { t } = useTranslation(); const { apiKeys } = useStores(); const [newModalOpen, handleNewModalOpen, handleNewModalClose] = useBoolean(); const can = usePolicy(team); return ( } actions={ <> {can.createApiKey && (