From cb23669d3eefea400fd05034c21e06ba05fb4fa3 Mon Sep 17 00:00:00 2001 From: rithviknishad Date: Fri, 13 Sep 2024 14:12:12 +0530 Subject: [PATCH] Update view details page; fixes #8532 --- .../DailyRounds/DefaultLogUpdateCard.tsx | 2 +- .../LogUpdate/CriticalCarePreview.tsx | 121 ++++++++++++++++-- 2 files changed, 109 insertions(+), 14 deletions(-) diff --git a/src/Components/Facility/Consultations/DailyRounds/DefaultLogUpdateCard.tsx b/src/Components/Facility/Consultations/DailyRounds/DefaultLogUpdateCard.tsx index 9096e66b69b..e7759395615 100644 --- a/src/Components/Facility/Consultations/DailyRounds/DefaultLogUpdateCard.tsx +++ b/src/Components/Facility/Consultations/DailyRounds/DefaultLogUpdateCard.tsx @@ -21,7 +21,7 @@ const DefaultLogUpdateCard = ({ round, ...props }: Props) => { > -

Consultation Updates

+

+ Consultation Updates +
+ {t(`ROUNDS_TYPE__${data.rounds_type}`)} +
+

- {/* */}
+
+ + +
+ + + + +
+
+ + + +
+
+
{(["left", "right"] as const).map((dir) => ( -
+
{dir} Pupil
{ +type SectionContextType = { + hasValue: () => void; +}; + +const sectionContext = React.createContext(null); + +const Section = (props: { + title: string; + children: React.ReactNode; + subSection?: boolean; +}) => { + const parentContext = React.useContext(sectionContext); + const [hasValue, setHasValue] = React.useState(false); + + useEffect(() => { + if (parentContext && hasValue) { + parentContext.hasValue(); + } + }, [parentContext, hasValue]); + return ( -
setHasValue(true), + }} > -

{props.title}

- {props.children} -
+
+ {props.subSection ? ( +
{props.title}
+ ) : ( +

{props.title}

+ )} + {props.children} +
+ ); }; const Detail = (props: { label: React.ReactNode; - value?: string | number | boolean; + value?: string | number | boolean | null; suffix?: React.ReactNode; }) => { + const context = React.useContext(sectionContext); + + if (context === null) { + throw "This component must be used as a descendant of Section component only"; + } + let value = props.value; - value = value === "" ? undefined : value; + value = value === "" ? null : value; value = value === true ? "Yes" : value; value = value === false ? "No" : value; + React.useEffect(() => { + if (value != null) { + context.hasValue(); + } + }, [context, value]); + + if (value == null) { + // Skip showing detail if attribute not filled. + return null; + } + value = typeof value === "string" ? parseFloat(value) || value : value; value = typeof value === "number" ? properRoundOf(value) : value; @@ -516,6 +592,25 @@ const Detail = (props: { ); }; +const ChoiceDetail = (props: { + name: keyof DailyRoundsModel; + data: DailyRoundsModel; +}) => { + const { t } = useTranslation(); + const value = props.data[props.name]; + + if (value == null) { + return; + } + + return ( + + ); +}; + const RangeDetail = (props: { label: React.ReactNode; value?: number;