From 161fba8feecc4ce1bb0412dc887de0cd91256ada Mon Sep 17 00:00:00 2001 From: Radoslaw Szwajkowski Date: Fri, 15 Mar 2024 14:09:44 +0100 Subject: [PATCH] :sparkles: Add assessment/review status to archetype table (#1755) Review states: 1. Completed - a review exists 2. NotStarted Assessment states: 1. Completed - all required assessments done (based on 'assessed' flag) 2. InProgress - some assessments done 3. NotStarted Resolves: https://github.com/konveyor/tackle2-ui/issues/1751 Signed-off-by: Radoslaw Szwajkowski Co-authored-by: Ian Bolton --- .../app/pages/archetypes/archetypes-page.tsx | 125 ++++++++++++------ 1 file changed, 85 insertions(+), 40 deletions(-) diff --git a/client/src/app/pages/archetypes/archetypes-page.tsx b/client/src/app/pages/archetypes/archetypes-page.tsx index 0f44e8f1ca..b11e247497 100644 --- a/client/src/app/pages/archetypes/archetypes-page.tsx +++ b/client/src/app/pages/archetypes/archetypes-page.tsx @@ -43,6 +43,8 @@ import { useLocalTableControls, } from "@app/hooks/table-controls"; import { + ARCHETYPES_QUERY_KEY, + ARCHETYPE_QUERY_KEY, useDeleteArchetypeMutation, useFetchArchetypes, } from "@app/queries/archetypes"; @@ -69,11 +71,14 @@ import { } from "@app/rbac"; import { checkAccess } from "@app/utils/rbac-utils"; import keycloak from "@app/keycloak"; +import { IconedStatus } from "@app/components/IconedStatus"; +import { useQueryClient } from "@tanstack/react-query"; const Archetypes: React.FC = () => { const { t } = useTranslation(); const history = useHistory(); const { pushNotification } = React.useContext(NotificationsContext); + const queryClient = useQueryClient(); const [openCreateArchetype, setOpenCreateArchetype] = useState(false); @@ -115,34 +120,37 @@ const Archetypes: React.FC = () => { onError ); - const { mutate: deleteAssessment } = useDeleteAssessmentMutation(); - - const discardAssessment = async (archetype: Archetype) => { - try { - if (archetype.assessments) { - await Promise.all( - archetype.assessments.map(async (assessment) => { - await deleteAssessment({ - assessmentId: assessment.id, - archetypeId: archetype.id, - }); - }) - ).then(() => { - pushNotification({ - title: t("toastr.success.assessmentDiscarded", { - application: archetype.name, - }), - variant: "success", - }); + const { mutateAsync: deleteAssessment } = useDeleteAssessmentMutation(); + + const discardAssessment = (archetype: Archetype) => { + if (!archetype.assessments) { + return; + } + Promise.all( + archetype.assessments.map((assessment) => + deleteAssessment({ + assessmentId: assessment.id, + archetypeId: archetype.id, + }) + ) + ) + .then(() => { + pushNotification({ + title: t("toastr.success.assessmentDiscarded", { + application: archetype.name, + }), + variant: "success", + }); + queryClient.invalidateQueries([ARCHETYPES_QUERY_KEY]); + queryClient.invalidateQueries([ARCHETYPE_QUERY_KEY, archetype.id]); + }) + .catch((error) => { + console.error("Error while deleting assessments:", error); + pushNotification({ + title: getAxiosErrorMessage(error as AxiosError), + variant: "danger", }); - } - } catch (error) { - console.error("Error while deleting assessments:", error); - pushNotification({ - title: getAxiosErrorMessage(error as AxiosError), - variant: "danger", }); - } }; const onDeleteReviewSuccess = (name: string) => { @@ -154,25 +162,29 @@ const Archetypes: React.FC = () => { }); }; - const { mutate: deleteReview } = useDeleteReviewMutation( + const { mutateAsync: deleteReview } = useDeleteReviewMutation( onDeleteReviewSuccess ); - const discardReview = async (archetype: Archetype) => { - try { - if (archetype.review?.id) { - await deleteReview({ - id: archetype.review.id, - name: archetype.name, + const discardReview = (archetype: Archetype) => { + if (!archetype.review?.id) { + return; + } + deleteReview({ + id: archetype.review.id, + name: archetype.name, + }) + .then(() => { + queryClient.invalidateQueries([ARCHETYPES_QUERY_KEY]); + queryClient.invalidateQueries([ARCHETYPE_QUERY_KEY, archetype.id]); + }) + .catch((error) => { + console.error("Error while deleting review:", error); + pushNotification({ + title: getAxiosErrorMessage(error as AxiosError), + variant: "danger", }); - } - } catch (error) { - console.error("Error while deleting review:", error); - pushNotification({ - title: getAxiosErrorMessage(error as AxiosError), - variant: "danger", }); - } }; const urlParams = new URLSearchParams(window.location.search); const filters = urlParams.get("filters"); @@ -193,6 +205,8 @@ const Archetypes: React.FC = () => { tags: t("terms.tags"), maintainers: t("terms.maintainers"), applications: t("terms.applications"), + assessment: t("terms.assessment"), + review: t("terms.review"), }, isFilterEnabled: true, @@ -380,6 +394,11 @@ const Archetypes: React.FC = () => { + + @@ -427,6 +446,32 @@ const Archetypes: React.FC = () => { + + + + + + {(archetypeWriteAccess || assessmentWriteAccess ||