diff --git a/frontend/src/fixtures/destructionListItem.ts b/frontend/src/fixtures/destructionListItem.ts index fe08291f6..bed7e13b1 100644 --- a/frontend/src/fixtures/destructionListItem.ts +++ b/frontend/src/fixtures/destructionListItem.ts @@ -12,6 +12,7 @@ export const FIXTURE_DESTRUCTION_LIST_ITEM: DestructionListItem = { zaak: zaakFactory(), processingStatus: "new", plannedDestructionDate: null, + reviewAdviceIgnored: null, }; export const FIXTURE_DESTRUCTION_LIST_ITEM_DELETED: DestructionListItem = { pk: 2, @@ -20,6 +21,7 @@ export const FIXTURE_DESTRUCTION_LIST_ITEM_DELETED: DestructionListItem = { zaak: null, processingStatus: "succeeded", plannedDestructionDate: "2026-01-01T00:00:00Z", + reviewAdviceIgnored: null, }; export const FIXTURE_DESTRUCTION_LIST_ITEM_FAILED: DestructionListItem = { pk: 3, @@ -28,6 +30,7 @@ export const FIXTURE_DESTRUCTION_LIST_ITEM_FAILED: DestructionListItem = { zaak: zaakFactory(), processingStatus: "failed", plannedDestructionDate: "2026-01-01T00:00:00Z", + reviewAdviceIgnored: null, }; export const destructionListItemFactory = createObjectFactory( diff --git a/frontend/src/hooks/useZaakReviewStatusBadges.tsx b/frontend/src/hooks/useZaakReviewStatusBadges.tsx index 89acd95ea..3b942c364 100644 --- a/frontend/src/hooks/useZaakReviewStatusBadges.tsx +++ b/frontend/src/hooks/useZaakReviewStatusBadges.tsx @@ -16,14 +16,27 @@ import { export function useZaakReviewStatusBadges( zakenOnPage: Zaak[], reviewedZaakSelectionOnPage: ZaakSelection<{ approved: boolean }>, + reviewAdviceIgnoredResults: Record, // Map of reviewAdviceIgnored ): Record { const statuses = useZaakReviewStatuses( zakenOnPage, reviewedZaakSelectionOnPage, ); + return useMemo(() => { const badges = zakenOnPage.map((z) => { const status = statuses[z.url as string]; + const reviewAdviceIgnored = reviewAdviceIgnoredResults[z.url as string]; + + if (reviewAdviceIgnored) { + // Display "Herboordelen" badge for reviewAdviceIgnored zaken + return ( + // @ts-expect-error - style props not supported (yet?) + + Herboordelen + + ); + } if (typeof status === "boolean") { if (status) { @@ -37,8 +50,7 @@ export function useZaakReviewStatusBadges( return ( // @ts-expect-error - style props not supported (yet?) - - Uitgezonderd + Uitgezonderd ); } @@ -46,8 +58,7 @@ export function useZaakReviewStatusBadges( return ( // @ts-expect-error - style props not supported (yet?) - - Niet beoordeeld + Niet beoordeeld ); } @@ -58,5 +69,5 @@ export function useZaakReviewStatusBadges( { badge: badges[i], status: statuses[z.url as string] }, ]); return Object.fromEntries(entries); - }, [statuses]); + }, [statuses, reviewAdviceIgnoredResults, zakenOnPage]); } diff --git a/frontend/src/lib/api/destructionListsItem.ts b/frontend/src/lib/api/destructionListsItem.ts index 49dfe293b..3ccc22f0c 100644 --- a/frontend/src/lib/api/destructionListsItem.ts +++ b/frontend/src/lib/api/destructionListsItem.ts @@ -10,6 +10,7 @@ export type DestructionListItem = { zaak: Zaak | null; processingStatus: ProcessingStatus; plannedDestructionDate: string | null; + reviewAdviceIgnored: boolean | null; }; export interface ZaakItem extends Zaak { @@ -32,15 +33,25 @@ export async function listDestructionListItems( page?: number; page_size?: number; "item-processing_status"?: ProcessingStatus; - "item-status": DestructionListItemStatus; // TODO ? - "item-order_review_ignored"?: string; + "item-status"?: DestructionListItemStatus; + "item-order_review_ignored"?: string | boolean; }, ) { + if (params && !(params instanceof URLSearchParams)) { + if (typeof params["item-order_review_ignored"] === "boolean") { + params["item-order_review_ignored"] = String( + params["item-order_review_ignored"], + ); + } + } + + // Use the params object directly in the request const response = await request("GET", "/destruction-list-items/", { "item-destruction_list": destructionListUuid, "item-status": "suggested", - ...params, - } as typeof params & { "item-destruction_list": string }); + ...((params as Record) || {}), + }); + const promise: Promise = response.json(); return promise; } diff --git a/frontend/src/lib/api/review.ts b/frontend/src/lib/api/review.ts index 89596adee..5281c5ead 100644 --- a/frontend/src/lib/api/review.ts +++ b/frontend/src/lib/api/review.ts @@ -5,7 +5,7 @@ import { request } from "./request"; export type Review = { destructionList: string; - decision: "accepted" | "rejected"; + decision: "accepted" | "rejected" | "ignored_review"; listFeedback: string; pk?: number; author?: User; diff --git a/frontend/src/pages/constants.tsx b/frontend/src/pages/constants.tsx index 2a16f8d0f..16e502780 100644 --- a/frontend/src/pages/constants.tsx +++ b/frontend/src/pages/constants.tsx @@ -10,6 +10,7 @@ import { Review } from "../lib/api/review"; export const REVIEW_DECISION_MAPPING: Record = { accepted: "Goedgekeurd", rejected: "Afgewezen", + ignored_review: "Herboordelen", }; export const REVIEW_DECISION_LEVEL_MAPPING: Record< @@ -18,6 +19,7 @@ export const REVIEW_DECISION_LEVEL_MAPPING: Record< > = { accepted: "success", rejected: "danger", + ignored_review: "info", }; export const STATUSES_ELIGIBLE_FOR_EDIT = ["new", "changes_requested"]; diff --git a/frontend/src/pages/destructionlist/review/DestructionListReview.loader.ts b/frontend/src/pages/destructionlist/review/DestructionListReview.loader.ts index b72758ae4..d9671eaca 100644 --- a/frontend/src/pages/destructionlist/review/DestructionListReview.loader.ts +++ b/frontend/src/pages/destructionlist/review/DestructionListReview.loader.ts @@ -80,8 +80,8 @@ export const destructionListReviewLoader = loginRequired( reviewResponsePromise, listReviewers(), listDestructionListItems(uuid, { - "item-order_review_ignored": String(true), - ...(objParams as unknown as URLSearchParams), + "item-order_review_ignored": true, + ...objParams, }), ]); diff --git a/frontend/src/pages/destructionlist/review/DestructionListReview.tsx b/frontend/src/pages/destructionlist/review/DestructionListReview.tsx index 6004ef366..fc2549bcb 100644 --- a/frontend/src/pages/destructionlist/review/DestructionListReview.tsx +++ b/frontend/src/pages/destructionlist/review/DestructionListReview.tsx @@ -123,15 +123,26 @@ export function DestructionListReviewPage() { ), ); + const reviewAdviceIgnoredResults = Object.fromEntries( + paginatedZaken.results.map((result) => [ + result.zaak?.url as string, + result.reviewAdviceIgnored || false, + ]), + ); + const submitAction = useSubmitAction(); const destructionListReviewKey = getDestructionListReviewKey( uuid, destructionList.status, ); - const zaakReviewStatusBadges = useZaakReviewStatusBadges(zakenResults, { - ...approvedZaakSelection, - ...excludedZaakSelection, - }); + const zaakReviewStatusBadges = useZaakReviewStatusBadges( + zakenResults, + { + ...approvedZaakSelection, + ...excludedZaakSelection, + }, + reviewAdviceIgnoredResults, + ); // The object list of the current page with review actions appended. const objectList = useMemo(() => {