Skip to content

Commit

Permalink
wip
Browse files Browse the repository at this point in the history
  • Loading branch information
ibolton336 committed Sep 20, 2023
1 parent 2d191a6 commit 038230e
Show file tree
Hide file tree
Showing 7 changed files with 52 additions and 94 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@ import {
ApplicationDetailDrawer,
IApplicationDetailDrawerProps,
} from "./application-detail-drawer";
import { useGetReviewByItemId } from "@app/queries/reviews";
import { useFetchReviewById } from "@app/queries/reviews";

export interface IApplicationDetailDrawerAssessmentProps
extends Pick<IApplicationDetailDrawerProps, "application" | "onCloseClick"> {
Expand All @@ -32,7 +32,7 @@ export const ApplicationDetailDrawerAssessment: React.FC<
> = ({ application, onCloseClick, task }) => {
const { t } = useTranslation();

const { review: appReview } = useGetReviewByItemId(application?.id);
const { review: appReview } = useFetchReviewById(application?.review?.id);
const notYetReviewed = (
<EmptyTextMessage message={t("terms.notYetReviewed")} />
);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -37,7 +37,7 @@ import { ApplicationSelectionContext } from "../../application-selection-context
import { CartesianSquare } from "./cartesian-square";
import { Arrow } from "./arrow";
import useFetchApplicationDependencies from "@app/hooks/useFetchApplicationDependencies/useFetchApplicationDependencies";
import { useGetReviewByItemId } from "@app/queries/reviews";
import { useFetchReviewById } from "@app/queries/reviews";

interface Line {
from: LinePoint;
Expand Down Expand Up @@ -165,7 +165,7 @@ export const AdoptionCandidateGraph: React.FC = () => {
const appConfidence = confidences.find(
(elem) => elem.applicationId === current.id
);
const { review: appReview } = useGetReviewByItemId(current?.id);
const { review: appReview } = useFetchReviewById(current?.review?.id);

if (appConfidence && appReview) {
const key = appReview.proposedAction;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@ import {
} from "@app/api/models";

import { ApplicationSelectionContext } from "../../application-selection-context";
import { useGetReviewByItemId } from "@app/queries/reviews";
import { useFetchReviewById } from "@app/queries/reviews";
import { useQuery } from "@tanstack/react-query";
import { useFetchRisks } from "@app/queries/risks";
import { AppTableWithControls } from "@app/components/AppTableWithControls";
Expand Down Expand Up @@ -110,7 +110,7 @@ export const AdoptionCandidateTable: React.FC<IAdoptionCandidateTable> = () => {
const confidenceData = confidence?.find(
(e) => e.applicationId === app.id
);
const { review: reviewData } = useGetReviewByItemId(app?.id);
const { review: reviewData } = useFetchReviewById(app?.review?.id);

const riskData = assessmentRisks?.find((e) => e.applicationId === app.id);

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ import { Application, Assessment } from "@app/api/models";
import { useFetchQuestionnaires } from "@app/queries/questionnaires";

export interface IApplicationDetailsProps {
application: Application;
application?: Application;
assessment?: Assessment;
}

Expand All @@ -27,7 +27,7 @@ export const ApplicationDetails: React.FC<IApplicationDetailsProps> = ({
(questionnaire) => questionnaire.id === assessment?.questionnaire?.id
);
const { t } = useTranslation();
if (!matchingQuestionnaire) {
if (!matchingQuestionnaire || !application) {
return null;
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -55,6 +55,7 @@ export const ReviewForm: React.FC<IReviewFormProps> = ({
application,
review,
}) => {
console.log("existing review", review);
const { t } = useTranslation();
const history = useHistory();
const { pushNotification } = React.useContext(NotificationsContext);
Expand Down
69 changes: 31 additions & 38 deletions client/src/app/pages/review/review-page.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -22,8 +22,9 @@ import QuestionnaireSummary, {
SummaryType,
} from "@app/components/questionnaire-summary/questionnaire-summary";
import { PageHeader } from "@app/components/PageHeader";
import { useGetReviewByItemId } from "@app/queries/reviews";
import { useFetchReviewById } from "@app/queries/reviews";
import useIsArchetype from "@app/hooks/useIsArchetype";
import { useFetchApplicationById } from "@app/queries/applications";
import { useFetchArchetypeById } from "@app/queries/archetypes";

const ReviewPage: React.FC = () => {
Expand All @@ -32,12 +33,15 @@ const ReviewPage: React.FC = () => {
const { applicationId, archetypeId } = useParams<ReviewRoute>();
const isArchetype = useIsArchetype();

const { application, review, fetchError, isFetching } = useGetReviewByItemId(
applicationId || archetypeId
);

const { archetype } = useFetchArchetypeById(archetypeId);
const { application } = useFetchApplicationById(applicationId);

const { review, fetchError, isFetching } = useFetchReviewById(
isArchetype ? archetype?.review?.id : application?.review?.id
);
console.log("archetype.review", archetype?.review?.id);
console.log("reviewl", review);
console.log("isFetchign", isFetching);
const assessment = undefined;
const breadcrumbs = [
...(isArchetype
Expand All @@ -53,10 +57,10 @@ const ReviewPage: React.FC = () => {
path: Paths.applications,
},
]),
{
title: t("terms.review"),
path: Paths.applicationsReview,
},
// {
// title: t("terms.review"),
// path: Paths.applicationsReview,
// },
];

if (fetchError) {
Expand Down Expand Up @@ -92,41 +96,30 @@ const ReviewPage: React.FC = () => {
description={
<Text component="p">{t("message.reviewInstructions")}</Text>
}
breadcrumbs={[
{
title: t("terms.applications"),
path: Paths.applications,
},
{
title: t("terms.review"),
path: Paths.applicationsReview,
},
]}
breadcrumbs={breadcrumbs}
menuActions={[]}
/>
</PageSection>
<PageSection variant="light">
<ConditionalRender when={isFetching} then={<AppPlaceholder />}>
<Grid hasGutter>
{application && (
<GridItem md={5}>
<div className="pf-v5-c-form">
<FormSection>
<ApplicationDetails
application={application}
assessment={assessment}
/>
</FormSection>
<FormSection>
<ReviewForm
review={review}
application={application}
archetype={archetype}
/>
</FormSection>
</div>
</GridItem>
)}
<GridItem md={5}>
<div className="pf-v5-c-form">
<FormSection>
<ApplicationDetails
application={application}
assessment={assessment}
/>
</FormSection>
<FormSection>
<ReviewForm
review={review}
application={application}
archetype={archetype}
/>
</FormSection>
</div>
</GridItem>
{assessment && (
<GridItem md={6}>
<ApplicationAssessmentDonutChart assessment={assessment} />
Expand Down
60 changes: 12 additions & 48 deletions client/src/app/queries/reviews.ts
Original file line number Diff line number Diff line change
Expand Up @@ -9,8 +9,6 @@ import {
} from "@app/api/rest";
import { New, Review } from "@app/api/models";
import { AxiosError } from "axios";
import { useFetchApplicationById } from "./applications";
import { useFetchArchetypeById } from "./archetypes";

export const reviewQueryKey = "review";
export const reviewsByItemIdQueryKey = "reviewsByItemId";
Expand Down Expand Up @@ -92,52 +90,18 @@ export const useDeleteReviewMutation = (
});
};

export function useGetReviewByItemId(id?: string | number) {
const {
application,
isFetching: isApplicationFetching,
fetchError: applicationError,
} = useFetchApplicationById(id);

const {
archetype,
isFetching: isArchetypeFetching,
fetchError: archetypeError,
} = useFetchArchetypeById(id);

let review = null;
let isLoading = false;
let isError = false;

const reviewId = application?.review?.id || archetype?.review?.id;

const reviewQuery = useQuery(
[
reviewsByItemIdQueryKey,
reviewId,
application?.review?.id,
archetype?.review?.id,
],
() => (reviewId ? getReviewById(reviewId) : null),
{
enabled: !!reviewId,
}
);

if (reviewId) {
review = reviewQuery.data;
isLoading = reviewQuery.isLoading;
isError = reviewQuery.isError;
}
export const useFetchReviewById = (id?: number | string) => {
const { data, isLoading, error, isFetching } = useQuery({
queryKey: [reviewQueryKey, id],
queryFn: () =>
id === undefined ? Promise.resolve(null) : getReviewById(id),
onError: (error: AxiosError) => console.log("error, ", error),
enabled: id !== undefined,
});

return {
application,
archetype,
review,
isLoading,
isError,
isFetching: isApplicationFetching || isLoading || isArchetypeFetching,
fetchError:
applicationError || (review ? reviewQuery.error : null) || archetypeError,
review: data,
isFetching: isFetching,
fetchError: error,
};
}
};

0 comments on commit 038230e

Please sign in to comment.