@ampath/esm-dha-workflow-app 4.0.0-next.15 → 4.0.0-next.151

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 (379) hide show
  1. package/dist/1197.js +1 -0
  2. package/dist/1277.js +1 -0
  3. package/dist/1277.js.map +1 -0
  4. package/dist/1558.js +2 -0
  5. package/dist/1558.js.map +1 -0
  6. package/dist/1729.js +1 -0
  7. package/dist/1729.js.map +1 -0
  8. package/dist/182.js +1 -0
  9. package/dist/182.js.map +1 -0
  10. package/dist/1826.js +1 -0
  11. package/dist/1826.js.map +1 -0
  12. package/dist/1833.js +1 -0
  13. package/dist/1833.js.map +1 -0
  14. package/dist/1856.js +1 -0
  15. package/dist/1856.js.map +1 -0
  16. package/dist/1925.js +1 -0
  17. package/dist/1925.js.map +1 -0
  18. package/dist/2021.js +1 -0
  19. package/dist/2021.js.map +1 -0
  20. package/dist/2054.js +1 -0
  21. package/dist/2054.js.map +1 -0
  22. package/dist/2177.js +2 -0
  23. package/dist/2177.js.map +1 -0
  24. package/dist/2333.js +1 -0
  25. package/dist/2333.js.map +1 -0
  26. package/dist/2364.js +2 -0
  27. package/dist/{388.js.LICENSE.txt → 2364.js.LICENSE.txt} +15 -0
  28. package/dist/2364.js.map +1 -0
  29. package/dist/2801.js +1 -0
  30. package/dist/2801.js.map +1 -0
  31. package/dist/3041.js +1 -0
  32. package/dist/3041.js.map +1 -0
  33. package/dist/3099.js +1 -0
  34. package/dist/3184.js +2 -0
  35. package/dist/3184.js.map +1 -0
  36. package/dist/3654.js +1 -0
  37. package/dist/3654.js.map +1 -0
  38. package/dist/4055.js +1 -0
  39. package/dist/4205.js +1 -0
  40. package/dist/4205.js.map +1 -0
  41. package/dist/4225.js +1 -0
  42. package/dist/4225.js.map +1 -0
  43. package/dist/4300.js +1 -0
  44. package/dist/4335.js +1 -0
  45. package/dist/4353.js +1 -0
  46. package/dist/4353.js.map +1 -0
  47. package/dist/4517.js +1 -0
  48. package/dist/4517.js.map +1 -0
  49. package/dist/4652.js +1 -0
  50. package/dist/4674.js +1 -0
  51. package/dist/4674.js.map +1 -0
  52. package/dist/4947.js +1 -0
  53. package/dist/4947.js.map +1 -0
  54. package/dist/5015.js +1 -0
  55. package/dist/5015.js.map +1 -0
  56. package/dist/5422.js +1 -0
  57. package/dist/5422.js.map +1 -0
  58. package/dist/5428.js +1 -0
  59. package/dist/5428.js.map +1 -0
  60. package/dist/5752.js +1 -0
  61. package/dist/5752.js.map +1 -0
  62. package/dist/5851.js +1 -0
  63. package/dist/5851.js.map +1 -0
  64. package/dist/6260.js +1 -0
  65. package/dist/6260.js.map +1 -0
  66. package/dist/6264.js +1 -0
  67. package/dist/6264.js.map +1 -0
  68. package/dist/6540.js +2 -0
  69. package/dist/6540.js.map +1 -0
  70. package/dist/6606.js +1 -0
  71. package/dist/6606.js.map +1 -0
  72. package/dist/{709.js → 693.js} +1 -1
  73. package/dist/693.js.map +1 -0
  74. package/dist/6991.js +1 -0
  75. package/dist/6991.js.map +1 -0
  76. package/dist/7199.js +1 -0
  77. package/dist/7199.js.map +1 -0
  78. package/dist/7255.js +1 -0
  79. package/dist/7255.js.map +1 -0
  80. package/dist/7258.js +1 -0
  81. package/dist/7258.js.map +1 -0
  82. package/dist/7420.js +1 -0
  83. package/dist/7420.js.map +1 -0
  84. package/dist/8114.js +1 -0
  85. package/dist/8114.js.map +1 -0
  86. package/dist/8235.js +1 -0
  87. package/dist/8235.js.map +1 -0
  88. package/dist/8339.js +1 -0
  89. package/dist/8339.js.map +1 -0
  90. package/dist/8558.js +1 -0
  91. package/dist/8558.js.map +1 -0
  92. package/dist/8865.js +1 -0
  93. package/dist/8865.js.map +1 -0
  94. package/dist/8895.js +1 -0
  95. package/dist/8895.js.map +1 -0
  96. package/dist/9037.js +1 -0
  97. package/dist/9037.js.map +1 -0
  98. package/dist/9091.js +1 -0
  99. package/dist/9091.js.map +1 -0
  100. package/dist/9093.js +1 -0
  101. package/dist/9093.js.map +1 -0
  102. package/dist/9117.js +1 -0
  103. package/dist/9117.js.map +1 -0
  104. package/dist/9721.js +1 -0
  105. package/dist/9721.js.map +1 -0
  106. package/dist/esm-dha-workflow-app.js +1 -1
  107. package/dist/esm-dha-workflow-app.js.buildmanifest.json +990 -215
  108. package/dist/esm-dha-workflow-app.js.map +1 -1
  109. package/dist/main.js +1 -1
  110. package/dist/main.js.map +1 -1
  111. package/dist/routes.json +1 -1
  112. package/package.json +10 -3
  113. package/src/accounting/accounting.component.tsx +13 -0
  114. package/src/admissions/admission-request-list/admission-request-list.scss +0 -0
  115. package/src/admissions/admission-request-list/admission-request-list.tsx +134 -0
  116. package/src/admissions/admissions-dashboard.component.scss +15 -0
  117. package/src/admissions/admissions-dashboard.component.tsx +160 -0
  118. package/src/admissions/admissions.resource.ts +101 -0
  119. package/src/admissions/admitted-list/admitted-patients-list.tsx +141 -0
  120. package/src/admissions/constants/index.ts +33 -0
  121. package/src/admissions/discharged-list/discharged-list.scss +0 -0
  122. package/src/admissions/discharged-list/discharged-list.tsx +58 -0
  123. package/src/admissions/inpatient/admission-history/patient-admission-history.tsx +76 -0
  124. package/src/admissions/inpatient/admission-requests/patient-admission-requests.scss +19 -0
  125. package/src/admissions/inpatient/admission-requests/patient-admission-requests.tsx +72 -0
  126. package/src/admissions/inpatient/inpatient-admissions.component.scss +7 -0
  127. package/src/admissions/inpatient/inpatient-admissions.component.tsx +46 -0
  128. package/src/admissions/modal/admit-elsewhere/admit-elsewhere.modal.scss +23 -0
  129. package/src/admissions/modal/admit-elsewhere/admit-elsewhere.modal.tsx +156 -0
  130. package/src/admissions/modal/admit-patient/admit-patient.modal.scss +0 -0
  131. package/src/admissions/modal/admit-patient/admit-patient.modal.tsx +109 -0
  132. package/src/admissions/modal/bed-swap/bed-swap.modal.scss +0 -0
  133. package/src/admissions/modal/bed-swap/bed-swap.modal.tsx +102 -0
  134. package/src/admissions/modal/cancel-admission-request/cancel-admission-request.scss +11 -0
  135. package/src/admissions/modal/cancel-admission-request/cancel-admission-request.tsx +105 -0
  136. package/src/admissions/modal/discharge/discharge-patient.modal.scss +13 -0
  137. package/src/admissions/modal/discharge/discharge-patient.modal.tsx +84 -0
  138. package/src/admissions/types/index.ts +192 -0
  139. package/src/appointments/appointments.component.tsx +13 -0
  140. package/src/billing/api/billing.api.ts +107 -0
  141. package/src/billing/billing-root.tsx +20 -0
  142. package/src/billing/dashboard/billingDashboard.component.scss +0 -0
  143. package/src/billing/dashboard/billingDashboard.component.tsx +25 -0
  144. package/src/billing/extensions/visit-billing/visit-billing.extension.scss +0 -0
  145. package/src/billing/extensions/visit-billing/visit-billing.extension.tsx +508 -0
  146. package/src/billing/invoice/bill.resource.ts +47 -0
  147. package/src/billing/invoice/invoice-header/header-card/header-card.scss +17 -0
  148. package/src/billing/invoice/invoice-header/header-card/header-card.tsx +21 -0
  149. package/src/billing/invoice/invoice.scss +113 -0
  150. package/src/billing/invoice/invoice.tsx +1441 -0
  151. package/src/billing/invoice/line-items/line-items.scss +0 -0
  152. package/src/billing/invoice/line-items/line-items.tsx +120 -0
  153. package/src/billing/invoice/modal/delete-bill-item/delete-bill-item.modal.scss +23 -0
  154. package/src/billing/invoice/modal/delete-bill-item/delete-bill-item.modal.tsx +114 -0
  155. package/src/billing/invoice/modal/edit-bill-item/edit-bill-item.modal.scss +0 -0
  156. package/src/billing/invoice/modal/edit-bill-item/edit-bill-item.modal.tsx +122 -0
  157. package/src/billing/invoice/payment-details/payment-details.scss +0 -0
  158. package/src/billing/invoice/payment-details/payment-details.tsx +43 -0
  159. package/src/billing/invoice/print-invoice/print-receipt.component.tsx +44 -0
  160. package/src/billing/invoice/print-invoice/print-receipt.scss +14 -0
  161. package/src/billing/types/index.ts +84 -0
  162. package/src/billing/utils/index.ts +17 -0
  163. package/src/billing/widgets/billingTotalsRow.component.scss +0 -0
  164. package/src/billing/widgets/billingTotalsRow.component.tsx +712 -0
  165. package/src/billing/workspaces/create-order-bill-form-workspace/create-order-bill-form.resource.ts +103 -0
  166. package/src/billing/workspaces/create-order-bill-form-workspace/create-order-bill-form.scss +58 -0
  167. package/src/billing/workspaces/create-order-bill-form-workspace/create-order-bill-form.workspace.tsx +349 -0
  168. package/src/billing/workspaces/create-order-bill-form-workspace/schema.ts +11 -0
  169. package/src/bookings/bookings.component.scss +7 -0
  170. package/src/bookings/bookings.component.tsx +31 -0
  171. package/src/bookings/daily/daily-bookings.component.scss +38 -0
  172. package/src/bookings/daily/daily-bookings.component.tsx +138 -0
  173. package/src/bookings/daily/daily-bookings.resource.ts +28 -0
  174. package/src/bookings/daily/filters/daily-bookings-filter.component.scss +15 -0
  175. package/src/bookings/daily/filters/daily-bookings-filter.component.tsx +80 -0
  176. package/src/bookings/daily/patient-list/daily-bookings-patient-list.component.tsx +97 -0
  177. package/src/bookings/types/index.ts +68 -0
  178. package/src/config-schema.ts +91 -1
  179. package/src/createDashboardLink.tsx +9 -0
  180. package/src/dashboard/charts/chart.component.scss +13 -0
  181. package/src/dashboard/charts/chart.component.tsx +56 -0
  182. package/src/dashboard/dashboard.component.scss +7 -0
  183. package/src/dashboard/dashboard.component.tsx +51 -0
  184. package/src/dashboard/overview/overview.component.scss +150 -0
  185. package/src/dashboard/overview/overview.component.tsx +134 -0
  186. package/src/dashboard/patient-list/patient-list.component.tsx +41 -0
  187. package/src/dashboard-meta/accounting-dashboard.meta.ts +6 -0
  188. package/src/dashboard-meta/admissions-dashboard.meta.ts +6 -0
  189. package/src/dashboard-meta/billing-dashboard.meta.ts +6 -0
  190. package/src/dashboard-meta/bookings-dashboard.meta.ts +6 -0
  191. package/src/dashboard-meta/consultation-dashboard.meta.ts +6 -0
  192. package/src/dashboard-meta/dha-workflow-dashboard.meta.ts +6 -0
  193. package/src/dashboard-meta/inpatient-admissions.meta.ts +6 -0
  194. package/src/dashboard-meta/maternity-dashboard.meta.ts +6 -0
  195. package/src/dashboard-meta/mch-dashboard.meta.ts +6 -0
  196. package/src/dashboard-meta/pharmacy-dashboard.meta.ts +6 -0
  197. package/src/dashboard-meta/queue-dashboard.meta.ts +6 -0
  198. package/src/dashboard-meta/registers-dashboard.meta.ts +6 -0
  199. package/src/dashboard-meta/registry-dashboard.meta.ts +6 -0
  200. package/src/dashboard-meta/service-queue-admin.meta.ts +6 -0
  201. package/src/dashboard-meta/triage-dashboard.meta.ts +6 -0
  202. package/src/hooks/useActions.ts +19 -2
  203. package/src/index.ts +110 -15
  204. package/src/laboratory/laboratory.component.tsx +13 -0
  205. package/src/mnch/maternity/maternity-queues.component.scss +7 -0
  206. package/src/mnch/maternity/maternity-queues.component.tsx +28 -0
  207. package/src/mnch/maternity/queues/triage/maternity-triage.tsx +15 -0
  208. package/src/mnch/mch/mch-queues.component.scss +7 -0
  209. package/src/mnch/mch/mch-queues.component.tsx +32 -0
  210. package/src/mnch/mch/queues/consultation/mch-consultation.tsx +18 -0
  211. package/src/mnch/mch/queues/triage/mch-triage.tsx +15 -0
  212. package/src/mnch/mnch-root.tsx +17 -0
  213. package/src/mortuary/mortuary.component.tsx +13 -0
  214. package/src/pharmacy/pharmacy.component.tsx +13 -0
  215. package/src/registers/registers.component.tsx +8 -0
  216. package/src/registry/eligibility/eliigibility-tags/eligibility-tags.scss +6 -0
  217. package/src/registry/eligibility/eliigibility-tags/eligibility-tags.tsx +137 -0
  218. package/src/registry/eligibility/modal/eligibility-details.modal.scss +38 -0
  219. package/src/registry/eligibility/modal/eligibility-details.modal.tsx +131 -0
  220. package/src/registry/modal/client-details-modal/client-details-modal.tsx +9 -26
  221. package/src/registry/modal/otp-verification-modal/otp-verification-modal.scss +31 -1
  222. package/src/registry/modal/otp-verification-modal/otp-verification-modal.tsx +139 -54
  223. package/src/registry/modal/send-to-triage/send-to-triage.modal.scss +9 -1
  224. package/src/registry/modal/send-to-triage/send-to-triage.modal.tsx +665 -45
  225. package/src/registry/payment-details/payment-options/payment-options.scss +13 -0
  226. package/src/registry/payment-details/payment-options/payment-options.tsx +61 -14
  227. package/src/registry/registry.component.scss +6 -0
  228. package/src/registry/registry.component.tsx +94 -27
  229. package/src/registry/registry.resource.ts +10 -6
  230. package/src/registry/types/index.ts +120 -0
  231. package/src/registry/utils/hie-client-adapter.ts +3 -0
  232. package/src/registry/utils/mask-data.ts +11 -0
  233. package/src/resources/dashboard.resource.ts +20 -0
  234. package/src/resources/identifier-types.ts +2 -0
  235. package/src/resources/patient-resource.ts +3 -1
  236. package/src/resources/queue.resource.ts +24 -1
  237. package/src/resources/superset.resource.ts +21 -0
  238. package/src/resources/visit.resource.ts +19 -1
  239. package/src/root.component.tsx +27 -6
  240. package/src/routes.json +222 -15
  241. package/src/{consultation → service-queues}/action-button.component.tsx +2 -2
  242. package/src/{consultation → service-queues}/action-overflow-menu-item.component.tsx +2 -2
  243. package/src/service-queues/admin/queue/modal/create-queue/create-queue.modal.scss +31 -0
  244. package/src/service-queues/admin/queue/modal/create-queue/create-queue.modal.tsx +143 -0
  245. package/src/service-queues/admin/queue/modal/edit-queue/edit-queue.modal.scss +0 -0
  246. package/src/service-queues/admin/queue/modal/edit-queue/edit-queue.modal.tsx +154 -0
  247. package/src/service-queues/admin/queue/queue-list/queue-list.scss +33 -0
  248. package/src/service-queues/admin/queue/queue-list/queue-list.tsx +113 -0
  249. package/src/service-queues/admin/queue-entry/queue-entry-list.component.scss +6 -0
  250. package/src/service-queues/admin/queue-entry/queue-entry-list.component.tsx +137 -0
  251. package/src/service-queues/admin/queue-room/modal/create-queue-room/create-queue-room.modal.scss +31 -0
  252. package/src/service-queues/admin/queue-room/modal/create-queue-room/create-queue-room.modal.tsx +137 -0
  253. package/src/service-queues/admin/queue-room/modal/edit-queue-room/edit-queue-room.modal.scss +0 -0
  254. package/src/service-queues/admin/queue-room/modal/edit-queue-room/edit-queue-room.modal.tsx +146 -0
  255. package/src/service-queues/admin/queue-room/queue-room-list/queue-room-list.scss +22 -0
  256. package/src/service-queues/admin/queue-room/queue-room-list/queue-room-list.tsx +120 -0
  257. package/src/service-queues/admin/service-queue-admin-dashboard.component.scss +6 -0
  258. package/src/service-queues/admin/service-queue-admin-dashboard.component.tsx +34 -0
  259. package/src/service-queues/consultation/consultation.component.scss +7 -0
  260. package/src/service-queues/consultation/consultation.component.tsx +15 -0
  261. package/src/service-queues/extensions/service-queue-patient-banner/service-queue-patient-banner.scss +30 -0
  262. package/src/service-queues/extensions/service-queue-patient-banner/service-queue-patient-banner.tsx +108 -0
  263. package/src/service-queues/metrics/metrics-cards/attended-patients.extension.tsx +38 -0
  264. package/src/service-queues/metrics/metrics-cards/waiting-patients.extension.tsx +34 -0
  265. package/src/service-queues/metrics/metrics-container.component.tsx +23 -0
  266. package/src/{metrics → service-queues/metrics}/metrics.resource.ts +0 -36
  267. package/src/service-queues/modals/daily-report-patient-list/daily-report-patient-list.scss +26 -0
  268. package/src/service-queues/modals/daily-report-patient-list/daily-report-patient-list.tsx +108 -0
  269. package/src/service-queues/modals/move/move-patient.component.scss +35 -0
  270. package/src/service-queues/modals/move/move-patient.component.tsx +152 -0
  271. package/src/service-queues/modals/serve/serve-patient.comppnent.scss +0 -0
  272. package/src/service-queues/modals/serve/serve-patient.comppnent.tsx +80 -0
  273. package/src/service-queues/modals/sign-off/sign-off.modal.scss +0 -0
  274. package/src/service-queues/modals/sign-off/sign-off.modal.tsx +79 -0
  275. package/src/service-queues/modals/transition/transition-patient.component.scss +0 -0
  276. package/src/service-queues/modals/transition/transition-patient.component.tsx +122 -0
  277. package/src/service-queues/queue-list/check-in.service.ts +26 -0
  278. package/src/service-queues/queue-list/queue-list.component.scss +50 -0
  279. package/src/service-queues/queue-list/queue-list.component.tsx +302 -0
  280. package/src/service-queues/queue-room.component.tsx +39 -0
  281. package/src/service-queues/room/room.component.tsx +58 -0
  282. package/src/service-queues/service-queue/service-queue.component.scss +14 -0
  283. package/src/service-queues/service-queue/service-queue.component.tsx +399 -0
  284. package/src/service-queues/service-queue/stats/stat-details/stat-details.component.scss +12 -0
  285. package/src/service-queues/service-queue/stats/stat-details/stat-details.component.tsx +63 -0
  286. package/src/service-queues/service-queue.scss +27 -0
  287. package/src/service-queues/service-queue.tsx +37 -0
  288. package/src/service-queues/service-queues.resource.ts +303 -4
  289. package/src/service-queues/service.resource.ts +28 -0
  290. package/src/shared/constants/concepts.ts +18 -0
  291. package/src/shared/constants/index.ts +1 -2
  292. package/src/shared/constants/patient-category.ts +6 -0
  293. package/src/shared/constants/patient-type.ts +10 -0
  294. package/src/shared/constants/visit-types.ts +7 -0
  295. package/src/shared/services/billing.resource.ts +38 -0
  296. package/src/shared/services/client-payment-mode.resource.ts +27 -0
  297. package/src/shared/services/client-payment.resource.ts +17 -0
  298. package/src/shared/services/eligibility.resource.ts +19 -0
  299. package/src/shared/services/encounters.resource.ts +27 -0
  300. package/src/shared/services/location.resource.ts +9 -0
  301. package/src/shared/types/index.ts +152 -0
  302. package/src/shared/ui/aggregate-stat-card/aggregate-stat-card.scss +42 -0
  303. package/src/shared/ui/aggregate-stat-card/aggregate-stat-card.tsx +42 -0
  304. package/src/shared/ui/confirm-modal/confirm.modal.scss +18 -0
  305. package/src/shared/ui/confirm-modal/confirm.modal.tsx +38 -0
  306. package/src/shared/ui/otp-input/otp-input.component.scss +14 -0
  307. package/src/shared/ui/otp-input/otp-input.component.tsx +90 -0
  308. package/src/shared/ui/stat-card/stat-card.component.scss +10 -0
  309. package/src/shared/ui/stat-card/stat-card.component.tsx +26 -0
  310. package/src/shared/ui/timer/timer.component.scss +5 -0
  311. package/src/shared/ui/timer/timer.component.tsx +40 -0
  312. package/src/shared/utils/get-base-url.ts +27 -0
  313. package/src/shared/utils/get-tag-type.ts +66 -0
  314. package/src/side-nav-menu/mnch-nav-link-config.ts +16 -0
  315. package/src/side-nav-menu/mnch-nav-links.tsx +42 -0
  316. package/src/side-nav-menu/nav-link-config.ts +6 -4
  317. package/src/triage/metrics/attended-patients.extension.tsx +42 -0
  318. package/src/triage/metrics/metrics.scss +36 -0
  319. package/src/triage/metrics/triage-metrics.component.tsx +21 -0
  320. package/src/triage/metrics/waiting-patients.extension.tsx +39 -0
  321. package/src/triage/room/room.scss +29 -0
  322. package/src/triage/triage.component.tsx +15 -0
  323. package/src/triage/triage.resource.ts +19 -0
  324. package/src/triage/types.ts +16 -0
  325. package/src/types/types.ts +82 -2
  326. package/dist/104.js +0 -2
  327. package/dist/104.js.map +0 -1
  328. package/dist/184.js +0 -2
  329. package/dist/184.js.map +0 -1
  330. package/dist/197.js +0 -1
  331. package/dist/255.js +0 -1
  332. package/dist/255.js.map +0 -1
  333. package/dist/300.js +0 -1
  334. package/dist/306.js +0 -1
  335. package/dist/306.js.map +0 -1
  336. package/dist/335.js +0 -1
  337. package/dist/353.js +0 -1
  338. package/dist/353.js.map +0 -1
  339. package/dist/388.js +0 -2
  340. package/dist/388.js.map +0 -1
  341. package/dist/420.js +0 -1
  342. package/dist/420.js.map +0 -1
  343. package/dist/460.js +0 -1
  344. package/dist/460.js.map +0 -1
  345. package/dist/540.js +0 -2
  346. package/dist/540.js.map +0 -1
  347. package/dist/55.js +0 -1
  348. package/dist/560.js +0 -1
  349. package/dist/560.js.map +0 -1
  350. package/dist/635.js +0 -1
  351. package/dist/635.js.map +0 -1
  352. package/dist/652.js +0 -1
  353. package/dist/695.js +0 -1
  354. package/dist/695.js.map +0 -1
  355. package/dist/709.js.map +0 -1
  356. package/dist/710.js +0 -2
  357. package/dist/710.js.map +0 -1
  358. package/dist/91.js +0 -1
  359. package/dist/91.js.map +0 -1
  360. package/dist/93.js +0 -1
  361. package/dist/93.js.map +0 -1
  362. package/dist/978.js +0 -1
  363. package/dist/978.js.map +0 -1
  364. package/dist/99.js +0 -1
  365. package/src/consultation/consultation-room.component.tsx +0 -60
  366. package/src/consultation/consultation.scss +0 -5
  367. package/src/consultation/consultation.tsx +0 -14
  368. package/src/hooks/useQueueEntries.ts +0 -35
  369. package/src/metrics/metrics-cards/attended-patients.extension.tsx +0 -18
  370. package/src/metrics/metrics-cards/waiting-patients.extension.tsx +0 -18
  371. package/src/metrics/metrics-container.component.tsx +0 -16
  372. package/src/registry/mock-client.ts +0 -627
  373. /package/dist/{710.js.LICENSE.txt → 1558.js.LICENSE.txt} +0 -0
  374. /package/dist/{104.js.LICENSE.txt → 2177.js.LICENSE.txt} +0 -0
  375. /package/dist/{184.js.LICENSE.txt → 3184.js.LICENSE.txt} +0 -0
  376. /package/dist/{540.js.LICENSE.txt → 6540.js.LICENSE.txt} +0 -0
  377. /package/src/{metrics → service-queues/metrics}/metrics-cards/metrics-card.component.tsx +0 -0
  378. /package/src/{metrics → service-queues/metrics}/metrics-cards/metrics-card.scss +0 -0
  379. /package/src/{metrics → service-queues/metrics}/metrics-container.scss +0 -0
@@ -0,0 +1,150 @@
1
+ .container {
2
+ display: flex;
3
+ width: 100%;
4
+ justify-content: flex-start;
5
+ flex-wrap: wrap;
6
+ gap: 1rem;
7
+
8
+ .card {
9
+ border: 1px solid grey;
10
+ border-radius: 5px;
11
+ background-color: white;
12
+ font-weight: bold;
13
+ flex: 0 0 250px;
14
+ height: 5rem;
15
+ min-width: 0;
16
+ }
17
+
18
+ .title {
19
+ display: flex;
20
+ align-items: center;
21
+ gap: 0.5rem;
22
+ white-space: nowrap;
23
+ }
24
+ }
25
+
26
+ @media (max-width: 1584px) {
27
+ .container .card {
28
+ flex: 0 0 calc(20% - 1rem);
29
+ }
30
+
31
+ .text {
32
+ font-size: 1rem;
33
+ }
34
+ }
35
+ @media (max-width: 1456px) {
36
+ .container .card {
37
+ flex: 0 0 calc(25% - 1rem);
38
+ }
39
+
40
+ .text {
41
+ font-size: 1rem;
42
+ }
43
+ }
44
+
45
+ @media (max-width: 1356px) {
46
+ .container .card {
47
+ flex: 0 0 calc(25% - 1rem);
48
+ }
49
+
50
+ .text {
51
+ font-size: 1rem;
52
+ }
53
+ }
54
+
55
+ @media (max-width: 1264px) {
56
+ .container .card {
57
+ flex: 0 0 calc(30% - 1rem);
58
+ }
59
+
60
+ .text {
61
+ font-size: 1rem;
62
+ }
63
+ }
64
+
65
+ @media (max-width: 1095px) {
66
+ .container .card {
67
+ flex: 0 0 calc(30% - 1rem);
68
+ }
69
+
70
+ .text {
71
+ font-size: 1rem;
72
+ }
73
+ }
74
+
75
+ @media (max-width: 1024px) {
76
+ .container .card {
77
+ flex: 0 0 calc(50% - 1rem);
78
+ }
79
+ .text {
80
+ font-size: 1rem;
81
+ }
82
+ }
83
+
84
+ @media (max-width: 600px) {
85
+ .container .card {
86
+ flex: 0 0 100%;
87
+ }
88
+ }
89
+
90
+
91
+ h4 {
92
+ font-weight: bold;
93
+ }
94
+
95
+ .dropdownItem {
96
+ display: flex;
97
+ justify-self: flex-end;
98
+ width: 25%;
99
+ min-width: 180px;
100
+ max-width: 280px;
101
+ margin-top: 5rem;
102
+ margin-bottom: 5rem;
103
+ }
104
+
105
+ .dropdownContainer {
106
+ .cds--list-box__menu-item__option {
107
+ font-weight: 600;
108
+ }
109
+
110
+ .cds--list-box__field {
111
+ font-weight: 600;
112
+ }
113
+ }
114
+
115
+ .opd {
116
+ background-color: #2B579A !important;
117
+ }
118
+ .completed {
119
+ background-color: #4CAF50 !important;
120
+ }
121
+
122
+ .uncompleted {
123
+ background-color: #FFC107 !important;
124
+ }
125
+ .emergencies {
126
+ background-color: lightcoral !important;
127
+ }
128
+
129
+ .waitingTime {
130
+ background-color: lightblue !important;
131
+ }
132
+ .labs {
133
+ background-color: lightgrey !important;
134
+ }
135
+
136
+ .pharmacy {
137
+ background-color: lightgreen !important;
138
+ }
139
+
140
+ .text {
141
+ color: white;
142
+ display: flex;
143
+ align-items: center;
144
+ gap: 0.5rem;
145
+ white-space: nowrap;
146
+ font-size: 1rem;
147
+ }
148
+ .tabsContainer {
149
+ margin-top: 2rem;
150
+ }
@@ -0,0 +1,134 @@
1
+ import { FluidDropdown, Tab, TabList, TabPanel, TabPanels, Tabs, Tile } from '@carbon/react';
2
+ import React, { useState } from 'react';
3
+ import { UserMultiple, CheckmarkFilled, Time, Hospital, Chemistry, Medication } from '@carbon/react/icons';
4
+
5
+ import styles from './overview.component.scss';
6
+ import { type QueueEntryResult } from '../../registry/types';
7
+ import PatientList from '../patient-list/patient-list.component';
8
+ import Chart from '../charts/chart.component';
9
+
10
+ interface OverviewProps {
11
+ triageCount?: QueueEntryResult[];
12
+ consultationCount?: QueueEntryResult[];
13
+ dashboardSummary?: any;
14
+ }
15
+
16
+ const Overview: React.FC<OverviewProps> = ({ triageCount, consultationCount, dashboardSummary }) => {
17
+ const totalPatients: QueueEntryResult[] = [...triageCount, ...consultationCount];
18
+ const patientsInQueue = totalPatients.filter(
19
+ (patient) => patient.status === 'WAITING' || patient.status === 'IN SERVICE',
20
+ ).length;
21
+ const [selected, setSelected] = useState<string | null>(null);
22
+ const triagePatients = triageCount?.length ?? 0;
23
+ const consultationPatients = consultationCount?.length ?? 0;
24
+ const dropDownItems = [
25
+ 'Total Patients',
26
+ 'Triage Patients',
27
+ 'Consultation Patients',
28
+ 'Walk-In Patients',
29
+ 'Emergency Patients',
30
+ ];
31
+
32
+ const handleDropdownChange = (data: { selectedItem: string }) => {
33
+ const value = data.selectedItem;
34
+ setSelected(value);
35
+ };
36
+
37
+ let selectedPatients: QueueEntryResult[] = [];
38
+
39
+ switch (selected) {
40
+ case 'Triage Patients':
41
+ selectedPatients = triageCount ?? [];
42
+ break;
43
+
44
+ case 'Consultation Patients':
45
+ selectedPatients = consultationCount ?? [];
46
+ break;
47
+ case 'Walk-In Patients':
48
+ selectedPatients = [];
49
+ break;
50
+ case 'Emergency Patients':
51
+ selectedPatients = [];
52
+ break;
53
+
54
+ case 'Total Patients':
55
+ selectedPatients = [...(triageCount ?? []), ...(consultationCount ?? [])];
56
+ break;
57
+
58
+ default:
59
+ selectedPatients = [...(triageCount ?? []), ...(consultationCount ?? [])];
60
+ break;
61
+ }
62
+
63
+ return (
64
+ <>
65
+ <div className={styles.container}>
66
+ <Tile className={`${styles.card} ${styles.opd}`}>
67
+ <h4 className={styles.text}>
68
+ <UserMultiple size={24} />
69
+ Total OPD Visits
70
+ </h4>
71
+ <h4 className={styles.text}>{dashboardSummary?.total_opd_visits ?? 0}</h4>
72
+ </Tile>
73
+ <Tile className={`${styles.card} ${styles.completed}`}>
74
+ <h4 className={styles.text}>
75
+ <CheckmarkFilled size={20} /> Completed Visits
76
+ </h4>
77
+ <h4 className={styles.text}>{dashboardSummary?.completed_visits ?? 0}</h4>
78
+ </Tile>
79
+ <Tile className={`${styles.card} ${styles.uncompleted}`}>
80
+ <h4 className={styles.text}>
81
+ <Time size={20} /> Uncompleted visits
82
+ </h4>
83
+ <h4 className={styles.text}>{dashboardSummary?.uncompleted_visits ?? 0}</h4>
84
+ </Tile>
85
+ <Tile className={`${styles.card} ${styles.labs}`}>
86
+ <h4 className={styles.text}>
87
+ <Chemistry size={20} /> Labs
88
+ </h4>
89
+ <h4 className={styles.text}>{dashboardSummary?.labs ?? 0}</h4>
90
+ </Tile>
91
+ <Tile className={`${styles.card} ${styles.pharmacy}`}>
92
+ <h4 className={styles.text}>
93
+ <Medication size={20} /> Pharmacy
94
+ </h4>
95
+ <h4 className={styles.text}>{dashboardSummary?.pharmacy ?? 0}</h4>
96
+ </Tile>
97
+ <Tile className={`${styles.card} ${styles.emergencies}`}>
98
+ <h4 className={styles.text}>
99
+ <Hospital size={20} /> Emergencies
100
+ </h4>
101
+ <h4 className={styles.text}>{dashboardSummary?.emergencies ?? 0}</h4>
102
+ </Tile>
103
+ <Tile className={`${styles.card} ${styles.waitingTime}`}>
104
+ <h4 className={styles.text}>
105
+ <Time size={20} /> Avg. Waiting Time
106
+ </h4>
107
+ <h4 className={styles.text}>{dashboardSummary?.average_waiting_minutes ?? 0} mins</h4>
108
+ </Tile>
109
+ </div>
110
+ <div className={styles.tabsContainer}>
111
+ <Tabs>
112
+ <TabList>
113
+ <Tab>Daily</Tab>
114
+ <Tab>Weekly</Tab>
115
+ <Tab>Monthly</Tab>
116
+ </TabList>
117
+ <TabPanels>
118
+ <TabPanel>
119
+ <Chart dashboardId="1bdad7e2-e9a7-4cb5-886c-185f63b2eae0" />
120
+ </TabPanel>
121
+ <TabPanel>
122
+ <Chart dashboardId="0c59e7cd-2eba-4426-9d52-1db0866e0377" />
123
+ </TabPanel>
124
+ <TabPanel>
125
+ <Chart dashboardId="fe8606e8-2160-4914-860a-f5abc386d9c1" />
126
+ </TabPanel>
127
+ </TabPanels>
128
+ </Tabs>
129
+ </div>
130
+ </>
131
+ );
132
+ };
133
+
134
+ export default Overview;
@@ -0,0 +1,41 @@
1
+ import React from 'react';
2
+ import { type QueueEntryResult } from '../../registry/types';
3
+ import { Table, TableBody, TableCell, TableHead, TableHeader, TableRow } from '@carbon/react';
4
+ import { isDesktop, useLayoutType } from '@openmrs/esm-framework';
5
+
6
+ interface PatientListProps {
7
+ patients?: QueueEntryResult[];
8
+ }
9
+
10
+ const PatientList: React.FC<PatientListProps> = ({ patients }) => {
11
+ const layout = useLayoutType();
12
+ const desktop = isDesktop(layout);
13
+ return (
14
+ <Table size={desktop ? 'sm' : 'lg'}>
15
+ <TableHead>
16
+ <TableRow>
17
+ <TableHeader>No</TableHeader>
18
+ <TableHeader>Name</TableHeader>
19
+ <TableHeader>Ticket</TableHeader>
20
+ <TableHeader>Status</TableHeader>
21
+ <TableHeader>Priority</TableHeader>
22
+ </TableRow>
23
+ </TableHead>
24
+ <TableBody>
25
+ {patients?.map((patient, index) => {
26
+ return (
27
+ <TableRow>
28
+ <TableCell>{index + 1}</TableCell>
29
+ <TableCell>{`${patient.given_name} ${patient.middle_name} ${patient.family_name}`}</TableCell>
30
+ <TableCell>{patient.queue_id}</TableCell>
31
+ <TableCell>{patient.status}</TableCell>
32
+ <TableCell>{patient.priority}</TableCell>
33
+ </TableRow>
34
+ );
35
+ })}
36
+ </TableBody>
37
+ </Table>
38
+ );
39
+ };
40
+
41
+ export default PatientList;
@@ -0,0 +1,6 @@
1
+ export const accountingDashboardMeta = {
2
+ path: 'accounting',
3
+ slot: 'accounting-dashboard-slot',
4
+ title: 'Accounting',
5
+ basePath: `${window.spaBase}/home`,
6
+ };
@@ -0,0 +1,6 @@
1
+ export const admissionsDashboardMeta = {
2
+ path: 'admissions-dashboard',
3
+ slot: 'admissions-dashboard-slot',
4
+ title: 'Admissions',
5
+ basePath: `${window.spaBase}/home`,
6
+ };
@@ -0,0 +1,6 @@
1
+ export const billingDashboardMeta = {
2
+ path: 'billing',
3
+ slot: 'ampath-billing-dashboard-slot',
4
+ title: 'Accounting',
5
+ basePath: `${window.spaBase}/home`,
6
+ };
@@ -0,0 +1,6 @@
1
+ export const bookingsDashboardMeta = {
2
+ path: 'bookings',
3
+ slot: 'bookings-dashboard-slot',
4
+ title: 'Bookings',
5
+ basePath: `${window.spaBase}/home`,
6
+ };
@@ -0,0 +1,6 @@
1
+ export const consultationDashboardMeta = {
2
+ path: 'consultation',
3
+ slot: 'consultation-dashboard-slot',
4
+ title: 'Consultation',
5
+ basePath: `${window.spaBase}/home`,
6
+ };
@@ -0,0 +1,6 @@
1
+ export const dhaWorkflowDashboardMeta = {
2
+ path: 'dashboard',
3
+ slot: 'dha-workflow-dashboard-slot',
4
+ title: 'Dashboard',
5
+ basePath: `${window.spaBase}/home`,
6
+ };
@@ -0,0 +1,6 @@
1
+ export const patientChartAdmissionsMetaData = {
2
+ path: 'Admissions',
3
+ slot: 'patient-chart-admissions-summary-dashboard-slot',
4
+ title: 'Admissions',
5
+ icon: 'omrs-icon-hospital-bed',
6
+ };
@@ -0,0 +1,6 @@
1
+ export const maternityDashboardMeta = {
2
+ path: 'maternity',
3
+ slot: 'maternity-queue-dashboard-slot',
4
+ title: 'Maternity',
5
+ basePath: `${window.spaBase}/home`,
6
+ };
@@ -0,0 +1,6 @@
1
+ export const mchQueueDashboardMeta = {
2
+ path: 'mnch',
3
+ slot: 'mnch-queue-dashboard-slot',
4
+ title: 'MCH',
5
+ basePath: `${window.spaBase}/home`,
6
+ };
@@ -0,0 +1,6 @@
1
+ export const pharmacyDashboardMeta = {
2
+ path: 'dispensing',
3
+ slot: 'dispensing-dashboard-slot',
4
+ title: 'Pharmacy',
5
+ basePath: `${window.spaBase}/home`,
6
+ } as const;
@@ -0,0 +1,6 @@
1
+ export const queueDashboardMeta = {
2
+ path: 'dashboard',
3
+ slot: 'queue-dashboard-slot',
4
+ title: 'Dashboard',
5
+ basePath: `${window.spaBase}/home`,
6
+ } as const;
@@ -0,0 +1,6 @@
1
+ export const registersDashboardMeta = {
2
+ path: 'registers',
3
+ slot: 'registers-dashboard-slot',
4
+ title: 'Registers',
5
+ basePath: `${window.spaBase}/home`,
6
+ };
@@ -0,0 +1,6 @@
1
+ export const registryDashboardMeta = {
2
+ path: 'registry',
3
+ slot: 'client-registry-dashboard-slot',
4
+ title: 'Registry',
5
+ basePath: `${window.spaBase}/home`,
6
+ } as const;
@@ -0,0 +1,6 @@
1
+ export const serviceQueueAdminDashboardMeta = {
2
+ path: 'service-queue-admin',
3
+ slot: 'service-queue-admin-dashboard-slot',
4
+ title: 'Service Queue Admin',
5
+ basePath: 'dha-workflow',
6
+ };
@@ -0,0 +1,6 @@
1
+ export const triageDashboardMeta = {
2
+ path: 'triage',
3
+ slot: 'triage-queue-dashboard-slot',
4
+ title: 'Triage',
5
+ basePath: `${window.spaBase}/home`,
6
+ };
@@ -1,7 +1,7 @@
1
- import { showModal, useConfig } from '@openmrs/esm-framework';
1
+ import { restBaseUrl, showModal, useConfig } from '@openmrs/esm-framework';
2
2
  import { type ConfigObject, type QueueEntryAction } from '../config-schema';
3
3
  import { useMemo } from 'react';
4
- import { useMutateQueueEntries } from './useQueueEntries';
4
+ import { useSWRConfig } from 'swr';
5
5
  import { type QueueEntry } from '../types/types';
6
6
  import { mapVisitQueueEntryProperties, serveQueueEntry } from '../service-queues/service-queues.resource';
7
7
 
@@ -13,6 +13,23 @@ type ActionProps = {
13
13
  isDelete?: boolean;
14
14
  };
15
15
 
16
+ export function useMutateQueueEntries() {
17
+ const { mutate } = useSWRConfig();
18
+
19
+ return {
20
+ mutateQueueEntries: () => {
21
+ return mutate((key) => {
22
+ return (
23
+ typeof key === 'string' &&
24
+ (key.includes(`${restBaseUrl}/queue-entry`) || key.includes(`${restBaseUrl}/visit-queue-entry`))
25
+ );
26
+ }).then(() => {
27
+ window.dispatchEvent(new CustomEvent('queue-entry-updated'));
28
+ });
29
+ },
30
+ };
31
+ }
32
+
16
33
  export function useActionPropsByKey() {
17
34
  const {
18
35
  concepts: { defaultStatusConceptUuid },
package/src/index.ts CHANGED
@@ -1,13 +1,21 @@
1
- /**
2
- * This is the entrypoint file of the application. It communicates the
3
- * important features of this microfrontend to the app shell. It
4
- * connects the app shell to the React application(s) that make up this
5
- * microfrontend.
6
- */
7
1
  import { getAsyncLifecycle, defineConfigSchema, getSyncLifecycle } from '@openmrs/esm-framework';
8
2
  import { configSchema } from './config-schema';
3
+ import { registryDashboardMeta } from './dashboard-meta/registry-dashboard.meta';
4
+ import { createDashboardLink } from './createDashboardLink';
5
+ import { createDashboardLink as openMrsCreateDashboardLink } from '@openmrs/esm-patient-common-lib';
6
+ import { queueDashboardMeta } from './dashboard-meta/queue-dashboard.meta';
7
+ import { pharmacyDashboardMeta } from './dashboard-meta/pharmacy-dashboard.meta';
8
+ import { triageDashboardMeta } from './dashboard-meta/triage-dashboard.meta';
9
+ import { consultationDashboardMeta } from './dashboard-meta/consultation-dashboard.meta';
10
+ import { dhaWorkflowDashboardMeta } from './dashboard-meta/dha-workflow-dashboard.meta';
11
+ import { accountingDashboardMeta } from './dashboard-meta/accounting-dashboard.meta';
12
+ import { bookingsDashboardMeta } from './dashboard-meta/bookings-dashboard.meta';
13
+ import { serviceQueueAdminDashboardMeta } from './dashboard-meta/service-queue-admin.meta';
14
+ import { admissionsDashboardMeta } from './dashboard-meta/admissions-dashboard.meta';
15
+ import { patientChartAdmissionsMetaData } from './dashboard-meta/inpatient-admissions.meta';
16
+ import { billingDashboardMeta } from './dashboard-meta/billing-dashboard.meta';
9
17
 
10
- const moduleName = '@ampath/openmrs-esm-home-app.js';
18
+ export const moduleName = '@ampath/esm-dha-workflow-app';
11
19
 
12
20
  const options = {
13
21
  featureName: 'Consulation Workflow',
@@ -44,18 +52,105 @@ export const navLinks = getAsyncLifecycle(() => import('./side-nav-menu/nav-link
44
52
  */
45
53
  export const root = getAsyncLifecycle(() => import('./root.component'), options);
46
54
  export const registry = getAsyncLifecycle(() => import('./registry/registry.component'), options);
47
- export const waitingPatientsExtension = getAsyncLifecycle(() => import('./metrics/metrics-cards/waiting-patients.extension'), options);
48
- export const attendedToPatientsExtension = getAsyncLifecycle(() => import('./metrics/metrics-cards/attended-patients.extension'), options);
55
+ export const waitingPatientsExtension = getAsyncLifecycle(
56
+ () => import('./service-queues/metrics/metrics-cards/waiting-patients.extension'),
57
+ options,
58
+ );
59
+ export const attendedToPatientsExtension = getAsyncLifecycle(
60
+ () => import('./service-queues/metrics/metrics-cards/attended-patients.extension'),
61
+ options,
62
+ );
63
+ export const triageWaitingPatientsExtension = getAsyncLifecycle(
64
+ () => import('./triage/metrics/waiting-patients.extension'),
65
+ options,
66
+ );
67
+ export const triageAttendedToPatientsExtension = getAsyncLifecycle(
68
+ () => import('./triage/metrics/attended-patients.extension'),
69
+ options,
70
+ );
49
71
 
50
72
  export const workflowRegistryLink = getAsyncLifecycle(() => import('./widgets/workflow-registry-link.extension'), {
51
73
  featureName: 'workflow-registry-link',
52
74
  moduleName,
53
75
  });
54
76
 
55
- export const signOffModal = getAsyncLifecycle(
56
- () => import('./modals/sign-off-modal'),
57
- {
58
- featureName: 'sign off',
59
- moduleName,
60
- },
77
+ export const registryDashboardLink = getSyncLifecycle(createDashboardLink(registryDashboardMeta), options);
78
+
79
+ export const registryExtension = getAsyncLifecycle(() => import('./registry/registry.component'), options);
80
+
81
+ export const queueDashboardLink = getSyncLifecycle(createDashboardLink(queueDashboardMeta), options);
82
+
83
+ export const queueDashboardExtension = getAsyncLifecycle(() => import('./dashboard/dashboard.component'), options);
84
+
85
+ export const pharmacyDashboardLink = getSyncLifecycle(createDashboardLink(pharmacyDashboardMeta), options);
86
+
87
+ export const triageDashboardLink = getSyncLifecycle(createDashboardLink(triageDashboardMeta), options);
88
+
89
+ export const triageQueueExtension = getAsyncLifecycle(() => import('./triage/triage.component'), options);
90
+
91
+ export const consultationDashboardLink = getSyncLifecycle(createDashboardLink(consultationDashboardMeta), options);
92
+
93
+ export const consultationQueue = getAsyncLifecycle(
94
+ () => import('./service-queues/consultation/consultation.component'),
95
+ options,
96
+ );
97
+
98
+ export const dhaWorkflowDashboardLink = getSyncLifecycle(createDashboardLink(dhaWorkflowDashboardMeta), options);
99
+
100
+ export const dhaWorkflowDashboard = getAsyncLifecycle(() => import('./dashboard/dashboard.component'), options);
101
+
102
+ export const accountingDashboardLink = getSyncLifecycle(createDashboardLink(accountingDashboardMeta), options);
103
+
104
+ export const accountingDashboard = getAsyncLifecycle(() => import('./accounting/accounting.component'), options);
105
+
106
+ export const bookingsDashboardLink = getSyncLifecycle(createDashboardLink(bookingsDashboardMeta), options);
107
+
108
+ export const bookings = getAsyncLifecycle(() => import('./bookings/bookings.component'), options);
109
+
110
+ export const mnchQueueDashboardLink = getAsyncLifecycle(() => import('./side-nav-menu/mnch-nav-links'), options);
111
+
112
+ export const MNCHRoot = getAsyncLifecycle(() => import('./mnch/mnch-root'), options);
113
+
114
+ export const serviceQueueAdmin = getAsyncLifecycle(
115
+ () => import('./service-queues/admin/service-queue-admin-dashboard.component'),
116
+ options,
117
+ );
118
+
119
+ export const serviceQueuesAdminLink = getSyncLifecycle(createDashboardLink(serviceQueueAdminDashboardMeta), options);
120
+ export const admissionsDashboardLink = getSyncLifecycle(createDashboardLink(admissionsDashboardMeta), options);
121
+
122
+ export const admissionsDashboard = getAsyncLifecycle(
123
+ () => import('./admissions/admissions-dashboard.component'),
124
+ options,
125
+ );
126
+
127
+ export const serviceQueueBannerComponent = getAsyncLifecycle(
128
+ () => import('./service-queues/extensions/service-queue-patient-banner/service-queue-patient-banner'),
129
+ options,
130
+ );
131
+ export const patientChartAdmissionsLink = getSyncLifecycle(
132
+ openMrsCreateDashboardLink(patientChartAdmissionsMetaData as any),
133
+ options,
134
+ );
135
+ export const patientAdmissionSummary = getAsyncLifecycle(
136
+ () => import('./admissions/inpatient/inpatient-admissions.component'),
137
+ options,
138
+ );
139
+ export const billingDashboardLink = getSyncLifecycle(createDashboardLink(billingDashboardMeta), options);
140
+
141
+ export const billingDashboard = getAsyncLifecycle(
142
+ () => import('./billing/dashboard/billingDashboard.component'),
143
+ options,
144
+ );
145
+
146
+ export const billingRoot = getAsyncLifecycle(() => import('./billing/billing-root'), options);
147
+
148
+ export const createOrderBillFormWorkspace = getAsyncLifecycle(
149
+ () => import('./billing/workspaces/create-order-bill-form-workspace/create-order-bill-form.workspace'),
150
+ options,
151
+ );
152
+
153
+ export const visitBillingForm = getAsyncLifecycle(
154
+ () => import('./billing/extensions/visit-billing/visit-billing.extension'),
155
+ options,
61
156
  );
@@ -0,0 +1,13 @@
1
+ import React, { useEffect, useState } from 'react';
2
+ import { ExtensionSlot, WorkspaceContainer } from '@openmrs/esm-framework';
3
+
4
+ const LaboratoryComponent: React.FC = () => {
5
+
6
+ return (
7
+ <div>
8
+ <ExtensionSlot name="laboratory-dashboard-slot" />
9
+ </div>
10
+ );
11
+ };
12
+
13
+ export default LaboratoryComponent;
@@ -0,0 +1,7 @@
1
+ .mnchLayout{
2
+ display: flex;
3
+ flex-direction: column;
4
+ width: 100%;
5
+ row-gap: 10px;
6
+ padding: 2% 2%;
7
+ }
@@ -0,0 +1,28 @@
1
+ import React from 'react';
2
+ import styles from './maternity-queues.component.scss';
3
+ import { Tab, TabList, TabPanel, TabPanels, Tabs } from '@carbon/react';
4
+ import MaternityTriage from './queues/triage/maternity-triage';
5
+ interface MchQueuesProps {}
6
+ const MaternityQueues: React.FC<MchQueuesProps> = () => {
7
+ return (
8
+ <div className={styles.mnchLayout}>
9
+ <div className={styles.mnchHeader}>
10
+ <h4>Maternity</h4>
11
+ </div>
12
+ <div className={styles.mnchContent}>
13
+ <Tabs>
14
+ <TabList contained>
15
+ <Tab>Triage</Tab>
16
+ </TabList>
17
+ <TabPanels>
18
+ <TabPanel>
19
+ <MaternityTriage />
20
+ </TabPanel>
21
+
22
+ </TabPanels>
23
+ </Tabs>
24
+ </div>
25
+ </div>
26
+ );
27
+ };
28
+ export default MaternityQueues;