@ampath/esm-dha-workflow-app 4.0.0-next.13 → 4.0.0-next.131

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 (362) 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/{198.js.LICENSE.txt → 1558.js.LICENSE.txt} +0 -10
  6. package/dist/1558.js.map +1 -0
  7. package/dist/1729.js +1 -0
  8. package/dist/1729.js.map +1 -0
  9. package/dist/182.js +1 -0
  10. package/dist/182.js.map +1 -0
  11. package/dist/1826.js +1 -0
  12. package/dist/1826.js.map +1 -0
  13. package/dist/1833.js +1 -0
  14. package/dist/1833.js.map +1 -0
  15. package/dist/1856.js +1 -0
  16. package/dist/1856.js.map +1 -0
  17. package/dist/1925.js +1 -0
  18. package/dist/1925.js.map +1 -0
  19. package/dist/2021.js +1 -0
  20. package/dist/2021.js.map +1 -0
  21. package/dist/2054.js +1 -0
  22. package/dist/2054.js.map +1 -0
  23. package/dist/2177.js +2 -0
  24. package/dist/2177.js.LICENSE.txt +9 -0
  25. package/dist/2177.js.map +1 -0
  26. package/dist/2364.js +2 -0
  27. package/dist/{200.js.LICENSE.txt → 2364.js.LICENSE.txt} +15 -0
  28. package/dist/2364.js.map +1 -0
  29. package/dist/2566.js +1 -0
  30. package/dist/2566.js.map +1 -0
  31. package/dist/2801.js +1 -0
  32. package/dist/2801.js.map +1 -0
  33. package/dist/2975.js +1 -0
  34. package/dist/2975.js.map +1 -0
  35. package/dist/3041.js +1 -0
  36. package/dist/3041.js.map +1 -0
  37. package/dist/3099.js +1 -0
  38. package/dist/3184.js +2 -0
  39. package/dist/3184.js.map +1 -0
  40. package/dist/3485.js +1 -0
  41. package/dist/3485.js.map +1 -0
  42. package/dist/3654.js +1 -0
  43. package/dist/3654.js.map +1 -0
  44. package/dist/4055.js +1 -0
  45. package/dist/4205.js +1 -0
  46. package/dist/4205.js.map +1 -0
  47. package/dist/4225.js +1 -0
  48. package/dist/4225.js.map +1 -0
  49. package/dist/4300.js +1 -0
  50. package/dist/4335.js +1 -0
  51. package/dist/4353.js +1 -0
  52. package/dist/4353.js.map +1 -0
  53. package/dist/4517.js +1 -0
  54. package/dist/4517.js.map +1 -0
  55. package/dist/4652.js +1 -0
  56. package/dist/4674.js +1 -0
  57. package/dist/4674.js.map +1 -0
  58. package/dist/4947.js +1 -0
  59. package/dist/4947.js.map +1 -0
  60. package/dist/5015.js +1 -0
  61. package/dist/5015.js.map +1 -0
  62. package/dist/5422.js +1 -0
  63. package/dist/5422.js.map +1 -0
  64. package/dist/5428.js +1 -0
  65. package/dist/5428.js.map +1 -0
  66. package/dist/5752.js +1 -0
  67. package/dist/5752.js.map +1 -0
  68. package/dist/5851.js +1 -0
  69. package/dist/5851.js.map +1 -0
  70. package/dist/6264.js +1 -0
  71. package/dist/6264.js.map +1 -0
  72. package/dist/6540.js +2 -0
  73. package/dist/6540.js.map +1 -0
  74. package/dist/6606.js +1 -0
  75. package/dist/6606.js.map +1 -0
  76. package/dist/693.js +1 -0
  77. package/dist/693.js.map +1 -0
  78. package/dist/6991.js +1 -0
  79. package/dist/6991.js.map +1 -0
  80. package/dist/7199.js +1 -0
  81. package/dist/7199.js.map +1 -0
  82. package/dist/7255.js +1 -0
  83. package/dist/7255.js.map +1 -0
  84. package/dist/7258.js +1 -0
  85. package/dist/7258.js.map +1 -0
  86. package/dist/7420.js +1 -0
  87. package/dist/7420.js.map +1 -0
  88. package/dist/8114.js +1 -0
  89. package/dist/8114.js.map +1 -0
  90. package/dist/8339.js +1 -0
  91. package/dist/8339.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 -0
  107. package/dist/esm-dha-workflow-app.js.buildmanifest.json +1546 -0
  108. package/dist/esm-dha-workflow-app.js.map +1 -0
  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 +11 -4
  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 +95 -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 +409 -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 +1371 -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 +85 -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 +330 -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 +186 -32
  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 +54 -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 +147 -0
  185. package/src/dashboard/overview/overview.component.tsx +115 -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/mch-dashboard.meta.ts +6 -0
  195. package/src/dashboard-meta/pharmacy-dashboard.meta.ts +6 -0
  196. package/src/dashboard-meta/queue-dashboard.meta.ts +6 -0
  197. package/src/dashboard-meta/registers-dashboard.meta.ts +6 -0
  198. package/src/dashboard-meta/registry-dashboard.meta.ts +6 -0
  199. package/src/dashboard-meta/service-queue-admin.meta.ts +6 -0
  200. package/src/dashboard-meta/triage-dashboard.meta.ts +6 -0
  201. package/src/hooks/useActions.ts +165 -0
  202. package/src/index.ts +113 -1
  203. package/src/laboratory/laboratory.component.tsx +13 -0
  204. package/src/left-panel/left-panel.component.tsx +0 -2
  205. package/src/mch/mch-queues.component.scss +7 -0
  206. package/src/mch/mch-queues.component.tsx +32 -0
  207. package/src/mch/queues/consultation/mch-consultation.tsx +18 -0
  208. package/src/mch/queues/triage/mch-triage.tsx +15 -0
  209. package/src/modals/sign-off-modal.scss +7 -0
  210. package/src/modals/sign-off-modal.tsx +52 -0
  211. package/src/mortuary/mortuary.component.tsx +13 -0
  212. package/src/pharmacy/pharmacy.component.tsx +13 -0
  213. package/src/registers/registers.component.tsx +8 -0
  214. package/src/registry/eligibility/eliigibility-tags/eligibility-tags.scss +6 -0
  215. package/src/registry/eligibility/eliigibility-tags/eligibility-tags.tsx +137 -0
  216. package/src/registry/eligibility/modal/eligibility-details.modal.scss +38 -0
  217. package/src/registry/eligibility/modal/eligibility-details.modal.tsx +131 -0
  218. package/src/registry/modal/client-details-modal/client-details-modal.tsx +9 -26
  219. package/src/registry/modal/otp-verification-modal/otp-verification-modal.scss +31 -1
  220. package/src/registry/modal/otp-verification-modal/otp-verification-modal.tsx +145 -58
  221. package/src/registry/modal/send-to-triage/send-to-triage.modal.scss +16 -1
  222. package/src/registry/modal/send-to-triage/send-to-triage.modal.tsx +681 -97
  223. package/src/registry/payment-details/payment-options/payment-options.scss +13 -0
  224. package/src/registry/payment-details/payment-options/payment-options.tsx +61 -14
  225. package/src/registry/registry.component.scss +18 -1
  226. package/src/registry/registry.component.tsx +242 -111
  227. package/src/registry/registry.resource.ts +8 -5
  228. package/src/registry/types/index.ts +179 -1
  229. package/src/registry/utils/error-handler.ts +33 -0
  230. package/src/registry/utils/format-dependant-display-data.ts +8 -0
  231. package/src/registry/utils/hie-client-adapter.ts +312 -0
  232. package/src/registry/utils/mask-data.ts +11 -0
  233. package/src/resources/dashboard.resource.ts +20 -0
  234. package/src/resources/hie-amrs-automatic-registration.service.ts +16 -0
  235. package/src/resources/identifier-types.ts +29 -0
  236. package/src/resources/patient-resource.ts +62 -0
  237. package/src/resources/queue.resource.ts +23 -0
  238. package/src/resources/superset.resource.ts +20 -0
  239. package/src/resources/visit.resource.ts +19 -1
  240. package/src/root.component.tsx +32 -6
  241. package/src/routes.json +215 -7
  242. package/src/service-queues/action-button.component.tsx +34 -0
  243. package/src/service-queues/action-overflow-menu-item.component.tsx +34 -0
  244. package/src/service-queues/admin/queue/modal/create-queue/create-queue.modal.scss +31 -0
  245. package/src/service-queues/admin/queue/modal/create-queue/create-queue.modal.tsx +142 -0
  246. package/src/service-queues/admin/queue/modal/edit-queue/edit-queue.modal.scss +0 -0
  247. package/src/service-queues/admin/queue/modal/edit-queue/edit-queue.modal.tsx +150 -0
  248. package/src/service-queues/admin/queue/queue-list/queue-list.scss +33 -0
  249. package/src/service-queues/admin/queue/queue-list/queue-list.tsx +113 -0
  250. package/src/service-queues/admin/queue-entry/queue-entry-list.component.scss +6 -0
  251. package/src/service-queues/admin/queue-entry/queue-entry-list.component.tsx +137 -0
  252. package/src/service-queues/admin/queue-room/modal/create-queue-room/create-queue-room.modal.scss +31 -0
  253. package/src/service-queues/admin/queue-room/modal/create-queue-room/create-queue-room.modal.tsx +137 -0
  254. package/src/service-queues/admin/queue-room/modal/edit-queue-room/edit-queue-room.modal.scss +0 -0
  255. package/src/service-queues/admin/queue-room/modal/edit-queue-room/edit-queue-room.modal.tsx +146 -0
  256. package/src/service-queues/admin/queue-room/queue-room-list/queue-room-list.scss +22 -0
  257. package/src/service-queues/admin/queue-room/queue-room-list/queue-room-list.tsx +120 -0
  258. package/src/service-queues/admin/service-queue-admin-dashboard.component.scss +6 -0
  259. package/src/service-queues/admin/service-queue-admin-dashboard.component.tsx +34 -0
  260. package/src/service-queues/consultation/consultation.component.scss +7 -0
  261. package/src/service-queues/consultation/consultation.component.tsx +15 -0
  262. package/src/service-queues/extensions/service-queue-patient-banner/service-queue-patient-banner.scss +30 -0
  263. package/src/service-queues/extensions/service-queue-patient-banner/service-queue-patient-banner.tsx +108 -0
  264. package/src/service-queues/metrics/metrics-cards/attended-patients.extension.tsx +38 -0
  265. package/src/service-queues/metrics/metrics-cards/metrics-card.component.tsx +86 -0
  266. package/src/service-queues/metrics/metrics-cards/metrics-card.scss +106 -0
  267. package/src/service-queues/metrics/metrics-cards/waiting-patients.extension.tsx +34 -0
  268. package/src/service-queues/metrics/metrics-container.component.tsx +23 -0
  269. package/src/service-queues/metrics/metrics-container.scss +36 -0
  270. package/src/service-queues/metrics/metrics.resource.ts +65 -0
  271. package/src/service-queues/modals/daily-report-patient-list/daily-report-patient-list.scss +26 -0
  272. package/src/service-queues/modals/daily-report-patient-list/daily-report-patient-list.tsx +108 -0
  273. package/src/service-queues/modals/move/move-patient.component.scss +35 -0
  274. package/src/service-queues/modals/move/move-patient.component.tsx +152 -0
  275. package/src/service-queues/modals/serve/serve-patient.comppnent.scss +0 -0
  276. package/src/service-queues/modals/serve/serve-patient.comppnent.tsx +80 -0
  277. package/src/service-queues/modals/sign-off/sign-off.modal.scss +0 -0
  278. package/src/service-queues/modals/sign-off/sign-off.modal.tsx +79 -0
  279. package/src/service-queues/modals/transition/transition-patient.component.scss +0 -0
  280. package/src/service-queues/modals/transition/transition-patient.component.tsx +122 -0
  281. package/src/service-queues/queue-list/check-in.service.ts +26 -0
  282. package/src/service-queues/queue-list/queue-list.component.scss +36 -0
  283. package/src/service-queues/queue-list/queue-list.component.tsx +249 -0
  284. package/src/service-queues/queue-room.component.tsx +39 -0
  285. package/src/service-queues/room/room.component.tsx +58 -0
  286. package/src/service-queues/service-queue/service-queue.component.scss +14 -0
  287. package/src/service-queues/service-queue/service-queue.component.tsx +399 -0
  288. package/src/service-queues/service-queue/stats/stat-details/stat-details.component.scss +12 -0
  289. package/src/service-queues/service-queue/stats/stat-details/stat-details.component.tsx +63 -0
  290. package/src/service-queues/service-queue.scss +27 -0
  291. package/src/service-queues/service-queue.tsx +37 -0
  292. package/src/service-queues/service-queues.resource.ts +361 -0
  293. package/src/service-queues/service.resource.ts +28 -0
  294. package/src/shared/constants/civil-status.ts +29 -0
  295. package/src/shared/constants/concepts.ts +15 -0
  296. package/src/shared/constants/index.ts +1 -2
  297. package/src/shared/constants/patient-category.ts +6 -0
  298. package/src/shared/constants/person-attributes.ts +33 -0
  299. package/src/shared/constants/visit-types.ts +7 -0
  300. package/src/shared/services/billing.resource.ts +38 -0
  301. package/src/shared/services/client-payment-mode.resource.ts +27 -0
  302. package/src/shared/services/client-payment.resource.ts +17 -0
  303. package/src/shared/services/eligibility.resource.ts +19 -0
  304. package/src/shared/services/encounters.resource.ts +27 -0
  305. package/src/shared/services/location.resource.ts +9 -0
  306. package/src/shared/types/index.ts +152 -0
  307. package/src/shared/ui/aggregate-stat-card/aggregate-stat-card.scss +42 -0
  308. package/src/shared/ui/aggregate-stat-card/aggregate-stat-card.tsx +42 -0
  309. package/src/shared/ui/confirm-modal/confirm.modal.scss +18 -0
  310. package/src/shared/ui/confirm-modal/confirm.modal.tsx +38 -0
  311. package/src/shared/ui/otp-input/otp-input.component.scss +14 -0
  312. package/src/shared/ui/otp-input/otp-input.component.tsx +90 -0
  313. package/src/shared/ui/stat-card/stat-card.component.scss +10 -0
  314. package/src/shared/ui/stat-card/stat-card.component.tsx +26 -0
  315. package/src/shared/ui/timer/timer.component.scss +5 -0
  316. package/src/shared/ui/timer/timer.component.tsx +40 -0
  317. package/src/shared/utils/get-base-url.ts +27 -0
  318. package/src/shared/utils/get-tag-type.ts +66 -0
  319. package/src/side-nav-menu/nav-link-config.ts +6 -4
  320. package/src/triage/metrics/attended-patients.extension.tsx +42 -0
  321. package/src/triage/metrics/metrics.scss +36 -0
  322. package/src/triage/metrics/triage-metrics.component.tsx +21 -0
  323. package/src/triage/metrics/waiting-patients.extension.tsx +39 -0
  324. package/src/triage/room/room.scss +29 -0
  325. package/src/triage/triage.component.tsx +15 -0
  326. package/src/triage/triage.resource.ts +19 -0
  327. package/src/triage/types.ts +16 -0
  328. package/src/types/types.ts +180 -0
  329. package/dist/16.js +0 -1
  330. package/dist/16.js.map +0 -1
  331. package/dist/184.js +0 -2
  332. package/dist/184.js.map +0 -1
  333. package/dist/197.js +0 -1
  334. package/dist/198.js +0 -2
  335. package/dist/198.js.map +0 -1
  336. package/dist/200.js +0 -2
  337. package/dist/200.js.map +0 -1
  338. package/dist/255.js +0 -1
  339. package/dist/255.js.map +0 -1
  340. package/dist/300.js +0 -1
  341. package/dist/335.js +0 -1
  342. package/dist/353.js +0 -1
  343. package/dist/353.js.map +0 -1
  344. package/dist/420.js +0 -1
  345. package/dist/420.js.map +0 -1
  346. package/dist/540.js +0 -2
  347. package/dist/540.js.map +0 -1
  348. package/dist/55.js +0 -1
  349. package/dist/652.js +0 -1
  350. package/dist/860.js +0 -1
  351. package/dist/860.js.map +0 -1
  352. package/dist/91.js +0 -1
  353. package/dist/91.js.map +0 -1
  354. package/dist/93.js +0 -1
  355. package/dist/93.js.map +0 -1
  356. package/dist/99.js +0 -1
  357. package/dist/openmrs-esm-home-app.js +0 -1
  358. package/dist/openmrs-esm-home-app.js.buildmanifest.json +0 -626
  359. package/dist/openmrs-esm-home-app.js.map +0 -1
  360. package/src/consultation/consultation.tsx +0 -7
  361. /package/dist/{184.js.LICENSE.txt → 3184.js.LICENSE.txt} +0 -0
  362. /package/dist/{540.js.LICENSE.txt → 6540.js.LICENSE.txt} +0 -0
@@ -0,0 +1,399 @@
1
+ import React, { useEffect, useMemo, useState } from 'react';
2
+ import { type QueueEntryResult } from '../../registry/types';
3
+ import { showSnackbar, useSession } from '@openmrs/esm-framework';
4
+ import {
5
+ closeQueueEntry,
6
+ getServiceQueueByLocationUuid,
7
+ getServiceQueueDailyPatientListReport,
8
+ getServiceQueueDailyReport,
9
+ } from '../service-queues.resource';
10
+ import { Button, InlineLoading, Tab, TabList, TabPanel, TabPanels, Tabs } from '@carbon/react';
11
+ import QueueList from '../queue-list/queue-list.component';
12
+ import styles from './service-queue.component.scss';
13
+ import MovePatientModal from '../modals/move/move-patient.component';
14
+ import TransitionPatientModal from '../modals/transition/transition-patient.component';
15
+ import ServePatientModal from '../modals/serve/serve-patient.comppnent';
16
+ import StatDetails from './stats/stat-details/stat-details.component';
17
+ import SignOffEntryModal from '../modals/sign-off/sign-off.modal';
18
+ import { endVisit } from '../../resources/visit.resource';
19
+ import { QUEUE_SERVICE_UUIDS } from '../../shared/constants/concepts';
20
+ import ConfirmModal from '../../shared/ui/confirm-modal/confirm.modal';
21
+ import { type ServiceQueueReportPatientList, type ServiceQueueDailyReport } from '../../shared/types';
22
+ import DailyReportPatientListModal from '../modals/daily-report-patient-list/daily-report-patient-list';
23
+
24
+ interface ServiceQueueComponentProps {
25
+ serviceTypeUuid: string;
26
+ title: string;
27
+ }
28
+
29
+ const ServiceQueueComponent: React.FC<ServiceQueueComponentProps> = ({ serviceTypeUuid, title }) => {
30
+ const [queueEntries, setQueueEntries] = useState<QueueEntryResult[]>([]);
31
+ const [queueEntryDailyReport, setQueueEntryDailyReport] = useState<ServiceQueueDailyReport[]>([]);
32
+ const [queueEntryDailyReportPatientList, setQueueEntryDailyReportPatientList] = useState<
33
+ ServiceQueueReportPatientList[]
34
+ >([]);
35
+ const [selectedQueueEntry, setSelectedQueueEntry] = useState<QueueEntryResult>();
36
+ const [displayMoveModal, setDisplayMoveModal] = useState<boolean>(false);
37
+ const [displayTransitionModal, setDisplayTransitionModal] = useState<boolean>(false);
38
+ const [displayServeModal, setDisplayServeModal] = useState<boolean>(false);
39
+ const [displaySignOffModal, setDisplaySignOffModal] = useState<boolean>(false);
40
+ const [displayConfirmClearQueueModal, setDisplayConfirmClearQueueModal] = useState<boolean>(false);
41
+ const [queueEntryToClear, setQueueEntryToClear] = useState<QueueEntryResult[]>();
42
+ const [displayDailyReportPatientListModal, setDisplayDailyReportPatientListModal] = useState<boolean>(false);
43
+ const [loading, setLoading] = useState<boolean>(false);
44
+ const session = useSession();
45
+ const locationUuid = session.sessionLocation.uuid;
46
+
47
+ const groupEntriesByRooms = () => {
48
+ const roomEntries = {};
49
+ if (!queueEntries || queueEntries.length === 0) return {};
50
+ queueEntries.forEach((qe) => {
51
+ const room = qe.queue_room;
52
+ if (!roomEntries[room]) {
53
+ roomEntries[room] = [qe];
54
+ } else {
55
+ roomEntries[room].push(qe);
56
+ }
57
+ });
58
+ return roomEntries;
59
+ };
60
+
61
+ const groupedByRoom: { [key: string]: QueueEntryResult[] } = useMemo(() => groupEntriesByRooms(), [queueEntries]);
62
+
63
+ useEffect(() => {
64
+ if (serviceTypeUuid && locationUuid) {
65
+ getEntryQueues();
66
+ getEntryQueueDailyReport();
67
+ fetchStatsPatientList();
68
+ }
69
+ }, [serviceTypeUuid, locationUuid]);
70
+
71
+ const filterOutClients = (queueEntries: QueueEntryResult[]) => {
72
+ if (!queueEntries) {
73
+ return [];
74
+ }
75
+ return queueEntries.filter((q) => {
76
+ if ('hide_in_queue' in q) {
77
+ return q.hide_in_queue === 0;
78
+ } else {
79
+ return true;
80
+ }
81
+ });
82
+ };
83
+
84
+ const getEntryQueues = async () => {
85
+ setLoading(true);
86
+ try {
87
+ const res = await getServiceQueueByLocationUuid(serviceTypeUuid, locationUuid);
88
+ const queueClients = filterOutClients(res);
89
+ setQueueEntries(queueClients);
90
+ setLoading(false);
91
+ } catch (error) {
92
+ showSnackbar({
93
+ kind: 'error',
94
+ title: 'Error fetching queue',
95
+ subtitle: 'An error occurred while fetching the queue. Please reload or contact support',
96
+ });
97
+ }
98
+ };
99
+
100
+ const getEntryQueueDailyReport = async () => {
101
+ setLoading(true);
102
+ try {
103
+ const res = await getServiceQueueDailyReport(serviceTypeUuid, locationUuid);
104
+ setQueueEntryDailyReport(res);
105
+ setLoading(false);
106
+ } catch (error) {
107
+ showSnackbar({
108
+ kind: 'error',
109
+ title: 'Error fetching queue daily report',
110
+ subtitle: 'An error occurred while fetching the queue daily report. Please reload or contact support',
111
+ });
112
+ }
113
+ };
114
+
115
+ if (!groupedByRoom) {
116
+ return <>No Data to Display</>;
117
+ }
118
+ const handleMovePatient = (queueEntry: QueueEntryResult) => {
119
+ setDisplayMoveModal(true);
120
+ setSelectedQueueEntry(queueEntry);
121
+ };
122
+ const handleModalCloes = () => {
123
+ setDisplayMoveModal(false);
124
+ setDisplayTransitionModal(false);
125
+ setDisplayServeModal(false);
126
+ handleRefresh();
127
+ };
128
+
129
+ const handleTransitionPatient = (queueEntry: QueueEntryResult) => {
130
+ setDisplayTransitionModal(true);
131
+ setSelectedQueueEntry(queueEntry);
132
+ };
133
+
134
+ const handleServePatient = (queueEntry: QueueEntryResult) => {
135
+ setDisplayServeModal(true);
136
+ setSelectedQueueEntry(queueEntry);
137
+ };
138
+
139
+ const navigateToPatientChart = () => {
140
+ if (selectedQueueEntry && selectedQueueEntry.patient_uuid) {
141
+ window.location.href = `${window.spaBase}/patient/${selectedQueueEntry.patient_uuid}/chart`;
142
+ }
143
+ };
144
+
145
+ const handleSuccessfullServe = () => {
146
+ handleModalCloes();
147
+ navigateToPatientChart();
148
+ };
149
+
150
+ const handleSignOff = (queueEntry: QueueEntryResult) => {
151
+ setDisplaySignOffModal(true);
152
+ setSelectedQueueEntry(queueEntry);
153
+ };
154
+
155
+ const onSuccessfullSignOff = () => {
156
+ setDisplaySignOffModal(false);
157
+ handleRefresh();
158
+ };
159
+
160
+ const handleRefresh = () => {
161
+ getEntryQueues();
162
+ };
163
+
164
+ const handleRemovePatient = async (queueEntryResult: QueueEntryResult) => {
165
+ try {
166
+ await closeQueueEntry(queueEntryResult.queue_entry_uuid);
167
+ showSnackbar({
168
+ kind: 'success',
169
+ title: 'Patient removal from queue successfully!',
170
+ subtitle: '',
171
+ });
172
+ await endVisit(queueEntryResult.visit_uuid, {
173
+ stopDatetime: new Date().toISOString(),
174
+ });
175
+ showSnackbar({
176
+ kind: 'success',
177
+ title: 'Visit Ended successfully!',
178
+ subtitle: '',
179
+ });
180
+ handleRefresh();
181
+ } catch (e) {
182
+ showSnackbar({
183
+ kind: 'error',
184
+ title: 'Patient removal from queue failed!',
185
+ subtitle: e.message ?? '',
186
+ });
187
+ }
188
+ };
189
+ const handleClearQueue = async (queueEntries: QueueEntryResult[]) => {
190
+ setQueueEntryToClear(queueEntries);
191
+ setDisplayConfirmClearQueueModal(true);
192
+ };
193
+
194
+ const clearQueue = async () => {
195
+ for (let i = 0; i < queueEntryToClear.length; i++) {
196
+ const queueEntryResult = queueEntries[i];
197
+ await closeQueue(queueEntryResult);
198
+ }
199
+ };
200
+
201
+ const closeQueue = async (queueEntryResult: QueueEntryResult) => {
202
+ try {
203
+ await closeQueueEntry(queueEntryResult.queue_entry_uuid);
204
+ await endVisit(queueEntryResult.visit_uuid, {
205
+ stopDatetime: new Date().toISOString(),
206
+ });
207
+ showSnackbar({
208
+ kind: 'success',
209
+ title: 'Queue entry successfully closed',
210
+ subtitle: `Queue entry ${queueEntryResult.queue_id} successfully closed`,
211
+ });
212
+ } catch (error) {
213
+ showSnackbar({
214
+ kind: 'error',
215
+ title: 'Queue entry close failrure',
216
+ subtitle: `Queue entry ${queueEntryResult.queue_id} could not be closed. Please retry of contact support`,
217
+ });
218
+ }
219
+ };
220
+
221
+ const handleConfirmClearQueue = () => {
222
+ setDisplayConfirmClearQueueModal(false);
223
+ clearQueue();
224
+ setQueueEntryToClear([]);
225
+ handleRefresh();
226
+ };
227
+
228
+ const handleCloseConfirmClearQueueModal = () => {
229
+ setDisplayConfirmClearQueueModal(false);
230
+ setQueueEntryToClear([]);
231
+ };
232
+
233
+ const fetchStatsPatientList = async () => {
234
+ try {
235
+ const resp = await getServiceQueueDailyPatientListReport(serviceTypeUuid, locationUuid);
236
+ setQueueEntryDailyReportPatientList(resp);
237
+ } catch (error) {
238
+ showSnackbar({
239
+ kind: 'error',
240
+ title: 'Error fetching patient list',
241
+ subtitle: 'An error ocuured while fetching the service queue checked in patient list',
242
+ });
243
+ }
244
+ };
245
+
246
+ const getStatsPatientList = () => {
247
+ showDailiyReportPatientListModal();
248
+ };
249
+ const handleCloseDailiyReportPatientListModal = () => {
250
+ setDisplayDailyReportPatientListModal(false);
251
+ };
252
+ const showDailiyReportPatientListModal = () => {
253
+ setDisplayDailyReportPatientListModal(true);
254
+ };
255
+
256
+ if (!serviceTypeUuid) {
257
+ return <>No service type defined</>;
258
+ }
259
+
260
+ return (
261
+ <>
262
+ <div className={styles.consultationLayout}>
263
+ <div className={styles.headerSection}>
264
+ <h4>{title}</h4>
265
+ </div>
266
+ <div>
267
+ {queueEntries ? (
268
+ <>
269
+ <StatDetails
270
+ queueEntries={queueEntries}
271
+ report={queueEntryDailyReport}
272
+ onStatDetailsRequest={getStatsPatientList}
273
+ />
274
+ </>
275
+ ) : (
276
+ <></>
277
+ )}
278
+ </div>
279
+ <div className={styles.headerAction}>
280
+ <Button kind="tertiary" onClick={handleRefresh} disabled={loading}>
281
+ {loading ? <InlineLoading description="Refreshing..." /> : 'Refresh'}
282
+ </Button>
283
+ </div>
284
+
285
+ <div className={styles.contentSection}>
286
+ <Tabs>
287
+ <TabList contained>
288
+ {groupedByRoom &&
289
+ Object.keys(groupedByRoom).map((key) => {
290
+ return <Tab>{key}</Tab>;
291
+ })}
292
+ </TabList>
293
+ <TabPanels>
294
+ {groupedByRoom &&
295
+ Object.keys(groupedByRoom).map((key) => {
296
+ return (
297
+ <TabPanel>
298
+ {
299
+ <QueueList
300
+ queueRoom={key}
301
+ queueEntries={groupedByRoom[key]}
302
+ handleMovePatient={handleMovePatient}
303
+ handleTransitionPatient={handleTransitionPatient}
304
+ handleServePatient={handleServePatient}
305
+ handleSignOff={handleSignOff}
306
+ handleRemovePatient={handleRemovePatient}
307
+ showComingFromCol={serviceTypeUuid !== QUEUE_SERVICE_UUIDS.TRIAGE_SERVICE_UUID}
308
+ handleClearQueue={handleClearQueue}
309
+ />
310
+ }
311
+ </TabPanel>
312
+ );
313
+ })}
314
+ </TabPanels>
315
+ </Tabs>
316
+ </div>
317
+ </div>
318
+ {displayMoveModal && selectedQueueEntry ? (
319
+ <>
320
+ <MovePatientModal
321
+ open={displayMoveModal}
322
+ locationUuid={locationUuid}
323
+ onModalClose={handleModalCloes}
324
+ currentQueueEntryUuid={selectedQueueEntry.queue_entry_uuid}
325
+ onTransferSuccess={handleModalCloes}
326
+ />
327
+ </>
328
+ ) : (
329
+ <></>
330
+ )}
331
+
332
+ {displayTransitionModal ? (
333
+ <>
334
+ <TransitionPatientModal
335
+ open={displayTransitionModal}
336
+ onModalClose={handleModalCloes}
337
+ currentQueueEntry={selectedQueueEntry}
338
+ />
339
+ </>
340
+ ) : (
341
+ <></>
342
+ )}
343
+
344
+ {displayServeModal ? (
345
+ <>
346
+ <ServePatientModal
347
+ open={displayServeModal}
348
+ onModalClose={handleModalCloes}
349
+ currentQueueEntry={selectedQueueEntry}
350
+ onSuccessfullServe={handleSuccessfullServe}
351
+ />
352
+ </>
353
+ ) : (
354
+ <></>
355
+ )}
356
+
357
+ {displaySignOffModal ? (
358
+ <>
359
+ <SignOffEntryModal
360
+ open={displaySignOffModal}
361
+ onModalClose={handleModalCloes}
362
+ currentQueueEntry={selectedQueueEntry}
363
+ onSuccessfullSignOff={onSuccessfullSignOff}
364
+ />
365
+ </>
366
+ ) : (
367
+ <></>
368
+ )}
369
+
370
+ {displayConfirmClearQueueModal ? (
371
+ <>
372
+ <ConfirmModal
373
+ open={displayConfirmClearQueueModal}
374
+ onConfirm={handleConfirmClearQueue}
375
+ onModalClose={handleCloseConfirmClearQueueModal}
376
+ title="Clear Queue"
377
+ subtitle="You are about to clear the patient queue and their respective visits. Are you sure?"
378
+ />
379
+ </>
380
+ ) : (
381
+ <></>
382
+ )}
383
+
384
+ {displayDailyReportPatientListModal && queueEntryDailyReportPatientList ? (
385
+ <>
386
+ <DailyReportPatientListModal
387
+ open={displayDailyReportPatientListModal}
388
+ onModalClose={handleCloseDailiyReportPatientListModal}
389
+ patientList={queueEntryDailyReportPatientList}
390
+ />
391
+ </>
392
+ ) : (
393
+ <></>
394
+ )}
395
+ </>
396
+ );
397
+ };
398
+
399
+ export default ServiceQueueComponent;
@@ -0,0 +1,12 @@
1
+ .statsSection{
2
+ display: flex;
3
+ flex-direction: row;
4
+ width: 100%;
5
+ column-gap: 15px;
6
+ margin-bottom: 15px;
7
+ .aggregate{
8
+ display: flex;
9
+ flex-direction: column;
10
+ width: 50%;
11
+ }
12
+ }
@@ -0,0 +1,63 @@
1
+ import React, { useMemo } from 'react';
2
+ import styles from './stat-details.component.scss';
3
+ import { type QueueEntryResult } from '../../../../registry/types';
4
+ import StatCard from '../../../../shared/ui/stat-card/stat-card.component';
5
+ import { type ServiceQueueDailyReport } from '../../../../shared/types';
6
+ import AgregateStatCard from '../../../../shared/ui/aggregate-stat-card/aggregate-stat-card';
7
+
8
+ interface StatDetailsProps {
9
+ queueEntries: QueueEntryResult[];
10
+ report: ServiceQueueDailyReport[];
11
+ onStatDetailsRequest: () => void;
12
+ }
13
+
14
+ const StatDetails: React.FC<StatDetailsProps> = ({ queueEntries, report, onStatDetailsRequest }) => {
15
+ const patientsInWaiting = useMemo(() => getCategoryTotal(['WAITING']), [queueEntries]);
16
+ const patientsAttendedTo = useMemo(() => getCategoryTotal(['IN SERVICE', 'COMPLETED']), [queueEntries]);
17
+ const patientsCheckedIn = useMemo(() => getTotalCheckedIn(), [report]);
18
+ const aggregateStats = useMemo(() => getAggregateStats(), [report]);
19
+ if (!queueEntries) {
20
+ return 'No queue entry records';
21
+ }
22
+ function getCategoryTotal(categories: string[]) {
23
+ let total = 0;
24
+ queueEntries.forEach((q) => {
25
+ if (categories.includes(q.status)) {
26
+ total += 1;
27
+ }
28
+ });
29
+ return total;
30
+ }
31
+ function getTotalCheckedIn() {
32
+ let total = 0;
33
+ report.forEach((r) => {
34
+ total += r.patients;
35
+ });
36
+ return total;
37
+ }
38
+ function getAggregateStats() {
39
+ return report.map((r) => {
40
+ return {
41
+ title: r.queue_room_name,
42
+ count: r.patients,
43
+ };
44
+ });
45
+ }
46
+
47
+ return (
48
+ <div className={styles.statsSection}>
49
+ <div className={styles.aggregate}>
50
+ <AgregateStatCard
51
+ title="Total Checked In"
52
+ totalCount={patientsCheckedIn ?? 0}
53
+ stats={aggregateStats}
54
+ onStatDetailsRequest={onStatDetailsRequest}
55
+ />
56
+ </div>
57
+ <StatCard title="Patients in waiting" count={patientsInWaiting ?? 0} />
58
+ <StatCard title="Patients attended to" count={patientsAttendedTo ?? 0} />
59
+ </div>
60
+ );
61
+ };
62
+
63
+ export default StatDetails;
@@ -0,0 +1,27 @@
1
+ @use '@carbon/layout';
2
+ @use '@openmrs/esm-styleguide/src/vars' as *;
3
+
4
+ .menuItem {
5
+ max-width: none;
6
+ }
7
+
8
+ .cardContainer {
9
+ background-color: $ui-02;
10
+ display: flex;
11
+ padding: layout.$spacing-05;
12
+ flex-flow: row wrap;
13
+ gap: layout.$spacing-05;
14
+ align-items: stretch;
15
+ }
16
+
17
+ .cardContainer > * {
18
+ flex: 1 0 0%;
19
+ min-width: 25rem;
20
+ max-width: 35rem;
21
+ }
22
+
23
+ .cardHeaderStack {
24
+ width: 100%;
25
+ justify-content: space-between;
26
+ align-items: center;
27
+ }
@@ -0,0 +1,37 @@
1
+ /* eslint-disable no-console */
2
+ import React, { useMemo } from 'react';
3
+ import MetricsContainer from './metrics/metrics-container.component';
4
+ import QueueRoom from './queue-room.component';
5
+ import { type QueueEntryAction } from '../config-schema';
6
+
7
+ interface ServiceQueueProps {
8
+ isTriage: boolean;
9
+ }
10
+ const ServiceQueue: React.FC<ServiceQueueProps> = ({ isTriage }) => {
11
+ const roomParams = useMemo(() => {
12
+ return isTriage
13
+ ? {
14
+ serviceUuid: 'triage-service-uuid',
15
+ overflowMenuKeys: ['call', 'transition', 'edit', 'remove', 'undo'] as QueueEntryAction[],
16
+ defaultMenuKey: 'call' as QueueEntryAction,
17
+ }
18
+ : {
19
+ serviceUuid: '7f7ec7ad-cdd7-4ed9-bc2e-5c5bd9f065b2',
20
+ overflowMenuKeys: ['move', 'transition', 'signOff', 'edit', 'remove', 'undo'] as QueueEntryAction[],
21
+ defaultMenuKey: 'move' as QueueEntryAction,
22
+ };
23
+ }, [isTriage]);
24
+
25
+ return (
26
+ <>
27
+ <MetricsContainer />
28
+ <QueueRoom
29
+ serviceUuid={roomParams.serviceUuid}
30
+ overflowMenuKeys={roomParams.overflowMenuKeys}
31
+ defaultMenuKey={roomParams.defaultMenuKey}
32
+ />
33
+ </>
34
+ );
35
+ };
36
+
37
+ export default ServiceQueue;