From e4a1104961b950bcbd1c0864349b1804c7e32041 Mon Sep 17 00:00:00 2001 From: jabahum Date: Thu, 20 Jun 2024 09:05:21 +0300 Subject: [PATCH 01/10] lab filter setup --- .../completed-list.component.tsx | 5 ++-- .../referred-orders.component.tsx | 27 +++++++++++++++++- .../rejected-tests-list.component.tsx | 9 +++++- src/review-list/review-list.component.tsx | 5 ++-- .../laboratory-summary-tiles.component.tsx | 10 ++----- .../laboratory-tabs.component.tsx | 1 + .../tests-ordered-list.component.tsx | 28 +++++++++++++++++-- src/work-list/work-list.component.tsx | 8 +++--- src/work-list/work-list.resource.ts | 10 +++++-- 9 files changed, 80 insertions(+), 23 deletions(-) diff --git a/src/completed-list/completed-list.component.tsx b/src/completed-list/completed-list.component.tsx index 94dce05f..a30efb58 100644 --- a/src/completed-list/completed-list.component.tsx +++ b/src/completed-list/completed-list.component.tsx @@ -35,11 +35,12 @@ interface CompletedListProps { const CompletedList: React.FC = ({ fulfillerStatus }) => { const { t } = useTranslation(); - const today = dayjs(new Date()).format("YYYY-MM-DD"); + const fromDate = dayjs(new Date()).format("YYYY-MM-DD"); const { data: completedOrderList, isLoading } = useGetOrdersWorklist( fulfillerStatus, - today + fromDate, + "" ); const pageSizes = [10, 20, 30, 40, 50]; diff --git a/src/referred-orders/referred-orders.component.tsx b/src/referred-orders/referred-orders.component.tsx index e313aca9..f8ca40e5 100644 --- a/src/referred-orders/referred-orders.component.tsx +++ b/src/referred-orders/referred-orders.component.tsx @@ -23,14 +23,23 @@ import { TableToolbarSearch, Layer, Tile, + DatePicker, + DatePickerInput, } from "@carbon/react"; import { getStatusColor } from "../utils/functions"; import styles from "./referred-orders.scss"; +import dayjs from "dayjs"; const ReferredOrdersList: React.FC = () => { const { t } = useTranslation(); - const { data: referredOrderList, isLoading } = useGetOrdersWorklist(""); + const fromDate = dayjs(new Date()).format("YYYY-MM-DD"); + + const { data: referredOrderList, isLoading } = useGetOrdersWorklist( + "", + fromDate, + "" + ); const pageSizes = [10, 20, 30, 40, 50]; const [currentPageSize, setPageSize] = useState(10); @@ -127,6 +136,22 @@ const ReferredOrdersList: React.FC = () => { }} > + + + + + + { const { t } = useTranslation(); - const { data: pickedOrderList, isLoading } = useGetOrdersWorklist(""); + const fromDate = dayjs(new Date()).format("YYYY-MM-DD"); + + const { data: pickedOrderList, isLoading } = useGetOrdersWorklist( + "", + fromDate, + "" + ); const data = pickedOrderList.filter( (item) => item?.fulfillerStatus === "DECLINED" diff --git a/src/review-list/review-list.component.tsx b/src/review-list/review-list.component.tsx index d9584168..04b8658f 100644 --- a/src/review-list/review-list.component.tsx +++ b/src/review-list/review-list.component.tsx @@ -67,11 +67,12 @@ const ApproveTestMenu: React.FC = ({ const ReviewList: React.FC = ({ fulfillerStatus }) => { const { t } = useTranslation(); - const today = dayjs(new Date()).format("YYYY-MM-DD"); + const fromDate = dayjs(new Date()).format("YYYY-MM-DD"); const { data: reviewOrderEntries, isLoading } = useGetOrdersWorklist( fulfillerStatus, - today + fromDate, + "" ); const filtered = reviewOrderEntries?.filter( diff --git a/src/summary-tiles/laboratory-summary-tiles.component.tsx b/src/summary-tiles/laboratory-summary-tiles.component.tsx index 1c323767..5adf6c08 100644 --- a/src/summary-tiles/laboratory-summary-tiles.component.tsx +++ b/src/summary-tiles/laboratory-summary-tiles.component.tsx @@ -1,23 +1,16 @@ -import React, { useEffect, useMemo, useState } from "react"; +import React from "react"; import { useTranslation } from "react-i18next"; import styles from "./laboratory-summary-tiles.scss"; import { AssignedExtension, - ExtensionSlot, useConnectedExtensions, - useSession, - attach, - detachAll, Extension, } from "@openmrs/esm-framework"; import { ComponentContext } from "@openmrs/esm-framework/src/internal"; -import SummaryTile from "./summary-tile.component"; const LaboratorySummaryTiles: React.FC = () => { const { t } = useTranslation(); - const session = useSession(); - const labTileSlot = "lab-tiles-slot"; const tilesExtensions = useConnectedExtensions( @@ -33,6 +26,7 @@ const LaboratorySummaryTiles: React.FC = () => { { = () => { const { t } = useTranslation(); - const today = dayjs(new Date()).format("YYYY-MM-DD"); - const { data: pickedOrderList, isLoading } = useGetOrdersWorklist("", today); + + const fromDate = dayjs(new Date()).format("YYYY-MM-DD"); + + const { data: pickedOrderList, isLoading } = useGetOrdersWorklist( + "", + fromDate, + "" + ); const data = pickedOrderList.filter( (item) => @@ -138,6 +146,22 @@ const TestsOrderedList: React.FC = () => { }} > + + + + + + = ({ fulfillerStatus }) => { const { t } = useTranslation(); - const today = dayjs(new Date()).format("YYYY-MM-DD"); + const fromDate = dayjs(new Date()).format("YYYY-MM-DD"); const { data: pickedOrderEntries, isLoading } = useGetOrdersWorklist( fulfillerStatus, - today + fromDate, + "" ); const pageSizes = [10, 20, 30, 40, 50]; @@ -68,8 +69,7 @@ const WorkList: React.FC = ({ fulfillerStatus }) => { (item) => item?.fulfillerStatus === "IN_PROGRESS" && item?.accessionNumber !== null && - item?.dateStopped === null && - item?.instructions !== "REFER TO cphl" + item?.dateStopped === null ); const { diff --git a/src/work-list/work-list.resource.ts b/src/work-list/work-list.resource.ts index c067f728..87f52f5e 100644 --- a/src/work-list/work-list.resource.ts +++ b/src/work-list/work-list.resource.ts @@ -83,7 +83,11 @@ export interface IdentifierType { uuid: string; } -export function useGetOrdersWorklist(fulfillerStatus: string, date?: string) { +export function useGetOrdersWorklist( + fulfillerStatus: string, + dateFrom?: string, + dateTo?: string +) { const { laboratoryOrderTypeUuid } = useConfig(); const customRepresentation = "v=custom:(uuid,orderNumber,accessionNumber,instructions,careSetting:(uuid),encounter:(uuid,obs:(order:(uuid,display,patient:(uuid,display)))),fulfillerComment,orderType:(display),concept:(display,uuid),action,dateStopped,fulfillerStatus,dateActivated,orderer:(display),urgency,patient:(uuid,names:(display),display,gender,birthdate,identifiers:(voided,preferred,uuid,display,identifierType:(uuid))))"; @@ -92,8 +96,8 @@ export function useGetOrdersWorklist(fulfillerStatus: string, date?: string) { ? `orderTypes=${laboratoryOrderTypeUuid}` : ""; let apiUrl = `${restBaseUrl}/order?${orderTypeQuery}&fulfillerStatus=${fulfillerStatus}&${customRepresentation}`; - if (date) { - apiUrl += `&activatedOnOrAfterDate=${date}`; + if (dateFrom) { + apiUrl += `&activatedOnOrAfterDate=${dateFrom}`; } const mutateOrders = useCallback( From 6863b5d85679bce0ca187d749f23d0c00c16be99 Mon Sep 17 00:00:00 2001 From: jabahum Date: Fri, 21 Jun 2024 09:52:54 +0300 Subject: [PATCH 02/10] Add global date filter --- .../completed-list.component.tsx | 8 ++-- src/constants.ts | 3 +- src/header/laboratory-header.component.tsx | 36 ++++++++++++--- src/lab-tiles/completed-tile.component.tsx | 6 +-- src/lab-tiles/referred-tile.component.tsx | 8 +++- src/lab-tiles/rejected-tile.component.tsx | 5 ++- .../tests-ordered-tile.component.tsx | 7 +-- src/lab-tiles/worklist-tile.component.tsx | 9 ++-- .../laboratory-order-referals.component.tsx | 3 +- .../referred-orders.component.tsx | 29 +++--------- .../rejected-tests-list.component.tsx | 8 ++-- src/review-list/review-list.component.tsx | 12 +++-- .../tests-ordered-list.component.tsx | 25 ++--------- src/utils/functions.ts | 44 ++++++++++++++++++- src/work-list/work-list.component.tsx | 16 +++---- src/work-list/work-list.resource.ts | 10 ++--- 16 files changed, 127 insertions(+), 102 deletions(-) diff --git a/src/completed-list/completed-list.component.tsx b/src/completed-list/completed-list.component.tsx index a30efb58..8fab2d00 100644 --- a/src/completed-list/completed-list.component.tsx +++ b/src/completed-list/completed-list.component.tsx @@ -25,8 +25,7 @@ import { DataTableSkeleton, } from "@carbon/react"; import styles from "./completed-list.scss"; -import { getStatusColor } from "../utils/functions"; -import dayjs from "dayjs"; +import { getStatusColor, useOrderDate } from "../utils/functions"; interface CompletedListProps { fulfillerStatus: string; @@ -35,12 +34,11 @@ interface CompletedListProps { const CompletedList: React.FC = ({ fulfillerStatus }) => { const { t } = useTranslation(); - const fromDate = dayjs(new Date()).format("YYYY-MM-DD"); + const { currentOrdersDate } = useOrderDate(); const { data: completedOrderList, isLoading } = useGetOrdersWorklist( fulfillerStatus, - fromDate, - "" + currentOrdersDate ); const pageSizes = [10, 20, 30, 40, 50]; diff --git a/src/constants.ts b/src/constants.ts index e96e6edb..a7b443b7 100644 --- a/src/constants.ts +++ b/src/constants.ts @@ -1,5 +1,6 @@ export const moduleName = "@openmrs/esm-laboratory-app"; - export const LABORATARORY_ENCOUNTER_TYPE = "cbf01392-ca29-11e9-a32f-2a2ae2dbcce4"; export const TEST_ORDER_ENCOUNTER_TYPE = "dca07f4a-30ab-102d-86b0-7a5022ba4115"; +export const omrsDateFormat = "YYYY-MM-DD"; +export const REFERINSTRUCTIONS = "REFER TO cphl"; diff --git a/src/header/laboratory-header.component.tsx b/src/header/laboratory-header.component.tsx index 3bbc5100..7e4c9d67 100644 --- a/src/header/laboratory-header.component.tsx +++ b/src/header/laboratory-header.component.tsx @@ -1,15 +1,22 @@ -import React from "react"; +import React, { useRef } from "react"; import { useTranslation } from "react-i18next"; -import { Calendar, Location } from "@carbon/react/icons"; -import { useSession, formatDate } from "@openmrs/esm-framework"; +import { Location } from "@carbon/react/icons"; +import { useSession } from "@openmrs/esm-framework"; import LaboratoryIllustration from "./laboratory-illustration.component"; import styles from "./laboratory-header.scss"; +import { DatePicker, DatePickerInput } from "@carbon/react"; +import dayjs from "dayjs"; +import { changeStartDate, useOrderDate } from "../utils/functions"; export const LaboratoryHeader: React.FC = () => { const { t } = useTranslation(); + const datePickerRef = useRef(null); + const userSession = useSession(); const userLocation = userSession?.sessionLocation?.display; + const { currentOrdersDate } = useOrderDate(); + return (
@@ -23,10 +30,25 @@ export const LaboratoryHeader: React.FC = () => { {userLocation} · - - - {formatDate(new Date(), { mode: "standard" })} - + changeStartDate(new Date(date))} + ref={datePickerRef} + dateFormat="Y-m-d" + datePickerType="single" + > + +
diff --git a/src/lab-tiles/completed-tile.component.tsx b/src/lab-tiles/completed-tile.component.tsx index fedb3e0e..671cea0c 100644 --- a/src/lab-tiles/completed-tile.component.tsx +++ b/src/lab-tiles/completed-tile.component.tsx @@ -3,13 +3,13 @@ import { useTranslation } from "react-i18next"; import SummaryTile from "../summary-tiles/summary-tile.component"; import { useLabTestsStats } from "../summary-tiles/laboratory-summary.resource"; import dayjs from "dayjs"; +import { useOrderDate } from "../utils/functions"; const ApprovedTileComponent = () => { const { t } = useTranslation(); - const today = dayjs(new Date()).format("YYYY-MM-DD"); - - const { data } = useLabTestsStats("COMPLETED", today); + const { currentOrdersDate } = useOrderDate(); + const { data } = useLabTestsStats("COMPLETED", currentOrdersDate); return ( { const { t } = useTranslation(); - const { data } = useLabTestsStats(""); + const { currentOrdersDate } = useOrderDate(); + + const { data } = useLabTestsStats("", currentOrdersDate); const filteredData = data?.filter( (item) => item?.fulfillerStatus === "IN_PROGRESS" && item?.accessionNumber !== null && item?.dateStopped === null && - item?.instructions === "REFER TO cphl" + item?.instructions === REFERINSTRUCTIONS ); return ( diff --git a/src/lab-tiles/rejected-tile.component.tsx b/src/lab-tiles/rejected-tile.component.tsx index afbb12b6..dd4bab5f 100644 --- a/src/lab-tiles/rejected-tile.component.tsx +++ b/src/lab-tiles/rejected-tile.component.tsx @@ -2,11 +2,14 @@ import React from "react"; import { useTranslation } from "react-i18next"; import SummaryTile from "../summary-tiles/summary-tile.component"; import { useLabTestsStats } from "../summary-tiles/laboratory-summary.resource"; +import { useOrderDate } from "../utils/functions"; const RejectedTileComponent = () => { const { t } = useTranslation(); - const { data } = useLabTestsStats(""); + const { currentOrdersDate } = useOrderDate(); + + const { data } = useLabTestsStats("", currentOrdersDate); const filteredData = data?.filter( (item) => item?.fulfillerStatus === "DECLINED" diff --git a/src/lab-tiles/tests-ordered-tile.component.tsx b/src/lab-tiles/tests-ordered-tile.component.tsx index 3ff04cb6..7960148f 100644 --- a/src/lab-tiles/tests-ordered-tile.component.tsx +++ b/src/lab-tiles/tests-ordered-tile.component.tsx @@ -1,13 +1,14 @@ import React from "react"; import { useTranslation } from "react-i18next"; import SummaryTile from "../summary-tiles/summary-tile.component"; -import dayjs from "dayjs"; import { useGetOrdersWorklist } from "../work-list/work-list.resource"; +import { useOrderDate } from "../utils/functions"; const TestsOrderedTileComponent = () => { const { t } = useTranslation(); - const today = dayjs(new Date()).format("YYYY-MM-DD"); - const { data } = useGetOrdersWorklist("", today); + + const { currentOrdersDate } = useOrderDate(); + const { data } = useGetOrdersWorklist("", currentOrdersDate); const filteredData = data?.filter( (item) => diff --git a/src/lab-tiles/worklist-tile.component.tsx b/src/lab-tiles/worklist-tile.component.tsx index 2c337e93..3ceec07c 100644 --- a/src/lab-tiles/worklist-tile.component.tsx +++ b/src/lab-tiles/worklist-tile.component.tsx @@ -2,20 +2,21 @@ import React from "react"; import { useTranslation } from "react-i18next"; import SummaryTile from "../summary-tiles/summary-tile.component"; import { useLabTestsStats } from "../summary-tiles/laboratory-summary.resource"; -import dayjs from "dayjs"; +import { useOrderDate } from "../utils/functions"; +import { REFERINSTRUCTIONS } from "../constants"; const WorklistTileComponent = () => { const { t } = useTranslation(); - const today = dayjs(new Date()).format("YYYY-MM-DD"); + const { currentOrdersDate } = useOrderDate(); - const { data } = useLabTestsStats("IN_PROGRESS", today); + const { data } = useLabTestsStats("IN_PROGRESS", currentOrdersDate); const filteredData = data?.filter( (item) => item?.fulfillerStatus === "IN_PROGRESS" && item?.accessionNumber !== null && item?.dateStopped === null && - item?.instructions !== "REFER TO cphl" + item?.instructions !== REFERINSTRUCTIONS ); return ( diff --git a/src/patient-chart/laboratory-order-referals/laboratory-order-referals.component.tsx b/src/patient-chart/laboratory-order-referals/laboratory-order-referals.component.tsx index bf0b9f01..d33d8996 100644 --- a/src/patient-chart/laboratory-order-referals/laboratory-order-referals.component.tsx +++ b/src/patient-chart/laboratory-order-referals/laboratory-order-referals.component.tsx @@ -61,6 +61,7 @@ import { launchPatientWorkspace, } from "@openmrs/esm-patient-common-lib"; import { mutate } from "swr"; +import { REFERINSTRUCTIONS } from "../../constants"; interface LaboratoryOrderReferalResultsProps { patientUuid: string; @@ -117,7 +118,7 @@ const LaboratoryOrderReferalResults: React.FC< item?.encounterType?.uuid === artCardEncounterTypeUuid) && item?.orders?.filter( (order) => - order?.instructions === "REFER TO cphl" || + order?.instructions === REFERINSTRUCTIONS || order.orderType === laboratoryOrderTypeUuid ) ) diff --git a/src/referred-orders/referred-orders.component.tsx b/src/referred-orders/referred-orders.component.tsx index f8ca40e5..dbd49f99 100644 --- a/src/referred-orders/referred-orders.component.tsx +++ b/src/referred-orders/referred-orders.component.tsx @@ -26,19 +26,19 @@ import { DatePicker, DatePickerInput, } from "@carbon/react"; -import { getStatusColor } from "../utils/functions"; +import { getStatusColor, useOrderDate } from "../utils/functions"; import styles from "./referred-orders.scss"; import dayjs from "dayjs"; +import { REFERINSTRUCTIONS } from "../constants"; const ReferredOrdersList: React.FC = () => { const { t } = useTranslation(); - const fromDate = dayjs(new Date()).format("YYYY-MM-DD"); + const { currentOrdersDate } = useOrderDate(); const { data: referredOrderList, isLoading } = useGetOrdersWorklist( "", - fromDate, - "" + currentOrdersDate ); const pageSizes = [10, 20, 30, 40, 50]; @@ -48,8 +48,7 @@ const ReferredOrdersList: React.FC = () => { (item) => item?.fulfillerStatus === "IN_PROGRESS" && item?.accessionNumber !== null && - item?.dateStopped === null && - item?.instructions === "REFER TO cphl" + item?.instructions === REFERINSTRUCTIONS ); const { @@ -94,7 +93,7 @@ const ReferredOrdersList: React.FC = () => { item?.identifierType?.uuid === "e1731641-30ab-102d-86b0-7a5022ba4115" ) - .display.split("=")[1] + ?.display.split("=")[1] .trim(), orderNumber: entry?.orderNumber, accessionNumber: entry?.accessionNumber, @@ -137,22 +136,6 @@ const ReferredOrdersList: React.FC = () => { > - - - - - - { const { t } = useTranslation(); - const fromDate = dayjs(new Date()).format("YYYY-MM-DD"); - + const { currentOrdersDate } = useOrderDate(); const { data: pickedOrderList, isLoading } = useGetOrdersWorklist( "", - fromDate, - "" + currentOrdersDate ); const data = pickedOrderList.filter( diff --git a/src/review-list/review-list.component.tsx b/src/review-list/review-list.component.tsx index 04b8658f..38ad0425 100644 --- a/src/review-list/review-list.component.tsx +++ b/src/review-list/review-list.component.tsx @@ -28,8 +28,8 @@ import { import styles from "./review-list.scss"; import { Add } from "@carbon/react/icons"; -import { getStatusColor } from "../utils/functions"; -import dayjs from "dayjs"; +import { getStatusColor, useOrderDate } from "../utils/functions"; +import { REFERINSTRUCTIONS } from "../constants"; interface ReviewlistProps { fulfillerStatus: string; @@ -67,19 +67,17 @@ const ApproveTestMenu: React.FC = ({ const ReviewList: React.FC = ({ fulfillerStatus }) => { const { t } = useTranslation(); - const fromDate = dayjs(new Date()).format("YYYY-MM-DD"); - + const { currentOrdersDate } = useOrderDate(); const { data: reviewOrderEntries, isLoading } = useGetOrdersWorklist( fulfillerStatus, - fromDate, - "" + currentOrdersDate ); const filtered = reviewOrderEntries?.filter( (item) => item?.fulfillerStatus === "IN_PROGRESS" && item?.dateStopped !== null && - (item?.instructions !== "REFER TO cphl" || + (item?.instructions !== REFERINSTRUCTIONS || item?.instructions === null || item?.instructions === undefined) ); diff --git a/src/tests-ordered/tests-ordered-list.component.tsx b/src/tests-ordered/tests-ordered-list.component.tsx index 2476f3a7..a63c0798 100644 --- a/src/tests-ordered/tests-ordered-list.component.tsx +++ b/src/tests-ordered/tests-ordered-list.component.tsx @@ -15,8 +15,6 @@ import { Layer, Tile, TableToolbarSearch, - DatePicker, - DatePickerInput, } from "@carbon/react"; import { OverflowMenuVertical } from "@carbon/react/icons"; @@ -30,19 +28,18 @@ import { import styles from "./laboratory-queue.scss"; import { useGetOrdersWorklist } from "../work-list/work-list.resource"; import OrderCustomOverflowMenuComponent from "../ui-components/overflow-menu.component"; -import dayjs from "dayjs"; +import { useOrderDate } from "../utils/functions"; interface LaboratoryPatientListProps {} const TestsOrderedList: React.FC = () => { const { t } = useTranslation(); - const fromDate = dayjs(new Date()).format("YYYY-MM-DD"); + const { currentOrdersDate } = useOrderDate(); const { data: pickedOrderList, isLoading } = useGetOrdersWorklist( "", - fromDate, - "" + currentOrdersDate ); const data = pickedOrderList.filter( @@ -146,22 +143,6 @@ const TestsOrderedList: React.FC = () => { }} > - - - - - - { if (!visitNumber) { @@ -283,3 +290,38 @@ export function extractErrorMessagesFromResponse(errorObject) { errors.map((error) => error.message) ); } + +// orders date globally +const initialState = { + ordersDate: dayjs(new Date().setHours(0, 0, 0, 0)).format(omrsDateFormat), +}; + +export function getStartDate() { + return getGlobalStore<{ ordersDate: string | Date }>( + "ordersStartDate", + initialState + ); +} + +export function changeStartDate(updatedDate: string | Date) { + const store = getStartDate(); + store.setState({ + ordersDate: dayjs(new Date(updatedDate).setHours(0, 0, 0, 0)).format( + omrsDateFormat + ), + }); +} + +export const useOrderDate = () => { + const [currentOrdersDate, setCurrentOrdersDate] = useState( + initialState.ordersDate + ); + + useEffect(() => { + getStartDate().subscribe(({ ordersDate }) => + setCurrentOrdersDate(ordersDate.toString()) + ); + }, []); + + return { currentOrdersDate, setCurrentOrdersDate }; +}; diff --git a/src/work-list/work-list.component.tsx b/src/work-list/work-list.component.tsx index dc4d4dba..104713eb 100644 --- a/src/work-list/work-list.component.tsx +++ b/src/work-list/work-list.component.tsx @@ -13,16 +13,12 @@ import { TableHead, TableHeader, TableRow, - TabPanel, TableToolbar, TableToolbarContent, TableToolbarSearch, Layer, - Tag, Button, Tile, - DatePicker, - DatePickerInput, } from "@carbon/react"; import { Result, useGetOrdersWorklist } from "./work-list.resource"; import styles from "./work-list.scss"; @@ -35,8 +31,8 @@ import { } from "@openmrs/esm-framework"; import { launchOverlay } from "../components/overlay/hook"; import ResultForm from "../results/result-form.component"; -import { getStatusColor } from "../utils/functions"; -import dayjs from "dayjs"; +import { getStatusColor, useOrderDate } from "../utils/functions"; +import { REFERINSTRUCTIONS } from "../constants"; interface WorklistProps { fulfillerStatus: string; @@ -54,12 +50,11 @@ interface RejectOrderProps { const WorkList: React.FC = ({ fulfillerStatus }) => { const { t } = useTranslation(); - const fromDate = dayjs(new Date()).format("YYYY-MM-DD"); + const { currentOrdersDate } = useOrderDate(); const { data: pickedOrderEntries, isLoading } = useGetOrdersWorklist( fulfillerStatus, - fromDate, - "" + currentOrdersDate ); const pageSizes = [10, 20, 30, 40, 50]; @@ -69,7 +64,8 @@ const WorkList: React.FC = ({ fulfillerStatus }) => { (item) => item?.fulfillerStatus === "IN_PROGRESS" && item?.accessionNumber !== null && - item?.dateStopped === null + item.dateStopped === null && + item.instructions !== REFERINSTRUCTIONS ); const { diff --git a/src/work-list/work-list.resource.ts b/src/work-list/work-list.resource.ts index 87f52f5e..24a5a473 100644 --- a/src/work-list/work-list.resource.ts +++ b/src/work-list/work-list.resource.ts @@ -83,11 +83,7 @@ export interface IdentifierType { uuid: string; } -export function useGetOrdersWorklist( - fulfillerStatus: string, - dateFrom?: string, - dateTo?: string -) { +export function useGetOrdersWorklist(fulfillerStatus: string, dateTo?: string) { const { laboratoryOrderTypeUuid } = useConfig(); const customRepresentation = "v=custom:(uuid,orderNumber,accessionNumber,instructions,careSetting:(uuid),encounter:(uuid,obs:(order:(uuid,display,patient:(uuid,display)))),fulfillerComment,orderType:(display),concept:(display,uuid),action,dateStopped,fulfillerStatus,dateActivated,orderer:(display),urgency,patient:(uuid,names:(display),display,gender,birthdate,identifiers:(voided,preferred,uuid,display,identifierType:(uuid))))"; @@ -96,8 +92,8 @@ export function useGetOrdersWorklist( ? `orderTypes=${laboratoryOrderTypeUuid}` : ""; let apiUrl = `${restBaseUrl}/order?${orderTypeQuery}&fulfillerStatus=${fulfillerStatus}&${customRepresentation}`; - if (dateFrom) { - apiUrl += `&activatedOnOrAfterDate=${dateFrom}`; + if (dateTo) { + apiUrl += `&activatedOnOrAfterDate=${dateTo}`; } const mutateOrders = useCallback( From 6b2e642085c4a22df4710928662ed39a7131ce6d Mon Sep 17 00:00:00 2001 From: jabahum Date: Fri, 21 Jun 2024 10:09:26 +0300 Subject: [PATCH 03/10] clean up --- package.json | 4 +- src/lab-tabs/referred-tab.component.tsx | 1 - src/lab-tabs/work-list-tab.component.tsx | 1 - src/lab-tiles/completed-tile.component.tsx | 1 - yarn.lock | 534 ++++++++++++++++----- 5 files changed, 428 insertions(+), 113 deletions(-) diff --git a/package.json b/package.json index 15eed5e8..670de3c3 100644 --- a/package.json +++ b/package.json @@ -63,7 +63,7 @@ "devDependencies": { "@ohri/openmrs-esm-ohri-commons-lib": "next", "@openmrs/esm-extensions": "next", - "@openmrs/esm-framework": "^5.5.1-pre.1704", + "@openmrs/esm-framework": "^5.6.0", "@openmrs/esm-patient-common-lib": "next", "@openmrs/esm-react-utils": "next", "@openmrs/esm-styleguide": "next", @@ -96,7 +96,7 @@ "jest-cli": "^28.1.3", "jest-environment-jsdom": "^28.1.3", "lerna": "^5.6.1", - "openmrs": "^5.5.1-pre.1704", + "openmrs": "^5.6.1-pre.1930", "plotly.js": "^2.24.3", "prettier": "^2.8.8", "pretty-quick": "^3.1.3", diff --git a/src/lab-tabs/referred-tab.component.tsx b/src/lab-tabs/referred-tab.component.tsx index ebdc3ec9..f3afe760 100644 --- a/src/lab-tabs/referred-tab.component.tsx +++ b/src/lab-tabs/referred-tab.component.tsx @@ -1,5 +1,4 @@ import React from "react"; -import { EmptyState } from "@openmrs/esm-patient-common-lib"; import ReferredOrdersList from "../referred-orders/referred-orders.component"; const ReferredComponent = () => { diff --git a/src/lab-tabs/work-list-tab.component.tsx b/src/lab-tabs/work-list-tab.component.tsx index 365df9d7..351125ee 100644 --- a/src/lab-tabs/work-list-tab.component.tsx +++ b/src/lab-tabs/work-list-tab.component.tsx @@ -1,6 +1,5 @@ import React from "react"; import WorkList from "../work-list/work-list.component"; -import styles from "../queue-list/laboratory-queue.scss"; const WorkListComponent = () => { return ( diff --git a/src/lab-tiles/completed-tile.component.tsx b/src/lab-tiles/completed-tile.component.tsx index 671cea0c..7fb3f2ff 100644 --- a/src/lab-tiles/completed-tile.component.tsx +++ b/src/lab-tiles/completed-tile.component.tsx @@ -2,7 +2,6 @@ import React from "react"; import { useTranslation } from "react-i18next"; import SummaryTile from "../summary-tiles/summary-tile.component"; import { useLabTestsStats } from "../summary-tiles/laboratory-summary.resource"; -import dayjs from "dayjs"; import { useOrderDate } from "../utils/functions"; const ApprovedTileComponent = () => { diff --git a/yarn.lock b/yarn.lock index 8b849d89..bda2e9ae 100644 --- a/yarn.lock +++ b/yarn.lock @@ -1492,26 +1492,13 @@ __metadata: languageName: node linkType: hard -"@carbon/icon-helpers@npm:^10.44.0, @carbon/icon-helpers@npm:^10.45.0": +"@carbon/icon-helpers@npm:^10.45.0": version: 10.45.1 resolution: "@carbon/icon-helpers@npm:10.45.1" checksum: 10/69da5ae85b586c5bb754f1db90069fb48f556c9f5023318a25572faa07e6dca0f07aaec237eaec883029bb75819b64c30bf4716339cdbab590ca0ee648ef67bc languageName: node linkType: hard -"@carbon/icons-react@npm:11.26.0": - version: 11.26.0 - resolution: "@carbon/icons-react@npm:11.26.0" - dependencies: - "@carbon/icon-helpers": "npm:^10.44.0" - "@carbon/telemetry": "npm:0.1.0" - prop-types: "npm:^15.7.2" - peerDependencies: - react: ">=16" - checksum: 10/70fec92a7c24378647e7b4edb6d468a0f5a9260f68bcaf91dd3ffb90cd1d371c79ba156702b01db57db0ef9fc10049b71c16715015989c540bb1b1833abd3956 - languageName: node - linkType: hard - "@carbon/icons-react@npm:^11.9.0": version: 11.34.1 resolution: "@carbon/icons-react@npm:11.34.1" @@ -4141,9 +4128,9 @@ __metadata: languageName: node linkType: hard -"@openmrs/esm-api@npm:5.5.1-pre.1705": - version: 5.5.1-pre.1705 - resolution: "@openmrs/esm-api@npm:5.5.1-pre.1705" +"@openmrs/esm-api@npm:5.6.0": + version: 5.6.0 + resolution: "@openmrs/esm-api@npm:5.6.0" dependencies: "@types/fhir": "npm:0.0.31" lodash-es: "npm:^4.17.21" @@ -4152,17 +4139,32 @@ __metadata: "@openmrs/esm-error-handling": 5.x "@openmrs/esm-navigation": 5.x "@openmrs/esm-offline": 5.x - checksum: 10/0e24abb908828b19df31e5be0485f851c4a800b9d7c65d8081511656e6d5590c6853b90531cb1570bd684e697a6a87c2f613b75e7796a21c1bfbb79b5ef14f3d + checksum: 10/b51929735c6182825999042161983d0c0e584b2f0309d17e9f716c3ad2e1af0747afe2e8cc1ce2aab8ac97934c0f904144aa728ed83c0b8c67f019229c7eb985 languageName: node linkType: hard -"@openmrs/esm-app-shell@npm:5.5.1-pre.1705": - version: 5.5.1-pre.1705 - resolution: "@openmrs/esm-app-shell@npm:5.5.1-pre.1705" +"@openmrs/esm-api@npm:5.6.1-pre.1930": + version: 5.6.1-pre.1930 + resolution: "@openmrs/esm-api@npm:5.6.1-pre.1930" + dependencies: + "@types/fhir": "npm:0.0.31" + lodash-es: "npm:^4.17.21" + peerDependencies: + "@openmrs/esm-config": 5.x + "@openmrs/esm-error-handling": 5.x + "@openmrs/esm-navigation": 5.x + "@openmrs/esm-offline": 5.x + checksum: 10/8e8a9f6ec5877ffd11e67c42744c585cc1a89c91377a3567a7ebd0653d521e24e5e2181d14b33367cb97e7d27c62536556acb52995e2d419cbdf6d7eafe3316a + languageName: node + linkType: hard + +"@openmrs/esm-app-shell@npm:5.6.1-pre.1930": + version: 5.6.1-pre.1930 + resolution: "@openmrs/esm-app-shell@npm:5.6.1-pre.1930" dependencies: "@carbon/react": "npm:~1.37.0" - "@openmrs/esm-framework": "npm:5.5.1-pre.1705" - "@openmrs/esm-styleguide": "npm:5.5.1-pre.1705" + "@openmrs/esm-framework": "npm:5.6.1-pre.1930" + "@openmrs/esm-styleguide": "npm:5.6.1-pre.1930" dayjs: "npm:^1.10.4" dexie: "npm:^3.0.3" html-webpack-plugin: "npm:^5.5.0" @@ -4187,42 +4189,130 @@ __metadata: workbox-strategies: "npm:^6.1.5" workbox-webpack-plugin: "npm:^6.1.5" workbox-window: "npm:^6.1.5" - checksum: 10/d6072fea852314e7be7b258bdd39b76031e1f7801bab10baf4ac5b66b9db2da8b96f6ce29c43547cc1f667e19ca038e59ee3b4b64bc12ad1b0cd321e3ddfd5ac + checksum: 10/181ec0995bf7b6d86beac7bb97bf6cd509c9103fa3578493e991cc98e0a06e4575143757fa2664c89fea499d68c11ec92105db782c38f9f633deb7c75653820f languageName: node linkType: hard -"@openmrs/esm-config@npm:5.5.1-pre.1705": - version: 5.5.1-pre.1705 - resolution: "@openmrs/esm-config@npm:5.5.1-pre.1705" +"@openmrs/esm-config@npm:5.6.0": + version: 5.6.0 + resolution: "@openmrs/esm-config@npm:5.6.0" dependencies: ramda: "npm:^0.26.1" peerDependencies: "@openmrs/esm-globals": 5.x "@openmrs/esm-state": 5.x single-spa: 5.x - checksum: 10/02bbbf15f105765f214b01bf33ea02a5cd8e8aa8a20ca2cb0342ca7b41b48faec2c69e39c98a7a18cde61e3dc200958566d68402b679c4e4550aed48ff026881 + checksum: 10/60c61ab92f0585681b60f34806b42970819a51243a29873ded53fb443d015691e3480fafabf6304bc357769154321bb0e27ddaa93ff1ab22fb94293fb54cd099 languageName: node linkType: hard -"@openmrs/esm-dynamic-loading@npm:5.5.1-pre.1705": - version: 5.5.1-pre.1705 - resolution: "@openmrs/esm-dynamic-loading@npm:5.5.1-pre.1705" +"@openmrs/esm-config@npm:5.6.1-pre.1930": + version: 5.6.1-pre.1930 + resolution: "@openmrs/esm-config@npm:5.6.1-pre.1930" + dependencies: + ramda: "npm:^0.26.1" peerDependencies: "@openmrs/esm-globals": 5.x - checksum: 10/2d903118d553dbec6ca24ddb5c64ee295ad664f33257fe8d866a9b2ca1dfc19e66365b8528846436f31928a6b74eaa9de320fa55c1f71b824277d69c10edc0f5 + "@openmrs/esm-state": 5.x + single-spa: 5.x + checksum: 10/8a77d51cf685faed83c61f97836c3c6a32662850fb9df38282f04ec95b6fab547954eb76071630ec8d624e48c72cb3a67082cc5bfac3ab7170fbd5dd1ded6801 languageName: node linkType: hard -"@openmrs/esm-error-handling@npm:5.5.1-pre.1705": - version: 5.5.1-pre.1705 - resolution: "@openmrs/esm-error-handling@npm:5.5.1-pre.1705" +"@openmrs/esm-context@npm:5.6.0": + version: 5.6.0 + resolution: "@openmrs/esm-context@npm:5.6.0" + dependencies: + immer: "npm:^10.0.4" peerDependencies: "@openmrs/esm-globals": 5.x - checksum: 10/90e590db2eff444a2d27aa7a0c838da8da4dd9bd56f64f447ebea6aae3a327ca17173a4f8fbd870f58ed674278ccaa7c8f1257cd17d5f01480ddd038b65a5b21 + "@openmrs/esm-state": 5.x + checksum: 10/5e26573a616cfdb2a9bd926f5b51f14934211d33a979e05613c8dbde4e4792c493046f96239079a9380b667c7a0c12cf53d5267f361c6cd30c53d32273cfb131 + languageName: node + linkType: hard + +"@openmrs/esm-context@npm:5.6.1-pre.1930": + version: 5.6.1-pre.1930 + resolution: "@openmrs/esm-context@npm:5.6.1-pre.1930" + dependencies: + immer: "npm:^10.0.4" + peerDependencies: + "@openmrs/esm-globals": 5.x + "@openmrs/esm-state": 5.x + checksum: 10/5c67ca6bbf63640ca8bafa74aef4d02973444907663e5dcc0b36977b6ece0584e6cbd86574acae18b821d78d7fbbb12fffcdb796bb7cd49dcac33b79cd68173b + languageName: node + linkType: hard + +"@openmrs/esm-dynamic-loading@npm:5.6.0": + version: 5.6.0 + resolution: "@openmrs/esm-dynamic-loading@npm:5.6.0" + peerDependencies: + "@openmrs/esm-globals": 5.x + checksum: 10/cdf396f2cb346399fafb807e5a0876973bc8e37cf39b05fbf7805e63cad9e50e84c236cbbd260b18d80b3deed13ab101d6da84e87c7a39a9a3af8f02ebd24514 + languageName: node + linkType: hard + +"@openmrs/esm-dynamic-loading@npm:5.6.1-pre.1930": + version: 5.6.1-pre.1930 + resolution: "@openmrs/esm-dynamic-loading@npm:5.6.1-pre.1930" + peerDependencies: + "@openmrs/esm-globals": 5.x + "@openmrs/esm-translations": 5.x + checksum: 10/41e8ed0c99c009237477636f62200212574c4aa0b059166456c0ecc5354677e4a8203c79d4895f453274d404f1ff2773ecd8c37a9d41722687dfd59ce4a41f2a + languageName: node + linkType: hard + +"@openmrs/esm-error-handling@npm:5.6.0": + version: 5.6.0 + resolution: "@openmrs/esm-error-handling@npm:5.6.0" + peerDependencies: + "@openmrs/esm-globals": 5.x + checksum: 10/4e8a0b1b588223b3c17ea8319e6f51d7c40ee03793a66aa45f36e1a977ec3bc7f3b9015e09df629803838e0c107c7fbd7eb3a3815669fb242c46f6c2ecb21661 + languageName: node + linkType: hard + +"@openmrs/esm-error-handling@npm:5.6.1-pre.1930": + version: 5.6.1-pre.1930 + resolution: "@openmrs/esm-error-handling@npm:5.6.1-pre.1930" + peerDependencies: + "@openmrs/esm-globals": 5.x + checksum: 10/43e1ab6c5d4a347a45a2f209e2968a261c22cfa89e5aa7da35a197d1cd92a51308a2a709e57dfe51a23355571ba1838cc459e6f55880b742733026ae4239ebc5 + languageName: node + linkType: hard + +"@openmrs/esm-extensions@npm:5.6.0": + version: 5.6.0 + resolution: "@openmrs/esm-extensions@npm:5.6.0" + dependencies: + lodash-es: "npm:^4.17.21" + peerDependencies: + "@openmrs/esm-api": 5.x + "@openmrs/esm-config": 5.x + "@openmrs/esm-feature-flags": 5.x + "@openmrs/esm-state": 5.x + "@openmrs/esm-utils": 5.x + single-spa: 5.x + checksum: 10/73f475a98563a4c1d6d3dbb23a1ed3f34b97867d8ae7eccf48dbb8d9c0369761e1d3149c1f20f8538ff4f5aa4a606c18398f8685439c57912e57c6bad0612396 + languageName: node + linkType: hard + +"@openmrs/esm-extensions@npm:5.6.1-pre.1930": + version: 5.6.1-pre.1930 + resolution: "@openmrs/esm-extensions@npm:5.6.1-pre.1930" + dependencies: + lodash-es: "npm:^4.17.21" + peerDependencies: + "@openmrs/esm-api": 5.x + "@openmrs/esm-config": 5.x + "@openmrs/esm-feature-flags": 5.x + "@openmrs/esm-state": 5.x + "@openmrs/esm-utils": 5.x + single-spa: 5.x + checksum: 10/4e0f67fb984b614810c699f986f810f6fae056bff690008757293bd939030b13501128466125e673373a452a1da837e1ee758ca1bd32f7009da1bd260dcc2335 languageName: node linkType: hard -"@openmrs/esm-extensions@npm:5.5.1-pre.1705, @openmrs/esm-extensions@npm:next": +"@openmrs/esm-extensions@npm:next": version: 5.5.1-pre.1705 resolution: "@openmrs/esm-extensions@npm:5.5.1-pre.1705" dependencies: @@ -4237,38 +4327,52 @@ __metadata: languageName: node linkType: hard -"@openmrs/esm-feature-flags@npm:5.5.1-pre.1705": - version: 5.5.1-pre.1705 - resolution: "@openmrs/esm-feature-flags@npm:5.5.1-pre.1705" +"@openmrs/esm-feature-flags@npm:5.6.0": + version: 5.6.0 + resolution: "@openmrs/esm-feature-flags@npm:5.6.0" dependencies: ramda: "npm:^0.26.1" peerDependencies: "@openmrs/esm-globals": 5.x "@openmrs/esm-state": 5.x single-spa: 5.x - checksum: 10/babbfc37abe05557b60e0dab60eab445f365b56594f36b82baa23f2e053d78a725aa7f55bd640f1be8572ffed42f2672ebc0a3c52c210cda5f6eeb0b3f2f8871 + checksum: 10/6f74ccb19e70793cdd05d4a033eff9d412f5fe0fe4fc03d9d5d10ab60f2d94d08206949b52b31bd83a52bcbec298efe2422d249f2a79054003aec8d357819b07 languageName: node linkType: hard -"@openmrs/esm-framework@npm:5.5.1-pre.1705, @openmrs/esm-framework@npm:^5.5.1-pre.1704": - version: 5.5.1-pre.1705 - resolution: "@openmrs/esm-framework@npm:5.5.1-pre.1705" - dependencies: - "@openmrs/esm-api": "npm:5.5.1-pre.1705" - "@openmrs/esm-config": "npm:5.5.1-pre.1705" - "@openmrs/esm-dynamic-loading": "npm:5.5.1-pre.1705" - "@openmrs/esm-error-handling": "npm:5.5.1-pre.1705" - "@openmrs/esm-extensions": "npm:5.5.1-pre.1705" - "@openmrs/esm-feature-flags": "npm:5.5.1-pre.1705" - "@openmrs/esm-globals": "npm:5.5.1-pre.1705" - "@openmrs/esm-navigation": "npm:5.5.1-pre.1705" - "@openmrs/esm-offline": "npm:5.5.1-pre.1705" - "@openmrs/esm-react-utils": "npm:5.5.1-pre.1705" - "@openmrs/esm-routes": "npm:5.5.1-pre.1705" - "@openmrs/esm-state": "npm:5.5.1-pre.1705" - "@openmrs/esm-styleguide": "npm:5.5.1-pre.1705" - "@openmrs/esm-translations": "npm:5.5.1-pre.1705" - "@openmrs/esm-utils": "npm:5.5.1-pre.1705" +"@openmrs/esm-feature-flags@npm:5.6.1-pre.1930": + version: 5.6.1-pre.1930 + resolution: "@openmrs/esm-feature-flags@npm:5.6.1-pre.1930" + dependencies: + ramda: "npm:^0.26.1" + peerDependencies: + "@openmrs/esm-globals": 5.x + "@openmrs/esm-state": 5.x + single-spa: 5.x + checksum: 10/55bea4a452fa843eff3799210e842e6a735e7f1046037c303e7a34da15e7417775d435bf9421d8b75e24efc375ce43b2550c4efcacd2565e2a2f0a8c50ccddfe + languageName: node + linkType: hard + +"@openmrs/esm-framework@npm:5.6.1-pre.1930": + version: 5.6.1-pre.1930 + resolution: "@openmrs/esm-framework@npm:5.6.1-pre.1930" + dependencies: + "@openmrs/esm-api": "npm:5.6.1-pre.1930" + "@openmrs/esm-config": "npm:5.6.1-pre.1930" + "@openmrs/esm-context": "npm:5.6.1-pre.1930" + "@openmrs/esm-dynamic-loading": "npm:5.6.1-pre.1930" + "@openmrs/esm-error-handling": "npm:5.6.1-pre.1930" + "@openmrs/esm-extensions": "npm:5.6.1-pre.1930" + "@openmrs/esm-feature-flags": "npm:5.6.1-pre.1930" + "@openmrs/esm-globals": "npm:5.6.1-pre.1930" + "@openmrs/esm-navigation": "npm:5.6.1-pre.1930" + "@openmrs/esm-offline": "npm:5.6.1-pre.1930" + "@openmrs/esm-react-utils": "npm:5.6.1-pre.1930" + "@openmrs/esm-routes": "npm:5.6.1-pre.1930" + "@openmrs/esm-state": "npm:5.6.1-pre.1930" + "@openmrs/esm-styleguide": "npm:5.6.1-pre.1930" + "@openmrs/esm-translations": "npm:5.6.1-pre.1930" + "@openmrs/esm-utils": "npm:5.6.1-pre.1930" dayjs: "npm:^1.10.7" peerDependencies: dayjs: 1.x @@ -4279,33 +4383,106 @@ __metadata: rxjs: 6.x single-spa: 5.x swr: 2.x - checksum: 10/71d8b7357d84b9ac42d2e2bea75d596f1efe5c239b63c70d8d7a0723fcd07e15c8b42583fd3e432f754bc08d7119456f1725e4e73201d156e96a26de931f0ccc + checksum: 10/40853f883dbdc55482d4e6b8ca54aff680d7f7713166e6a9e11a22d70b5f218a30b4618e8fcb5d55f1e26d23a731d1d26f7851d0b9f847fa1c17a2940cc9c3aa languageName: node linkType: hard -"@openmrs/esm-globals@npm:5.5.1-pre.1705": - version: 5.5.1-pre.1705 - resolution: "@openmrs/esm-globals@npm:5.5.1-pre.1705" +"@openmrs/esm-framework@npm:^5.6.0": + version: 5.6.0 + resolution: "@openmrs/esm-framework@npm:5.6.0" + dependencies: + "@openmrs/esm-api": "npm:5.6.0" + "@openmrs/esm-config": "npm:5.6.0" + "@openmrs/esm-context": "npm:5.6.0" + "@openmrs/esm-dynamic-loading": "npm:5.6.0" + "@openmrs/esm-error-handling": "npm:5.6.0" + "@openmrs/esm-extensions": "npm:5.6.0" + "@openmrs/esm-feature-flags": "npm:5.6.0" + "@openmrs/esm-globals": "npm:5.6.0" + "@openmrs/esm-navigation": "npm:5.6.0" + "@openmrs/esm-offline": "npm:5.6.0" + "@openmrs/esm-react-utils": "npm:5.6.0" + "@openmrs/esm-routes": "npm:5.5.0" + "@openmrs/esm-state": "npm:5.6.0" + "@openmrs/esm-styleguide": "npm:5.6.0" + "@openmrs/esm-translations": "npm:5.6.0" + "@openmrs/esm-utils": "npm:5.6.0" + dayjs: "npm:^1.10.7" peerDependencies: + dayjs: 1.x + i18next: 21.x + react: 18.x + react-dom: 18.x + react-i18next: 11.x + rxjs: 6.x single-spa: 5.x - checksum: 10/f23cfaa5d115f4ffad5c2910c33a380cd57f8fce8bf75f50afaddae4a323d4ab6c09cef7800ccf453b0573da01877a8ebf8463119a8a7b38ec70bc8d038220d2 + swr: 2.x + checksum: 10/9c5eea62ba67d0a59027f6f2f89dbf6a0713d98c065294a89e0b70a48e10403ea2ea2c3911780f4bc39719f56363047113775119ee392bd0dfa549f3ae108c5a languageName: node linkType: hard -"@openmrs/esm-navigation@npm:5.5.1-pre.1705": - version: 5.5.1-pre.1705 - resolution: "@openmrs/esm-navigation@npm:5.5.1-pre.1705" +"@openmrs/esm-globals@npm:5.6.0": + version: 5.6.0 + resolution: "@openmrs/esm-globals@npm:5.6.0" + peerDependencies: + single-spa: 5.x + checksum: 10/c317c081aac3613e7a975ca903982558de4dfb5bc8aed744fd667849edfa583ba57b7fee45dbe6c316925c0b461556f936754faed647bbcd3650b421b9cf7591 + languageName: node + linkType: hard + +"@openmrs/esm-globals@npm:5.6.1-pre.1930": + version: 5.6.1-pre.1930 + resolution: "@openmrs/esm-globals@npm:5.6.1-pre.1930" + dependencies: + "@types/fhir": "npm:0.0.31" + peerDependencies: + single-spa: 5.x + checksum: 10/c370b85382f0663d94ed18c25c26a7aeb17e20456584550b62a3845dc6967a0005d53b8ad51e8ffaa32794544000e5748fd1adbecce741a1435b96a47d374f0a + languageName: node + linkType: hard + +"@openmrs/esm-navigation@npm:5.6.0": + version: 5.6.0 + resolution: "@openmrs/esm-navigation@npm:5.6.0" dependencies: path-to-regexp: "npm:6.1.0" peerDependencies: "@openmrs/esm-state": 5.x - checksum: 10/130c1453bf23ff186946c9d5be67e1123d86d0a0c9695d6fe358b50908922ed88ece26dfc941fe60dc644bd2d5987403c22a7e0af5f697584bb278d08906a46d + checksum: 10/7c3f8c550efcd70e21bb24752536b2d0d9c5f82c5002622a3bef1bf24f0726e3f8b397167b20412e53e61be721cce2968925249575564a5b4e0b53a0a452bcd8 languageName: node linkType: hard -"@openmrs/esm-offline@npm:5.5.1-pre.1705": - version: 5.5.1-pre.1705 - resolution: "@openmrs/esm-offline@npm:5.5.1-pre.1705" +"@openmrs/esm-navigation@npm:5.6.1-pre.1930": + version: 5.6.1-pre.1930 + resolution: "@openmrs/esm-navigation@npm:5.6.1-pre.1930" + dependencies: + path-to-regexp: "npm:6.1.0" + peerDependencies: + "@openmrs/esm-state": 5.x + checksum: 10/6dedcd2d078a8127bd6ba541d16c5599a6abd49363d0ed53fbfa90772a201efbe730b509e12ad884dad6c1dae5a2d7b533ec8e2d4940b94254a0d6a87aedc901 + languageName: node + linkType: hard + +"@openmrs/esm-offline@npm:5.6.0": + version: 5.6.0 + resolution: "@openmrs/esm-offline@npm:5.6.0" + dependencies: + dexie: "npm:^3.0.3" + lodash-es: "npm:^4.17.21" + uuid: "npm:^9.0.0" + workbox-window: "npm:^6.1.5" + peerDependencies: + "@openmrs/esm-api": 5.x + "@openmrs/esm-globals": 5.x + "@openmrs/esm-state": 5.x + rxjs: 6.x + checksum: 10/da428a9bb2e9d41315e92001cdbd8cc7b342fa161c1483e76d4a5f22a16ef937224619010d0067c76f3fccbde42a0a516341006ea781be4ba5b5b2e40f14011d + languageName: node + linkType: hard + +"@openmrs/esm-offline@npm:5.6.1-pre.1930": + version: 5.6.1-pre.1930 + resolution: "@openmrs/esm-offline@npm:5.6.1-pre.1930" dependencies: dexie: "npm:^3.0.3" lodash-es: "npm:^4.17.21" @@ -4315,9 +4492,8 @@ __metadata: "@openmrs/esm-api": 5.x "@openmrs/esm-globals": 5.x "@openmrs/esm-state": 5.x - "@openmrs/esm-styleguide": 5.x rxjs: 6.x - checksum: 10/6359d27bab5978f060f6b29afe7e1be757407d8b566c9fa309ab3cb25b449c002af0f79c02fdb9e9df0cf5a0d3c763250693f9880fca1f1e4ee8b3e9a82a5036 + checksum: 10/3fc18a6e27d49026dfd5b9d145ae20e27c040bac76d43955c2f584da17da597bd96a55e8816f6c881bb8e859ae853dc0346c56660121a9a6b4904e4d2be52197 languageName: node linkType: hard @@ -4336,7 +4512,61 @@ __metadata: languageName: node linkType: hard -"@openmrs/esm-react-utils@npm:5.5.1-pre.1705, @openmrs/esm-react-utils@npm:next": +"@openmrs/esm-react-utils@npm:5.6.0": + version: 5.6.0 + resolution: "@openmrs/esm-react-utils@npm:5.6.0" + dependencies: + lodash-es: "npm:^4.17.21" + single-spa-react: "npm:^6.0.0" + peerDependencies: + "@openmrs/esm-api": 5.x + "@openmrs/esm-config": 5.x + "@openmrs/esm-context": 5.x + "@openmrs/esm-error-handling": 5.x + "@openmrs/esm-extensions": 5.x + "@openmrs/esm-feature-flags": 5.x + "@openmrs/esm-globals": 5.x + "@openmrs/esm-navigation": 5.x + "@openmrs/esm-utils": 5.x + dayjs: 1.x + i18next: 21.x + react: 18.x + react-dom: 18.x + react-i18next: 11.x + rxjs: 6.x + swr: 2.x + checksum: 10/3a7688fe829017713b9e6646b300908e42f87b53bce62cc986c7fb65f6e516e06744ade75e9cac59d8bd85bad88c4e1d6aa725ff9010c66c2e537e75b6f4717e + languageName: node + linkType: hard + +"@openmrs/esm-react-utils@npm:5.6.1-pre.1930": + version: 5.6.1-pre.1930 + resolution: "@openmrs/esm-react-utils@npm:5.6.1-pre.1930" + dependencies: + lodash-es: "npm:^4.17.21" + single-spa-react: "npm:^6.0.0" + peerDependencies: + "@openmrs/esm-api": 5.x + "@openmrs/esm-config": 5.x + "@openmrs/esm-context": 5.x + "@openmrs/esm-error-handling": 5.x + "@openmrs/esm-extensions": 5.x + "@openmrs/esm-feature-flags": 5.x + "@openmrs/esm-globals": 5.x + "@openmrs/esm-navigation": 5.x + "@openmrs/esm-utils": 5.x + dayjs: 1.x + i18next: 21.x + react: 18.x + react-dom: 18.x + react-i18next: 11.x + rxjs: 6.x + swr: 2.x + checksum: 10/b3fbea4fc693c59acecf1cb86e99fe3f871e2f6731be3d4a1c7042b0facd4a1521c56f0a1b450f71f11d84ee353096849bd62509d0b60fb54265cc2d127d3022 + languageName: node + linkType: hard + +"@openmrs/esm-react-utils@npm:next": version: 5.5.1-pre.1705 resolution: "@openmrs/esm-react-utils@npm:5.5.1-pre.1705" dependencies: @@ -4361,30 +4591,51 @@ __metadata: languageName: node linkType: hard -"@openmrs/esm-routes@npm:5.5.1-pre.1705": - version: 5.5.1-pre.1705 - resolution: "@openmrs/esm-routes@npm:5.5.1-pre.1705" +"@openmrs/esm-routes@npm:5.5.0": + version: 5.5.0 + resolution: "@openmrs/esm-routes@npm:5.5.0" peerDependencies: "@openmrs/esm-globals": 5.x "@openmrs/esm-utils": 5.x - checksum: 10/95f387a688793ff72a8bcf5563ccb06dbf1f311734639c8162df3e7eddbe826bc13a7e4816daded5415b6fc2b1b3e548a154d25a3940cb1845e47180693bb5ff + checksum: 10/a4a36f47bbff2d7a2997ed6bf2616bff63ae6df76a08cefe22e88ecb2e3aa2751417d2bd06edecfced721e38760663cc88f721c96dea78ddd6ecd3a094e2611e languageName: node linkType: hard -"@openmrs/esm-state@npm:5.5.1-pre.1705": - version: 5.5.1-pre.1705 - resolution: "@openmrs/esm-state@npm:5.5.1-pre.1705" +"@openmrs/esm-routes@npm:5.6.1-pre.1930": + version: 5.6.1-pre.1930 + resolution: "@openmrs/esm-routes@npm:5.6.1-pre.1930" + peerDependencies: + "@openmrs/esm-globals": 5.x + "@openmrs/esm-utils": 5.x + checksum: 10/d6bc9c5aa76eb168f36b04baf2217d7f256ab13ed717195a7558dbdfed781788de19de40c4dd90e158c43516bd99fdb3b75c83a9c06b35514bb48b7c6aceadc7 + languageName: node + linkType: hard + +"@openmrs/esm-state@npm:5.6.0": + version: 5.6.0 + resolution: "@openmrs/esm-state@npm:5.6.0" dependencies: zustand: "npm:^4.3.6" peerDependencies: "@openmrs/esm-globals": 5.x - checksum: 10/479c7683afcadfc0f5279c81ca36663a535bd665473b09cd7a0e458e211f05145d5b7c8081e943ffb31863f33b57e4627ee6fef30b5ca4466a95e9d0d7c7ead3 + checksum: 10/f9cec80f539fd687111e628f1b6792601e36a602244fa038f6c8d072837f729d46734a95c4b5872a2e628d6cbcb933b365ab111045fae2811f527de6b1ce224e languageName: node linkType: hard -"@openmrs/esm-styleguide@npm:5.5.1-pre.1705": - version: 5.5.1-pre.1705 - resolution: "@openmrs/esm-styleguide@npm:5.5.1-pre.1705" +"@openmrs/esm-state@npm:5.6.1-pre.1930": + version: 5.6.1-pre.1930 + resolution: "@openmrs/esm-state@npm:5.6.1-pre.1930" + dependencies: + zustand: "npm:^4.3.6" + peerDependencies: + "@openmrs/esm-globals": 5.x + checksum: 10/01f38b355ee75531850941e624de5ff264dc5a164a7485b7c22d714c50875e656e70fd68c8ff604c1ffa63c140120ae0d1e0efb49aa8db0b8b25d47091ee8126 + languageName: node + linkType: hard + +"@openmrs/esm-styleguide@npm:5.6.0": + version: 5.6.0 + resolution: "@openmrs/esm-styleguide@npm:5.6.0" dependencies: "@carbon/charts": "npm:^1.12.0" "@carbon/react": "npm:~1.37.0" @@ -4398,7 +4649,9 @@ __metadata: lodash-es: "npm:^4.17.21" react-avatar: "npm:^5.0.3" peerDependencies: + "@openmrs/esm-error-handling": 5.x "@openmrs/esm-extensions": 5.x + "@openmrs/esm-navigation": 5.x "@openmrs/esm-react-utils": 5.x "@openmrs/esm-state": 5.x "@openmrs/esm-translations": 5.x @@ -4407,7 +4660,38 @@ __metadata: react: 18.x react-dom: 18.x rxjs: 6.x - checksum: 10/75ed7f2c2a842b8bc4a0a06054685205d03744c69b3775994b079a3d4a2833629cdab370e0ef49d3b75508de7f3a10b7d12e8d32528250f479dc69e78c2841f9 + checksum: 10/23de1e5baed1b1da1991fc3b553a39bb63faca2490e089eed359cbd6b60658bd99c697dfcf29c600b89c5d717e2bdde524899c0b71f45eeb39e8f1b0057e6fa9 + languageName: node + linkType: hard + +"@openmrs/esm-styleguide@npm:5.6.1-pre.1930": + version: 5.6.1-pre.1930 + resolution: "@openmrs/esm-styleguide@npm:5.6.1-pre.1930" + dependencies: + "@carbon/charts": "npm:^1.12.0" + "@carbon/react": "npm:~1.37.0" + "@internationalized/date": "npm:^3.5.0" + "@react-spectrum/datepicker": "npm:^3.8.0" + "@react-spectrum/provider": "npm:^3.9.0" + "@react-spectrum/theme-default": "npm:^3.5.6" + core-js-pure: "npm:^3.36.0" + d3: "npm:^7.8.0" + geopattern: "npm:^1.2.3" + lodash-es: "npm:^4.17.21" + react-avatar: "npm:^5.0.3" + peerDependencies: + "@openmrs/esm-error-handling": 5.x + "@openmrs/esm-extensions": 5.x + "@openmrs/esm-navigation": 5.x + "@openmrs/esm-react-utils": 5.x + "@openmrs/esm-state": 5.x + "@openmrs/esm-translations": 5.x + dayjs: 1.x + i18next: 21.x + react: 18.x + react-dom: 18.x + rxjs: 6.x + checksum: 10/2f657773973643a95feba6e0699593c53ad2e456834b560015d5378ad1e97793efaf64f3597a6d79c032320edebec57f39ee13e7ddd09e14a182e5665759e1f8 languageName: node linkType: hard @@ -4440,27 +4724,54 @@ __metadata: languageName: node linkType: hard -"@openmrs/esm-translations@npm:5.5.1-pre.1705": - version: 5.5.1-pre.1705 - resolution: "@openmrs/esm-translations@npm:5.5.1-pre.1705" +"@openmrs/esm-translations@npm:5.6.0": + version: 5.6.0 + resolution: "@openmrs/esm-translations@npm:5.6.0" dependencies: i18next: "npm:21.10.0" peerDependencies: i18next: 21.x - checksum: 10/d68e208f74a25dd7d14f0c9985866881deffc851585cf36ddd59f3bbc86cdfcc6313ab888240a0c1cd41c4b2c9f0297993add48deccffb6f9617f31d459b6e12 + checksum: 10/55eae9599fbada40d79a0dc09d66f27b8f099f4d171aad1218f7142f938c3829d87df3e283cf84b5815d7c8e43af2ac35606101f4288cf2c538675c9922d29aa languageName: node linkType: hard -"@openmrs/esm-utils@npm:5.5.1-pre.1705": - version: 5.5.1-pre.1705 - resolution: "@openmrs/esm-utils@npm:5.5.1-pre.1705" +"@openmrs/esm-translations@npm:5.6.1-pre.1930": + version: 5.6.1-pre.1930 + resolution: "@openmrs/esm-translations@npm:5.6.1-pre.1930" + dependencies: + i18next: "npm:21.10.0" + peerDependencies: + i18next: 21.x + checksum: 10/8891c2347622e38128b13c2493348279c15e953cc83fc2fdf2368c8842eaeafd72c5888fd6299d4e247b31dc838936cef103a5c588c38f634f6dc1ed751b9376 + languageName: node + linkType: hard + +"@openmrs/esm-utils@npm:5.6.0": + version: 5.6.0 + resolution: "@openmrs/esm-utils@npm:5.6.0" dependencies: semver: "npm:7.3.2" peerDependencies: + "@openmrs/esm-globals": 5.x dayjs: 1.x i18next: 21.x rxjs: 6.x - checksum: 10/f3fe4cd1da5f98eb7418bf3a2e0daa9dcdba1acbba3bb26ce25a4557b3aa8ec25c7fbe02ebdedd39e7c5e8bece3a3be9203bd24c57d9e711957f3cc1051509b7 + checksum: 10/c87f1e3d0a5288b471b3e8049801c5829bbd12b12eccfeebd08c10af324b317bc7abeae982adec847b50bf91500ce6c449706185bce7e91083fdd32306169c95 + languageName: node + linkType: hard + +"@openmrs/esm-utils@npm:5.6.1-pre.1930": + version: 5.6.1-pre.1930 + resolution: "@openmrs/esm-utils@npm:5.6.1-pre.1930" + dependencies: + "@internationalized/date": "npm:^3.5.0" + semver: "npm:7.3.2" + peerDependencies: + "@openmrs/esm-globals": 5.x + dayjs: 1.x + i18next: 21.x + rxjs: 6.x + checksum: 10/e99c323c5326bdf3abdb136b92cce555e2f3a8c184b062745495081ea49fd6aee7da2323e900163e6a11d8a4b4bf9a6a0ff0ec8883932df76144027a83a44456 languageName: node linkType: hard @@ -4491,9 +4802,9 @@ __metadata: languageName: node linkType: hard -"@openmrs/webpack-config@npm:5.5.1-pre.1705": - version: 5.5.1-pre.1705 - resolution: "@openmrs/webpack-config@npm:5.5.1-pre.1705" +"@openmrs/webpack-config@npm:5.6.1-pre.1930": + version: 5.6.1-pre.1930 + resolution: "@openmrs/webpack-config@npm:5.6.1-pre.1930" dependencies: "@swc/core": "npm:^1.3.58" clean-webpack-plugin: "npm:^4.0.0" @@ -4510,7 +4821,7 @@ __metadata: webpack-stats-plugin: "npm:^1.0.3" peerDependencies: webpack: 5.x - checksum: 10/125e185bf4ac7828ab688d64ea9631ef5b5bb950865b7707ff0853f58707c5b4860f3e2b29b19af1cd93e6e6650cd274926840dfdc8f0602410da967c3663653 + checksum: 10/93480983256be067683618700b180540722e5e72c7c6cd54f54915f5b348119f9f9e9022fa970566f989a95d18c36be83025984fa5b67b1c6168140635f490b4 languageName: node linkType: hard @@ -6720,7 +7031,7 @@ __metadata: "@hookform/resolvers": "npm:^3.3.4" "@ohri/openmrs-esm-ohri-commons-lib": "npm:next" "@openmrs/esm-extensions": "npm:next" - "@openmrs/esm-framework": "npm:^5.5.1-pre.1704" + "@openmrs/esm-framework": "npm:^5.6.0" "@openmrs/esm-patient-common-lib": "npm:next" "@openmrs/esm-react-utils": "npm:next" "@openmrs/esm-styleguide": "npm:next" @@ -6754,7 +7065,7 @@ __metadata: jest-environment-jsdom: "npm:^28.1.3" lerna: "npm:^5.6.1" lodash-es: "npm:^4.17.21" - openmrs: "npm:^5.5.1-pre.1704" + openmrs: "npm:^5.6.1-pre.1930" plotly.js: "npm:^2.24.3" prettier: "npm:^2.8.8" pretty-quick: "npm:^3.1.3" @@ -13282,6 +13593,13 @@ __metadata: languageName: node linkType: hard +"immer@npm:^10.0.4": + version: 10.1.1 + resolution: "immer@npm:10.1.1" + checksum: 10/9dacf1e8c201d69191ccd88dc5d733bafe166cd45a5a360c5d7c88f1de0dff974a94114d72b35f3106adfe587fcfb131c545856184a2247d89d735ad25589863 + languageName: node + linkType: hard + "immutability-helper@npm:^2.3.1": version: 2.9.1 resolution: "immutability-helper@npm:2.9.1" @@ -17144,13 +17462,12 @@ __metadata: languageName: node linkType: hard -"openmrs@npm:^5.5.1-pre.1704": - version: 5.5.1-pre.1705 - resolution: "openmrs@npm:5.5.1-pre.1705" +"openmrs@npm:^5.6.1-pre.1930": + version: 5.6.1-pre.1930 + resolution: "openmrs@npm:5.6.1-pre.1930" dependencies: - "@carbon/icons-react": "npm:11.26.0" - "@openmrs/esm-app-shell": "npm:5.5.1-pre.1705" - "@openmrs/webpack-config": "npm:5.5.1-pre.1705" + "@openmrs/esm-app-shell": "npm:5.6.1-pre.1930" + "@openmrs/webpack-config": "npm:5.6.1-pre.1930" "@pnpm/npm-conf": "npm:^2.1.0" "@swc/core": "npm:^1.3.58" autoprefixer: "npm:^10.4.2" @@ -17170,6 +17487,7 @@ __metadata: postcss: "npm:^8.4.6" postcss-loader: "npm:^6.2.1" rimraf: "npm:^3.0.2" + semver: "npm:^7.3.4" swc-loader: "npm:^0.2.3" tar: "npm:^6.0.5" typescript: "npm:^4.6.4" @@ -17181,7 +17499,7 @@ __metadata: yargs: "npm:^17.6.2" bin: openmrs: ./dist/cli.js - checksum: 10/eaf45d9459338b55540a1bd27baacb8ed75a162f197c3b7a031b849c603f185994e310ea80c6f74653a4182865d947c8d7c12d13a5edb39eae384f79ef184010 + checksum: 10/386542e81340ff5b24f33fb0290344baffec9c2c43df714b232d7e1f3b5ebe32e6cd7860d9097d1dc0654d1feb1968d919ad8e32df110c358a6d23d4e98e8cd3 languageName: node linkType: hard From 005100e748bd5883a7753506a9170e866fb198a6 Mon Sep 17 00:00:00 2001 From: jabahum Date: Tue, 25 Jun 2024 14:04:26 +0300 Subject: [PATCH 04/10] fix add fixes --- ...ry-active-test-order-results.component.tsx | 24 +++++++++++------ .../laboratory-order-referals.component.tsx | 26 ++++++++++++------- ...tory-past-test-order-results.component.tsx | 24 +++++++++++------ src/results/result-form.component.tsx | 2 +- src/work-list/work-list.resource.ts | 3 ++- 5 files changed, 51 insertions(+), 28 deletions(-) diff --git a/src/patient-chart/laboratory-active-test-order/laboratory-active-test-order-results.component.tsx b/src/patient-chart/laboratory-active-test-order/laboratory-active-test-order-results.component.tsx index 18443848..e959ad08 100644 --- a/src/patient-chart/laboratory-active-test-order/laboratory-active-test-order-results.component.tsx +++ b/src/patient-chart/laboratory-active-test-order/laboratory-active-test-order-results.component.tsx @@ -102,14 +102,22 @@ const LaboratoryActiveTestOrderResults: React.FC< const sortedLabRequests = useMemo(() => { return [...items] - ?.filter( - (item) => - (item?.encounterType?.uuid === laboratoryEncounterTypeUuid || - item?.encounterType?.uuid === artCardEncounterTypeUuid) && - item.orders.filter( - (order) => order.orderType === laboratoryOrderTypeUuid - ) - ) + ?.filter((item) => { + const { encounterType, orders } = item || {}; + const { uuid: encounterTypeUuid } = encounterType || {}; + + // Check if the encounterType UUID matches either of the specified UUIDs + const isMatchingEncounterType = + encounterTypeUuid === laboratoryEncounterTypeUuid || + encounterTypeUuid === artCardEncounterTypeUuid; + + // Check if any order has a matching orderType UUID + const hasMatchingOrder = orders?.some( + ({ orderType }) => orderType?.uuid === laboratoryOrderTypeUuid + ); + + return isMatchingEncounterType && hasMatchingOrder; + }) ?.sort((a, b) => { const dateA = new Date(a.encounterDatetime); const dateB = new Date(b.encounterDatetime); diff --git a/src/patient-chart/laboratory-order-referals/laboratory-order-referals.component.tsx b/src/patient-chart/laboratory-order-referals/laboratory-order-referals.component.tsx index d33d8996..98907084 100644 --- a/src/patient-chart/laboratory-order-referals/laboratory-order-referals.component.tsx +++ b/src/patient-chart/laboratory-order-referals/laboratory-order-referals.component.tsx @@ -112,16 +112,22 @@ const LaboratoryOrderReferalResults: React.FC< const sortedLabRequests = useMemo(() => { return [...items] - ?.filter( - (item) => - (item?.encounterType?.uuid === laboratoryEncounterTypeUuid || - item?.encounterType?.uuid === artCardEncounterTypeUuid) && - item?.orders?.filter( - (order) => - order?.instructions === REFERINSTRUCTIONS || - order.orderType === laboratoryOrderTypeUuid - ) - ) + ?.filter((item) => { + const { encounterType, orders } = item || {}; + const { uuid: encounterTypeUuid } = encounterType || {}; + + // Check if the encounterType UUID matches either of the specified UUIDs + const isMatchingEncounterType = + encounterTypeUuid === laboratoryEncounterTypeUuid || + encounterTypeUuid === artCardEncounterTypeUuid; + + // Check if any order has a matching orderType UUID + const hasMatchingOrder = orders?.some( + ({ orderType }) => orderType?.uuid === laboratoryOrderTypeUuid + ); + + return isMatchingEncounterType && hasMatchingOrder; + }) ?.sort((a, b) => { const dateA = new Date(a.encounterDatetime); const dateB = new Date(b.encounterDatetime); diff --git a/src/patient-chart/laboratory-past-test/laboratory-past-test-order-results.component.tsx b/src/patient-chart/laboratory-past-test/laboratory-past-test-order-results.component.tsx index adc66e01..5d693f38 100644 --- a/src/patient-chart/laboratory-past-test/laboratory-past-test-order-results.component.tsx +++ b/src/patient-chart/laboratory-past-test/laboratory-past-test-order-results.component.tsx @@ -97,14 +97,22 @@ const LaboratoryPastTestOrderResults: React.FC< const sortedLabRequests = useMemo(() => { return [...items] - ?.filter( - (item) => - (item?.encounterType?.uuid === laboratoryEncounterTypeUuid || - item?.encounterType?.uuid === artCardEncounterTypeUuid) && - item.orders.filter( - (order) => order.orderType === laboratoryOrderTypeUuid - ) - ) + ?.filter((item) => { + const { encounterType, orders } = item || {}; + const { uuid: encounterTypeUuid } = encounterType || {}; + + // Check if the encounterType UUID matches either of the specified UUIDs + const isMatchingEncounterType = + encounterTypeUuid === laboratoryEncounterTypeUuid || + encounterTypeUuid === artCardEncounterTypeUuid; + + // Check if any order has a matching orderType UUID + const hasMatchingOrder = orders?.some( + ({ orderType }) => orderType?.uuid === laboratoryOrderTypeUuid + ); + + return isMatchingEncounterType && hasMatchingOrder; + }) ?.sort((a, b) => { const dateA = new Date(a.encounterDatetime); const dateB = new Date(b.encounterDatetime); diff --git a/src/results/result-form.component.tsx b/src/results/result-form.component.tsx index eb38739e..48c47189 100644 --- a/src/results/result-form.component.tsx +++ b/src/results/result-form.component.tsx @@ -121,7 +121,7 @@ const ResultForm: React.FC = ({ order, patientUuid }) => { encounter: order.encounter.uuid, patient: order.patient.uuid, concept: order.concept.uuid, - orderer: order.orderer, + orderer: order.orderer.uuid, }; UpdateOrderResult( diff --git a/src/work-list/work-list.resource.ts b/src/work-list/work-list.resource.ts index 24a5a473..71bb3be5 100644 --- a/src/work-list/work-list.resource.ts +++ b/src/work-list/work-list.resource.ts @@ -55,6 +55,7 @@ export interface Concept { } export interface Orderer { + uuid: string; display: string; } @@ -86,7 +87,7 @@ export interface IdentifierType { export function useGetOrdersWorklist(fulfillerStatus: string, dateTo?: string) { const { laboratoryOrderTypeUuid } = useConfig(); const customRepresentation = - "v=custom:(uuid,orderNumber,accessionNumber,instructions,careSetting:(uuid),encounter:(uuid,obs:(order:(uuid,display,patient:(uuid,display)))),fulfillerComment,orderType:(display),concept:(display,uuid),action,dateStopped,fulfillerStatus,dateActivated,orderer:(display),urgency,patient:(uuid,names:(display),display,gender,birthdate,identifiers:(voided,preferred,uuid,display,identifierType:(uuid))))"; + "v=custom:(uuid,orderNumber,accessionNumber,instructions,careSetting:(uuid),encounter:(uuid,obs:(order:(uuid,display,patient:(uuid,display)))),fulfillerComment,orderType:(display),concept:(display,uuid),action,dateStopped,fulfillerStatus,dateActivated,orderer:(uuid,display),urgency,patient:(uuid,names:(display),display,gender,birthdate,identifiers:(voided,preferred,uuid,display,identifierType:(uuid))))"; const orderTypeQuery = laboratoryOrderTypeUuid !== "" ? `orderTypes=${laboratoryOrderTypeUuid}` From 4df82e27e0085711afe1930cca12425d6ab68520 Mon Sep 17 00:00:00 2001 From: jabahum Date: Tue, 25 Jun 2024 14:32:00 +0300 Subject: [PATCH 05/10] fix review bug --- src/review-list/dialog/review-item.component.tsx | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) diff --git a/src/review-list/dialog/review-item.component.tsx b/src/review-list/dialog/review-item.component.tsx index 96149f11..f5122fac 100644 --- a/src/review-list/dialog/review-item.component.tsx +++ b/src/review-list/dialog/review-item.component.tsx @@ -43,9 +43,7 @@ const ReviewItem: React.FC = ({ const { encounter, isLoading } = useGetEncounterById(encounterUuid); const testsOrder = useMemo(() => { - return encounter?.obs?.filter( - (item) => item?.order?.display === "Test Order" - ); + return encounter?.obs?.filter((item) => item?.order?.type === "testorder"); }, [encounter?.obs]); const filteredGroupedResults = useMemo(() => { From 32ca35d372d0fe9f1b829619a03350b9618c0168 Mon Sep 17 00:00:00 2001 From: jabahum Date: Tue, 25 Jun 2024 15:10:05 +0300 Subject: [PATCH 06/10] return only laborders --- .../laboratory-active-test-order-results.component.tsx | 7 ++++--- .../laboratory-order-referals.component.tsx | 7 ++++--- .../laboratory-past-test-order-results.component.tsx | 7 ++++--- 3 files changed, 12 insertions(+), 9 deletions(-) diff --git a/src/patient-chart/laboratory-active-test-order/laboratory-active-test-order-results.component.tsx b/src/patient-chart/laboratory-active-test-order/laboratory-active-test-order-results.component.tsx index e959ad08..a3573498 100644 --- a/src/patient-chart/laboratory-active-test-order/laboratory-active-test-order-results.component.tsx +++ b/src/patient-chart/laboratory-active-test-order/laboratory-active-test-order-results.component.tsx @@ -111,12 +111,13 @@ const LaboratoryActiveTestOrderResults: React.FC< encounterTypeUuid === laboratoryEncounterTypeUuid || encounterTypeUuid === artCardEncounterTypeUuid; - // Check if any order has a matching orderType UUID - const hasMatchingOrder = orders?.some( + // Filter orders to only include those with the matching orderType UUID + const matchingOrders = orders?.filter( ({ orderType }) => orderType?.uuid === laboratoryOrderTypeUuid ); - return isMatchingEncounterType && hasMatchingOrder; + // Return the item only if it has matching encounterType and at least one matching order + return isMatchingEncounterType && matchingOrders?.length > 0; }) ?.sort((a, b) => { const dateA = new Date(a.encounterDatetime); diff --git a/src/patient-chart/laboratory-order-referals/laboratory-order-referals.component.tsx b/src/patient-chart/laboratory-order-referals/laboratory-order-referals.component.tsx index 98907084..8253a2bc 100644 --- a/src/patient-chart/laboratory-order-referals/laboratory-order-referals.component.tsx +++ b/src/patient-chart/laboratory-order-referals/laboratory-order-referals.component.tsx @@ -121,12 +121,13 @@ const LaboratoryOrderReferalResults: React.FC< encounterTypeUuid === laboratoryEncounterTypeUuid || encounterTypeUuid === artCardEncounterTypeUuid; - // Check if any order has a matching orderType UUID - const hasMatchingOrder = orders?.some( + // Filter orders to only include those with the matching orderType UUID + const matchingOrders = orders?.filter( ({ orderType }) => orderType?.uuid === laboratoryOrderTypeUuid ); - return isMatchingEncounterType && hasMatchingOrder; + // Return the item only if it has matching encounterType and at least one matching order + return isMatchingEncounterType && matchingOrders?.length > 0; }) ?.sort((a, b) => { const dateA = new Date(a.encounterDatetime); diff --git a/src/patient-chart/laboratory-past-test/laboratory-past-test-order-results.component.tsx b/src/patient-chart/laboratory-past-test/laboratory-past-test-order-results.component.tsx index 5d693f38..dc8cc782 100644 --- a/src/patient-chart/laboratory-past-test/laboratory-past-test-order-results.component.tsx +++ b/src/patient-chart/laboratory-past-test/laboratory-past-test-order-results.component.tsx @@ -106,12 +106,13 @@ const LaboratoryPastTestOrderResults: React.FC< encounterTypeUuid === laboratoryEncounterTypeUuid || encounterTypeUuid === artCardEncounterTypeUuid; - // Check if any order has a matching orderType UUID - const hasMatchingOrder = orders?.some( + // Filter orders to only include those with the matching orderType UUID + const matchingOrders = orders?.filter( ({ orderType }) => orderType?.uuid === laboratoryOrderTypeUuid ); - return isMatchingEncounterType && hasMatchingOrder; + // Return the item only if it has matching encounterType and at least one matching order + return isMatchingEncounterType && matchingOrders?.length > 0; }) ?.sort((a, b) => { const dateA = new Date(a.encounterDatetime); From d46df4beef1ff31069827c8b7a101ee2591beeb1 Mon Sep 17 00:00:00 2001 From: jabahum Date: Tue, 25 Jun 2024 15:58:01 +0300 Subject: [PATCH 07/10] remove drug orders --- .../laboratory-active-test-order-results.component.tsx | 4 +++- .../laboratory-order-referals.component.tsx | 4 +++- .../laboratory-past-test-order-results.component.tsx | 4 +++- 3 files changed, 9 insertions(+), 3 deletions(-) diff --git a/src/patient-chart/laboratory-active-test-order/laboratory-active-test-order-results.component.tsx b/src/patient-chart/laboratory-active-test-order/laboratory-active-test-order-results.component.tsx index a3573498..aafec840 100644 --- a/src/patient-chart/laboratory-active-test-order/laboratory-active-test-order-results.component.tsx +++ b/src/patient-chart/laboratory-active-test-order/laboratory-active-test-order-results.component.tsx @@ -113,7 +113,9 @@ const LaboratoryActiveTestOrderResults: React.FC< // Filter orders to only include those with the matching orderType UUID const matchingOrders = orders?.filter( - ({ orderType }) => orderType?.uuid === laboratoryOrderTypeUuid + ({ orderType }) => + orderType?.uuid === laboratoryOrderTypeUuid && + orderType?.uuid !== "131168f4-15f5-102d-96e4-000c29c2a5d7" ); // Return the item only if it has matching encounterType and at least one matching order diff --git a/src/patient-chart/laboratory-order-referals/laboratory-order-referals.component.tsx b/src/patient-chart/laboratory-order-referals/laboratory-order-referals.component.tsx index 8253a2bc..1ce92ae2 100644 --- a/src/patient-chart/laboratory-order-referals/laboratory-order-referals.component.tsx +++ b/src/patient-chart/laboratory-order-referals/laboratory-order-referals.component.tsx @@ -123,7 +123,9 @@ const LaboratoryOrderReferalResults: React.FC< // Filter orders to only include those with the matching orderType UUID const matchingOrders = orders?.filter( - ({ orderType }) => orderType?.uuid === laboratoryOrderTypeUuid + ({ orderType }) => + orderType?.uuid === laboratoryOrderTypeUuid && + orderType?.uuid !== "131168f4-15f5-102d-96e4-000c29c2a5d7" ); // Return the item only if it has matching encounterType and at least one matching order diff --git a/src/patient-chart/laboratory-past-test/laboratory-past-test-order-results.component.tsx b/src/patient-chart/laboratory-past-test/laboratory-past-test-order-results.component.tsx index dc8cc782..a5ce7911 100644 --- a/src/patient-chart/laboratory-past-test/laboratory-past-test-order-results.component.tsx +++ b/src/patient-chart/laboratory-past-test/laboratory-past-test-order-results.component.tsx @@ -108,7 +108,9 @@ const LaboratoryPastTestOrderResults: React.FC< // Filter orders to only include those with the matching orderType UUID const matchingOrders = orders?.filter( - ({ orderType }) => orderType?.uuid === laboratoryOrderTypeUuid + ({ orderType }) => + orderType?.uuid === laboratoryOrderTypeUuid && + orderType.uuid !== "131168f4-15f5-102d-96e4-000c29c2a5d7" ); // Return the item only if it has matching encounterType and at least one matching order From 9d702334f48a40be33e49c30894d40070c9b9bc0 Mon Sep 17 00:00:00 2001 From: jabahum Date: Tue, 25 Jun 2024 16:08:26 +0300 Subject: [PATCH 08/10] fix bug --- ...tient-laboratory-order-results.resource.ts | 23 +++++++++++-------- 1 file changed, 13 insertions(+), 10 deletions(-) diff --git a/src/patient-chart/patient-laboratory-order-results.resource.ts b/src/patient-chart/patient-laboratory-order-results.resource.ts index 1b77aa99..adaba907 100644 --- a/src/patient-chart/patient-laboratory-order-results.resource.ts +++ b/src/patient-chart/patient-laboratory-order-results.resource.ts @@ -453,17 +453,20 @@ export function usePatientLaboratoryOrders(filter: LaboratoryOrderFilter) { Error >(apiUrl, openmrsFetch, { refreshInterval: 3000 }); + const filteredItems = data?.data?.results + ? data.data.results + .map((item) => ({ + ...item, + orders: item.orders.filter( + (order) => + order?.orderType?.uuid !== "131168f4-15f5-102d-96e4-000c29c2a5d7" + ), + })) + .filter((item) => item.orders.length > 0) + : []; + return { - items: data?.data - ? data?.data?.results.filter( - (item) => - item?.orders.length !== 0 && - item.orders.filter( - (item) => - item?.orderType?.uuid !== "131168f4-15f5-102d-96e4-000c29c2a5d7" - ) - ) - : [], + items: filteredItems, isLoading, isError: error, }; From 7af205d1e4ed2ab52080fdd6ede2119730a6728c Mon Sep 17 00:00:00 2001 From: jabahum Date: Tue, 25 Jun 2024 16:27:19 +0300 Subject: [PATCH 09/10] fix refer bug --- .../laboratory-order-referals.component.tsx | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/src/patient-chart/laboratory-order-referals/laboratory-order-referals.component.tsx b/src/patient-chart/laboratory-order-referals/laboratory-order-referals.component.tsx index 1ce92ae2..4f8199b0 100644 --- a/src/patient-chart/laboratory-order-referals/laboratory-order-referals.component.tsx +++ b/src/patient-chart/laboratory-order-referals/laboratory-order-referals.component.tsx @@ -123,9 +123,10 @@ const LaboratoryOrderReferalResults: React.FC< // Filter orders to only include those with the matching orderType UUID const matchingOrders = orders?.filter( - ({ orderType }) => - orderType?.uuid === laboratoryOrderTypeUuid && - orderType?.uuid !== "131168f4-15f5-102d-96e4-000c29c2a5d7" + (order) => + order?.orderType?.uuid === laboratoryOrderTypeUuid && + order?.orderType?.uuid !== "131168f4-15f5-102d-96e4-000c29c2a5d7" && + order?.instructions === REFERINSTRUCTIONS ); // Return the item only if it has matching encounterType and at least one matching order From ccf8d1f6f8977bb9f250b2ceea92ad657ac5ff40 Mon Sep 17 00:00:00 2001 From: jabahum Date: Tue, 25 Jun 2024 16:33:33 +0300 Subject: [PATCH 10/10] fix bug --- .../laboratory-order-referals.component.tsx | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/src/patient-chart/laboratory-order-referals/laboratory-order-referals.component.tsx b/src/patient-chart/laboratory-order-referals/laboratory-order-referals.component.tsx index 4f8199b0..50890db1 100644 --- a/src/patient-chart/laboratory-order-referals/laboratory-order-referals.component.tsx +++ b/src/patient-chart/laboratory-order-referals/laboratory-order-referals.component.tsx @@ -292,7 +292,8 @@ const LaboratoryOrderReferalResults: React.FC< (order?.action === "NEW" || order?.action === "REVISE" || order?.action === "DISCONTINUE") && - order.dateStopped === null + order.dateStopped === null && + order.instructions === REFERINSTRUCTIONS ) { return (