@kenyaemr/esm-admin-app 5.4.4-pre.28 → 5.4.4-pre.281
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.
- package/.turbo/turbo-build.log +5 -12
- package/dist/1074.js +1 -0
- package/dist/1074.js.map +1 -0
- package/dist/12.js +17 -0
- package/dist/12.js.map +1 -0
- package/dist/1201.js +1 -0
- package/dist/1201.js.map +1 -0
- package/dist/1242.js +1 -0
- package/dist/1242.js.map +1 -0
- package/dist/1311.js +1 -0
- package/dist/1311.js.map +1 -0
- package/dist/1462.js +1 -0
- package/dist/1462.js.map +1 -0
- package/dist/1469.js +1 -0
- package/dist/1469.js.map +1 -0
- package/dist/1506.js +13 -0
- package/dist/1506.js.map +1 -0
- package/dist/1718.js +1 -0
- package/dist/1718.js.map +1 -0
- package/dist/1722.js +1 -0
- package/dist/1722.js.map +1 -0
- package/dist/1772.js +1 -0
- package/dist/1772.js.map +1 -0
- package/dist/1889.js +1 -0
- package/dist/1889.js.map +1 -0
- package/dist/1972.js +1 -0
- package/dist/1972.js.map +1 -0
- package/dist/1990.js +1 -0
- package/dist/1990.js.map +1 -0
- package/dist/2016.js +1 -0
- package/dist/2016.js.map +1 -0
- package/dist/2080.js +1 -0
- package/dist/2080.js.map +1 -0
- package/dist/2096.js +1 -0
- package/dist/2096.js.map +1 -0
- package/dist/2153.js +1 -0
- package/dist/2153.js.map +1 -0
- package/dist/216.js +1 -0
- package/dist/216.js.map +1 -0
- package/dist/2270.js +1 -0
- package/dist/2270.js.map +1 -0
- package/dist/2294.js +1 -0
- package/dist/2294.js.map +1 -0
- package/dist/2345.js +1 -0
- package/dist/2345.js.map +1 -0
- package/dist/2402.js +1 -0
- package/dist/2402.js.map +1 -0
- package/dist/2500.js +1 -0
- package/dist/2500.js.map +1 -0
- package/dist/251.js +1 -0
- package/dist/251.js.map +1 -0
- package/dist/257.js +1 -0
- package/dist/257.js.map +1 -0
- package/dist/2586.js +1 -0
- package/dist/2586.js.map +1 -0
- package/dist/2625.js +1 -0
- package/dist/2625.js.map +1 -0
- package/dist/2652.js +1 -0
- package/dist/2652.js.map +1 -0
- package/dist/2685.js +1 -0
- package/dist/2685.js.map +1 -0
- package/dist/2948.js +1 -0
- package/dist/2948.js.map +1 -0
- package/dist/3089.js +1 -0
- package/dist/3089.js.map +1 -0
- package/dist/3190.js +1 -0
- package/dist/3190.js.map +1 -0
- package/dist/3224.js +1 -0
- package/dist/3224.js.map +1 -0
- package/dist/3366.js +1 -0
- package/dist/3366.js.map +1 -0
- package/dist/3548.js +1 -0
- package/dist/3548.js.map +1 -0
- package/dist/3571.js +1 -0
- package/dist/3571.js.map +1 -0
- package/dist/3691.js +1 -0
- package/dist/3691.js.map +1 -0
- package/dist/3775.js +1 -0
- package/dist/3775.js.map +1 -0
- package/dist/3816.js +1 -0
- package/dist/3816.js.map +1 -0
- package/dist/3852.js +1 -0
- package/dist/3852.js.map +1 -0
- package/dist/3906.js +1 -0
- package/dist/3906.js.map +1 -0
- package/dist/3963.js +1 -0
- package/dist/3963.js.map +1 -0
- package/dist/4047.js +1 -0
- package/dist/4047.js.map +1 -0
- package/dist/405.js +1 -0
- package/dist/405.js.map +1 -0
- package/dist/4296.js +1 -0
- package/dist/4296.js.map +1 -0
- package/dist/4337.js +1 -0
- package/dist/4337.js.map +1 -0
- package/dist/4584.js +1 -0
- package/dist/4584.js.map +1 -0
- package/dist/4735.js +1 -0
- package/dist/4735.js.map +1 -0
- package/dist/4744.js +1 -0
- package/dist/4744.js.map +1 -0
- package/dist/4813.js +2 -0
- package/dist/4813.js.map +1 -0
- package/dist/4858.js +1 -0
- package/dist/4858.js.map +1 -0
- package/dist/487.js +1 -0
- package/dist/487.js.map +1 -0
- package/dist/4970.js +1 -0
- package/dist/4970.js.map +1 -0
- package/dist/5202.js +1 -0
- package/dist/5202.js.map +1 -0
- package/dist/5294.js +1 -0
- package/dist/5294.js.map +1 -0
- package/dist/545.js +1 -0
- package/dist/545.js.map +1 -0
- package/dist/552.js +1 -0
- package/dist/552.js.map +1 -0
- package/dist/5592.js +1 -0
- package/dist/5592.js.map +1 -0
- package/dist/5669.js +1 -0
- package/dist/5669.js.map +1 -0
- package/dist/5884.js +1 -0
- package/dist/5884.js.map +1 -0
- package/dist/5940.js +1 -0
- package/dist/5940.js.map +1 -0
- package/dist/6092.js +1 -0
- package/dist/6092.js.map +1 -0
- package/dist/6155.js +1 -0
- package/dist/6155.js.map +1 -0
- package/dist/6178.js +1 -0
- package/dist/6178.js.map +1 -0
- package/dist/6399.js +1 -0
- package/dist/6399.js.map +1 -0
- package/dist/6456.js +1 -0
- package/dist/6466.js +3 -0
- package/dist/6466.js.map +1 -0
- package/dist/6492.js +1 -0
- package/dist/6492.js.map +1 -0
- package/dist/6676.js +1 -0
- package/dist/6676.js.map +1 -0
- package/dist/6800.js +1 -0
- package/dist/6800.js.map +1 -0
- package/dist/6976.js +1 -0
- package/dist/6976.js.map +1 -0
- package/dist/7005.js +1 -0
- package/dist/7005.js.map +1 -0
- package/dist/7201.js +1 -0
- package/dist/7201.js.map +1 -0
- package/dist/7210.js +1 -0
- package/dist/7210.js.map +1 -0
- package/dist/7234.js +1 -0
- package/dist/7234.js.map +1 -0
- package/dist/7261.js +1 -0
- package/dist/7261.js.map +1 -0
- package/dist/7326.js +1 -0
- package/dist/7463.js +1 -0
- package/dist/7463.js.map +1 -0
- package/dist/7528.js +1 -0
- package/dist/7528.js.map +1 -0
- package/dist/7607.js +1 -0
- package/dist/7717.js +1 -0
- package/dist/7717.js.map +1 -0
- package/dist/7737.js +1 -0
- package/dist/7737.js.map +1 -0
- package/dist/7739.js +1 -0
- package/dist/7739.js.map +1 -0
- package/dist/7765.js +1 -0
- package/dist/7765.js.map +1 -0
- package/dist/7820.js +1 -0
- package/dist/7820.js.map +1 -0
- package/dist/7844.js +1 -0
- package/dist/7844.js.map +1 -0
- package/dist/7866.js +1 -0
- package/dist/7866.js.map +1 -0
- package/dist/7916.js +1 -0
- package/dist/7916.js.map +1 -0
- package/dist/7971.js +1 -0
- package/dist/7971.js.map +1 -0
- package/dist/8159.js +7 -0
- package/dist/8159.js.map +1 -0
- package/dist/8244.js +1 -0
- package/dist/8244.js.map +1 -0
- package/dist/8262.js +1 -0
- package/dist/8262.js.map +1 -0
- package/dist/8376.js +1 -0
- package/dist/8376.js.map +1 -0
- package/dist/845.js +1 -0
- package/dist/845.js.map +1 -0
- package/dist/8570.js +1 -0
- package/dist/8570.js.map +1 -0
- package/dist/87.js +1 -0
- package/dist/87.js.map +1 -0
- package/dist/8727.js +1 -0
- package/dist/8828.js +1 -0
- package/dist/8828.js.map +1 -0
- package/dist/8860.js +1 -0
- package/dist/8860.js.map +1 -0
- package/dist/9036.js +1 -0
- package/dist/9036.js.map +1 -0
- package/dist/9124.js +1 -0
- package/dist/9124.js.map +1 -0
- package/dist/9182.js +1 -0
- package/dist/921.js +1 -0
- package/dist/921.js.map +1 -0
- package/dist/9404.js +1 -0
- package/dist/9404.js.map +1 -0
- package/dist/9406.js +1 -0
- package/dist/9406.js.map +1 -0
- package/dist/9446.js +1 -0
- package/dist/9446.js.map +1 -0
- package/dist/9449.js +1 -0
- package/dist/9449.js.map +1 -0
- package/dist/9566.js +5 -0
- package/dist/9566.js.map +1 -0
- package/dist/9641.js +1 -0
- package/dist/9641.js.map +1 -0
- package/dist/9711.js +1 -0
- package/dist/9711.js.map +1 -0
- package/dist/9801.js +1 -0
- package/dist/9801.js.map +1 -0
- package/dist/9835.js +11 -0
- package/dist/9835.js.map +1 -0
- package/dist/kenyaemr-esm-admin-app.js +5 -5
- package/dist/kenyaemr-esm-admin-app.js.buildmanifest.json +2649 -154
- package/dist/kenyaemr-esm-admin-app.js.map +1 -1
- package/dist/main.js +5 -31
- package/dist/main.js.map +1 -1
- package/dist/routes.json +1 -1
- package/package.json +5 -7
- package/rspack.config.js +1 -1
- package/src/components/facility-setup/constant/index.ts +3 -0
- package/src/components/facility-setup/facility-info.component.tsx +247 -108
- package/src/components/facility-setup/facility-info.scss +136 -55
- package/src/components/facility-setup/facility-setup.component.tsx +2 -2
- package/src/components/facility-setup/header/header.component.tsx +4 -10
- package/src/components/facility-setup/header/header.scss +3 -9
- package/src/components/facility-setup/shared/custom-info.component.tsx +9 -0
- package/src/components/facility-setup/shared/custom-section-card.component.tsx +10 -0
- package/src/components/facility-setup/shared/custom-status-tag.component.tsx +22 -0
- package/src/components/facility-setup/type/index.ts +61 -0
- package/src/components/facility-setup/useFacilityRegistry.ts +29 -0
- package/src/components/hook/healthWorkerRegistry.ts +78 -0
- package/src/components/hook/useProfessionalRegistryEnums.ts +59 -0
- package/src/components/locations/forms/add-location/add-location.workspace.tsx +96 -95
- package/src/components/locations/forms/search-location/search-location.workspace.tsx +90 -85
- package/src/components/locations/tables/locations-table.component.tsx +117 -121
- package/src/components/modal/hwr-confirmation.modal.scss +80 -4
- package/src/components/modal/hwr-confirmation.modal.tsx +118 -128
- package/src/components/modal/hwr-sync.modal.tsx +194 -106
- package/src/components/users/manage-users/manage-user-role-scope/user-role-scope-workspace/user-role-scope.workspace.tsx +13 -13
- package/src/components/users/manage-users/user-details/user-detail.scss +168 -39
- package/src/components/users/manage-users/user-details/user-details.component.tsx +130 -122
- package/src/components/users/manage-users/user-list/user-list.component.tsx +22 -9
- package/src/components/users/manage-users/user-management.workspace.scss +233 -95
- package/src/components/users/manage-users/user-management.workspace.tsx +800 -687
- package/src/components/users/userManagementFormSchema.tsx +17 -8
- package/src/config-schema.ts +48 -68
- package/src/index.ts +55 -30
- package/src/left-pannel-link.component.tsx +5 -3
- package/src/root.component.tsx +11 -13
- package/src/routes.json +40 -40
- package/src/types/index.ts +29 -1
- package/translations/am.json +158 -13
- package/translations/en.json +158 -13
- package/translations/fr.json +193 -47
- package/translations/sw.json +158 -13
- package/tsconfig.json +1 -1
- package/dist/127.js +0 -1
- package/dist/267.js +0 -1
- package/dist/267.js.map +0 -1
- package/dist/281.js +0 -15
- package/dist/281.js.map +0 -1
- package/dist/329.js +0 -1
- package/dist/329.js.map +0 -1
- package/dist/40.js +0 -1
- package/dist/466.js +0 -1
- package/dist/466.js.map +0 -1
- package/dist/472.js +0 -1
- package/dist/472.js.map +0 -1
- package/dist/478.js +0 -1
- package/dist/478.js.map +0 -1
- package/dist/585.js +0 -1
- package/dist/585.js.map +0 -1
- package/dist/630.js +0 -1
- package/dist/630.js.map +0 -1
- package/dist/675.js +0 -1
- package/dist/675.js.map +0 -1
- package/dist/689.js +0 -1
- package/dist/689.js.map +0 -1
- package/dist/706.js +0 -27
- package/dist/706.js.map +0 -1
- package/dist/729.js +0 -17
- package/dist/729.js.map +0 -1
- package/dist/774.js +0 -1
- package/dist/774.js.map +0 -1
- package/dist/847.js +0 -1
- package/dist/847.js.map +0 -1
- package/dist/85.js +0 -1
- package/dist/85.js.map +0 -1
- package/dist/882.js +0 -1
- package/dist/91.js +0 -1
- package/dist/91.js.map +0 -1
- package/dist/916.js +0 -1
- package/dist/998.js +0 -1
- package/dist/998.js.map +0 -1
- package/jest.config.js +0 -8
- package/src/components/facility-setup/card.component.tsx +0 -16
- package/src/components/facility-setup/facility-setup.resource.tsx +0 -7
- package/src/components/hook/healthWorkerAdapter.ts +0 -213
- package/src/components/hook/useFacilityInfo.tsx +0 -37
|
@@ -1,162 +1,152 @@
|
|
|
1
|
-
import { Button, Tag } from '@carbon/react';
|
|
1
|
+
import { Button, Tag, SkeletonText } from '@carbon/react';
|
|
2
2
|
import { ExtensionSlot } from '@openmrs/esm-framework';
|
|
3
|
-
import
|
|
4
|
-
import React from 'react';
|
|
3
|
+
import React, { useMemo } from 'react';
|
|
5
4
|
import { useTranslation } from 'react-i18next';
|
|
6
|
-
import {
|
|
7
|
-
import { NormalizedPractitioner } from '../hook/healthWorkerAdapter';
|
|
8
|
-
import styles from './hwr-confirmation.modal.scss';
|
|
5
|
+
import { ProfessionalRegistryResponse } from '../hook/healthWorkerRegistry';
|
|
9
6
|
import { formatDateTime } from '../../utils/utils';
|
|
10
|
-
|
|
11
|
-
interface HealthWorkerInfoProps {
|
|
12
|
-
label: string;
|
|
13
|
-
value: string | boolean | React.ReactNode;
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
const HealthWorkerInfo: React.FC<HealthWorkerInfoProps> = ({ label, value }) => {
|
|
17
|
-
return (
|
|
18
|
-
<div className={styles.healthWorkerInfoContainer}>
|
|
19
|
-
<span className={styles.healthWorkerInfoLabel}>{label}</span>
|
|
20
|
-
<span>{value}</span>
|
|
21
|
-
</div>
|
|
22
|
-
);
|
|
23
|
-
};
|
|
7
|
+
import styles from './hwr-confirmation.modal.scss';
|
|
24
8
|
|
|
25
9
|
interface HWRConfirmModalProps {
|
|
26
10
|
onConfirm: () => void;
|
|
27
11
|
close: () => void;
|
|
28
|
-
healthWorker:
|
|
29
|
-
normalizedData: NormalizedPractitioner;
|
|
30
|
-
fhirFormat: boolean;
|
|
12
|
+
healthWorker: ProfessionalRegistryResponse;
|
|
31
13
|
}
|
|
32
14
|
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
15
|
+
type License = NonNullable<ProfessionalRegistryResponse['professional']['licenses']>[number];
|
|
16
|
+
|
|
17
|
+
const InfoRow: React.FC<{ label: string; value: React.ReactNode }> = ({ label, value }) => (
|
|
18
|
+
<div className={styles.healthWorkerInfoContainer}>
|
|
19
|
+
<span className={styles.healthWorkerInfoLabel}>{label}</span>
|
|
20
|
+
<span>{value || '--'}</span>
|
|
21
|
+
</div>
|
|
22
|
+
);
|
|
23
|
+
|
|
24
|
+
const SectionHeading: React.FC<{ children: React.ReactNode }> = ({ children }) => (
|
|
25
|
+
<div className={styles.sectionHeading}>{children}</div>
|
|
26
|
+
);
|
|
27
|
+
|
|
28
|
+
const useCurrentLicense = (licenses: Array<License> = []): License | undefined =>
|
|
29
|
+
useMemo(() => {
|
|
30
|
+
if (licenses.length === 0) {
|
|
31
|
+
return undefined;
|
|
32
|
+
}
|
|
33
|
+
const sorted = [...licenses]
|
|
34
|
+
.filter((l) => l.license_end)
|
|
35
|
+
.sort((a, b) => new Date(b.license_end).getTime() - new Date(a.license_end).getTime());
|
|
36
|
+
const now = Date.now();
|
|
37
|
+
return sorted.find((l) => new Date(l.license_end).getTime() >= now) ?? sorted[0];
|
|
38
|
+
}, [licenses]);
|
|
39
|
+
|
|
40
|
+
const HWRConfirmModal: React.FC<HWRConfirmModalProps> = ({ close, onConfirm, healthWorker }) => {
|
|
40
41
|
const { t } = useTranslation();
|
|
42
|
+
const { professional } = healthWorker;
|
|
43
|
+
const { membership, licenses, contacts, identifiers, professional_details } = professional;
|
|
41
44
|
|
|
42
|
-
const
|
|
45
|
+
const currentLicense = useCurrentLicense(licenses);
|
|
46
|
+
const isLicenseValid = currentLicense?.license_end ? new Date(currentLicense.license_end) > new Date() : false;
|
|
43
47
|
|
|
44
48
|
return (
|
|
45
49
|
<>
|
|
46
50
|
<div className="cds--modal-header">
|
|
47
51
|
<h3 className="cds--modal-header__heading">{t('healthWorkerRegistry', 'Health worker registry')}</h3>
|
|
48
52
|
</div>
|
|
53
|
+
|
|
49
54
|
<div className="cds--modal-content">
|
|
50
|
-
<p>
|
|
55
|
+
<p className={styles.modalIntro}>
|
|
51
56
|
{t(
|
|
52
57
|
'healthWorkerDetailsFound',
|
|
53
|
-
'Health worker
|
|
58
|
+
'Health worker found in the registry. Use this information to pre-fill the registration form?',
|
|
54
59
|
)}
|
|
55
60
|
</p>
|
|
61
|
+
|
|
56
62
|
<div className={styles.healthWorkerOverview}>
|
|
57
63
|
<ExtensionSlot
|
|
58
64
|
className={styles.healthWorkerPhoto}
|
|
59
65
|
name="patient-photo-slot"
|
|
60
|
-
state={{
|
|
61
|
-
patientName: normalizedData.fullName || '',
|
|
62
|
-
}}
|
|
66
|
+
state={{ patientName: membership.full_name || '' }}
|
|
63
67
|
/>
|
|
64
|
-
<div
|
|
65
|
-
<
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
<
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
{
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
)}
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
<
|
|
128
|
-
label={`${license.license_type} ${t('license', 'License')}`}
|
|
129
|
-
value={license.external_reference_id || '--'}
|
|
130
|
-
/>
|
|
131
|
-
<HealthWorkerInfo
|
|
68
|
+
<div className={styles.healthWorkerSummary}>
|
|
69
|
+
<h4 className={styles.healthWorkerName}>{membership.full_name || '--'}</h4>
|
|
70
|
+
<div className={styles.healthWorkerSubtitle}>
|
|
71
|
+
{membership.specialty || t('practitioner', 'Practitioner')}
|
|
72
|
+
{membership.licensing_body && ` · ${membership.licensing_body}`}
|
|
73
|
+
</div>
|
|
74
|
+
<div className={styles.tagRow}>
|
|
75
|
+
<Tag type={membership.is_active === 1 ? 'green' : 'gray'} size="md">
|
|
76
|
+
{membership.is_active === 1 ? t('active', 'Active') : t('inactive', 'Inactive')}
|
|
77
|
+
</Tag>
|
|
78
|
+
<Tag type={isLicenseValid ? 'green' : 'red'} size="md">
|
|
79
|
+
{isLicenseValid ? t('licenseValid', 'License valid') : t('licenseExpired', 'License expired')}
|
|
80
|
+
</Tag>
|
|
81
|
+
</div>
|
|
82
|
+
</div>
|
|
83
|
+
</div>
|
|
84
|
+
|
|
85
|
+
<SectionHeading>{t('identity', 'Identity')}</SectionHeading>
|
|
86
|
+
<InfoRow label={t('providerUniqueIdentifier', 'Provider unique identifier')} value={membership.id} />
|
|
87
|
+
<InfoRow label={t('registrationId', 'Registration ID')} value={membership.registration_id} />
|
|
88
|
+
<InfoRow label={t('externalReferenceId', 'External reference ID')} value={membership.external_reference_id} />
|
|
89
|
+
<InfoRow label={t('gender', 'Gender')} value={membership.gender} />
|
|
90
|
+
{identifiers?.identification_number && (
|
|
91
|
+
<InfoRow
|
|
92
|
+
label={t('identificationNumber', 'Identification number')}
|
|
93
|
+
value={`${identifiers.identification_type ?? ''} ${identifiers.identification_number}`.trim()}
|
|
94
|
+
/>
|
|
95
|
+
)}
|
|
96
|
+
|
|
97
|
+
<SectionHeading>{t('licensing', 'Licensing & qualifications')}</SectionHeading>
|
|
98
|
+
<InfoRow label={t('licensingBody', 'Licensing body')} value={membership.licensing_body} />
|
|
99
|
+
<InfoRow label={t('specialty', 'Specialty')} value={membership.specialty} />
|
|
100
|
+
{professional_details?.professional_cadre && (
|
|
101
|
+
<InfoRow
|
|
102
|
+
label={t('professionalCadre', 'Professional cadre')}
|
|
103
|
+
value={professional_details.professional_cadre}
|
|
104
|
+
/>
|
|
105
|
+
)}
|
|
106
|
+
{professional_details?.practice_type && (
|
|
107
|
+
<InfoRow label={t('practiceType', 'Practice type')} value={professional_details.practice_type} />
|
|
108
|
+
)}
|
|
109
|
+
{professional_details?.educational_qualifications && (
|
|
110
|
+
<InfoRow
|
|
111
|
+
label={t('qualification', 'Qualification')}
|
|
112
|
+
value={professional_details.educational_qualifications}
|
|
113
|
+
/>
|
|
114
|
+
)}
|
|
115
|
+
|
|
116
|
+
{licenses && licenses.length > 0 && (
|
|
117
|
+
<>
|
|
118
|
+
<SectionHeading>{t('licenses', 'Licenses')}</SectionHeading>
|
|
119
|
+
<div className={styles.licenseList}>
|
|
120
|
+
{licenses.map((license) => {
|
|
121
|
+
const expired = license.license_end && new Date(license.license_end) < new Date();
|
|
122
|
+
return (
|
|
123
|
+
<div key={license.id} className={styles.licenseCard}>
|
|
124
|
+
<div className={styles.licenseHeader}>
|
|
125
|
+
<span className={styles.licenseType}>{license.license_type}</span>
|
|
126
|
+
<Tag type={expired ? 'red' : 'green'} size="sm">
|
|
127
|
+
{expired ? t('expired', 'Expired') : t('valid', 'Valid')}
|
|
128
|
+
</Tag>
|
|
129
|
+
</div>
|
|
130
|
+
<InfoRow label={t('licenseNumber', 'License no.')} value={license.external_reference_id} />
|
|
131
|
+
<InfoRow
|
|
132
132
|
label={t('validity', 'Validity')}
|
|
133
|
-
value={`${formatDateTime(license.license_start)}
|
|
133
|
+
value={`${formatDateTime(license.license_start)} → ${formatDateTime(license.license_end)}`}
|
|
134
134
|
/>
|
|
135
135
|
</div>
|
|
136
|
-
)
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
<HealthWorkerInfo
|
|
150
|
-
label={t('licenseValid', 'License Validity')}
|
|
151
|
-
value={
|
|
152
|
-
<Tag type={isLicenseValid ? 'green' : 'red'}>
|
|
153
|
-
{isLicenseValid ? t('licenseValid', 'License Valid') : t('licenseExpired', 'License Expired')}
|
|
154
|
-
</Tag>
|
|
155
|
-
}
|
|
156
|
-
/>
|
|
157
|
-
</div>
|
|
158
|
-
</div>
|
|
136
|
+
);
|
|
137
|
+
})}
|
|
138
|
+
</div>
|
|
139
|
+
</>
|
|
140
|
+
)}
|
|
141
|
+
|
|
142
|
+
<SectionHeading>{t('contact', 'Contact')}</SectionHeading>
|
|
143
|
+
<InfoRow label={t('phone', 'Phone')} value={contacts?.phone} />
|
|
144
|
+
<InfoRow label={t('email', 'Email')} value={contacts?.email} />
|
|
145
|
+
{contacts?.postal_address && (
|
|
146
|
+
<InfoRow label={t('postalAddress', 'Postal address')} value={contacts.postal_address} />
|
|
147
|
+
)}
|
|
159
148
|
</div>
|
|
149
|
+
|
|
160
150
|
<div className="cds--modal-footer">
|
|
161
151
|
<Button kind="secondary" onClick={close}>
|
|
162
152
|
{t('cancel', 'Cancel')}
|