Skip to content

Commit

Permalink
feat: deleting release-plan templates (#8678)
Browse files Browse the repository at this point in the history
  • Loading branch information
daveleek authored Nov 6, 2024
1 parent f5eafe6 commit cfe19de
Show file tree
Hide file tree
Showing 3 changed files with 88 additions and 2 deletions.
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { useState } from 'react';
import { useCallback, useState } from 'react';
import {
IconButton,
Tooltip,
Expand All @@ -8,12 +8,34 @@ import {
} from '@mui/material';
import MoreVertIcon from '@mui/icons-material/MoreVert';
import type { IReleasePlanTemplate } from 'interfaces/releasePlans';
import { useReleasePlanTemplatesApi } from 'hooks/api/actions/useReleasePlanTemplatesApi/useReleasePlanTemplatesApi';
import { useReleasePlanTemplates } from 'hooks/api/getters/useReleasePlanTemplates/useReleasePlanTemplates';
import useToast from 'hooks/useToast';
import { formatUnknownError } from 'utils/formatUnknownError';
import { TemplateDeleteDialog } from './TemplateDeleteDialog';

export const ReleasePlanTemplateCardMenu = ({
template,
}: { template: IReleasePlanTemplate }) => {
const [isMenuOpen, setIsMenuOpen] = useState(false);
const [anchorEl, setAnchorEl] = useState<Element | null>(null);
const { deleteReleasePlanTemplate } = useReleasePlanTemplatesApi();
const { refetch } = useReleasePlanTemplates();
const { setToastData, setToastApiError } = useToast();
const [deleteOpen, setDeleteOpen] = useState(false);
const deleteReleasePlan = useCallback(async () => {
try {
await deleteReleasePlanTemplate(template.id);
refetch();
setToastData({
type: 'success',
title: 'Success',
text: 'Release plan template deleted',
});
} catch (error: unknown) {
setToastApiError(formatUnknownError(error));
}
}, [setToastApiError, refetch, setToastData, deleteReleasePlanTemplate]);

const closeMenu = () => {
setIsMenuOpen(false);
Expand Down Expand Up @@ -66,12 +88,19 @@ export const ReleasePlanTemplateCardMenu = ({
</MenuItem>
<MenuItem
onClick={() => {
setDeleteOpen(true);
closeMenu();
}}
>
<ListItemText>Delete template </ListItemText>
<ListItemText>Delete template</ListItemText>
</MenuItem>
</Menu>
<TemplateDeleteDialog
template={template}
open={deleteOpen}
setOpen={setDeleteOpen}
onConfirm={deleteReleasePlan}
/>
</>
);
};
Original file line number Diff line number Diff line change
@@ -0,0 +1,34 @@
import { Dialogue } from 'component/common/Dialogue/Dialogue';
import type { IReleasePlanTemplate } from 'interfaces/releasePlans';

interface ITemplateDeleteDialogProps {
template?: IReleasePlanTemplate;
open: boolean;
setOpen: React.Dispatch<React.SetStateAction<boolean>>;
onConfirm: (template: IReleasePlanTemplate) => void;
}

export const TemplateDeleteDialog: React.FC<ITemplateDeleteDialogProps> = ({
template,
open,
setOpen,
onConfirm,
}) => {
return (
<Dialogue
title='Delete release plan template?'
open={open}
primaryButtonText='Delete template'
secondaryButtonText='Cancel'
onClick={() => onConfirm(template!)}
onClose={() => {
setOpen(false);
}}
>
<p>
You are about to delete release plan template:{' '}
<strong>{template?.name}</strong>
</p>
</Dialogue>
);
};
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
import useAPI from '../useApi/useApi';

export const useReleasePlanTemplatesApi = () => {
const { makeRequest, makeLightRequest, createRequest, errors, loading } =
useAPI({
propagateErrors: true,
});

const deleteReleasePlanTemplate = async (id: string) => {
const path = `api/admin/release-plan-templates/${id}`;
const req = createRequest(path, {
method: 'DELETE',
});

return makeRequest(req.caller, req.id);
};

return {
deleteReleasePlanTemplate,
};
};

export default useReleasePlanTemplatesApi;

0 comments on commit cfe19de

Please sign in to comment.