diff --git a/client/src/app/pages/applications/applications-table/applications-table.tsx b/client/src/app/pages/applications/applications-table/applications-table.tsx index bd45aa2f41..f64899b4bf 100644 --- a/client/src/app/pages/applications/applications-table/applications-table.tsx +++ b/client/src/app/pages/applications/applications-table/applications-table.tsx @@ -87,7 +87,7 @@ import { useDeleteAssessmentMutation, useFetchAssessments, } from "@app/queries/assessments"; -import { useDeleteReviewMutation } from "@app/queries/reviews"; +import { useDeleteReviewMutation, useFetchReviews } from "@app/queries/reviews"; import { useFetchIdentities } from "@app/queries/identities"; import { useFetchTagsWithTagItems } from "@app/queries/tags"; @@ -119,6 +119,9 @@ export const ApplicationsTable: React.FC = () => { const { pushNotification } = React.useContext(NotificationsContext); const { identities } = useFetchIdentities(); + + const { reviews, isFetching: isFetchingReviews } = useFetchReviews(); + const [isToolbarKebabOpen, setIsToolbarKebabOpen] = React.useState(false); @@ -1099,6 +1102,8 @@ export const ApplicationsTable: React.FC = () => { application={activeItem} applications={applications} assessments={assessments} + archetypes={archetypes} + reviews={reviews} onCloseClick={clearActiveItem} onEditClick={() => setSaveApplicationModalState(activeItem)} task={activeItem ? getTask(activeItem) : null} diff --git a/client/src/app/pages/applications/components/application-detail-drawer/application-detail-drawer.tsx b/client/src/app/pages/applications/components/application-detail-drawer/application-detail-drawer.tsx index b721a02478..d32f14fad8 100644 --- a/client/src/app/pages/applications/components/application-detail-drawer/application-detail-drawer.tsx +++ b/client/src/app/pages/applications/components/application-detail-drawer/application-detail-drawer.tsx @@ -32,6 +32,7 @@ import { Ref, Archetype, AssessmentWithSectionOrder, + Review, } from "@app/api/models"; import { IPageDrawerContentProps, @@ -57,7 +58,6 @@ import { ReviewFields } from "./review-fields"; import { LabelsFromItems } from "@app/components/labels/labels-from-items/labels-from-items"; import { RiskLabel } from "@app/components/RiskLabel"; import { ApplicationDetailFields } from "./application-detail-fields"; -import { useFetchArchetypes } from "@app/queries/archetypes"; import { AssessedArchetypes } from "./components/assessed-archetypes"; export interface IApplicationDetailDrawerProps @@ -66,6 +66,8 @@ export interface IApplicationDetailDrawerProps task: Task | undefined | null; applications?: Application[]; assessments?: AssessmentWithSectionOrder[]; + reviews?: Review[]; + archetypes?: Archetype[]; onEditClick: () => void; } @@ -79,7 +81,15 @@ enum TabKey { export const ApplicationDetailDrawer: React.FC< IApplicationDetailDrawerProps -> = ({ onCloseClick, application, assessments, task, onEditClick }) => { +> = ({ + onCloseClick, + application, + assessments, + reviews, + archetypes, + task, + onEditClick, +}) => { const { t } = useTranslation(); const [activeTabKey, setActiveTabKey] = React.useState( TabKey.Details @@ -88,7 +98,6 @@ export const ApplicationDetailDrawer: React.FC< const isTaskRunning = task?.state === "Running"; const { identities } = useFetchIdentities(); - const { archetypes } = useFetchArchetypes(); const { facts, isFetching } = useFetchFacts(application?.id); const [taskIdToView, setTaskIdToView] = React.useState(); @@ -106,8 +115,9 @@ export const ApplicationDetailDrawer: React.FC< const reviewedArchetypes = application?.archetypes - ?.map((archetypeRef) => - archetypes.find((archetype) => archetype.id === archetypeRef.id) + ?.map( + (archetypeRef) => + archetypes?.find((archetype) => archetype.id === archetypeRef.id) ) .filter((fullArchetype) => fullArchetype?.review) .filter(Boolean) || []; @@ -445,7 +455,7 @@ export const ApplicationDetailDrawer: React.FC< eventKey={TabKey.Reviews} title={{t("terms.review")}} > - + diff --git a/client/src/app/pages/applications/components/application-detail-drawer/review-fields.tsx b/client/src/app/pages/applications/components/application-detail-drawer/review-fields.tsx index f40fdfce1c..c14d13e74c 100644 --- a/client/src/app/pages/applications/components/application-detail-drawer/review-fields.tsx +++ b/client/src/app/pages/applications/components/application-detail-drawer/review-fields.tsx @@ -6,11 +6,12 @@ import { DescriptionListDescription, } from "@patternfly/react-core"; import { Application, Archetype, Review } from "@app/api/models"; -import { useFetchReviewById, useFetchReviews } from "@app/queries/reviews"; +import { useFetchReviewById } from "@app/queries/reviews"; import { useFetchArchetypes } from "@app/queries/archetypes"; import { EmptyTextMessage } from "@app/components/EmptyTextMessage"; import { PROPOSED_ACTION_LIST, EFFORT_ESTIMATE_LIST } from "@app/Constants"; import { ReviewLabel } from "./review-label"; +import spacing from "@patternfly/react-styles/css/utilities/Spacing/spacing"; export type ReviewDrawerLabelItem = { review?: Review | null; @@ -21,9 +22,9 @@ export type ReviewDrawerLabelItem = { export const ReviewFields: React.FC<{ application?: Application | null; archetype?: Archetype | null; -}> = ({ application, archetype }) => { + reviews?: Review[]; +}> = ({ application, archetype, reviews }) => { const { archetypes } = useFetchArchetypes(); - const { reviews } = useFetchReviews(); const { t } = useTranslation(); const { review: appReview } = useFetchReviewById(application?.review?.id); @@ -41,7 +42,7 @@ export const ReviewFields: React.FC<{ const matchedArchetypeReviews: Review[] = (applicationArchetypes || []) .map((archetype) => { - return reviews.find((review) => review.id === archetype?.review?.id); + return reviews?.find((review) => review.id === archetype?.review?.id); }) .filter(Boolean); @@ -71,7 +72,7 @@ export const ReviewFields: React.FC<{ ].filter((item) => item.review?.proposedAction); return ( - <> +
{t("terms.proposedAction")} @@ -150,6 +151,6 @@ export const ReviewFields: React.FC<{ })} - +
); }; diff --git a/client/src/app/pages/archetypes/components/archetype-detail-drawer.tsx b/client/src/app/pages/archetypes/components/archetype-detail-drawer.tsx index 90b85d0574..d6f2f80832 100644 --- a/client/src/app/pages/archetypes/components/archetype-detail-drawer.tsx +++ b/client/src/app/pages/archetypes/components/archetype-detail-drawer.tsx @@ -18,7 +18,7 @@ import { } from "@patternfly/react-core"; import spacing from "@patternfly/react-styles/css/utilities/Spacing/spacing"; -import { Archetype, Ref, Tag, TagRef } from "@app/api/models"; +import { Archetype, Ref, Review, Tag, TagRef } from "@app/api/models"; import { EmptyTextMessage } from "@app/components/EmptyTextMessage"; import { PageDrawerContent } from "@app/components/PageDrawerContext"; @@ -34,6 +34,7 @@ import { Link } from "react-router-dom"; export interface IArchetypeDetailDrawerProps { onCloseClick: () => void; archetype: Archetype | null; + reviews?: Review[]; } enum TabKey { @@ -44,6 +45,7 @@ enum TabKey { const ArchetypeDetailDrawer: React.FC = ({ onCloseClick, archetype, + reviews, }) => { const { t } = useTranslation(); @@ -226,7 +228,7 @@ const ArchetypeDetailDrawer: React.FC = ({ eventKey={TabKey.Reviews} title={{t("terms.review")}} > - + diff --git a/client/src/app/pages/review/components/review-form/review-form.tsx b/client/src/app/pages/review/components/review-form/review-form.tsx index 7b6100d4e2..3ebcfecb63 100644 --- a/client/src/app/pages/review/components/review-form/review-form.tsx +++ b/client/src/app/pages/review/components/review-form/review-form.tsx @@ -55,7 +55,6 @@ export const ReviewForm: React.FC = ({ application, review, }) => { - console.log("existing review", review); const { t } = useTranslation(); const history = useHistory(); const { pushNotification } = React.useContext(NotificationsContext); diff --git a/client/src/app/queries/applications.ts b/client/src/app/queries/applications.ts index 8e5fc98eb8..12639b102e 100644 --- a/client/src/app/queries/applications.ts +++ b/client/src/app/queries/applications.ts @@ -20,7 +20,6 @@ import { updateAllApplications, updateApplication, } from "@app/api/rest"; -import { reviewsQueryKey } from "./reviews"; import { assessmentsByItemIdQueryKey } from "./assessments"; import saveAs from "file-saver"; @@ -41,7 +40,6 @@ export const useFetchApplications = (refetchDisabled: boolean = false) => { queryFn: getApplications, refetchInterval: !refetchDisabled ? 5000 : false, onSuccess: () => { - queryClient.invalidateQueries([reviewsQueryKey]); queryClient.invalidateQueries([assessmentsByItemIdQueryKey]); }, onError: (error: AxiosError) => console.log(error), diff --git a/client/src/app/queries/archetypes.ts b/client/src/app/queries/archetypes.ts index 2dc818c4db..b64c191064 100644 --- a/client/src/app/queries/archetypes.ts +++ b/client/src/app/queries/archetypes.ts @@ -10,7 +10,6 @@ import { updateArchetype, } from "@app/api/rest"; import { assessmentsByItemIdQueryKey } from "./assessments"; -import { reviewsQueryKey } from "./reviews"; import { useState } from "react"; export const ARCHETYPES_QUERY_KEY = "archetypes"; @@ -39,7 +38,6 @@ export const useFetchArchetypes = (forApplication?: Application | null) => { setFilteredArchetypes([]); } - queryClient.invalidateQueries([reviewsQueryKey]); queryClient.invalidateQueries([assessmentsByItemIdQueryKey]); }, onError: (error: AxiosError) => console.log(error),