diff --git a/src/components/repositories/RepositoryDangerSettings.tsx b/src/components/repositories/RepositoryDangerSettings.tsx new file mode 100644 index 000000000..7f5fbf893 --- /dev/null +++ b/src/components/repositories/RepositoryDangerSettings.tsx @@ -0,0 +1,95 @@ +import React, { useState } from 'react'; +import environment from '../../createRelayEnvironment'; +import { commitMutation, createFragmentContainer } from 'react-relay'; +import { graphql } from 'babel-plugin-relay/macro'; +import Card from '@mui/material/Card'; +import CardContent from '@mui/material/CardContent'; +import CardHeader from '@mui/material/CardHeader'; +import FormControl from '@mui/material/FormControl'; +import { RepositoryDangerSettings_repository } from './__generated__/RepositoryDangerSettings_repository.graphql'; +import { navigateHelper } from '../../utils/navigateHelper'; +import { useNavigate } from 'react-router-dom'; +import { + RepositoryDangerSettingsDeleteMutationResponse, + RepositoryDangerSettingsDeleteMutationVariables, +} from './__generated__/RepositoryDangerSettingsDeleteMutation.graphql'; +import InputLabel from '@mui/material/InputLabel'; +import Input from '@mui/material/Input'; +import { FormHelperText, ListItem, ListItemText } from '@mui/material'; +import Button from '@mui/material/Button'; +import Check from '@mui/icons-material/Check'; +import List from '@mui/material/List'; + +const deleteMutation = graphql` + mutation RepositoryDangerSettingsDeleteMutation($input: RepositoryDeleteInput!) { + deleteRepository(input: $input) { + deleted + } + } +`; + +interface Props { + repository: RepositoryDangerSettings_repository; +} + +function RepositoryDangerSettings(props: Props) { + let navigate = useNavigate(); + let [inputValue, setInputValue] = useState(''); + let [securedVariableName, setSecuredVariableName] = useState(undefined); + + function deleteCurrentRepository() { + let valueToSecure = inputValue; + const variables: RepositoryDangerSettingsDeleteMutationVariables = { + input: { + clientMutationId: props.repository.name, // todo: replace with a hash of valueToSecure + repositoryId: props.repository.id, + }, + }; + + commitMutation(environment, { + mutation: deleteMutation, + variables: variables, + onCompleted: (response: RepositoryDangerSettingsDeleteMutationResponse, errors) => { + if (errors) { + console.log(errors); + } else { + navigateHelper(navigate, null, '/'); + } + }, + onError: err => console.error(err), + }); + } + + return ( + + + + + deleteCurrentRepository()}> + Delete + + } + disablePadding + > + + + + + + ); +} + +export default createFragmentContainer(RepositoryDangerSettings, { + repository: graphql` + fragment RepositoryDangerSettings_repository on Repository { + id + owner + name + } + `, +}); diff --git a/src/components/repositories/RepositorySettingsPage.tsx b/src/components/repositories/RepositorySettingsPage.tsx index 7a15ae92f..20b4714ae 100644 --- a/src/components/repositories/RepositorySettingsPage.tsx +++ b/src/components/repositories/RepositorySettingsPage.tsx @@ -11,6 +11,7 @@ import withStyles from '@mui/styles/withStyles'; import { RepositorySettingsPage_repository } from './__generated__/RepositorySettingsPage_repository.graphql'; import RepositoryCronSettings from './RepositoryCronSettings'; import { Link } from '@mui/material'; +import RepositoryDangerSettings from './RepositoryDangerSettings'; const styles = { settingGap: { @@ -51,6 +52,10 @@ let RepositorySettingsPage = (props: Props) => { +
+ + +
); }; @@ -64,6 +69,7 @@ export default createFragmentContainer(withStyles(styles)(RepositorySettingsPage ...RepositorySettings_repository ...RepositorySecuredVariables_repository ...RepositoryCronSettings_repository + ...RepositoryDangerSettings_repository } `, });