Skip to content

Commit

Permalink
Merge branch 'main' into rob/2646-align-patient-info-population-betwe…
Browse files Browse the repository at this point in the history
…en-design-and-dev
  • Loading branch information
robertandremitchell authored Oct 10, 2024
2 parents b1659b5 + 280b94e commit 96fa090
Show file tree
Hide file tree
Showing 3 changed files with 363 additions and 140 deletions.
85 changes: 70 additions & 15 deletions containers/ecr-viewer/src/app/components/EcrTable.tsx
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
import { Table } from "@trussworks/react-uswds";
import { EcrDisplay, listEcrData } from "@/app/api/services/listEcrDataService";
import { toSentenceCase } from "@/app/services/formatService";

const basePath =
process.env.NODE_ENV === "production" ? process.env.NEXT_PUBLIC_BASEPATH : "";
Expand Down Expand Up @@ -68,22 +69,76 @@ const EcrTable = async ({
*/
const renderListEcrTableData = (listFhirData: EcrDisplay[]) => {
return listFhirData.map((item, index) => {
return (
<tr key={`table-row-${index}`}>
<td>
<a href={`${basePath}/view-data?id=${item.ecrId}`}>
{item.patient_first_name} {item.patient_last_name}
</a>
<br />
{"DOB: " + item.patient_date_of_birth || ""}
</td>
<td>{item.date_created}</td>
<td>{item.patient_report_date}</td>
<td>{item.reportable_condition}</td>
<td>{item.rule_summary}</td>
</tr>
);
return formatRow(item, index);
});
};

/**
* Formats a single row of the eCR table.
* @param item - The eCR data to be formatted.
* @param index - The index of the eCR data in the list.
* @returns A JSX table row element representing the eCR data.
*/
const formatRow = (item: EcrDisplay, index: number) => {
let patient_first_name = toSentenceCase(item.patient_first_name);
let patient_last_name = toSentenceCase(item.patient_last_name);
let createDateObj = new Date(item.date_created);
let createDateDate = formatDate(createDateObj);
let createDateTime = formatTime(createDateObj);
let patientReportDateObj = new Date(item.patient_report_date);
let patientReportDate = formatDate(patientReportDateObj);
let patientReportTime = formatTime(patientReportDateObj);

return (
<tr key={`table-row-${index}`}>
<td>
<a href={`${basePath}/view-data?id=${item.ecrId}`}>
{patient_first_name} {patient_last_name}
</a>
<br />
<div>{"DOB: " + item.patient_date_of_birth || ""}</div>
</td>
<td>
{createDateDate}
<br />
{createDateTime}
</td>
<td>
{patientReportDate}
<br />
{patientReportTime}
</td>
<td>{item.reportable_condition}</td>
<td>{item.rule_summary}</td>
</tr>
);
};

/**
* Formats a date object to a string in the format MM/DD/YYYY.
* @param date - The date object to be formatted.
* @returns A string in the format MM/DD/YYYY.
*/
const formatDate = (date: Date) => {
return date.toLocaleDateString("en-US");
};

/**
* Formats a date object to a string in the format HH:MM AM/PM.
* @param date - The date object to be formatted.
* @returns A string in the format HH:MM AM/PM.
*/
const formatTime = (date: Date) => {
let hours = date.getHours();
const minutes = date.getMinutes();
const ampm = hours >= 12 ? "PM" : "AM";

hours = hours % 12;
hours = hours ? hours : 12;

const minutesStr = minutes < 10 ? `0${minutes}` : minutes;

return `${hours}:${minutesStr} ${ampm}`;
};

export default EcrTable;
Loading

0 comments on commit 96fa090

Please sign in to comment.