@ampath/esm-reports-app 1.0.0-next.4 → 1.0.0-next.41

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (132) hide show
  1. package/dist/110.js +1 -0
  2. package/dist/110.js.map +1 -0
  3. package/dist/{260.js → 205.js} +1 -1
  4. package/dist/{260.js.map → 205.js.map} +1 -1
  5. package/dist/812.js +1 -1
  6. package/dist/812.js.map +1 -1
  7. package/dist/822.js +2 -0
  8. package/dist/822.js.map +1 -0
  9. package/dist/ampath-esm-reports-app.js +1 -1
  10. package/dist/ampath-esm-reports-app.js.buildmanifest.json +95 -74
  11. package/dist/ampath-esm-reports-app.js.map +1 -1
  12. package/dist/main.js +1 -1
  13. package/dist/main.js.map +1 -1
  14. package/dist/routes.json +1 -1
  15. package/package.json +1 -1
  16. package/src/common/report-filters/report-filters.component.tsx +68 -7
  17. package/src/common/report-filters/report-filters.scss +42 -0
  18. package/src/dashboard/reports-dasboard.tsx +21 -0
  19. package/src/reports/datatable-wrapper/datatable-wrapper.component.tsx +54 -0
  20. package/src/reports/moh-240/moh-240-header.component.tsx +61 -0
  21. package/src/reports/moh-240/moh-240.component.tsx +93 -0
  22. package/src/reports/moh-240/moh-240.scss +11 -0
  23. package/src/reports/moh-240/sub-reports/moh-240-register.component.tsx +75 -0
  24. package/src/reports/moh-240/sub-reports/page-summary.component.tsx +98 -0
  25. package/src/reports/moh-505/moh-505-header.component.tsx +62 -0
  26. package/src/reports/moh-505/moh-505.component.tsx +440 -0
  27. package/src/reports/moh-505/moh-505.scss +3 -0
  28. package/src/reports/moh-705B/moh-204b-register.component.tsx +236 -0
  29. package/src/reports/moh-705B/moh-705b.component.tsx +524 -0
  30. package/src/reports/moh-705B/moh-705b.scss +44 -0
  31. package/src/reports/moh-705a/moh-705a.component.tsx +528 -0
  32. package/src/reports/moh-705a/moh-705a.scss +45 -0
  33. package/src/reports/moh-705a/registers/moh-204a-register.component.tsx +321 -0
  34. package/src/reports/moh-705a/type.ts +6 -0
  35. package/src/reports/moh-706/moh-706-header.component.tsx +61 -0
  36. package/src/reports/moh-706/moh-706.component.tsx +117 -0
  37. package/src/reports/moh-706/moh-706.scss +30 -0
  38. package/src/reports/moh-706/sub-reports/bacteriology/bacteriology.component.tsx +124 -0
  39. package/src/reports/moh-706/sub-reports/blood-chemistry/blood-chemistry.component.tsx +318 -0
  40. package/src/reports/moh-706/sub-reports/drug-susceptibility-testing/drug-susceptibility-testing.component.tsx +137 -0
  41. package/src/reports/moh-706/sub-reports/haematology/haematology.component.tsx +179 -0
  42. package/src/reports/moh-706/sub-reports/histology-and-cytology/histology-and-cytology.component.tsx +88 -0
  43. package/src/reports/moh-706/sub-reports/parasitology/parasitology.component.tsx +121 -0
  44. package/src/reports/moh-706/sub-reports/serology/serology.component.tsx +47 -0
  45. package/src/reports/moh-706/sub-reports/specimen-referral-to-higher-levels/specimen-referral-to-higher-levels.component.tsx +39 -0
  46. package/src/reports/moh-706/sub-reports/urine-analysis/urine-analysis.component.tsx +108 -0
  47. package/src/reports/moh-710/moh-710.component.tsx +211 -79
  48. package/src/reports/moh-710/moh-710.scss +5 -1
  49. package/src/reports/moh-710/registers/moh-511-710-register.component.tsx +263 -0
  50. package/src/reports/moh-710/registers/type.ts +31 -0
  51. package/src/reports/moh-711/moh-711.component.tsx +109 -1234
  52. package/src/reports/moh-711/moh711.scss +92 -8
  53. package/src/reports/moh-711/registers/moh-333-register.component.tsx +639 -0
  54. package/src/reports/moh-711/registers/moh-405-register.component.tsx +521 -0
  55. package/src/reports/moh-711/registers/moh-406-register.component.tsx +533 -0
  56. package/src/reports/moh-711/registers/moh-510-register.component.tsx +61 -0
  57. package/src/reports/moh-711/registers/moh-511-register.component.tsx +271 -0
  58. package/src/reports/moh-711/registers/type.ts +192 -0
  59. package/src/reports/moh-711/sections/anc.component.tsx +159 -0
  60. package/src/reports/moh-711/sections/cervical-cancer.component.tsx +148 -0
  61. package/src/reports/moh-711/sections/chanis.component.tsx +367 -0
  62. package/src/reports/moh-711/sections/family-planning.component.tsx +221 -0
  63. package/src/reports/moh-711/sections/gbv.component.tsx +115 -0
  64. package/src/reports/moh-711/sections/maternity.component.tsx +326 -0
  65. package/src/reports/moh-711/sections/medical-social-work.component.tsx +83 -0
  66. package/src/reports/moh-711/sections/other.component.tsx +47 -0
  67. package/src/reports/moh-711/sections/physiotherapy.component.tsx +61 -0
  68. package/src/reports/moh-711/sections/pnc.component.tsx +125 -0
  69. package/src/reports/moh-711/sections/post-abortion.component.tsx +42 -0
  70. package/src/reports/moh-711/sections/rehabilitation.component.tsx +57 -0
  71. package/src/reports/moh-711/sections/report-compiled-by.component.tsx +42 -0
  72. package/src/reports/moh-711/sections/tb-screening.component.tsx +57 -0
  73. package/src/reports/moh-717/moh-717.component.tsx +120 -946
  74. package/src/reports/moh-717/moh717.scss +138 -3
  75. package/src/reports/moh-717/registers/nutrition-register.component.tsx +48 -0
  76. package/src/reports/moh-717/sections/finance.component.tsx +42 -0
  77. package/src/reports/moh-717/sections/inpatient.component.tsx +374 -0
  78. package/src/reports/moh-717/sections/maternity.component.tsx +126 -0
  79. package/src/reports/moh-717/sections/medical-records.component.tsx +35 -0
  80. package/src/reports/moh-717/sections/mortuary.component.tsx +43 -0
  81. package/src/reports/moh-717/sections/operations.component.tsx +53 -0
  82. package/src/reports/moh-717/sections/orthopaedic-trauma.component.tsx +98 -0
  83. package/src/reports/moh-717/sections/outpatient.component.tsx +597 -0
  84. package/src/reports/moh-717/sections/pharmacy.component.tsx +43 -0
  85. package/src/reports/moh-717/sections/preparedby.component.tsx +47 -0
  86. package/src/reports/moh-717/sections/special-services.component.tsx +114 -0
  87. package/src/reports/moh-731/moh-731.component.tsx +181 -0
  88. package/src/reports/moh-731/moh-731.scss +118 -0
  89. package/src/reports/moh-731/registers/moh-366.component.tsx +478 -0
  90. package/src/reports/moh-731/registers/moh-366.scss +45 -0
  91. package/src/reports/moh-731/registers/prep-register.component.tsx +292 -0
  92. package/src/reports/moh-731/registers/prep-registers.scss +45 -0
  93. package/src/reports/moh-731/sections/hiv-and-tb-treatment.component.tsx +932 -0
  94. package/src/reports/moh-731/sections/hiv-testing-and-pre-exposure.component.tsx +569 -0
  95. package/src/reports/moh-731/sections/pmtct.component.tsx +451 -0
  96. package/src/reports/moh-740/moh-740.component.scss +120 -0
  97. package/src/reports/moh-740/moh-740.component.tsx +1271 -0
  98. package/src/reports/moh-740/moh-740.resource.ts +42 -0
  99. package/src/reports/moh-740/registers/moh-222-daily-register/moh-222-daily-register.scss +18 -0
  100. package/src/reports/moh-740/registers/moh-222-daily-register/moh-222-daily-register.tsx +104 -0
  101. package/src/reports/moh-740/registers/moh-270-permanent-register/moh-270-permanent-register.scss +18 -0
  102. package/src/reports/moh-740/registers/moh-270-permanent-register/moh-270-permanent-register.tsx +79 -0
  103. package/src/reports/moh-740/registers/moh-740-patient-list.scss +0 -0
  104. package/src/reports/moh-740/registers/moh-740-patient-list.tsx +66 -0
  105. package/src/reports/moh-740/shared/data-cell/data-cell.scss +6 -0
  106. package/src/reports/moh-740/shared/data-cell/data-cell.tsx +23 -0
  107. package/src/reports/moh-740/shared/utils/format-indicator.ts +22 -0
  108. package/src/reports/moh-740/shared/utils/indicator-register-map.ts +157 -0
  109. package/src/reports/moh-740/types/index.ts +216 -0
  110. package/src/reports/moh-745/moh-745.component.tsx +928 -0
  111. package/src/reports/moh-745/moh-745.scss +74 -0
  112. package/src/reports/moh-745/registers/moh-412-register.component.tsx +191 -0
  113. package/src/reports/moh-745/registers/type.ts +30 -0
  114. package/src/reports/table-wrapper/table-row-mapper.component.tsx +53 -0
  115. package/src/reports/table-wrapper/table-wrapper.component.tsx +21 -0
  116. package/src/reports/table-wrapper/table-wrapper.scss +31 -0
  117. package/src/resources/moh-505.resource.ts +86 -0
  118. package/src/resources/moh-705.resource.ts +117 -0
  119. package/src/resources/moh-706.resource.ts +86 -0
  120. package/src/resources/moh-710.resource.ts +28 -0
  121. package/src/resources/moh-711.resource.ts +146 -0
  122. package/src/resources/moh-717.resource.ts +27 -0
  123. package/src/resources/moh-731.resource.ts +96 -0
  124. package/src/resources/moh-745.resource.ts +64 -0
  125. package/src/root.component.tsx +39 -0
  126. package/src/routes.json +3 -1
  127. package/src/utils/utils.ts +36 -0
  128. package/dist/367.js +0 -2
  129. package/dist/367.js.map +0 -1
  130. package/dist/86.js +0 -1
  131. package/dist/86.js.map +0 -1
  132. /package/dist/{367.js.LICENSE.txt → 822.js.LICENSE.txt} +0 -0
@@ -0,0 +1,42 @@
1
+ import { openmrsFetch } from '@openmrs/esm-framework';
2
+ import { getEtlBaseUrl } from '../../utils/get-base-url';
3
+ import {
4
+ type Moh740Resp,
5
+ type Moh740Dto,
6
+ type Moh740Data,
7
+ type Moh740RegisterDto,
8
+ type Moh740RegisterResp,
9
+ type Moh270Patient,
10
+ } from './types';
11
+
12
+ const baseMoh740Url = 'moh-740-report';
13
+
14
+ export async function fetchMoh740Report(params: Moh740Dto): Promise<Moh740Data | null> {
15
+ const etlBaseUrl = await getEtlBaseUrl();
16
+ const moh740Url = `${etlBaseUrl}/${baseMoh740Url}?endDate=${params.endDate}&locationUuids=${params.locationUuid}`;
17
+ const resp = await openmrsFetch(moh740Url);
18
+ const data: Moh740Resp = await resp.json();
19
+ if (data && data.result) {
20
+ return data.result[0];
21
+ } else {
22
+ return null;
23
+ }
24
+ }
25
+
26
+ export async function fetchMoh740Register(params: Moh740RegisterDto): Promise<Moh270Patient[]> {
27
+ const etlBaseUrl = await getEtlBaseUrl();
28
+ const p = {
29
+ endDate: params.endDate,
30
+ indicators: params.indicators,
31
+ locationUuids: params.locationUuid,
32
+ };
33
+ const queryString = new URLSearchParams(p).toString();
34
+ const moh740RegisterUrl = `${etlBaseUrl}/${baseMoh740Url}/patient-list`;
35
+ const resp = await openmrsFetch(`${moh740RegisterUrl}?${queryString}`);
36
+ const data: Moh740RegisterResp = await resp.json();
37
+ if (data && data.result) {
38
+ return data.result;
39
+ } else {
40
+ return [];
41
+ }
42
+ }
@@ -0,0 +1,18 @@
1
+ .registerLayout{
2
+ display: flex;
3
+ flex-direction: column;
4
+ width: 100%;
5
+ padding: 10px 10px;
6
+ row-gap: 10px;
7
+ .registerHeader{
8
+ display: flex;
9
+ flex-direction: column;
10
+ width: 100%;
11
+ row-gap: 10px;
12
+ .pageTitle{
13
+ width: 100%;
14
+ justify-content: center;
15
+ text-align: center;
16
+ }
17
+ }
18
+ }
@@ -0,0 +1,104 @@
1
+ import React, { useMemo } from 'react';
2
+ import styles from './moh-222-daily-register.scss';
3
+ import { type Moh222Patient } from '../../types';
4
+ import { formatIndicatorName } from '../../shared/utils/format-indicator';
5
+ import { Link, Table, TableBody, TableCell, TableHead, TableHeader, TableRow } from '@carbon/react';
6
+ interface Moh222DailyRegisterProps {
7
+ moh222PatientList: Moh222Patient[];
8
+ indicator: string;
9
+ }
10
+ const Moh222DailyRegister: React.FC<Moh222DailyRegisterProps> = ({ moh222PatientList, indicator }) => {
11
+ const pageTitle = useMemo(() => formatIndicatorName(indicator ?? ''), [indicator]);
12
+ const reportTitle = 'Daily Activity Register - MOH 222';
13
+ if (!moh222PatientList) {
14
+ return <>No Data to display</>;
15
+ }
16
+ return (
17
+ <>
18
+ <div className={styles.registerLayout}>
19
+ <div className={styles.registerHeader}>
20
+ <h4 className={styles.pageTitle}>{reportTitle}</h4>
21
+ <h6 className={styles.pageTitle}>{pageTitle}</h6>
22
+ </div>
23
+ <div className={styles.content}>
24
+
25
+ <Table>
26
+ <TableHead>
27
+ <TableRow>
28
+ <TableHeader>No</TableHeader>
29
+ <TableHeader>Date</TableHeader>
30
+ <TableHeader>Patient No</TableHeader>
31
+ <TableHeader>Patient Name</TableHeader>
32
+ <TableHeader>Age</TableHeader>
33
+ <TableHeader>D.O.B</TableHeader>
34
+ <TableHeader>Sex(M/F)</TableHeader>
35
+ <TableHeader>Visit for the month</TableHeader>
36
+ <TableHeader>Weight(Kg)</TableHeader>
37
+ <TableHeader>Height(cm)</TableHeader>
38
+ <TableHeader>BMI</TableHeader>
39
+ <TableHeader>Waist Circumference</TableHeader>
40
+ <TableHeader>BP(mmHg)</TableHeader>
41
+ <TableHeader>HTN</TableHeader>
42
+ <TableHeader>Diabetes</TableHeader>
43
+ <TableHeader>Both Diabetes and Hypetention(HTN)</TableHeader>
44
+ <TableHeader>RBS(mmol/L)</TableHeader>
45
+ <TableHeader>FBS(mmol/L)</TableHeader>
46
+ <TableHeader>HbA1C(%) within 3 months</TableHeader>
47
+ <TableHeader>Complications/Co-morbidities at enrollment(2)</TableHeader>
48
+ <TableHeader>Treatment</TableHeader>
49
+ <TableHeader>Diabetic Foot Screening</TableHeader>
50
+ <TableHeader>Diabetic Foot(New,Known,Nill)</TableHeader>
51
+ <TableHeader>Foot Risk Assessment</TableHeader>
52
+ <TableHeader>Footcare Outcome</TableHeader>
53
+ <TableHeader>Screened for TB</TableHeader>
54
+ <TableHeader>TB Status after Screening</TableHeader>
55
+ <TableHeader>Active NHIF(Y/N)</TableHeader>
56
+ </TableRow>
57
+ </TableHead>
58
+ <TableBody>
59
+ {moh222PatientList.map((p, index) => (
60
+ <TableRow key={p.patient_uuid}>
61
+ <TableCell>{index + 1}</TableCell>
62
+ <TableCell>{p.encounter_date}</TableCell>
63
+ <TableCell>{p.amrs_universal_id}</TableCell>
64
+ <TableCell>
65
+ <Link href={`${window.spaBase}/patient/${p.patient_uuid}/chart/`}>
66
+ {p.person_name}
67
+ </Link>
68
+ </TableCell>
69
+ <TableCell>{p.age}</TableCell>
70
+ <TableCell>{p.birthdate}</TableCell>
71
+ <TableCell>{p.gender}</TableCell>
72
+ <TableCell>{p.visit_for_the_month}</TableCell>
73
+ <TableCell>{p.weight}</TableCell>
74
+ <TableCell>{p.height}</TableCell>
75
+ <TableCell>{p.bmi}</TableCell>
76
+ <TableCell>{p.waist_circumference}</TableCell>
77
+ <TableCell>{p.bp}</TableCell>
78
+ <TableCell>{p.htn}</TableCell>
79
+ <TableCell>{p.diabetes}</TableCell>
80
+ <TableCell>{p.both_htn_and_diabetic}</TableCell>
81
+ <TableCell>{p.rbs}</TableCell>
82
+ <TableCell>{p.fbs}</TableCell>
83
+ <TableCell>{p.hba1c}</TableCell>
84
+ <TableCell>{p.complications_at_enrollment}</TableCell>
85
+ <TableCell>{p.treatment}</TableCell>
86
+ <TableCell>{p.diabetic_foot_screening}</TableCell>
87
+ <TableCell>{p.diabetic_foot}</TableCell>
88
+ <TableCell>{p.foot_risk_assessment}</TableCell>
89
+ <TableCell>{p.footcare_outcome}</TableCell>
90
+ <TableCell>{p.screened_for_tb}</TableCell>
91
+ <TableCell>{p.tbs_status}</TableCell>
92
+ <TableCell>{p.covered_by_shif ? 'Y' : 'N'}</TableCell>
93
+ </TableRow>
94
+ ))}
95
+ </TableBody>
96
+ </Table>
97
+
98
+ </div>
99
+
100
+ </div>
101
+
102
+ </>)
103
+ };
104
+ export default Moh222DailyRegister;
@@ -0,0 +1,18 @@
1
+ .registerLayout{
2
+ display: flex;
3
+ flex-direction: column;
4
+ width: 100%;
5
+ padding: 10px 10px;
6
+ row-gap: 10px;
7
+ .registerHeader{
8
+ display: flex;
9
+ flex-direction: column;
10
+ width: 100%;
11
+ row-gap: 10px;
12
+ .pageTitle{
13
+ width: 100%;
14
+ justify-content: center;
15
+ text-align: center;
16
+ }
17
+ }
18
+ }
@@ -0,0 +1,79 @@
1
+ import { Link, Table, TableBody, TableCell, TableHead, TableHeader, TableRow } from '@carbon/react';
2
+ import React, { useMemo } from 'react';
3
+ import { type Moh270Patient } from '../../types';
4
+ import { formatIndicatorName } from '../../shared/utils/format-indicator';
5
+ import styles from './moh-270-permanent-register.scss';
6
+ interface Moh270DailyRegisterProps {
7
+ moh270PatientList: Moh270Patient[];
8
+ indicator: string;
9
+ }
10
+ const Moh270DailyRegister: React.FC<Moh270DailyRegisterProps> = ({ moh270PatientList, indicator }) => {
11
+ const pageTitle = useMemo(() => formatIndicatorName(indicator ?? ''), [indicator]);
12
+ const reportTitle = 'Permanent Register - MOH 270';
13
+ if (!moh270PatientList) {
14
+ return <>No Data to display</>;
15
+ }
16
+ return (
17
+ <>
18
+ <div className={styles.registerLayout}>
19
+ <div className={styles.registerHeader}>
20
+ <h4 className={styles.pageTitle}>{reportTitle}</h4>
21
+ <h6 className={styles.pageTitle}>{pageTitle}</h6>
22
+ </div>
23
+ <div className={styles.content}>
24
+
25
+ <Table>
26
+ <TableHead>
27
+ <TableRow>
28
+ <TableHeader>No</TableHeader>
29
+ <TableHeader>Date</TableHeader>
30
+ <TableHeader>Patient No</TableHeader>
31
+ <TableHeader>Name</TableHeader>
32
+ <TableHeader>D.O.B</TableHeader>
33
+ <TableHeader>Sex(M/F)</TableHeader>
34
+ <TableHeader>Telephone No</TableHeader>
35
+ <TableHeader>Sub County</TableHeader>
36
+ <TableHeader>Village/Estate</TableHeader>
37
+ <TableHeader>Landmark</TableHeader>
38
+ <TableHeader>Treatment supporter</TableHeader>
39
+ <TableHeader>Diagnosis at enrolment</TableHeader>
40
+ <TableHeader>Year of diagnosis</TableHeader>
41
+ <TableHeader>Complications/Co-morbidities at enrollment(2)</TableHeader>
42
+ <TableHeader>NHIF(Y/N)</TableHeader>
43
+ </TableRow>
44
+ </TableHead>
45
+ <TableBody>
46
+ {moh270PatientList.map((p, index) => (
47
+ <TableRow key={p.patient_uuid}>
48
+ <TableCell>{index + 1}</TableCell>
49
+ <TableCell>{p.encounter_date}</TableCell>
50
+ <TableCell>{p.amrs_universal_id}</TableCell>
51
+ <TableCell>
52
+ <Link href={`${window.spaBase}/patient/${p.patient_uuid}/chart/`}>
53
+ {p.person_name}
54
+ </Link>
55
+ </TableCell>
56
+ <TableCell>{p.birthdate}</TableCell>
57
+ <TableCell>{p.gender}</TableCell>
58
+ <TableCell>{p.phone_number}</TableCell>
59
+ <TableCell>{p.sub_county}</TableCell>
60
+ <TableCell>{p.ward}</TableCell>
61
+ <TableCell>{p.landmark}</TableCell>
62
+ <TableCell>{p.contact_of_the_treatment_supporter_and_relationship ?? ''}</TableCell>
63
+ <TableCell>{p.diagnosis_at_enrolment ?? ''}</TableCell>
64
+ <TableCell>{p.diagnosis_year ?? ''}</TableCell>
65
+ <TableCell>{p.complications_at_enrollment ?? ''}</TableCell>
66
+ <TableCell>{p.covered_by_shif ? 'Y' : 'N'}</TableCell>
67
+ </TableRow>
68
+ ))}
69
+ </TableBody>
70
+ </Table>
71
+
72
+ </div>
73
+
74
+ </div>
75
+
76
+ </>
77
+ );
78
+ };
79
+ export default Moh270DailyRegister;
@@ -0,0 +1,66 @@
1
+ import React, { useEffect, useState } from 'react';
2
+ import { type Moh222Patient, type Moh270Patient } from '../types';
3
+ import { fetchMoh740Register } from '../moh-740.resource';
4
+ import Moh270DailyRegister from './moh-270-permanent-register/moh-270-permanent-register';
5
+ import { InlineLoading } from '@carbon/react';
6
+ import { Moh740Rgisters } from '../shared/utils/indicator-register-map';
7
+ import Moh222DailyRegister from './moh-222-daily-register/moh-222-daily-register';
8
+ interface Moh740PatientListProps {
9
+ locationUuid: string;
10
+ reportingMonth: string;
11
+ indicators: string;
12
+ register: string;
13
+ }
14
+ const Moh740PatientList: React.FC<Moh740PatientListProps> = ({ locationUuid, reportingMonth, indicators, register }) => {
15
+ const [moh270patientList, setMoh270PatientList] = useState<Moh270Patient[]>([]);
16
+ const [loading, setIsLoading] = useState<boolean>(false);
17
+ const [moh222PatientList, setMoh222PatientList] = useState<Moh222Patient[]>([]);
18
+
19
+ useEffect(() => {
20
+ if (locationUuid && reportingMonth && indicators) {
21
+ fethPatientList();
22
+ }
23
+ }, [locationUuid, reportingMonth, indicators,register]);
24
+ async function fethPatientList() {
25
+ setIsLoading(true);
26
+ const resp = await fetchMoh740Register({
27
+ locationUuid: locationUuid,
28
+ endDate: reportingMonth,
29
+ indicators: indicators,
30
+ });
31
+
32
+ setIsLoading(false);
33
+
34
+ if (resp) {
35
+ if (register === Moh740Rgisters.DailyRegister) {
36
+ setMoh222PatientList(resp as any);
37
+ setMoh270PatientList([]);
38
+ }
39
+ if (register === Moh740Rgisters.PermanentRegister) {
40
+ setMoh270PatientList(resp);
41
+ setMoh222PatientList([]);
42
+ }
43
+
44
+ }
45
+ }
46
+ if (!locationUuid || !reportingMonth || !indicators) {
47
+ return <></>;
48
+ }
49
+ if (loading) {
50
+ return <InlineLoading description="Fetching patient list..." />;
51
+ }
52
+ return <>
53
+
54
+ {
55
+ moh270patientList && register === Moh740Rgisters.PermanentRegister && <Moh270DailyRegister indicator={indicators} moh270PatientList={moh270patientList} />
56
+ }
57
+ {
58
+ moh222PatientList && register === Moh740Rgisters.DailyRegister && <Moh222DailyRegister
59
+ moh222PatientList={moh222PatientList}
60
+ indicator={indicators}
61
+ />
62
+ }
63
+ </>;
64
+ };
65
+
66
+ export default Moh740PatientList;
@@ -0,0 +1,6 @@
1
+ .dataCell{
2
+ color: blue;
3
+ }
4
+ .dataCell:hover{
5
+ cursor: pointer;
6
+ }
@@ -0,0 +1,23 @@
1
+ import React from 'react';
2
+ import styles from './data-cell.scss';
3
+ interface DataCellProps {
4
+ value: number;
5
+ indicator: string;
6
+ indicatorSelected: (indicator: string) => void;
7
+ }
8
+ const DataCell: React.FC<DataCellProps> = ({ value, indicator, indicatorSelected }) => {
9
+ const handleCellClicked = () => {
10
+ indicatorSelected(indicator);
11
+ };
12
+ if (!value || value < 0) {
13
+ return 0;
14
+ }
15
+ return (
16
+ <>
17
+ <span onClick={handleCellClicked} className={styles.dataCell}>
18
+ {value ?? 0}
19
+ </span>
20
+ </>
21
+ );
22
+ };
23
+ export default DataCell;
@@ -0,0 +1,22 @@
1
+ export function formatIndicatorName(indicator: string): string {
2
+ if (!indicator) {
3
+ return '';
4
+ }
5
+
6
+ const parts = indicator.includes("__")
7
+ ? indicator.split("__").slice(1)
8
+ : [indicator];
9
+
10
+ return parts
11
+ .map(part =>
12
+ part
13
+ .split("_")
14
+ .map(word =>
15
+ word.length === 1
16
+ ? word.toUpperCase()
17
+ : word.charAt(0).toUpperCase() + word.slice(1).toLowerCase()
18
+ )
19
+ .join(" ")
20
+ )
21
+ .join(" ");
22
+ }
@@ -0,0 +1,157 @@
1
+ import { type Moh740Data } from "../../types";
2
+ export enum Moh740Rgisters {
3
+ DailyRegister = 'MOH 722 Daily Register',
4
+ PermanentRegister = 'MOH 270 Permanent Register'
5
+ }
6
+
7
+ type RegisterKeys = keyof Moh740Data;
8
+
9
+ const Moh740DIncatorRegisterMap: Record <RegisterKeys, string> = {
10
+ location_id: '',
11
+ facility: '',
12
+ mfl_code: '',
13
+ county: '',
14
+ sub_county: '',
15
+ reportingMonth: '',
16
+ cumulative_diabetes_patients_in_care: Moh740Rgisters.PermanentRegister,
17
+ newly_diagnosed_diabetes: Moh740Rgisters.DailyRegister,
18
+ total_type_1_diabetes: Moh740Rgisters.DailyRegister,
19
+ total_type_2_diabetes: Moh740Rgisters.DailyRegister,
20
+ cumulative_htn_patient: Moh740Rgisters.PermanentRegister,
21
+ covered_by_shif: Moh740Rgisters.PermanentRegister,
22
+ screened_for_tb_this_month: Moh740Rgisters.DailyRegister,
23
+ screened_postive_for_tb_this_month: Moh740Rgisters.DailyRegister,
24
+ screened_for_diabetic_foot_this_month: Moh740Rgisters.DailyRegister,
25
+ has_diabetic_foot: Moh740Rgisters.DailyRegister,
26
+ type_1_diabetes_mellitus: Moh740Rgisters.DailyRegister,
27
+ type_2_diabetes_mellitus: Moh740Rgisters.DailyRegister,
28
+ revisit_to_clinic_known_dm: Moh740Rgisters.DailyRegister,
29
+ amputation_due_to_diabetic_foot: Moh740Rgisters.DailyRegister,
30
+ stroke_diagnosis: Moh740Rgisters.DailyRegister,
31
+ ischemic_heart_disease_diagnosis: Moh740Rgisters.DailyRegister,
32
+ heart_failure_diagnosis: Moh740Rgisters.DailyRegister,
33
+ has_neuropathies: Moh740Rgisters.DailyRegister,
34
+ newly_diagnosed_htn_this_month: Moh740Rgisters.DailyRegister,
35
+ revisit_known_htn: Moh740Rgisters.DailyRegister,
36
+ is_co_morbid: Moh740Rgisters.PermanentRegister,
37
+ revisit_known_co_morbid: Moh740Rgisters.DailyRegister,
38
+ newly_diagnosed_co_morbid_this_month: Moh740Rgisters.DailyRegister,
39
+ on_insulin_this_month: Moh740Rgisters.DailyRegister,
40
+ on_ogla_meds_this_month: Moh740Rgisters.DailyRegister,
41
+ on_both_insulin_and_ogla_meds_this_month: Moh740Rgisters.DailyRegister,
42
+ dc__age_range__0_to_5__type_1_diabetes_mellitus: Moh740Rgisters.DailyRegister,
43
+ dc__age_range__6_to_9__type_1_diabetes_mellitus:Moh740Rgisters.DailyRegister,
44
+ dc__age_range__10_to_19__type_1_diabetes_mellitus:Moh740Rgisters.DailyRegister,
45
+ dc__age_range__20_to_35__type_1_diabetes_mellitus:Moh740Rgisters.DailyRegister,
46
+ dc__age_range__36_and_above__type_1_diabetes_mellitus:Moh740Rgisters.DailyRegister,
47
+ dc__age_range__0_to_18__type_2_diabetes_mellitus:Moh740Rgisters.DailyRegister,
48
+ dc__age_range__19_to_35__type_2_diabetes_mellitus:Moh740Rgisters.DailyRegister,
49
+ dc__age_range__36_to_60__type_2_diabetes_mellitus:Moh740Rgisters.DailyRegister,
50
+ dc__age_range__61_and_above__type_2_diabetes_mellitus:Moh740Rgisters.DailyRegister,
51
+ dc__gender__M__cumulative_diabetes_patients_in_care: Moh740Rgisters.PermanentRegister,
52
+ dc__gender__F__cumulative_diabetes_patients_in_care: Moh740Rgisters.PermanentRegister,
53
+ dc__gender__M__newly_diagnosed_diabetes: Moh740Rgisters.DailyRegister,
54
+ dc__gender__F__newly_diagnosed_diabetes: Moh740Rgisters.DailyRegister,
55
+ dc__gender__M__revisit_to_clinic_known_dm: Moh740Rgisters.DailyRegister,
56
+ dc__gender__F__revisit_to_clinic_known_dm: Moh740Rgisters.DailyRegister,
57
+ dc__gender__M__total_type_1_diabetes: Moh740Rgisters.DailyRegister,
58
+ dc__gender__F__total_type_1_diabetes: Moh740Rgisters.DailyRegister,
59
+ dc__gender__M__total_type_2_diabetes: Moh740Rgisters.DailyRegister,
60
+ dc__gender__F__total_type_2_diabetes: Moh740Rgisters.DailyRegister,
61
+ dc__gender__M__cumulative_htn_patient: Moh740Rgisters.PermanentRegister,
62
+ dc__gender__F__cumulative_htn_patient: Moh740Rgisters.PermanentRegister,
63
+ dc__gender__F__newly_diagnosed_htn_this_month: Moh740Rgisters.DailyRegister,
64
+ dc__gender__M__newly_diagnosed_htn_this_month: Moh740Rgisters.DailyRegister,
65
+ dc__gender__M__revisit_known_htn: Moh740Rgisters.DailyRegister,
66
+ dc__gender__F__revisit_known_htn: Moh740Rgisters.DailyRegister,
67
+ dc__gender__M__is_co_morbid: Moh740Rgisters.DailyRegister,
68
+ dc__gender__F__is_co_morbid: Moh740Rgisters.DailyRegister,
69
+ dc__gender__F__revisit_known_co_morbid: Moh740Rgisters.DailyRegister,
70
+ dc__gender__M__revisit_known_co_morbid: Moh740Rgisters.DailyRegister,
71
+ dc__gender__M__newly_diagnosed_co_morbid_this_month: Moh740Rgisters.DailyRegister,
72
+ dc__gender__F__newly_diagnosed_co_morbid_this_month: Moh740Rgisters.DailyRegister,
73
+ dc__gender__M__age_range__10_to_19__diabetes_mellitus_type__diabetes_mellitus_type_1__total: Moh740Rgisters.DailyRegister,
74
+ dc__gender__M__age_range__0_to_9__has_htn: Moh740Rgisters.DailyRegister,
75
+ dc__gender__F__age_range__0_to_9__has_htn: Moh740Rgisters.DailyRegister,
76
+ dc__gender__M__age_range__10_to_19__has_htn: Moh740Rgisters.DailyRegister,
77
+ dc__gender__F__age_range__10_to_19__has_htn: Moh740Rgisters.DailyRegister,
78
+ dc__gender__M__age_range__20_to_35__has_htn: Moh740Rgisters.DailyRegister,
79
+ dc__gender__F__age_range__20_to_35__has_htn: Moh740Rgisters.DailyRegister,
80
+ dc__gender__M__age_range__36_to_60__has_htn: Moh740Rgisters.DailyRegister,
81
+ dc__gender__F__age_range__36_to_60__has_htn: Moh740Rgisters.DailyRegister,
82
+ dc__gender__M__age_range__61_and_above__has_htn: Moh740Rgisters.DailyRegister,
83
+ dc__gender__F__age_range__61_and_above__has_htn: Moh740Rgisters.DailyRegister,
84
+ dc__gender__M__age_range__10_to_19__total: Moh740Rgisters.DailyRegister,
85
+ dc__gender__M__screened_for_tb_this_month: Moh740Rgisters.DailyRegister,
86
+ dc__gender__F__screened_for_tb_this_month: Moh740Rgisters.DailyRegister,
87
+ dc__gender__M__screened_postive_for_tb_this_month: Moh740Rgisters.DailyRegister,
88
+ dc__gender__F__screened_postive_for_tb_this_month: Moh740Rgisters.DailyRegister,
89
+ dc__gender__M__covered_by_shif: Moh740Rgisters.PermanentRegister,
90
+ dc__gender__F__covered_by_shif: Moh740Rgisters.PermanentRegister,
91
+ dc__gender__M__screened_for_diabetic_foot_this_month: Moh740Rgisters.DailyRegister,
92
+ dc__gender__F__screened_for_diabetic_foot_this_month: Moh740Rgisters.DailyRegister,
93
+ dc__gender__M__has_diabetic_foot: Moh740Rgisters.DailyRegister,
94
+ dc__gender__F__has_diabetic_foot: Moh740Rgisters.DailyRegister,
95
+ dc__gender__M__amputation_due_to_diabetic_foot: Moh740Rgisters.DailyRegister,
96
+ dc__gender__F__amputation_due_to_diabetic_foot: Moh740Rgisters.DailyRegister,
97
+ dc__gender__M__stroke_diagnosis: Moh740Rgisters.DailyRegister,
98
+ dc__gender__F__stroke_diagnosis: Moh740Rgisters.DailyRegister,
99
+ dc__gender__M__ischemic_heart_disease_diagnosis: Moh740Rgisters.DailyRegister,
100
+ dc__gender__F__ischemic_heart_disease_diagnosis: Moh740Rgisters.DailyRegister,
101
+ dc__gender__M__heart_failure_diagnosis: Moh740Rgisters.DailyRegister,
102
+ dc__gender__F__heart_failure_diagnosis: Moh740Rgisters.DailyRegister,
103
+ dc__gender__M__has_neuropathies: Moh740Rgisters.DailyRegister,
104
+ dc__gender__F__has_neuropathies: Moh740Rgisters.DailyRegister,
105
+ dc__gender__M__age_range__0_to_5__type_1_diabetes_mellitus: Moh740Rgisters.DailyRegister,
106
+ dc__gender__F__age_range__0_to_5__type_1_diabetes_mellitus: Moh740Rgisters.DailyRegister,
107
+ dc__gender__M__age_range__6_to_9__type_1_diabetes_mellitus: Moh740Rgisters.DailyRegister,
108
+ dc__gender__F__age_range__6_to_9__type_1_diabetes_mellitus: Moh740Rgisters.DailyRegister,
109
+ dc__gender__M__age_range__10_to_19__type_1_diabetes_mellitus: Moh740Rgisters.DailyRegister,
110
+ dc__gender__F__age_range__10_to_19__type_1_diabetes_mellitus: Moh740Rgisters.DailyRegister,
111
+ dc__gender__M__age_range__20_to_35__type_1_diabetes_mellitus: Moh740Rgisters.DailyRegister,
112
+ dc__gender__F__age_range__20_to_35__type_1_diabetes_mellitus: Moh740Rgisters.DailyRegister,
113
+ dc__gender__M__age_range__36_and_above__type_1_diabetes_mellitus: Moh740Rgisters.DailyRegister,
114
+ dc__gender__F__age_range__36_and_above__type_1_diabetes_mellitus: Moh740Rgisters.DailyRegister,
115
+ dc__gender__M__age_range__0_to_18__type_2_diabetes_mellitus: Moh740Rgisters.DailyRegister,
116
+ dc__gender__F__age_range__0_to_18__type_2_diabetes_mellitus: Moh740Rgisters.DailyRegister,
117
+ dc__gender__M__age_range__19_to_35__type_2_diabetes_mellitus: Moh740Rgisters.DailyRegister,
118
+ dc__gender__F__age_range__19_to_35__type_2_diabetes_mellitus: Moh740Rgisters.DailyRegister,
119
+ dc__gender__M__age_range__36_to_60__type_2_diabetes_mellitus: Moh740Rgisters.DailyRegister,
120
+ dc__gender__F__age_range__36_to_60__type_2_diabetes_mellitus: Moh740Rgisters.DailyRegister,
121
+ dc__gender__M__age_range__61_and_above__type_2_diabetes_mellitus: Moh740Rgisters.DailyRegister,
122
+ dc__gender__F__age_range__61_and_above__type_2_diabetes_mellitus: Moh740Rgisters.DailyRegister,
123
+ dc__gender__M__on_insulin_this_month: Moh740Rgisters.DailyRegister,
124
+ dc__gender__F__on_insulin_this_month: Moh740Rgisters.DailyRegister,
125
+ dc__gender__M__on_ogla_meds_this_month: Moh740Rgisters.DailyRegister,
126
+ dc__gender__F__on_ogla_meds_this_month: Moh740Rgisters.DailyRegister,
127
+ dc__gender__M__on_both_insulin_and_ogla_meds_this_month: Moh740Rgisters.DailyRegister,
128
+ dc__gender__F__on_both_insulin_and_ogla_meds_this_month: Moh740Rgisters.DailyRegister,
129
+ dc__age_range__0_to_9__has_htn: Moh740Rgisters.DailyRegister,
130
+ dc__age_range__10_to_19__has_htn: Moh740Rgisters.DailyRegister,
131
+ dc__age_range__20_to_35__has_htn: Moh740Rgisters.DailyRegister,
132
+ dc__age_range__36_to_60__has_htn: Moh740Rgisters.DailyRegister,
133
+ dc__age_range__61_and_above__has_htn: Moh740Rgisters.DailyRegister,
134
+ done_hba1c_this_month:Moh740Rgisters.DailyRegister,
135
+ dc__gender__M__done_hba1c_this_month: Moh740Rgisters.DailyRegister,
136
+ dc__gender__F__done_hba1c_this_month: Moh740Rgisters.DailyRegister,
137
+ hba1c_less_than_7_percent_this_month:Moh740Rgisters.DailyRegister,
138
+ dc__gender__M__hba1c_less_than_7_percent_this_month:Moh740Rgisters.DailyRegister,
139
+ dc__gender__F__hba1c_less_than_7_percent_this_month:Moh740Rgisters.DailyRegister,
140
+ dc__gender__M__on_exercise_and_diet:Moh740Rgisters.DailyRegister,
141
+ dc__gender__F__on_exercise_and_diet:Moh740Rgisters.DailyRegister,
142
+ on_exercise_and_diet:Moh740Rgisters.DailyRegister,
143
+ on_antihypertensives_this_month:Moh740Rgisters.DailyRegister,
144
+ high_bp:Moh740Rgisters.DailyRegister,
145
+ dc__gender__M__on_antihypertensives_this_month: Moh740Rgisters.DailyRegister,
146
+ dc__gender__F__on_antihypertensives_this_month: Moh740Rgisters.DailyRegister,
147
+ dc__gender__M__high_bp:Moh740Rgisters.DailyRegister,
148
+ dc__gender__F__high_bp:Moh740Rgisters.DailyRegister,
149
+ };
150
+
151
+ export function getRegisterByIndicator(indicator: keyof Moh740Data){
152
+ if(Moh740DIncatorRegisterMap[indicator]){
153
+ return Moh740DIncatorRegisterMap[indicator];
154
+ }else{
155
+ return Moh740Rgisters.DailyRegister
156
+ }
157
+ }