1
0
mirror of https://github.com/Unleash/unleash.git synced 2025-01-25 00:07:47 +01:00

feat: update description on project deletion (#7539)

Improving the project deletion experience by adding information about
API keys and refining the messaging, making it easier to comprehend.
This commit is contained in:
Tymoteusz Czech 2024-07-05 13:07:47 +02:00 committed by GitHub
parent 963d051632
commit 1d7cd2e274
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 56 additions and 22 deletions

View File

@ -4,6 +4,10 @@ import { formatUnknownError } from 'utils/formatUnknownError';
import useProjectApi from 'hooks/api/actions/useProjectApi/useProjectApi';
import useProjects from 'hooks/api/getters/useProjects/useProjects';
import useToast from 'hooks/useToast';
import { ConditionallyRender } from 'component/common/ConditionallyRender/ConditionallyRender';
import { useUiFlag } from 'hooks/useUiFlag';
import useUiConfig from 'hooks/api/getters/useUiConfig/useUiConfig';
import { Typography } from '@mui/material';
interface IDeleteProjectDialogueProps {
project: string;
@ -21,6 +25,8 @@ export const DeleteProjectDialogue = ({
const { deleteProject } = useProjectApi();
const { refetch: refetchProjectOverview } = useProjects();
const { setToastData, setToastApiError } = useToast();
const { isEnterprise } = useUiConfig();
const automatedActionsEnabled = useUiFlag('automatedActions');
const onClick = async (e: React.SyntheticEvent) => {
e.preventDefault();
@ -45,6 +51,16 @@ export const DeleteProjectDialogue = ({
onClick={onClick}
onClose={onClose}
title='Really delete project'
/>
>
<Typography>
This will irreversibly remove the project, all feature flags
archived in it, all API keys scoped to only this project
<ConditionallyRender
condition={isEnterprise() && automatedActionsEnabled}
show=', and all actions configured for it'
/>
.
</Typography>
</Dialogue>
);
};

View File

@ -36,41 +36,59 @@ export const DeleteProject = ({
const automatedActionsEnabled = useUiFlag('automatedActions');
const { actions } = useActions(projectId);
const [showDelDialog, setShowDelDialog] = useState(false);
const actionsCount = actions.filter(({ enabled }) => enabled).length;
const navigate = useNavigate();
return (
<StyledContainer>
<p>
Before you can delete a project, you must first archive all the
feature flags associated with it. Keep in mind that deleting a
project will permanently remove all the archived feature flags,
and they cannot be recovered once deleted.
feature flags associated with it
{isEnterprise() && automatedActionsEnabled
? 'and disable all actions that are in it'
: ''}
.
</p>
<ConditionallyRender
condition={isEnterprise() && automatedActionsEnabled}
condition={featureCount > 0}
show={
<p>
Additionally, all configured actions for this project
will no longer be executed as they will be permanently
deleted.
</p>
}
/>
<p>
Currently there are{' '}
<strong>{featureCount} feature flags active</strong>
</p>
<ConditionallyRender
condition={isEnterprise() && automatedActionsEnabled}
show={
<p>
Currently there are{' '}
Currently there {featureCount <= 1 ? 'is' : 'are'}{' '}
<strong>
{actions.filter(({ enabled }) => enabled).length}{' '}
enabled actions
{featureCount} active feature{' '}
{featureCount === 1 ? 'flag' : 'flags'}.
</strong>
</p>
}
/>
<ConditionallyRender
condition={
isEnterprise() &&
automatedActionsEnabled &&
actionsCount > 0
}
show={
<p>
Currently there {actionsCount <= 1 ? 'is' : 'are'}{' '}
<strong>
{actionsCount} enabled{' '}
{actionsCount === 1 ? 'action' : 'actions'}.
</strong>
</p>
}
/>
<p>
Keep in mind that deleting a project{' '}
<strong>will permanently remove</strong>
<ul>
<li>all archived feature flags in this project</li>
<li>API keys configured to access only this project</li>
<ConditionallyRender
condition={isEnterprise() && automatedActionsEnabled}
show={<li>all actions configured for this project</li>}
/>
</ul>
and they <strong>cannot be recovered</strong> once deleted.
</p>
<StyledButtonContainer>
<PermissionButton
permission={DELETE_PROJECT}