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

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 (364) 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/3654.js +1 -0
  41. package/dist/3654.js.map +1 -0
  42. package/dist/4055.js +1 -0
  43. package/dist/4205.js +1 -0
  44. package/dist/4205.js.map +1 -0
  45. package/dist/4225.js +1 -0
  46. package/dist/4225.js.map +1 -0
  47. package/dist/4300.js +1 -0
  48. package/dist/4335.js +1 -0
  49. package/dist/4353.js +1 -0
  50. package/dist/4353.js.map +1 -0
  51. package/dist/4517.js +1 -0
  52. package/dist/4517.js.map +1 -0
  53. package/dist/4652.js +1 -0
  54. package/dist/4674.js +1 -0
  55. package/dist/4674.js.map +1 -0
  56. package/dist/4947.js +1 -0
  57. package/dist/4947.js.map +1 -0
  58. package/dist/5015.js +1 -0
  59. package/dist/5015.js.map +1 -0
  60. package/dist/5422.js +1 -0
  61. package/dist/5422.js.map +1 -0
  62. package/dist/5428.js +1 -0
  63. package/dist/5428.js.map +1 -0
  64. package/dist/5752.js +1 -0
  65. package/dist/5752.js.map +1 -0
  66. package/dist/5851.js +1 -0
  67. package/dist/5851.js.map +1 -0
  68. package/dist/6264.js +1 -0
  69. package/dist/6264.js.map +1 -0
  70. package/dist/6540.js +2 -0
  71. package/dist/6540.js.map +1 -0
  72. package/dist/6606.js +1 -0
  73. package/dist/6606.js.map +1 -0
  74. package/dist/693.js +1 -0
  75. package/dist/693.js.map +1 -0
  76. package/dist/6991.js +1 -0
  77. package/dist/6991.js.map +1 -0
  78. package/dist/7076.js +1 -0
  79. package/dist/7076.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/7523.js +1 -0
  89. package/dist/7523.js.map +1 -0
  90. package/dist/8114.js +1 -0
  91. package/dist/8114.js.map +1 -0
  92. package/dist/8339.js +1 -0
  93. package/dist/8339.js.map +1 -0
  94. package/dist/8865.js +1 -0
  95. package/dist/8865.js.map +1 -0
  96. package/dist/8895.js +1 -0
  97. package/dist/8895.js.map +1 -0
  98. package/dist/9037.js +1 -0
  99. package/dist/9037.js.map +1 -0
  100. package/dist/9091.js +1 -0
  101. package/dist/9091.js.map +1 -0
  102. package/dist/9093.js +1 -0
  103. package/dist/9093.js.map +1 -0
  104. package/dist/9117.js +1 -0
  105. package/dist/9117.js.map +1 -0
  106. package/dist/9721.js +1 -0
  107. package/dist/9721.js.map +1 -0
  108. package/dist/esm-dha-workflow-app.js +1 -0
  109. package/dist/esm-dha-workflow-app.js.buildmanifest.json +1570 -0
  110. package/dist/esm-dha-workflow-app.js.map +1 -0
  111. package/dist/main.js +1 -1
  112. package/dist/main.js.map +1 -1
  113. package/dist/routes.json +1 -1
  114. package/package.json +11 -4
  115. package/src/accounting/accounting.component.tsx +13 -0
  116. package/src/admissions/admission-request-list/admission-request-list.scss +0 -0
  117. package/src/admissions/admission-request-list/admission-request-list.tsx +134 -0
  118. package/src/admissions/admissions-dashboard.component.scss +15 -0
  119. package/src/admissions/admissions-dashboard.component.tsx +160 -0
  120. package/src/admissions/admissions.resource.ts +101 -0
  121. package/src/admissions/admitted-list/admitted-patients-list.tsx +141 -0
  122. package/src/admissions/constants/index.ts +33 -0
  123. package/src/admissions/discharged-list/discharged-list.scss +0 -0
  124. package/src/admissions/discharged-list/discharged-list.tsx +58 -0
  125. package/src/admissions/inpatient/admission-history/patient-admission-history.tsx +76 -0
  126. package/src/admissions/inpatient/admission-requests/patient-admission-requests.scss +19 -0
  127. package/src/admissions/inpatient/admission-requests/patient-admission-requests.tsx +72 -0
  128. package/src/admissions/inpatient/inpatient-admissions.component.scss +7 -0
  129. package/src/admissions/inpatient/inpatient-admissions.component.tsx +46 -0
  130. package/src/admissions/modal/admit-elsewhere/admit-elsewhere.modal.scss +23 -0
  131. package/src/admissions/modal/admit-elsewhere/admit-elsewhere.modal.tsx +156 -0
  132. package/src/admissions/modal/admit-patient/admit-patient.modal.scss +0 -0
  133. package/src/admissions/modal/admit-patient/admit-patient.modal.tsx +109 -0
  134. package/src/admissions/modal/bed-swap/bed-swap.modal.scss +0 -0
  135. package/src/admissions/modal/bed-swap/bed-swap.modal.tsx +102 -0
  136. package/src/admissions/modal/cancel-admission-request/cancel-admission-request.scss +11 -0
  137. package/src/admissions/modal/cancel-admission-request/cancel-admission-request.tsx +105 -0
  138. package/src/admissions/modal/discharge/discharge-patient.modal.scss +13 -0
  139. package/src/admissions/modal/discharge/discharge-patient.modal.tsx +84 -0
  140. package/src/admissions/types/index.ts +192 -0
  141. package/src/appointments/appointments.component.tsx +13 -0
  142. package/src/billing/api/billing.api.ts +95 -0
  143. package/src/billing/billing-root.tsx +20 -0
  144. package/src/billing/dashboard/billingDashboard.component.scss +0 -0
  145. package/src/billing/dashboard/billingDashboard.component.tsx +25 -0
  146. package/src/billing/extensions/visit-billing/visit-billing.extension.scss +0 -0
  147. package/src/billing/extensions/visit-billing/visit-billing.extension.tsx +409 -0
  148. package/src/billing/invoice/bill.resource.ts +47 -0
  149. package/src/billing/invoice/invoice-header/header-card/header-card.scss +17 -0
  150. package/src/billing/invoice/invoice-header/header-card/header-card.tsx +21 -0
  151. package/src/billing/invoice/invoice.scss +113 -0
  152. package/src/billing/invoice/invoice.tsx +1371 -0
  153. package/src/billing/invoice/line-items/line-items.scss +0 -0
  154. package/src/billing/invoice/line-items/line-items.tsx +120 -0
  155. package/src/billing/invoice/modal/delete-bill-item/delete-bill-item.modal.scss +23 -0
  156. package/src/billing/invoice/modal/delete-bill-item/delete-bill-item.modal.tsx +114 -0
  157. package/src/billing/invoice/modal/edit-bill-item/edit-bill-item.modal.scss +0 -0
  158. package/src/billing/invoice/modal/edit-bill-item/edit-bill-item.modal.tsx +122 -0
  159. package/src/billing/invoice/payment-details/payment-details.scss +0 -0
  160. package/src/billing/invoice/payment-details/payment-details.tsx +43 -0
  161. package/src/billing/invoice/print-invoice/print-receipt.component.tsx +44 -0
  162. package/src/billing/invoice/print-invoice/print-receipt.scss +14 -0
  163. package/src/billing/types/index.ts +84 -0
  164. package/src/billing/utils/index.ts +17 -0
  165. package/src/billing/widgets/billingTotalsRow.component.scss +0 -0
  166. package/src/billing/widgets/billingTotalsRow.component.tsx +712 -0
  167. package/src/billing/workspaces/create-order-bill-form-workspace/create-order-bill-form.resource.ts +85 -0
  168. package/src/billing/workspaces/create-order-bill-form-workspace/create-order-bill-form.scss +58 -0
  169. package/src/billing/workspaces/create-order-bill-form-workspace/create-order-bill-form.workspace.tsx +330 -0
  170. package/src/billing/workspaces/create-order-bill-form-workspace/schema.ts +11 -0
  171. package/src/bookings/bookings.component.scss +7 -0
  172. package/src/bookings/bookings.component.tsx +31 -0
  173. package/src/bookings/daily/daily-bookings.component.scss +38 -0
  174. package/src/bookings/daily/daily-bookings.component.tsx +138 -0
  175. package/src/bookings/daily/daily-bookings.resource.ts +28 -0
  176. package/src/bookings/daily/filters/daily-bookings-filter.component.scss +15 -0
  177. package/src/bookings/daily/filters/daily-bookings-filter.component.tsx +80 -0
  178. package/src/bookings/daily/patient-list/daily-bookings-patient-list.component.tsx +97 -0
  179. package/src/bookings/types/index.ts +68 -0
  180. package/src/config-schema.ts +186 -32
  181. package/src/createDashboardLink.tsx +9 -0
  182. package/src/dashboard/charts/chart.component.scss +13 -0
  183. package/src/dashboard/charts/chart.component.tsx +54 -0
  184. package/src/dashboard/dashboard.component.scss +7 -0
  185. package/src/dashboard/dashboard.component.tsx +51 -0
  186. package/src/dashboard/overview/overview.component.scss +147 -0
  187. package/src/dashboard/overview/overview.component.tsx +115 -0
  188. package/src/dashboard/patient-list/patient-list.component.tsx +41 -0
  189. package/src/dashboard-meta/accounting-dashboard.meta.ts +6 -0
  190. package/src/dashboard-meta/admissions-dashboard.meta.ts +6 -0
  191. package/src/dashboard-meta/billing-dashboard.meta.ts +6 -0
  192. package/src/dashboard-meta/bookings-dashboard.meta.ts +6 -0
  193. package/src/dashboard-meta/consultation-dashboard.meta.ts +6 -0
  194. package/src/dashboard-meta/dha-workflow-dashboard.meta.ts +6 -0
  195. package/src/dashboard-meta/inpatient-admissions.meta.ts +6 -0
  196. package/src/dashboard-meta/mch-dashboard.meta.ts +6 -0
  197. package/src/dashboard-meta/pharmacy-dashboard.meta.ts +6 -0
  198. package/src/dashboard-meta/queue-dashboard.meta.ts +6 -0
  199. package/src/dashboard-meta/registers-dashboard.meta.ts +6 -0
  200. package/src/dashboard-meta/registry-dashboard.meta.ts +6 -0
  201. package/src/dashboard-meta/service-queue-admin.meta.ts +6 -0
  202. package/src/dashboard-meta/triage-dashboard.meta.ts +6 -0
  203. package/src/hooks/useActions.ts +165 -0
  204. package/src/index.ts +118 -1
  205. package/src/laboratory/laboratory.component.tsx +13 -0
  206. package/src/left-panel/left-panel.component.tsx +0 -2
  207. package/src/mch/mch-queues.component.scss +7 -0
  208. package/src/mch/mch-queues.component.tsx +32 -0
  209. package/src/mch/queues/consultation/mch-consultation.tsx +18 -0
  210. package/src/mch/queues/triage/mch-triage.tsx +15 -0
  211. package/src/modals/sign-off-modal.scss +7 -0
  212. package/src/modals/sign-off-modal.tsx +52 -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 +145 -58
  223. package/src/registry/modal/send-to-triage/send-to-triage.modal.scss +16 -1
  224. package/src/registry/modal/send-to-triage/send-to-triage.modal.tsx +681 -97
  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 +18 -1
  228. package/src/registry/registry.component.tsx +242 -111
  229. package/src/registry/registry.resource.ts +8 -5
  230. package/src/registry/types/index.ts +179 -1
  231. package/src/registry/utils/error-handler.ts +33 -0
  232. package/src/registry/utils/format-dependant-display-data.ts +8 -0
  233. package/src/registry/utils/hie-client-adapter.ts +312 -0
  234. package/src/registry/utils/mask-data.ts +11 -0
  235. package/src/resources/dashboard.resource.ts +20 -0
  236. package/src/resources/hie-amrs-automatic-registration.service.ts +16 -0
  237. package/src/resources/identifier-types.ts +29 -0
  238. package/src/resources/patient-resource.ts +62 -0
  239. package/src/resources/queue.resource.ts +23 -0
  240. package/src/resources/superset.resource.ts +20 -0
  241. package/src/resources/visit.resource.ts +19 -1
  242. package/src/root.component.tsx +32 -6
  243. package/src/routes.json +232 -7
  244. package/src/service-queues/action-button.component.tsx +34 -0
  245. package/src/service-queues/action-overflow-menu-item.component.tsx +34 -0
  246. package/src/service-queues/admin/queue/modal/create-queue/create-queue.modal.scss +31 -0
  247. package/src/service-queues/admin/queue/modal/create-queue/create-queue.modal.tsx +142 -0
  248. package/src/service-queues/admin/queue/modal/edit-queue/edit-queue.modal.scss +0 -0
  249. package/src/service-queues/admin/queue/modal/edit-queue/edit-queue.modal.tsx +150 -0
  250. package/src/service-queues/admin/queue/queue-list/queue-list.scss +33 -0
  251. package/src/service-queues/admin/queue/queue-list/queue-list.tsx +113 -0
  252. package/src/service-queues/admin/queue-entry/queue-entry-list.component.scss +6 -0
  253. package/src/service-queues/admin/queue-entry/queue-entry-list.component.tsx +137 -0
  254. package/src/service-queues/admin/queue-room/modal/create-queue-room/create-queue-room.modal.scss +31 -0
  255. package/src/service-queues/admin/queue-room/modal/create-queue-room/create-queue-room.modal.tsx +137 -0
  256. package/src/service-queues/admin/queue-room/modal/edit-queue-room/edit-queue-room.modal.scss +0 -0
  257. package/src/service-queues/admin/queue-room/modal/edit-queue-room/edit-queue-room.modal.tsx +146 -0
  258. package/src/service-queues/admin/queue-room/queue-room-list/queue-room-list.scss +22 -0
  259. package/src/service-queues/admin/queue-room/queue-room-list/queue-room-list.tsx +120 -0
  260. package/src/service-queues/admin/service-queue-admin-dashboard.component.scss +6 -0
  261. package/src/service-queues/admin/service-queue-admin-dashboard.component.tsx +34 -0
  262. package/src/service-queues/consultation/consultation.component.scss +7 -0
  263. package/src/service-queues/consultation/consultation.component.tsx +15 -0
  264. package/src/service-queues/extensions/service-queue-patient-banner/service-queue-patient-banner.scss +30 -0
  265. package/src/service-queues/extensions/service-queue-patient-banner/service-queue-patient-banner.tsx +108 -0
  266. package/src/service-queues/metrics/metrics-cards/attended-patients.extension.tsx +38 -0
  267. package/src/service-queues/metrics/metrics-cards/metrics-card.component.tsx +86 -0
  268. package/src/service-queues/metrics/metrics-cards/metrics-card.scss +106 -0
  269. package/src/service-queues/metrics/metrics-cards/waiting-patients.extension.tsx +34 -0
  270. package/src/service-queues/metrics/metrics-container.component.tsx +23 -0
  271. package/src/service-queues/metrics/metrics-container.scss +36 -0
  272. package/src/service-queues/metrics/metrics.resource.ts +65 -0
  273. package/src/service-queues/modals/daily-report-patient-list/daily-report-patient-list.scss +26 -0
  274. package/src/service-queues/modals/daily-report-patient-list/daily-report-patient-list.tsx +108 -0
  275. package/src/service-queues/modals/move/move-patient.component.scss +35 -0
  276. package/src/service-queues/modals/move/move-patient.component.tsx +152 -0
  277. package/src/service-queues/modals/serve/serve-patient.comppnent.scss +0 -0
  278. package/src/service-queues/modals/serve/serve-patient.comppnent.tsx +80 -0
  279. package/src/service-queues/modals/sign-off/sign-off.modal.scss +0 -0
  280. package/src/service-queues/modals/sign-off/sign-off.modal.tsx +79 -0
  281. package/src/service-queues/modals/transition/transition-patient.component.scss +0 -0
  282. package/src/service-queues/modals/transition/transition-patient.component.tsx +122 -0
  283. package/src/service-queues/queue-list/check-in.service.ts +26 -0
  284. package/src/service-queues/queue-list/queue-list.component.scss +36 -0
  285. package/src/service-queues/queue-list/queue-list.component.tsx +249 -0
  286. package/src/service-queues/queue-room.component.tsx +39 -0
  287. package/src/service-queues/room/room.component.tsx +58 -0
  288. package/src/service-queues/service-queue/service-queue.component.scss +14 -0
  289. package/src/service-queues/service-queue/service-queue.component.tsx +399 -0
  290. package/src/service-queues/service-queue/stats/stat-details/stat-details.component.scss +12 -0
  291. package/src/service-queues/service-queue/stats/stat-details/stat-details.component.tsx +63 -0
  292. package/src/service-queues/service-queue.scss +27 -0
  293. package/src/service-queues/service-queue.tsx +37 -0
  294. package/src/service-queues/service-queues.resource.ts +361 -0
  295. package/src/service-queues/service.resource.ts +28 -0
  296. package/src/shared/constants/civil-status.ts +29 -0
  297. package/src/shared/constants/concepts.ts +15 -0
  298. package/src/shared/constants/index.ts +1 -2
  299. package/src/shared/constants/patient-category.ts +6 -0
  300. package/src/shared/constants/person-attributes.ts +33 -0
  301. package/src/shared/constants/visit-types.ts +7 -0
  302. package/src/shared/services/billing.resource.ts +38 -0
  303. package/src/shared/services/client-payment-mode.resource.ts +27 -0
  304. package/src/shared/services/client-payment.resource.ts +17 -0
  305. package/src/shared/services/eligibility.resource.ts +19 -0
  306. package/src/shared/services/encounters.resource.ts +27 -0
  307. package/src/shared/services/location.resource.ts +9 -0
  308. package/src/shared/types/index.ts +152 -0
  309. package/src/shared/ui/aggregate-stat-card/aggregate-stat-card.scss +42 -0
  310. package/src/shared/ui/aggregate-stat-card/aggregate-stat-card.tsx +42 -0
  311. package/src/shared/ui/confirm-modal/confirm.modal.scss +18 -0
  312. package/src/shared/ui/confirm-modal/confirm.modal.tsx +38 -0
  313. package/src/shared/ui/otp-input/otp-input.component.scss +14 -0
  314. package/src/shared/ui/otp-input/otp-input.component.tsx +90 -0
  315. package/src/shared/ui/stat-card/stat-card.component.scss +10 -0
  316. package/src/shared/ui/stat-card/stat-card.component.tsx +26 -0
  317. package/src/shared/ui/timer/timer.component.scss +5 -0
  318. package/src/shared/ui/timer/timer.component.tsx +40 -0
  319. package/src/shared/utils/get-base-url.ts +27 -0
  320. package/src/shared/utils/get-tag-type.ts +66 -0
  321. package/src/side-nav-menu/nav-link-config.ts +6 -0
  322. package/src/triage/metrics/attended-patients.extension.tsx +42 -0
  323. package/src/triage/metrics/metrics.scss +36 -0
  324. package/src/triage/metrics/triage-metrics.component.tsx +21 -0
  325. package/src/triage/metrics/waiting-patients.extension.tsx +39 -0
  326. package/src/triage/room/room.scss +29 -0
  327. package/src/triage/triage.component.tsx +15 -0
  328. package/src/triage/triage.resource.ts +19 -0
  329. package/src/triage/types.ts +16 -0
  330. package/src/types/types.ts +180 -0
  331. package/dist/16.js +0 -1
  332. package/dist/16.js.map +0 -1
  333. package/dist/184.js +0 -2
  334. package/dist/184.js.map +0 -1
  335. package/dist/197.js +0 -1
  336. package/dist/198.js +0 -2
  337. package/dist/198.js.map +0 -1
  338. package/dist/200.js +0 -2
  339. package/dist/200.js.map +0 -1
  340. package/dist/255.js +0 -1
  341. package/dist/255.js.map +0 -1
  342. package/dist/300.js +0 -1
  343. package/dist/335.js +0 -1
  344. package/dist/353.js +0 -1
  345. package/dist/353.js.map +0 -1
  346. package/dist/420.js +0 -1
  347. package/dist/420.js.map +0 -1
  348. package/dist/540.js +0 -2
  349. package/dist/540.js.map +0 -1
  350. package/dist/55.js +0 -1
  351. package/dist/652.js +0 -1
  352. package/dist/860.js +0 -1
  353. package/dist/860.js.map +0 -1
  354. package/dist/91.js +0 -1
  355. package/dist/91.js.map +0 -1
  356. package/dist/93.js +0 -1
  357. package/dist/93.js.map +0 -1
  358. package/dist/99.js +0 -1
  359. package/dist/openmrs-esm-home-app.js +0 -1
  360. package/dist/openmrs-esm-home-app.js.buildmanifest.json +0 -626
  361. package/dist/openmrs-esm-home-app.js.map +0 -1
  362. package/src/consultation/consultation.tsx +0 -7
  363. /package/dist/{184.js.LICENSE.txt → 3184.js.LICENSE.txt} +0 -0
  364. /package/dist/{540.js.LICENSE.txt → 6540.js.LICENSE.txt} +0 -0
@@ -0,0 +1,712 @@
1
+ import React, { useState, useEffect, useMemo } from 'react';
2
+ import {
3
+ Grid,
4
+ Column,
5
+ Tile,
6
+ Tabs,
7
+ Tab,
8
+ TabList,
9
+ TabPanels,
10
+ TabPanel,
11
+ Stack,
12
+ DataTable,
13
+ Tag,
14
+ Pagination,
15
+ Search,
16
+ InlineLoading,
17
+ AISkeletonText,
18
+ DatePicker,
19
+ DatePickerInput,
20
+ } from '@carbon/react';
21
+ import { Money, WarningAlt, CheckmarkFilled, Hospital, PendingFilled, Receipt, Calendar } from '@carbon/react/icons';
22
+ import { ConfigurableLink, navigate } from '@openmrs/esm-framework';
23
+ import { spacing05 } from '@carbon/themes';
24
+ import './billingTotalsRow.component.scss';
25
+ import { fetchBillsByDate } from '../api/billing.api';
26
+
27
+ type BillStatus = 'UNPAID' | 'PAID' | 'CLAIM_SUBMITTED';
28
+
29
+ type Bill = {
30
+ id: string;
31
+ patientId: string;
32
+ receiptNo: string;
33
+ patient: string;
34
+ paymentMode: string;
35
+ date: string;
36
+ status: BillStatus;
37
+ total: string;
38
+ items: string;
39
+ billItems: any;
40
+ raisedBy: string;
41
+ createdAt: Date;
42
+ };
43
+
44
+ const SHA_INSURANCE_MODES = ['PHC', 'SHIF', 'ECCIF', 'SHA'];
45
+
46
+ async function fetchBills(date: string): Promise<Bill[]> {
47
+ const res = await fetchBillsByDate(date);
48
+ const bills: Bill[] = [];
49
+
50
+ (res.data ?? []).forEach((billNode: any) => {
51
+ const createdAt = new Date(billNode.dateCreated);
52
+
53
+ const dateStr =
54
+ createdAt.toLocaleDateString() === new Date().toLocaleDateString()
55
+ ? 'Today'
56
+ : createdAt.toLocaleDateString('en-GB', { day: '2-digit', month: 'short', year: 'numeric' });
57
+
58
+ const timeStr = createdAt.toLocaleTimeString([], {
59
+ hour: '2-digit',
60
+ minute: '2-digit',
61
+ hour12: true,
62
+ });
63
+
64
+ const services = billNode.billItems?.map((i: any) => i.billName).join(', ') ?? '';
65
+
66
+ const totalAmount =
67
+ billNode.billItems?.reduce((sum: number, i: any) => sum + Number(i.price ?? 0) * Number(i.quantity ?? 1), 0) ?? 0;
68
+
69
+ const shaAmount =
70
+ billNode.billItems
71
+ ?.filter((i: any) => SHA_INSURANCE_MODES.includes((i.paymentMode ?? '').toUpperCase()))
72
+ .reduce((sum: number, i: any) => sum + Number(i.price ?? 0) * Number(i.quantity ?? 1), 0) ?? 0;
73
+
74
+ const cashAmount =
75
+ billNode.billItems
76
+ ?.filter((i: any) => (i.paymentMode ?? '').toUpperCase() === 'CASH')
77
+ .reduce((sum: number, i: any) => sum + Number(i.price ?? 0) * Number(i.quantity ?? 1), 0) ?? 0;
78
+
79
+ const formatCurrency = (amt: number) =>
80
+ `Ksh ${amt.toLocaleString(undefined, { minimumFractionDigits: 2, maximumFractionDigits: 2 })}`;
81
+
82
+ let amountDisplay = '';
83
+ if (shaAmount > 0 && cashAmount > 0) {
84
+ amountDisplay = `SHA: ${formatCurrency(shaAmount)}, Cash: ${formatCurrency(cashAmount)} (Total: ${formatCurrency(totalAmount)})`;
85
+ } else if (shaAmount > 0) {
86
+ amountDisplay = `SHA: ${formatCurrency(shaAmount)}`;
87
+ } else if (cashAmount > 0) {
88
+ amountDisplay = `Cash: ${formatCurrency(cashAmount)}`;
89
+ } else {
90
+ amountDisplay = formatCurrency(0);
91
+ }
92
+
93
+ const hasSha =
94
+ billNode.billItems?.some((i: any) => SHA_INSURANCE_MODES.includes((i.paymentMode ?? '').toUpperCase())) ?? false;
95
+
96
+ let status: BillStatus;
97
+ let paymentMode: string;
98
+
99
+ if (billNode.balance > 0) {
100
+ status = 'UNPAID';
101
+ paymentMode = 'CASH';
102
+ } else if (hasSha) {
103
+ status = 'CLAIM_SUBMITTED';
104
+ paymentMode = 'SHA';
105
+ } else {
106
+ status = 'PAID';
107
+ paymentMode = 'CASH';
108
+ }
109
+
110
+ bills.push({
111
+ id: `${billNode.billUuid}|${billNode.patientUuid}`,
112
+ patientId: billNode.patientUuid ?? '',
113
+ receiptNo: billNode.receiptNumber ?? 'N/A',
114
+ patient: billNode.patientName ?? 'Unknown',
115
+ raisedBy: billNode.cashPoint ?? 'Unknown',
116
+ paymentMode,
117
+ date: `${dateStr}, ${timeStr}`,
118
+ status,
119
+ items: services,
120
+ total: amountDisplay,
121
+ billItems: billNode.billItems ?? [],
122
+ createdAt,
123
+ });
124
+ });
125
+
126
+ return bills.sort((a, b) => b.createdAt.getTime() - a.createdAt.getTime());
127
+ }
128
+
129
+ const headers = [
130
+ { key: 'date', header: 'Date' },
131
+ { key: 'patient', header: 'Patient' },
132
+ { key: 'total', header: 'Amount' },
133
+ { key: 'status', header: 'Status' },
134
+ { key: 'items', header: 'Billed Items' },
135
+ ];
136
+
137
+ const claimHeaders = [
138
+ { key: 'patient', header: 'Patient' },
139
+ { key: 'scheme', header: 'Scheme' },
140
+ { key: 'total', header: 'Amount' },
141
+ { key: 'date', header: 'Created' },
142
+ { key: 'actions', header: 'Actions' },
143
+ ];
144
+
145
+ const StatTile = ({
146
+ icon,
147
+ label,
148
+ value,
149
+ style,
150
+ }: {
151
+ icon: React.ReactNode;
152
+ label: string;
153
+ value: string | number | React.ReactNode;
154
+ style?: React.CSSProperties;
155
+ }) => (
156
+ <Tile style={style}>
157
+ <div style={{ display: 'flex', gap: spacing05, alignItems: 'center' }}>
158
+ {icon}
159
+ <div>
160
+ <p className="cds--label">{label}</p>
161
+ <p className="cds--heading-03" style={{ fontWeight: 'bold' }}>
162
+ {value}
163
+ </p>
164
+ </div>
165
+ </div>
166
+ </Tile>
167
+ );
168
+
169
+ const StatusTag = ({ status }: { status: BillStatus }) => {
170
+ switch (status) {
171
+ case 'UNPAID':
172
+ return (
173
+ <Tag size="md" type="red">
174
+ <PendingFilled size={10} style={{ marginRight: 4 }} />
175
+ Unpaid
176
+ </Tag>
177
+ );
178
+ case 'PAID':
179
+ return (
180
+ <Tag size="md" type="green">
181
+ <CheckmarkFilled size={10} style={{ marginRight: 4 }} />
182
+ Paid (Cash)
183
+ </Tag>
184
+ );
185
+ case 'CLAIM_SUBMITTED':
186
+ return (
187
+ <Tag size="md" type="blue">
188
+ <Hospital size={10} style={{ marginRight: 4 }} />
189
+ Claim Submitted
190
+ </Tag>
191
+ );
192
+ default:
193
+ return <Tag size="md">Other</Tag>;
194
+ }
195
+ };
196
+
197
+ const { Table, TableHead, TableRow, TableHeader, TableBody, TableCell } = DataTable;
198
+
199
+ const BillsTable = ({
200
+ rows,
201
+ }: {
202
+ rows: Bill[];
203
+ search: string;
204
+ setSearch: (val: string) => void;
205
+ filterDate: Date | null;
206
+ setFilterDate: (val: Date | null) => void;
207
+ }) => {
208
+ const [redirecting] = useState(false);
209
+
210
+ return (
211
+ <>
212
+ {redirecting && <InlineLoading description="Redirecting to patient bill..." status="active" />}
213
+
214
+ <DataTable rows={rows} headers={headers}>
215
+ {({ rows, headers, getTableProps }) => (
216
+ <Table {...getTableProps()}>
217
+ <TableHead>
218
+ <TableRow>
219
+ {headers.map((h) => (
220
+ <TableHeader key={h.key}>{h.header}</TableHeader>
221
+ ))}
222
+ </TableRow>
223
+ </TableHead>
224
+
225
+ <TableBody>
226
+ {rows.map((row) => (
227
+ <TableRow key={row.id}>
228
+ {row.cells.map((cell) => {
229
+ if (cell.info.header === 'patient') {
230
+ return (
231
+ <TableCell key={cell.id}>
232
+ <ConfigurableLink
233
+ style={{ textDecoration: 'none' }}
234
+ to={`${window.spaBase}/home/billing/patient/${row.id.split('|')[1]}/${row.id.split('|')[0]}`}
235
+ templateParams={{ patientUuid: row.id.split('|')[1], uuid: row.id.split('|')[0] }}
236
+ >
237
+ {cell.value}
238
+ </ConfigurableLink>
239
+ </TableCell>
240
+ );
241
+ }
242
+
243
+ if (cell.info.header === 'status') {
244
+ return (
245
+ <TableCell key={cell.id}>
246
+ <StatusTag status={cell.value as BillStatus} />
247
+ </TableCell>
248
+ );
249
+ }
250
+
251
+ return <TableCell key={cell.id}>{cell.value}</TableCell>;
252
+ })}
253
+ </TableRow>
254
+ ))}
255
+ </TableBody>
256
+ </Table>
257
+ )}
258
+ </DataTable>
259
+ </>
260
+ );
261
+ };
262
+
263
+ const BillsTab = ({
264
+ status,
265
+ source,
266
+ filterDate,
267
+ setFilterDate,
268
+ search,
269
+ setSearch,
270
+ loading,
271
+ }: {
272
+ status?: BillStatus;
273
+ source: Bill[];
274
+ filterDate: Date;
275
+ setFilterDate: (val: Date) => void;
276
+ search: string;
277
+ setSearch: (val: string) => void;
278
+ loading: boolean;
279
+ }) => {
280
+ const [page, setPage] = useState(1);
281
+ const [pageSize, setPageSize] = useState(10);
282
+
283
+ const filtered = useMemo(
284
+ () =>
285
+ source.filter((b) => {
286
+ const statusMatch = !status || b.status === status;
287
+ const searchMatch =
288
+ b.patient.toLowerCase().includes(search.toLowerCase()) ||
289
+ b.receiptNo.toLowerCase().includes(search.toLowerCase());
290
+ const start = new Date(filterDate);
291
+ start.setHours(0, 0, 0, 0);
292
+ const end = new Date(filterDate);
293
+ end.setHours(23, 59, 59, 999);
294
+ const dateMatch = b.createdAt >= start && b.createdAt <= end;
295
+ return statusMatch && searchMatch && dateMatch;
296
+ }),
297
+ [source, status, search, filterDate],
298
+ );
299
+
300
+ const paginated = filtered.slice((page - 1) * pageSize, page * pageSize);
301
+
302
+ return (
303
+ <Stack gap={4}>
304
+ {loading ? (
305
+ <InlineLoading description="Loading bills..." />
306
+ ) : (
307
+ <>
308
+ <BillsTable
309
+ rows={paginated}
310
+ search={search}
311
+ setSearch={setSearch}
312
+ filterDate={filterDate}
313
+ setFilterDate={setFilterDate}
314
+ />
315
+ <Pagination
316
+ page={page}
317
+ pageSize={pageSize}
318
+ pageSizes={[10, 25, 50, 100]}
319
+ totalItems={filtered.length}
320
+ onChange={({ page, pageSize }) => {
321
+ setPage(page);
322
+ setPageSize(pageSize);
323
+ }}
324
+ />
325
+ </>
326
+ )}
327
+ </Stack>
328
+ );
329
+ };
330
+
331
+ const BillingTotalsRow: React.FC = () => {
332
+ const [bills, setBills] = useState<Bill[]>([]);
333
+ const [loading, setLoading] = useState(true);
334
+ const [filterDate, setFilterDate] = useState<Date>(() => {
335
+ const saved = sessionStorage.getItem('billing-filter-date');
336
+ if (!saved) return new Date();
337
+
338
+ try {
339
+ const data = JSON.parse(saved);
340
+ if (data.expiry && new Date().getTime() > data.expiry) {
341
+ sessionStorage.removeItem('billing-filter-date');
342
+ return new Date();
343
+ }
344
+ return new Date(data.value);
345
+ } catch {
346
+ return new Date();
347
+ }
348
+ });
349
+ const [search, setSearch] = useState('');
350
+ const formatDate = (date: Date) =>
351
+ `${date.getFullYear()}-${(date.getMonth() + 1).toString().padStart(2, '0')}-${date.getDate().toString().padStart(2, '0')}`;
352
+
353
+ useEffect(() => {
354
+ const loadBills = async () => {
355
+ try {
356
+ setLoading(true);
357
+
358
+ const dateStr = formatDate(filterDate);
359
+ const fetchedBills = await fetchBills(dateStr);
360
+
361
+ setBills(fetchedBills);
362
+ } catch (error) {
363
+ console.error('Error fetching bills:', error);
364
+ } finally {
365
+ setLoading(false);
366
+ }
367
+ };
368
+
369
+ loadBills();
370
+ }, [filterDate]);
371
+
372
+ useEffect(() => {
373
+ const expiry = new Date().getTime() + 5 * 60 * 1000;
374
+ const data = {
375
+ value: filterDate.toISOString(),
376
+ expiry,
377
+ };
378
+ sessionStorage.setItem('billing-filter-date', JSON.stringify(data));
379
+ }, [filterDate]);
380
+
381
+ // Filter bills by selected date
382
+ const billsForDate = useMemo(() => {
383
+ const start = new Date(filterDate);
384
+ start.setHours(0, 0, 0, 0);
385
+ const end = new Date(filterDate);
386
+ end.setHours(23, 59, 59, 999);
387
+
388
+ return bills.filter((b) => b.createdAt >= start && b.createdAt <= end);
389
+ }, [bills, filterDate]);
390
+
391
+ const counts = useMemo(
392
+ () => ({
393
+ all: billsForDate.length,
394
+ unpaid: billsForDate.filter((b) => b.status === 'UNPAID').length,
395
+ paid: billsForDate.filter((b) => b.status === 'PAID').length,
396
+ submittedClaims: billsForDate.filter((b) => b.status === 'CLAIM_SUBMITTED').length,
397
+ }),
398
+ [billsForDate],
399
+ );
400
+
401
+ const revenueToday = useMemo(
402
+ () => billsForDate.filter((b) => b.status === 'PAID').reduce((sum, b) => sum + Number(b.total), 0),
403
+ [billsForDate],
404
+ );
405
+
406
+ const { cashTotal, shaTotal, pendingTotal } = useMemo(() => {
407
+ let cash = 0;
408
+ let sha = 0;
409
+ let pending = 0;
410
+
411
+ billsForDate.forEach((bill: any) => {
412
+ const items = bill.billItems ?? [];
413
+
414
+ items.forEach((item: any) => {
415
+ const amount = Number(item.price ?? 0) * Number(item.quantity ?? 1);
416
+ const mode = item.paymentMode?.toUpperCase();
417
+ const status = item.paymentStatus?.toUpperCase();
418
+
419
+ if (mode === 'CASH' && status === 'PAID') {
420
+ cash += amount;
421
+ }
422
+
423
+ if (SHA_INSURANCE_MODES.includes(mode) && status === 'PAID') {
424
+ sha += amount;
425
+ }
426
+
427
+ if (status === 'PENDING') {
428
+ pending += amount;
429
+ }
430
+ });
431
+ });
432
+
433
+ return {
434
+ cashTotal: cash,
435
+ shaTotal: sha,
436
+ pendingTotal: pending,
437
+ };
438
+ }, [billsForDate]);
439
+
440
+ const filterBillsBy = (status?: BillStatus) => {
441
+ const start = new Date(filterDate);
442
+ start.setHours(0, 0, 0, 0);
443
+ const end = new Date(filterDate);
444
+ end.setHours(23, 59, 59, 999);
445
+
446
+ return bills.filter((b) => {
447
+ const statusMatch = !status || b.status === status;
448
+ const searchMatch =
449
+ b.patient.toLowerCase().includes(search.toLowerCase()) ||
450
+ b.receiptNo.toLowerCase().includes(search.toLowerCase());
451
+ const dateMatch = b.createdAt >= start && b.createdAt <= end;
452
+ return statusMatch && searchMatch && dateMatch;
453
+ });
454
+ };
455
+
456
+ return (
457
+ <Stack gap={4} className="cds--pt-06">
458
+ {/* Stats Tiles */}
459
+ <div
460
+ style={{
461
+ padding: spacing05,
462
+ paddingBottom: 0,
463
+ }}
464
+ >
465
+ <div
466
+ style={{
467
+ display: 'flex',
468
+ alignItems: 'center',
469
+ justifyContent: 'space-between',
470
+ gap: '1rem',
471
+ paddingBottom: spacing05,
472
+ }}
473
+ >
474
+ <div style={{ display: 'flex', alignItems: 'center', gap: '0.75rem' }}>
475
+ <Receipt
476
+ size={36}
477
+ style={{
478
+ color: 'var(--omrs-color-primary, #005D5D)',
479
+ flexShrink: 0,
480
+ }}
481
+ />
482
+
483
+ <div style={{ display: 'flex', flexDirection: 'column', justifyContent: 'center' }}>
484
+ <p className="cds--heading-04" style={{ margin: 0, fontWeight: 600, color: '#003B3B' }}>
485
+ Billing Dashboard
486
+ </p>
487
+
488
+ <p
489
+ className="cds--label"
490
+ style={{
491
+ margin: 0,
492
+ opacity: 0.7,
493
+ fontStyle: 'italic',
494
+ letterSpacing: 0.5,
495
+ }}
496
+ >
497
+ Summary of billing activity
498
+ </p>
499
+ </div>
500
+ </div>
501
+
502
+ <div
503
+ style={{
504
+ display: 'flex',
505
+ alignItems: 'center',
506
+ gap: '0.5rem',
507
+ backgroundColor: 'var(--cds-interactive-02,#E0F4F4)',
508
+ color: 'var(--omrs-color-primary, #005D5D)',
509
+ padding: '0.25rem 0.75rem',
510
+ borderRadius: '0.5rem',
511
+ fontWeight: 600,
512
+ fontSize: '0.95rem',
513
+ boxShadow: '0 1px 3px rgba(0,0,0,0.1)',
514
+ minHeight: '36px',
515
+ }}
516
+ >
517
+ <Calendar size={18} style={{ color: 'var(--omrs-color-primary, #005D5D)', flexShrink: 0 }} />
518
+ <span>
519
+ {filterDate.toLocaleDateString('en-GB', {
520
+ weekday: 'short',
521
+ day: '2-digit',
522
+ month: 'short',
523
+ year: 'numeric',
524
+ })}
525
+ </span>
526
+ </div>
527
+ </div>
528
+
529
+ <hr
530
+ style={{
531
+ border: 'none',
532
+ borderTop: '1px solid #e0e0e0',
533
+ margin: 0,
534
+ }}
535
+ />
536
+ </div>
537
+
538
+ <div style={{ padding: spacing05 }}>
539
+ <Grid fullWidth>
540
+ <Column lg={4} md={8} sm={4}>
541
+ <StatTile
542
+ icon={<Money size={25} />}
543
+ label="Cash Paid"
544
+ value={
545
+ loading ? (
546
+ <AISkeletonText />
547
+ ) : (
548
+ `Ksh ${cashTotal.toLocaleString(undefined, {
549
+ minimumFractionDigits: 2,
550
+ maximumFractionDigits: 2,
551
+ })}`
552
+ )
553
+ }
554
+ style={{ backgroundColor: '#DFF6F0', color: '#00B37E', padding: spacing05, height: '100%' }}
555
+ />
556
+ </Column>
557
+
558
+ <Column lg={4} md={8} sm={4}>
559
+ <StatTile
560
+ icon={<Hospital size={25} />}
561
+ label="Amount Claimed (SHA)"
562
+ value={
563
+ loading ? (
564
+ <AISkeletonText />
565
+ ) : (
566
+ `Ksh ${shaTotal.toLocaleString(undefined, {
567
+ minimumFractionDigits: 2,
568
+ maximumFractionDigits: 2,
569
+ })}`
570
+ )
571
+ }
572
+ style={{ backgroundColor: '#F4EBFF', color: '#8C41FF', padding: spacing05, height: '100%' }}
573
+ />
574
+ </Column>
575
+
576
+ <Column lg={4} md={8} sm={4}>
577
+ <StatTile
578
+ icon={<PendingFilled size={25} />}
579
+ label="Pending Amount"
580
+ value={
581
+ loading ? (
582
+ <AISkeletonText />
583
+ ) : (
584
+ `Ksh ${pendingTotal.toLocaleString(undefined, {
585
+ minimumFractionDigits: 2,
586
+ maximumFractionDigits: 2,
587
+ })}`
588
+ )
589
+ }
590
+ style={{ backgroundColor: '#FFF5D9', color: '#F2B01F', padding: spacing05, height: '100%' }}
591
+ />
592
+ </Column>
593
+
594
+ <Column lg={4} md={8} sm={4}>
595
+ <StatTile
596
+ icon={<WarningAlt size={25} />}
597
+ label="Unpaid Bills"
598
+ value={loading ? <AISkeletonText /> : counts.unpaid}
599
+ style={{ backgroundColor: '#FFEDE1', color: '#FF6B35', padding: spacing05, height: '100%' }}
600
+ />
601
+ </Column>
602
+ </Grid>
603
+ </div>
604
+
605
+ {/* Filters + Tabs */}
606
+ <div style={{ padding: spacing05, paddingTop: 0 }}>
607
+ <div style={{ border: '1px solid #e0e0e0', borderRadius: '0.25rem', paddingTop: spacing05 }}>
608
+ <div style={{ display: 'flex', alignItems: 'flex-end', gap: '1rem', padding: spacing05 }}>
609
+ {/* Search */}
610
+ <div style={{ flex: 4 }}>
611
+ <Search
612
+ closeButtonLabelText="Clear search input"
613
+ id="search-default-1"
614
+ labelText="Search bills"
615
+ placeholder="Search bill or patient"
616
+ size="md"
617
+ value={search}
618
+ onChange={(e) => setSearch(e.target.value)}
619
+ />
620
+ </div>
621
+
622
+ {/* Date */}
623
+ <div style={{ flex: 1 }}>
624
+ <DatePicker
625
+ datePickerType="single"
626
+ value={[formatDate(filterDate)]}
627
+ dateFormat="Y-m-d"
628
+ onChange={(dates) => setFilterDate(new Date(dates[0] ?? new Date()))}
629
+ >
630
+ <DatePickerInput id="bill-date-filter" placeholder="yyyy-mm-dd" labelText="" size="md" />
631
+ </DatePicker>
632
+ </div>
633
+ </div>
634
+
635
+ <Tabs>
636
+ <TabList style={{ paddingLeft: spacing05 }}>
637
+ <Tab>
638
+ Unpaid (All Payment Modes){' '}
639
+ <Tag type="red" size="sm">
640
+ {loading ? <AISkeletonText /> : counts.unpaid}
641
+ </Tag>
642
+ </Tab>
643
+ <Tab>
644
+ Paid (Cash){' '}
645
+ <Tag type="green" size="sm">
646
+ {loading ? <AISkeletonText /> : counts.paid}
647
+ </Tag>
648
+ </Tab>
649
+ <Tab>
650
+ Submitted Claims (SHA/Co-Pay){' '}
651
+ <Tag type="purple" size="sm">
652
+ {loading ? <AISkeletonText /> : counts.submittedClaims}
653
+ </Tag>
654
+ </Tab>
655
+ <Tab>
656
+ All{' '}
657
+ <Tag type="blue" size="sm">
658
+ {loading ? <AISkeletonText /> : counts.all}
659
+ </Tag>
660
+ </Tab>
661
+ </TabList>
662
+
663
+ <TabPanels>
664
+ <TabPanel>
665
+ <BillsTab
666
+ source={filterBillsBy('UNPAID')}
667
+ filterDate={filterDate}
668
+ setFilterDate={setFilterDate}
669
+ search={search}
670
+ setSearch={setSearch}
671
+ loading={loading}
672
+ />
673
+ </TabPanel>
674
+ <TabPanel>
675
+ <BillsTab
676
+ source={filterBillsBy('PAID')}
677
+ filterDate={filterDate}
678
+ setFilterDate={setFilterDate}
679
+ search={search}
680
+ setSearch={setSearch}
681
+ loading={loading}
682
+ />
683
+ </TabPanel>
684
+ <TabPanel>
685
+ <BillsTab
686
+ source={filterBillsBy('CLAIM_SUBMITTED')}
687
+ filterDate={filterDate}
688
+ setFilterDate={setFilterDate}
689
+ search={search}
690
+ setSearch={setSearch}
691
+ loading={loading}
692
+ />
693
+ </TabPanel>
694
+ <TabPanel>
695
+ <BillsTab
696
+ source={filterBillsBy()}
697
+ filterDate={filterDate}
698
+ setFilterDate={setFilterDate}
699
+ search={search}
700
+ setSearch={setSearch}
701
+ loading={loading}
702
+ />
703
+ </TabPanel>
704
+ </TabPanels>
705
+ </Tabs>
706
+ </div>
707
+ </div>
708
+ </Stack>
709
+ );
710
+ };
711
+
712
+ export default BillingTotalsRow;