import { useNavigate } from 'react-router-dom'; import styled from '@emotion/styled'; import { useOptimisticEffect } from '@/apollo/optimistic-effect/hooks/useOptimisticEffect'; import { objectSettingsWidth } from '@/settings/data-model/constants/objectSettings'; import { SettingsApiKeysFieldItemTableRow } from '@/settings/developers/components/SettingsApiKeysFieldItemTableRow'; import { getApiKeysOptimisticEffectDefinition } from '@/settings/developers/optimistic-effect-definitions/getApiKeysOptimisticEffectDefinition'; import { formatExpirations } from '@/settings/developers/utils/format-expiration'; import { IconPlus, IconSettings } from '@/ui/display/icon'; import { H1Title } from '@/ui/display/typography/components/H1Title'; import { H2Title } from '@/ui/display/typography/components/H2Title'; import { Button } from '@/ui/input/button/components/Button'; import { SubMenuTopBarContainer } from '@/ui/layout/page/SubMenuTopBarContainer'; import { Table } from '@/ui/layout/table/components/Table'; import { TableHeader } from '@/ui/layout/table/components/TableHeader'; import { TableRow } from '@/ui/layout/table/components/TableRow'; import { useGetApiKeysQuery } from '~/generated/graphql'; const StyledContainer = styled.div` height: fit-content; padding: ${({ theme }) => theme.spacing(8)}; width: ${objectSettingsWidth}; `; const StyledTableRow = styled(TableRow)` grid-template-columns: 180px 98.7px 98.7px 98.7px 36px; `; const StyledHeader = styled.div` align-items: center; display: flex; justify-content: space-between; margin-bottom: ${({ theme }) => theme.spacing(8)}; `; const StyledH1Title = styled(H1Title)` margin-bottom: 0; `; export const SettingsDevelopersApiKeys = () => { const navigate = useNavigate(); const { registerOptimisticEffect } = useOptimisticEffect(); const apiKeysQuery = useGetApiKeysQuery({ onCompleted: () => { registerOptimisticEffect({ variables: {}, definition: getApiKeysOptimisticEffectDefinition, }); }, }); const apiKeys = apiKeysQuery.data ? formatExpirations(apiKeysQuery.data) : []; return (