@kenyaemr/esm-express-workflow-app 5.4.3 → 5.4.4-pre.100

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 (388) hide show
  1. package/.turbo/turbo-build.log +7 -12
  2. package/dist/1074.js +1 -0
  3. package/dist/1074.js.map +1 -0
  4. package/dist/12.js +17 -0
  5. package/dist/12.js.map +1 -0
  6. package/dist/1311.js +1 -0
  7. package/dist/1311.js.map +1 -0
  8. package/dist/1323.js +1 -0
  9. package/dist/1323.js.map +1 -0
  10. package/dist/1469.js +1 -0
  11. package/dist/1469.js.map +1 -0
  12. package/dist/1506.js +13 -0
  13. package/dist/1506.js.map +1 -0
  14. package/dist/1562.js +1 -0
  15. package/dist/1562.js.map +1 -0
  16. package/dist/1760.js +1 -0
  17. package/dist/1760.js.map +1 -0
  18. package/dist/1780.js +1 -0
  19. package/dist/1780.js.map +1 -0
  20. package/dist/1804.js +1 -0
  21. package/dist/1804.js.map +1 -0
  22. package/dist/1884.js +1 -0
  23. package/dist/1884.js.map +1 -0
  24. package/dist/1972.js +1 -0
  25. package/dist/1972.js.map +1 -0
  26. package/dist/1990.js +1 -0
  27. package/dist/1990.js.map +1 -0
  28. package/dist/2016.js +1 -0
  29. package/dist/2016.js.map +1 -0
  30. package/dist/2024.js +1 -0
  31. package/dist/2024.js.map +1 -0
  32. package/dist/2153.js +1 -0
  33. package/dist/2153.js.map +1 -0
  34. package/dist/216.js +1 -0
  35. package/dist/216.js.map +1 -0
  36. package/dist/2225.js +1 -0
  37. package/dist/2225.js.map +1 -0
  38. package/dist/2294.js +1 -0
  39. package/dist/2294.js.map +1 -0
  40. package/dist/2345.js +1 -0
  41. package/dist/2345.js.map +1 -0
  42. package/dist/2499.js +1 -0
  43. package/dist/2499.js.map +1 -0
  44. package/dist/2500.js +1 -0
  45. package/dist/2500.js.map +1 -0
  46. package/dist/2586.js +1 -0
  47. package/dist/2586.js.map +1 -0
  48. package/dist/2625.js +1 -0
  49. package/dist/2625.js.map +1 -0
  50. package/dist/2685.js +1 -0
  51. package/dist/2685.js.map +1 -0
  52. package/dist/2809.js +1 -0
  53. package/dist/2809.js.map +1 -0
  54. package/dist/2851.js +1 -0
  55. package/dist/2851.js.map +1 -0
  56. package/dist/2881.js +1 -0
  57. package/dist/2881.js.map +1 -0
  58. package/dist/2948.js +1 -0
  59. package/dist/2948.js.map +1 -0
  60. package/dist/2968.js +1 -0
  61. package/dist/2968.js.map +1 -0
  62. package/dist/2978.js +1 -0
  63. package/dist/2978.js.map +1 -0
  64. package/dist/2998.js +1 -0
  65. package/dist/2998.js.map +1 -0
  66. package/dist/3089.js +1 -0
  67. package/dist/3089.js.map +1 -0
  68. package/dist/3548.js +1 -0
  69. package/dist/3548.js.map +1 -0
  70. package/dist/3567.js +1 -0
  71. package/dist/3567.js.map +1 -0
  72. package/dist/3569.js +1 -0
  73. package/dist/3569.js.map +1 -0
  74. package/dist/3571.js +1 -0
  75. package/dist/3571.js.map +1 -0
  76. package/dist/3691.js +1 -0
  77. package/dist/3691.js.map +1 -0
  78. package/dist/3730.js +1 -0
  79. package/dist/3730.js.map +1 -0
  80. package/dist/3923.js +1 -0
  81. package/dist/3923.js.map +1 -0
  82. package/dist/3963.js +1 -0
  83. package/dist/3963.js.map +1 -0
  84. package/dist/4024.js +1 -0
  85. package/dist/4024.js.map +1 -0
  86. package/dist/405.js +1 -0
  87. package/dist/405.js.map +1 -0
  88. package/dist/4071.js +1 -0
  89. package/dist/4071.js.map +1 -0
  90. package/dist/4271.js +1 -0
  91. package/dist/4271.js.map +1 -0
  92. package/dist/4296.js +1 -0
  93. package/dist/4296.js.map +1 -0
  94. package/dist/4337.js +1 -0
  95. package/dist/4337.js.map +1 -0
  96. package/dist/4432.js +1 -0
  97. package/dist/4432.js.map +1 -0
  98. package/dist/4581.js +1 -0
  99. package/dist/4581.js.map +1 -0
  100. package/dist/4637.js +11 -0
  101. package/dist/4637.js.map +1 -0
  102. package/dist/4666.js +1 -0
  103. package/dist/4666.js.map +1 -0
  104. package/dist/4680.js +1 -0
  105. package/dist/4680.js.map +1 -0
  106. package/dist/4735.js +1 -0
  107. package/dist/4735.js.map +1 -0
  108. package/dist/4737.js +1 -0
  109. package/dist/4737.js.map +1 -0
  110. package/dist/4744.js +1 -0
  111. package/dist/4744.js.map +1 -0
  112. package/dist/4795.js +1 -0
  113. package/dist/4795.js.map +1 -0
  114. package/dist/4813.js +2 -0
  115. package/dist/4813.js.map +1 -0
  116. package/dist/4818.js +1 -0
  117. package/dist/4818.js.map +1 -0
  118. package/dist/4858.js +1 -0
  119. package/dist/4858.js.map +1 -0
  120. package/dist/487.js +1 -0
  121. package/dist/487.js.map +1 -0
  122. package/dist/4970.js +1 -0
  123. package/dist/4970.js.map +1 -0
  124. package/dist/5038.js +1 -0
  125. package/dist/5038.js.map +1 -0
  126. package/dist/5202.js +1 -0
  127. package/dist/5202.js.map +1 -0
  128. package/dist/5491.js +1 -0
  129. package/dist/5491.js.map +1 -0
  130. package/dist/5592.js +1 -0
  131. package/dist/5592.js.map +1 -0
  132. package/dist/5669.js +1 -0
  133. package/dist/5669.js.map +1 -0
  134. package/dist/586.js +1 -0
  135. package/dist/586.js.map +1 -0
  136. package/dist/5932.js +1 -0
  137. package/dist/5932.js.map +1 -0
  138. package/dist/5995.js +1 -0
  139. package/dist/5995.js.map +1 -0
  140. package/dist/6258.js +1 -0
  141. package/dist/6258.js.map +1 -0
  142. package/dist/629.js +1 -0
  143. package/dist/629.js.map +1 -0
  144. package/dist/6328.js +1 -0
  145. package/dist/6328.js.map +1 -0
  146. package/dist/6355.js +1 -0
  147. package/dist/6355.js.map +1 -0
  148. package/dist/6419.js +1 -0
  149. package/dist/6419.js.map +1 -0
  150. package/dist/644.js +1 -0
  151. package/dist/644.js.map +1 -0
  152. package/dist/6456.js +1 -0
  153. package/dist/6466.js +3 -0
  154. package/dist/6466.js.map +1 -0
  155. package/dist/655.js +1 -0
  156. package/dist/655.js.map +1 -0
  157. package/dist/6798.js +66 -0
  158. package/dist/6798.js.map +1 -0
  159. package/dist/6910.js +1 -0
  160. package/dist/6910.js.map +1 -0
  161. package/dist/6925.js +1 -0
  162. package/dist/6925.js.map +1 -0
  163. package/dist/70.js +1 -0
  164. package/dist/70.js.map +1 -0
  165. package/dist/7201.js +1 -0
  166. package/dist/7201.js.map +1 -0
  167. package/dist/7234.js +1 -0
  168. package/dist/7234.js.map +1 -0
  169. package/dist/7261.js +1 -0
  170. package/dist/7261.js.map +1 -0
  171. package/dist/7326.js +1 -0
  172. package/dist/7359.js +1 -0
  173. package/dist/7487.js +1 -0
  174. package/dist/7487.js.map +1 -0
  175. package/dist/7591.js +1 -0
  176. package/dist/7591.js.map +1 -0
  177. package/dist/7607.js +1 -0
  178. package/dist/7701.js +1 -0
  179. package/dist/7701.js.map +1 -0
  180. package/dist/7717.js +1 -0
  181. package/dist/7717.js.map +1 -0
  182. package/dist/7739.js +1 -0
  183. package/dist/7739.js.map +1 -0
  184. package/dist/7788.js +1 -0
  185. package/dist/7788.js.map +1 -0
  186. package/dist/7819.js +1 -0
  187. package/dist/7819.js.map +1 -0
  188. package/dist/7971.js +1 -0
  189. package/dist/7971.js.map +1 -0
  190. package/dist/7983.js +1 -0
  191. package/dist/7983.js.map +1 -0
  192. package/dist/807.js +1 -0
  193. package/dist/807.js.map +1 -0
  194. package/dist/8159.js +7 -0
  195. package/dist/8159.js.map +1 -0
  196. package/dist/8338.js +1 -0
  197. package/dist/8338.js.map +1 -0
  198. package/dist/845.js +1 -0
  199. package/dist/845.js.map +1 -0
  200. package/dist/8570.js +1 -0
  201. package/dist/8570.js.map +1 -0
  202. package/dist/8661.js +1 -0
  203. package/dist/8661.js.map +1 -0
  204. package/dist/87.js +1 -0
  205. package/dist/87.js.map +1 -0
  206. package/dist/8727.js +1 -0
  207. package/dist/8766.js +1 -0
  208. package/dist/8766.js.map +1 -0
  209. package/dist/8828.js +1 -0
  210. package/dist/8828.js.map +1 -0
  211. package/dist/8860.js +1 -0
  212. package/dist/8860.js.map +1 -0
  213. package/dist/8911.js +1 -0
  214. package/dist/8911.js.map +1 -0
  215. package/dist/8930.js +1 -0
  216. package/dist/8930.js.map +1 -0
  217. package/dist/8971.js +1 -0
  218. package/dist/8971.js.map +1 -0
  219. package/dist/9124.js +1 -0
  220. package/dist/9124.js.map +1 -0
  221. package/dist/9157.js +1 -0
  222. package/dist/9157.js.map +1 -0
  223. package/dist/9182.js +1 -0
  224. package/dist/921.js +1 -0
  225. package/dist/921.js.map +1 -0
  226. package/dist/9212.js +1 -0
  227. package/dist/9212.js.map +1 -0
  228. package/dist/9255.js +1 -0
  229. package/dist/9255.js.map +1 -0
  230. package/dist/9257.js +1 -0
  231. package/dist/9257.js.map +1 -0
  232. package/dist/9316.js +1 -0
  233. package/dist/9316.js.map +1 -0
  234. package/dist/9333.js +1 -0
  235. package/dist/9333.js.map +1 -0
  236. package/dist/9404.js +1 -0
  237. package/dist/9404.js.map +1 -0
  238. package/dist/9446.js +1 -0
  239. package/dist/9446.js.map +1 -0
  240. package/dist/9447.js +1 -0
  241. package/dist/9447.js.map +1 -0
  242. package/dist/9449.js +1 -0
  243. package/dist/9449.js.map +1 -0
  244. package/dist/9535.js +1 -0
  245. package/dist/9535.js.map +1 -0
  246. package/dist/9606.js +1 -0
  247. package/dist/9606.js.map +1 -0
  248. package/dist/973.js +1 -0
  249. package/dist/973.js.map +1 -0
  250. package/dist/9845.js +1 -0
  251. package/dist/9845.js.map +1 -0
  252. package/dist/kenyaemr-esm-express-workflow-app.js +5 -5
  253. package/dist/kenyaemr-esm-express-workflow-app.js.buildmanifest.json +3004 -175
  254. package/dist/kenyaemr-esm-express-workflow-app.js.map +1 -1
  255. package/dist/main.js +5 -114
  256. package/dist/main.js.map +1 -1
  257. package/dist/routes.json +1 -1
  258. package/package.json +6 -7
  259. package/rspack.config.js +1 -1
  260. package/src/components/accounting/index.tsx +11 -10
  261. package/src/components/admissions/index.tsx +11 -10
  262. package/src/components/appointments/index.ts +10 -8
  263. package/src/components/consultation/clinical-encounter/encounter-details.component.tsx +9 -9
  264. package/src/components/consultation/clinical-encounter/encounter-details.test.tsx +19 -18
  265. package/src/components/consultation/consultation-context.tsx +19 -0
  266. package/src/components/consultation/consultation-summary-cards.component.tsx +124 -0
  267. package/src/components/consultation/consultation.component.tsx +41 -268
  268. package/src/components/consultation/consultation.resource.ts +67 -24
  269. package/src/components/consultation/consultation.scss +5 -0
  270. package/src/components/consultation/consultation.utils.tsx +222 -0
  271. package/src/components/consultation/dashboard.component.tsx +0 -2
  272. package/src/components/consultation/index.ts +27 -20
  273. package/src/components/facility-dashboard/index.tsx +10 -9
  274. package/src/components/laboratory/index.ts +11 -10
  275. package/src/components/laboratory/lab-table.component.tsx +22 -8
  276. package/src/components/laboratory/laboratory-tabs.component.tsx +2 -2
  277. package/src/components/mch/dashboard.component.tsx +0 -2
  278. package/src/components/mch/index.tsx +10 -9
  279. package/src/components/mch/mch.consultation.component.tsx +27 -15
  280. package/src/components/mch/mch.triage.component.tsx +42 -33
  281. package/src/components/pharmacy/index.ts +20 -18
  282. package/src/components/pharmacy/orders/pharmacy-orders.component.tsx +35 -13
  283. package/src/components/pharmacy/orders/pharmacy-orders.test.tsx +8 -7
  284. package/src/components/procedures/index.ts +11 -10
  285. package/src/components/procedures/procedures-table.component.tsx +44 -13
  286. package/src/components/procedures/procedures-tabs.component.tsx +2 -2
  287. package/src/components/radiology-and-imaging/index.ts +14 -10
  288. package/src/components/radiology-and-imaging/radiology-and-imaging-table.component.tsx +35 -15
  289. package/src/components/radiology-and-imaging/radiology-and-imaging.component.tsx +2 -2
  290. package/src/components/registration/card/HIE-card/hie-card.component.tsx +32 -44
  291. package/src/components/registration/card/Local-card/local-card.component.tsx +22 -24
  292. package/src/components/registration/dependants/dependants.component.tsx +32 -60
  293. package/src/components/registration/dependants/dependants.resource.ts +79 -50
  294. package/src/components/registration/helper/index.ts +4 -0
  295. package/src/components/registration/index.ts +10 -9
  296. package/src/components/registration/search-bar/search-bar.resource.ts +32 -93
  297. package/src/components/registration/start-visit-form/hooks/useDefaultFacilityLocation.tsx +15 -0
  298. package/src/components/registration/start-visit-form/hooks/useDefaultVisitLocation.tsx +24 -0
  299. package/src/components/registration/start-visit-form/hooks/useOfflineVisitType.tsx +18 -0
  300. package/src/components/registration/start-visit-form/hooks/useRecommendedVisitTypes.tsx +36 -0
  301. package/src/components/registration/start-visit-form/hooks/useVisitAttributeType.tsx +102 -0
  302. package/src/components/registration/start-visit-form/overflow-menu-extension/overflow-menu-item.extension.tsx +55 -0
  303. package/src/components/registration/start-visit-form/overflow-menu-extension/overflow-menu-item.scss +3 -0
  304. package/src/components/registration/start-visit-form/start-visit-workspace/base-visit-type.component.tsx +126 -0
  305. package/src/components/registration/start-visit-form/start-visit-workspace/base-visit-type.scss +75 -0
  306. package/src/components/registration/start-visit-form/start-visit-workspace/exported-visit-form.workspace.tsx +743 -0
  307. package/src/components/registration/start-visit-form/start-visit-workspace/location-selector.component.tsx +86 -0
  308. package/src/components/registration/start-visit-form/start-visit-workspace/recommended-visit-type.component.tsx +32 -0
  309. package/src/components/registration/start-visit-form/start-visit-workspace/visit-attribute-type.component.tsx +257 -0
  310. package/src/components/registration/start-visit-form/start-visit-workspace/visit-attribute-type.scss +5 -0
  311. package/src/components/registration/start-visit-form/start-visit-workspace/visit-date-time.component.tsx +193 -0
  312. package/src/components/registration/start-visit-form/start-visit-workspace/visit-form.resource.ts +383 -0
  313. package/src/components/registration/start-visit-form/start-visit-workspace/visit-form.scss +166 -0
  314. package/src/components/registration/start-visit-form/visit-form-workspace/visit-form.workspace.tsx +55 -0
  315. package/src/components/reports/index.ts +10 -9
  316. package/src/components/triage/dashboard.component.tsx +0 -2
  317. package/src/components/triage/index.ts +10 -9
  318. package/src/components/triage/triage.component.tsx +92 -42
  319. package/src/components/triage/triage.resource.ts +56 -50
  320. package/src/components/triage/triage.scss +6 -0
  321. package/src/config-schema.ts +91 -0
  322. package/src/hooks/useServiceQueues.tsx +95 -25
  323. package/src/index.ts +32 -13
  324. package/src/routes.json +53 -254
  325. package/src/shared/orders/OrdersTabs.tsx +8 -3
  326. package/src/shared/patient-chart/patient-chart.resources.ts +8 -12
  327. package/src/shared/patient-chart/patient-summary-dashboard/patient-summary-dashboard.component.tsx +1 -2
  328. package/src/shared/pin-put/pinput.component.test.tsx +7 -6
  329. package/src/shared/queue/queue-entry/queue-entry-table.component.tsx +99 -88
  330. package/src/shared/queue/queue-entry/queue-entry-table.scss +4 -0
  331. package/src/shared/queue/queue-summary-cards.component.tsx +32 -0
  332. package/src/shared/queue/queue-tab.component.tsx +182 -70
  333. package/src/shared/queue/queue-tab.scss +1 -0
  334. package/src/shared/queue/queue-workflow-context.tsx +90 -0
  335. package/src/shared/tabs/extension-tabs.component.tsx +9 -6
  336. package/src/shared/utils/index.ts +1 -2
  337. package/src/types/index.ts +17 -2
  338. package/translations/am.json +64 -13
  339. package/translations/en.json +59 -8
  340. package/translations/sw.json +58 -7
  341. package/dist/127.js +0 -1
  342. package/dist/200.js +0 -1
  343. package/dist/200.js.map +0 -1
  344. package/dist/24.js +0 -1
  345. package/dist/24.js.map +0 -1
  346. package/dist/267.js +0 -1
  347. package/dist/267.js.map +0 -1
  348. package/dist/285.js +0 -1
  349. package/dist/285.js.map +0 -1
  350. package/dist/329.js +0 -1
  351. package/dist/329.js.map +0 -1
  352. package/dist/40.js +0 -1
  353. package/dist/466.js +0 -1
  354. package/dist/466.js.map +0 -1
  355. package/dist/472.js +0 -66
  356. package/dist/472.js.map +0 -1
  357. package/dist/490.js +0 -1
  358. package/dist/490.js.map +0 -1
  359. package/dist/54.js +0 -1
  360. package/dist/54.js.map +0 -1
  361. package/dist/689.js +0 -1
  362. package/dist/689.js.map +0 -1
  363. package/dist/697.js +0 -1
  364. package/dist/697.js.map +0 -1
  365. package/dist/704.js +0 -1
  366. package/dist/704.js.map +0 -1
  367. package/dist/710.js +0 -1
  368. package/dist/710.js.map +0 -1
  369. package/dist/729.js +0 -17
  370. package/dist/729.js.map +0 -1
  371. package/dist/805.js +0 -37
  372. package/dist/805.js.map +0 -1
  373. package/dist/847.js +0 -1
  374. package/dist/847.js.map +0 -1
  375. package/dist/85.js +0 -1
  376. package/dist/85.js.map +0 -1
  377. package/dist/882.js +0 -1
  378. package/dist/91.js +0 -1
  379. package/dist/91.js.map +0 -1
  380. package/dist/916.js +0 -1
  381. package/dist/994.js +0 -1
  382. package/dist/994.js.map +0 -1
  383. package/dist/998.js +0 -1
  384. package/dist/998.js.map +0 -1
  385. package/jest.config.js +0 -3
  386. package/src/shared/patient-chart/patient-chart.component.tsx +0 -61
  387. package/src/shared/patient-chart/patient-chart.scss +0 -15
  388. package/src/shared/patient-chart/useInitialize.ts +0 -24
@@ -5,13 +5,14 @@ import { ErrorState, useConfig } from '@openmrs/esm-framework';
5
5
  import { useTranslation } from 'react-i18next';
6
6
  import { useQueues } from '../../hooks/useServiceQueues';
7
7
  import QueueTab from '../../shared/queue/queue-tab.component';
8
+ import QueueSummaryCards, { QueueSummaryCard } from '../../shared/queue/queue-summary-cards.component';
8
9
  import { Queue, QueueFilter } from '../../types';
9
10
  import { useTriageQueuesMetrics } from '../triage/triage.resource';
10
11
  import { ExpressWorkflowConfig } from '../../config-schema';
11
12
 
12
13
  const MCHTriage: React.FC = () => {
13
14
  const { t } = useTranslation();
14
- const { queues, isLoading, error } = useQueues();
15
+ const { queues, isLoading: isLoadingQueues, error } = useQueues();
15
16
  const [currQueue, setCurrQueue] = useState<Queue>();
16
17
  const [filters, setFilters] = useState<Array<QueueFilter>>([]);
17
18
  const {
@@ -31,11 +32,15 @@ const MCHTriage: React.FC = () => {
31
32
  const {
32
33
  error: metricsError,
33
34
  isLoading: isLoadingMetrics,
34
- attendedtoEntries,
35
+ attendedToEntries,
35
36
  waitingEntries,
37
+ isValidating: isValidatingMetrics,
36
38
  } = useTriageQueuesMetrics(activeQueue);
37
39
 
38
- if (isLoading || isLoadingMetrics) {
40
+ const isLoading = isLoadingQueues || isLoadingMetrics;
41
+ const isValidating = isValidatingMetrics;
42
+
43
+ if (isLoading && !isValidating) {
39
44
  return <InlineLoading description={t('loadingQueues', 'Loading queues...')} />;
40
45
  }
41
46
 
@@ -43,37 +48,41 @@ const MCHTriage: React.FC = () => {
43
48
  return <ErrorState error={error ?? metricsError} headerTitle={t('errorLoadingQueues', 'Error loading queues')} />;
44
49
  }
45
50
 
51
+ const cards: Array<QueueSummaryCard> = [
52
+ {
53
+ title: t('patientsAwaiting', 'Patient awaiting'),
54
+ value: waitingEntries?.length?.toString(),
55
+ onClick: () => {
56
+ setFilters((prevFilters) => [
57
+ ...prevFilters.filter((f) => f.key !== 'status'),
58
+ { key: 'status', value: waitingStatus, label: t('waiting', 'Waiting') },
59
+ ]);
60
+ },
61
+ },
62
+ {
63
+ title: t('patientAttended', 'Patient attended to'),
64
+ value: attendedToEntries?.length?.toString(),
65
+ onClick: () => {
66
+ setFilters((prevFilters) => [
67
+ ...prevFilters.filter((f) => f.key !== 'status'),
68
+ { key: 'status', value: `${finishedStatus},${inServiceStatus}`, label: t('attendedTo', 'Attended to') },
69
+ ]);
70
+ },
71
+ },
72
+ ];
73
+
46
74
  return (
47
- <QueueTab
48
- queues={triageQueues}
49
- navigatePath="mch"
50
- cards={[
51
- {
52
- title: t('patientsAwaiting', 'Patient awaiting'),
53
- value: waitingEntries?.length?.toString(),
54
- onClick: () => {
55
- setFilters((prevFilters) => [
56
- ...prevFilters.filter((f) => f.key !== 'status'),
57
- { key: 'status', value: waitingStatus, label: t('waiting', 'Waiting') },
58
- ]);
59
- },
60
- },
61
- {
62
- title: t('patientAttended', 'Patient attended to'),
63
- value: attendedtoEntries?.length?.toString(),
64
- onClick: () => {
65
- setFilters((prevFilters) => [
66
- ...prevFilters.filter((f) => f.key !== 'status'),
67
- { key: 'status', value: `${finishedStatus},${inServiceStatus}`, label: t('attendedTo', 'Attended to') },
68
- ]);
69
- },
70
- },
71
- ]}
72
- onTabChanged={setCurrQueue}
73
- usePatientChart
74
- filters={filters}
75
- onFiltersChanged={setFilters}
76
- />
75
+ <>
76
+ <QueueSummaryCards cards={cards} />
77
+ <QueueTab
78
+ queues={triageQueues}
79
+ navigatePath="mch"
80
+ onTabChanged={setCurrQueue}
81
+ usePatientChart
82
+ filters={filters}
83
+ onFiltersChanged={setFilters}
84
+ />
85
+ </>
77
86
  );
78
87
  };
79
88
 
@@ -1,10 +1,6 @@
1
- import { getAsyncLifecycle, getSyncLifecycle } from '@openmrs/esm-framework';
1
+ import { getAsyncLifecycle } from '@openmrs/esm-framework';
2
2
 
3
- import { createDashboardLink } from '@openmrs/esm-patient-common-lib';
4
3
  import { moduleName } from '../../constants';
5
- import { createLeftPanelLink } from '../../shared/dashboard-link/dashboard-link.component';
6
- import PharmacyTabs from './pharmacy-tabs.component';
7
- import Pharmacy from './pharmacy.component';
8
4
 
9
5
  const options = {
10
6
  featureName: 'express-workflow',
@@ -12,23 +8,29 @@ const options = {
12
8
  };
13
9
 
14
10
  // t('pharmacy', 'Pharmacy')
15
- export const pharmacyLink = getSyncLifecycle(
16
- createLeftPanelLink({
17
- name: 'pharmacy',
18
- title: 'pharmacy',
19
- }),
11
+ export const pharmacyLink = getAsyncLifecycle(
12
+ () =>
13
+ import('../../shared/dashboard-link/dashboard-link.component').then((m) => ({
14
+ default: m.createLeftPanelLink({
15
+ name: 'pharmacy',
16
+ title: 'pharmacy',
17
+ }),
18
+ })),
20
19
  options,
21
20
  );
22
- export const pharmacy = getSyncLifecycle(Pharmacy, options);
23
- export const pharmacyTabs = getSyncLifecycle(PharmacyTabs, options);
21
+ export const pharmacy = getAsyncLifecycle(() => import('./pharmacy.component'), options);
22
+ export const pharmacyTabs = getAsyncLifecycle(() => import('./pharmacy-tabs.component'), options);
24
23
 
25
24
  // t('precription', 'Prescription')
26
- export const pharmacyPatientChartDashboardLink = getSyncLifecycle(
27
- createDashboardLink({
28
- path: 'pharmacy',
29
- title: 'prescription',
30
- icon: 'omrs-icon-medication',
31
- }),
25
+ export const pharmacyPatientChartDashboardLink = getAsyncLifecycle(
26
+ () =>
27
+ import('@openmrs/esm-patient-common-lib').then((m) => ({
28
+ default: m.createDashboardLink({
29
+ path: 'pharmacy',
30
+ title: 'prescription',
31
+ icon: 'omrs-icon-medication',
32
+ }),
33
+ })),
32
34
  options,
33
35
  );
34
36
  export const pharmacyOrders = getAsyncLifecycle(() => import('./orders/pharmacy-orders.component'), options);
@@ -18,12 +18,20 @@ import {
18
18
  } from '@carbon/react';
19
19
  import { Add, Renew } from '@carbon/react/icons';
20
20
  import { ErrorState, formatDatetime, parseDate, useDebounce, useLayoutType } from '@openmrs/esm-framework';
21
- import { EmptyState, useLaunchWorkspaceRequiringVisit, usePaginationInfo } from '@openmrs/esm-patient-common-lib';
21
+ import {
22
+ EmptyState,
23
+ invalidateVisitAndEncounterData,
24
+ invalidateVisitByUuid,
25
+ useLaunchWorkspaceRequiringVisit,
26
+ usePaginationInfo,
27
+ usePatientChartStore,
28
+ } from '@openmrs/esm-patient-common-lib';
22
29
  import capitalize from 'lodash-es/capitalize';
23
30
 
24
31
  import { usePharmacyOrders } from './pharmacy-orders.resource';
25
32
 
26
33
  import styles from './pharmacy-orders.scss';
34
+ import { useSWRConfig } from 'swr';
27
35
 
28
36
  type PharmacyOrdersProps = {
29
37
  patient: fhir.Patient;
@@ -36,18 +44,28 @@ const PharmacyOrders: React.FC<PharmacyOrdersProps> = ({ patient }) => {
36
44
  const debouncedSearchTerm = useDebounce(searchTerm, 500);
37
45
  const { medicationRequests, isLoading, error, mutate, currentPage, goTo, totalCount, currPageSize, setCurrPageSize } =
38
46
  usePharmacyOrders(patient.identifier[0]?.value ?? '', debouncedSearchTerm);
39
- const launchAddDrugOrder = useLaunchWorkspaceRequiringVisit('add-drug-order');
47
+ const { mutate: globalMutate } = useSWRConfig();
48
+
49
+ const { visitContext } = usePatientChartStore(patient.id);
50
+ const groupProps = useMemo(
51
+ () => ({
52
+ patient,
53
+ patientUuid: patient?.id,
54
+ visitContext: visitContext,
55
+ mutateVisitContext: () => {
56
+ invalidateVisitByUuid(globalMutate, visitContext.uuid);
57
+ invalidateVisitAndEncounterData(globalMutate, patient.id);
58
+ },
59
+ }),
60
+ [globalMutate, visitContext, patient.id],
61
+ );
62
+ const launchOrderBasket = useLaunchWorkspaceRequiringVisit(patient?.id, 'order-basket');
40
63
 
41
64
  const currentItems = useMemo(() => {
42
65
  return medicationRequests.length;
43
66
  }, [medicationRequests]);
44
67
 
45
- const { pageSizes, itemsDisplayed } = usePaginationInfo(
46
- currPageSize,
47
- totalCount || 0,
48
- currentPage || 1,
49
- currentItems,
50
- );
68
+ const { pageSizes } = usePaginationInfo(currPageSize, totalCount || 0, currentPage || 1, currentItems);
51
69
 
52
70
  const header = [
53
71
  { key: 'date', header: t('dateAndTime', 'Date and time') },
@@ -58,7 +76,7 @@ const PharmacyOrders: React.FC<PharmacyOrdersProps> = ({ patient }) => {
58
76
  ];
59
77
 
60
78
  const rows = medicationRequests.map((medicationRequest) => {
61
- const resource = medicationRequest.resource as fhir.MedicationRequest;
79
+ const resource = medicationRequest.resource;
62
80
  return {
63
81
  id: medicationRequest.fullUrl,
64
82
  date: formatDatetime(parseDate(resource?.authoredOn), { mode: 'standard', noToday: true }),
@@ -89,9 +107,9 @@ const PharmacyOrders: React.FC<PharmacyOrdersProps> = ({ patient }) => {
89
107
  return (
90
108
  <div className={styles.pharmacyOrdersContainer}>
91
109
  <EmptyState
92
- displayText={t('noMedicationOrdersFound', 'No medication orders found')}
93
- headerTitle={t('noMedicationOrders', 'No medication orders')}
94
- launchForm={launchAddDrugOrder}
110
+ displayText={t('noMedicationOrdersFound', 'medication orders found')}
111
+ headerTitle={t('medicationOrders', 'Medication Orders')}
112
+ launchForm={() => launchOrderBasket({}, { encounterUuid: '' }, groupProps)}
95
113
  />
96
114
  </div>
97
115
  );
@@ -118,7 +136,11 @@ const PharmacyOrders: React.FC<PharmacyOrdersProps> = ({ patient }) => {
118
136
  <Button kind="ghost" renderIcon={Renew} size={responseSize} onClick={() => mutate()}>
119
137
  {t('refresh', 'Refresh')}
120
138
  </Button>
121
- <Button size={responseSize} onClick={() => launchAddDrugOrder()} kind="ghost" renderIcon={Add}>
139
+ <Button
140
+ size={responseSize}
141
+ onClick={() => launchOrderBasket({}, { encounterUuid: '' }, groupProps)}
142
+ kind="ghost"
143
+ renderIcon={Add}>
122
144
  {t('addMedicationOrder', 'Add Medication Order')}
123
145
  </Button>
124
146
  </TableToolbarContent>
@@ -1,21 +1,22 @@
1
1
  import React from 'react';
2
2
  import { screen, waitFor } from '@testing-library/react';
3
3
  import userEvent from '@testing-library/user-event';
4
+ import { vi, type MockedFunction } from 'vitest';
4
5
  import { renderWithSwr } from '../../../../../../tools/test-helpers';
5
6
  import PharmacyOrders from './pharmacy-orders.component';
6
7
  import { usePharmacyOrders } from './pharmacy-orders.resource';
7
8
 
8
9
  // Mock the workspace launcher hook
9
- const mockLaunchAddDrugOrder = jest.fn();
10
- jest.mock('@openmrs/esm-patient-common-lib', () => ({
11
- ...jest.requireActual('@openmrs/esm-patient-common-lib'),
12
- useLaunchWorkspaceRequiringVisit: jest.fn(() => mockLaunchAddDrugOrder),
10
+ const mockLaunchAddDrugOrder = vi.fn();
11
+ vi.mock('@openmrs/esm-patient-common-lib', () => ({
12
+ ...vi.importActual<typeof import('@openmrs/esm-patient-common-lib')>('@openmrs/esm-patient-common-lib'),
13
+ useLaunchWorkspaceRequiringVisit: vi.fn(() => mockLaunchAddDrugOrder),
13
14
  }));
14
15
 
15
16
  // Mock the pharmacy orders hook
16
- jest.mock('./pharmacy-orders.resource');
17
+ vi.mock('./pharmacy-orders.resource');
17
18
 
18
- const mockUsePharmacyOrders = usePharmacyOrders as jest.MockedFunction<typeof usePharmacyOrders>;
19
+ const mockUsePharmacyOrders = usePharmacyOrders as MockedFunction<typeof usePharmacyOrders>;
19
20
 
20
21
  describe('PharmacyOrders Component', () => {
21
22
  const mockPatient: fhir.Patient = {
@@ -103,7 +104,7 @@ describe('PharmacyOrders Component', () => {
103
104
  const mockSetCurrPageSize = jest.fn() as unknown as React.Dispatch<React.SetStateAction<number>>;
104
105
 
105
106
  beforeEach(() => {
106
- jest.clearAllMocks();
107
+ vi.clearAllMocks();
107
108
  });
108
109
 
109
110
  describe('Loading State', () => {
@@ -1,21 +1,22 @@
1
- import { getSyncLifecycle } from '@openmrs/esm-framework';
1
+ import { getAsyncLifecycle } from '@openmrs/esm-framework';
2
2
 
3
- import { createDashboardLink } from '@openmrs/esm-patient-common-lib';
4
3
  import { moduleName } from '../../constants';
5
- import ProceduresTabs from './procedures-tabs.component';
6
4
 
7
5
  const options = {
8
6
  featureName: 'express-workflow',
9
7
  moduleName,
10
8
  };
11
9
 
12
- export const proceduresDashboard = getSyncLifecycle(ProceduresTabs, options);
10
+ export const proceduresDashboard = getAsyncLifecycle(() => import('./procedures-tabs.component'), options);
13
11
  // t('procedures', 'Procedures')
14
- export const proceduresLeftPanelLink = getSyncLifecycle(
15
- createDashboardLink({
16
- path: 'procedures',
17
- title: 'procedures',
18
- icon: 'omrs-icon-movement',
19
- }),
12
+ export const proceduresLeftPanelLink = getAsyncLifecycle(
13
+ () =>
14
+ import('@openmrs/esm-patient-common-lib').then((m) => ({
15
+ default: m.createDashboardLink({
16
+ path: 'procedures',
17
+ title: 'procedures',
18
+ icon: 'omrs-icon-movement',
19
+ }),
20
+ })),
20
21
  options,
21
22
  );
@@ -1,6 +1,12 @@
1
- import React from 'react';
1
+ import React, { useMemo } from 'react';
2
2
  import { useConfig } from '@openmrs/esm-framework';
3
- import { EmptyState, useLaunchWorkspaceRequiringVisit } from '@openmrs/esm-patient-common-lib';
3
+ import {
4
+ EmptyState,
5
+ invalidateVisitAndEncounterData,
6
+ invalidateVisitByUuid,
7
+ useLaunchWorkspaceRequiringVisit,
8
+ usePatientChartStore,
9
+ } from '@openmrs/esm-patient-common-lib';
4
10
  import { Layer } from '@carbon/react';
5
11
  import { useTranslation } from 'react-i18next';
6
12
 
@@ -9,15 +15,32 @@ import OrderTable from '../../shared/orders/OrderTable';
9
15
  import { type Order } from '../../types/order/order';
10
16
  import { type ExpressWorkflowConfig } from '../../config-schema';
11
17
  import styles from './procedures.scss';
18
+ import { useSWRConfig } from 'swr';
12
19
 
13
20
  type ProceduresTableProps = {
14
21
  orders: Order[];
22
+ patientUuid: string;
23
+ patient: fhir.Patient;
15
24
  };
16
- const ProceduresTable: React.FC<ProceduresTableProps> = ({ orders }) => {
25
+ const ProceduresTable: React.FC<ProceduresTableProps> = ({ orders, patientUuid, patient }) => {
17
26
  const { t } = useTranslation();
18
27
  const { imagingOrderTypeUuid, imagingOrderableConceptSets } = useConfig<ExpressWorkflowConfig>();
19
-
20
- const launchAddLabOrder = useLaunchWorkspaceRequiringVisit('add-procedures-order');
28
+ const { visitContext } = usePatientChartStore(patientUuid);
29
+ const { mutate: globalMutate } = useSWRConfig();
30
+ const windowProps = useMemo(() => ({ encounterUuid: orders[0]?.encounter?.uuid }), [orders[0]?.encounter?.uuid]);
31
+ const groupProps = useMemo(
32
+ () => ({
33
+ patient,
34
+ patientUuid: patient?.id,
35
+ visitContext: visitContext,
36
+ mutateVisitContext: () => {
37
+ invalidateVisitByUuid(globalMutate, visitContext.uuid);
38
+ invalidateVisitAndEncounterData(globalMutate, patient.id);
39
+ },
40
+ }),
41
+ [globalMutate, visitContext, patient.id],
42
+ );
43
+ const launchOrderBasket = useLaunchWorkspaceRequiringVisit(patientUuid ?? '', 'order-basket');
21
44
 
22
45
  if (orders?.length === 0) {
23
46
  return (
@@ -26,10 +49,14 @@ const ProceduresTable: React.FC<ProceduresTableProps> = ({ orders }) => {
26
49
  displayText={t('orders', 'Orders')}
27
50
  headerTitle={t('proceduresOrders', 'Procedures Orders')}
28
51
  launchForm={() =>
29
- launchAddLabOrder({
30
- orderTypeUuid: imagingOrderTypeUuid,
31
- orderableConceptSets: imagingOrderableConceptSets,
32
- })
52
+ launchOrderBasket(
53
+ {
54
+ orderTypeUuid: imagingOrderTypeUuid,
55
+ orderableConceptSets: imagingOrderableConceptSets,
56
+ },
57
+ windowProps,
58
+ groupProps,
59
+ )
33
60
  }
34
61
  />
35
62
  </Layer>
@@ -41,10 +68,14 @@ const ProceduresTable: React.FC<ProceduresTableProps> = ({ orders }) => {
41
68
  title={t('proceduresOrders', 'Procedures Orders')}
42
69
  orders={orders}
43
70
  onAdd={() =>
44
- launchAddLabOrder({
45
- orderTypeUuid: imagingOrderTypeUuid,
46
- orderableConceptSets: imagingOrderableConceptSets,
47
- })
71
+ launchOrderBasket(
72
+ {
73
+ orderTypeUuid: imagingOrderTypeUuid,
74
+ orderableConceptSets: imagingOrderableConceptSets,
75
+ },
76
+ windowProps,
77
+ groupProps,
78
+ )
48
79
  }
49
80
  containerClassName={styles.labTableContainer}
50
81
  tableCellClassName={styles.tableCell}
@@ -2,7 +2,7 @@ import React from 'react';
2
2
  import { useConfig } from '@openmrs/esm-framework';
3
3
 
4
4
  import OrdersTabs from '../../shared/orders/OrdersTabs';
5
- import LabTable from './procedures-table.component';
5
+ import ProceduresTable from './procedures-table.component';
6
6
  import { ExpressWorkflowConfig } from '../../config-schema';
7
7
 
8
8
  type ProceduresTabsProps = {
@@ -20,7 +20,7 @@ const ProceduresTabs: React.FC<ProceduresTabsProps> = ({ patientUuid, patient })
20
20
  resultsSlotName="ewf-procedures-results-slot"
21
21
  orderTypeUuid={imagingOrderTypeUuid}
22
22
  filter={(order) => order.concept?.conceptClass?.uuid === proceduresConceptClassUuid}
23
- Table={({ orders }) => <LabTable orders={orders} />}
23
+ Table={({ orders }) => <ProceduresTable orders={orders} patientUuid={patientUuid} patient={patient} />}
24
24
  />
25
25
  );
26
26
  };
@@ -1,21 +1,25 @@
1
- import { getSyncLifecycle } from '@openmrs/esm-framework';
1
+ import { getAsyncLifecycle } from '@openmrs/esm-framework';
2
2
 
3
- import { createDashboardLink } from '@openmrs/esm-patient-common-lib/src';
4
3
  import { moduleName } from '../../constants';
5
- import RadiologyAndImagingTabs from './radiology-and-imaging.component';
6
4
 
7
5
  const options = {
8
6
  featureName: 'express-workflow',
9
7
  moduleName,
10
8
  };
11
9
 
12
- export const radiologyAndImagingDashboard = getSyncLifecycle(RadiologyAndImagingTabs, options);
10
+ export const radiologyAndImagingDashboard = getAsyncLifecycle(
11
+ () => import('./radiology-and-imaging.component'),
12
+ options,
13
+ );
13
14
  // t('radiologyAndImaging', 'Radiology and Imaging')
14
- export const radiologyAndImagingLeftPanelLink = getSyncLifecycle(
15
- createDashboardLink({
16
- path: 'radiology-and-imaging',
17
- title: 'radiologyAndImaging',
18
- icon: 'omrs-icon-user-xray',
19
- }),
15
+ export const radiologyAndImagingLeftPanelLink = getAsyncLifecycle(
16
+ () =>
17
+ import('@openmrs/esm-patient-common-lib').then((m) => ({
18
+ default: m.createDashboardLink({
19
+ path: 'radiology-and-imaging',
20
+ title: 'radiologyAndImaging',
21
+ icon: 'omrs-icon-user-xray',
22
+ }),
23
+ })),
20
24
  options,
21
25
  );
@@ -1,7 +1,6 @@
1
- import React from 'react';
2
- import { parseDate, formatDatetime, useConfig } from '@openmrs/esm-framework';
3
- import { CardHeader, EmptyState, useLaunchWorkspaceRequiringVisit } from '@openmrs/esm-patient-common-lib';
4
- import { Add } from '@carbon/react/icons';
1
+ import React, { useMemo } from 'react';
2
+ import { useConfig } from '@openmrs/esm-framework';
3
+ import { EmptyState, useLaunchWorkspaceRequiringVisit, usePatientChartStore } from '@openmrs/esm-patient-common-lib';
5
4
  import { Layer } from '@carbon/react';
6
5
  import { useTranslation } from 'react-i18next';
7
6
  import OrderTable from '../../shared/orders/OrderTable';
@@ -11,13 +10,26 @@ import { type ExpressWorkflowConfig } from '../../config-schema';
11
10
  import styles from './radiology-and-imaging.scss';
12
11
 
13
12
  type RadiologyAndImagingTableProps = {
14
- orders: Order[];
13
+ orders: Array<Order>;
14
+ patientUuid: string;
15
+ patient: fhir.Patient;
15
16
  };
16
- const RadiologyAndImagingTable: React.FC<RadiologyAndImagingTableProps> = ({ orders }) => {
17
+ const RadiologyAndImagingTable: React.FC<RadiologyAndImagingTableProps> = ({ orders, patientUuid, patient }) => {
17
18
  const { t } = useTranslation();
18
19
  const { imagingOrderTypeUuid, imagingOrderableConceptSets } = useConfig<ExpressWorkflowConfig>();
20
+ const { mutateVisitContext, visitContext } = usePatientChartStore(patientUuid);
19
21
 
20
- const launchAddLabOrder = useLaunchWorkspaceRequiringVisit('add-imaging-order');
22
+ const windowProps = useMemo(() => ({ encounterUuid: orders[0]?.encounter?.uuid }), [orders[0]?.encounter?.uuid]);
23
+ const groupProps = useMemo(
24
+ () => ({
25
+ patient,
26
+ patientUuid: patient?.id,
27
+ visitContext: visitContext,
28
+ mutateVisitContext: mutateVisitContext,
29
+ }),
30
+ [patient, visitContext, mutateVisitContext],
31
+ );
32
+ const launchAddLabOrder = useLaunchWorkspaceRequiringVisit(patientUuid, 'order-basket');
21
33
 
22
34
  if (orders?.length === 0) {
23
35
  return (
@@ -26,10 +38,14 @@ const RadiologyAndImagingTable: React.FC<RadiologyAndImagingTableProps> = ({ ord
26
38
  displayText={t('orders', 'Orders')}
27
39
  headerTitle={t('radiologyAndImagingOrders', 'Radiology and Imaging Orders')}
28
40
  launchForm={() =>
29
- launchAddLabOrder({
30
- orderTypeUuid: imagingOrderTypeUuid,
31
- orderableConceptSets: imagingOrderableConceptSets,
32
- })
41
+ launchAddLabOrder(
42
+ {
43
+ orderTypeUuid: imagingOrderTypeUuid,
44
+ orderableConceptSets: imagingOrderableConceptSets,
45
+ },
46
+ windowProps,
47
+ groupProps,
48
+ )
33
49
  }
34
50
  />
35
51
  </Layer>
@@ -41,10 +57,14 @@ const RadiologyAndImagingTable: React.FC<RadiologyAndImagingTableProps> = ({ ord
41
57
  title={t('radiologyAndImagingOrders', 'Radiology & Imaging Orders')}
42
58
  orders={orders}
43
59
  onAdd={() =>
44
- launchAddLabOrder({
45
- orderTypeUuid: imagingOrderTypeUuid,
46
- orderableConceptSets: imagingOrderableConceptSets,
47
- })
60
+ launchAddLabOrder(
61
+ {
62
+ orderTypeUuid: imagingOrderTypeUuid,
63
+ orderableConceptSets: imagingOrderableConceptSets,
64
+ },
65
+ windowProps,
66
+ groupProps,
67
+ )
48
68
  }
49
69
  containerClassName={styles.labTableContainer}
50
70
  tableCellClassName={styles.tableCell}
@@ -1,7 +1,7 @@
1
1
  import React from 'react';
2
2
  import { useConfig } from '@openmrs/esm-framework';
3
3
  import OrdersTabs from '../../shared/orders/OrdersTabs';
4
- import LabTable from './radiology-and-imaging-table.component';
4
+ import RadiologyAndImagingTable from './radiology-and-imaging-table.component';
5
5
  import { ExpressWorkflowConfig } from '../../config-schema';
6
6
 
7
7
  type RadiologyAndImagingTabsProps = {
@@ -20,7 +20,7 @@ const RadiologyAndImagingTabs: React.FC<RadiologyAndImagingTabsProps> = ({ patie
20
20
  resultsSlotName="ewf-radiology-and-imaging-results-slot"
21
21
  orderTypeUuid={imagingOrderTypeUuid}
22
22
  filter={(order) => order.concept?.conceptClass?.uuid === imagingRadiologyConceptClassUuid}
23
- Table={({ orders }) => <LabTable orders={orders} />}
23
+ Table={({ orders }) => <RadiologyAndImagingTable orders={orders} patientUuid={patientUuid} patient={patient} />}
24
24
  />
25
25
  );
26
26
  };