Skip to content

Commit

Permalink
♻️ refactor: Rewrite <AppointmentsForPatient> for readability.
Browse files Browse the repository at this point in the history
  • Loading branch information
make-github-pseudonymous-again committed Dec 10, 2024
1 parent ad68bfe commit 5a31e0a
Show file tree
Hide file tree
Showing 2 changed files with 42 additions and 38 deletions.
6 changes: 6 additions & 0 deletions imports/lib/array/removeUndefined.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
const removeUndefined = <T extends any[]>(array: T) =>
array.filter((value: T) => value !== undefined) as {
[K in keyof T]: T[K] extends {} ? T[K] : never;
};

export default removeUndefined;
74 changes: 36 additions & 38 deletions imports/ui/appointments/AppointmentsForPatient.tsx
Original file line number Diff line number Diff line change
@@ -1,10 +1,13 @@
import React, {useState} from 'react';
import React, {useState, useMemo} from 'react';

import PhoneDisabledIcon from '@mui/icons-material/PhoneDisabled';
import AlarmOffIcon from '@mui/icons-material/AlarmOff';

import startOfToday from 'date-fns/startOfToday';

import removeUndefinedValuesFromArray from '../../lib/array/removeUndefined';
import removeUndefinedValuesFromObject from '../../lib/object/removeUndefined';

import usePatient from '../patients/usePatient';

import Loading from '../navigation/Loading';
Expand All @@ -18,6 +21,32 @@ type Props = {
readonly patientId: string;
};

const _sort = {datetime: -1} as const;

const _filter = (patientId: string, {showCancelled, showNoShow}) => {
return {
patientId,
isDone: false,
$or: removeUndefinedValuesFromArray([
removeUndefinedValuesFromObject({
isCancelled: {
$in: [false, null!],
},
scheduledDatetime: showNoShow
? undefined
: {
$ge: startOfToday(), // TODO make reactive?
},
}),
showCancelled
? {
isCancelled: true,
}
: undefined,
]),
};
};

const AppointmentsForPatient = ({patientId}: Props) => {
const [showCancelled, setShowCancelled] = useState(true);
const [showNoShow, setShowNoShow] = useState(true);
Expand All @@ -28,6 +57,11 @@ const AppointmentsForPatient = ({patientId}: Props) => {
[patientId],
);

const filter = useMemo(
() => _filter(patientId, {showCancelled, showNoShow}),
[patientId, showCancelled, showNoShow],
);

if (loading) {
return <Loading />;
}
Expand All @@ -36,48 +70,12 @@ const AppointmentsForPatient = ({patientId}: Props) => {
return <NoContent>Patient not found.</NoContent>;
}

const $or: Array<{
isCancelled: boolean | {$in: boolean[]};
scheduledDatetime?: {$gt: Date};
}> = [
{
isCancelled: {
$in: [false, null!],
},
scheduledDatetime: {
$gt: startOfToday(), // TODO make reactive?
},
},
];

const filter = {
patientId,
isDone: false,
$or,
};

if (showCancelled) {
$or.push({
isCancelled: true,
});
}

if (showNoShow) {
$or.push({
isCancelled: {
$in: [false, null!],
},
});
}

const sort = {datetime: -1};

return (
<>
<ConsultationsPager
defaultExpandedFirst
filter={filter}
sort={sort}
sort={_sort}
perpage={5}
/>
<ManageConsultationsForPatientButton
Expand Down

0 comments on commit 5a31e0a

Please sign in to comment.