ui-soxo-bootstrap-core 2.6.40-dev.1 → 2.6.40-dev.12

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 (420) hide show
  1. package/.babelrc +8 -8
  2. package/.github/workflows/npm-publish.yml +5 -4
  3. package/.husky/pre-commit +11 -11
  4. package/.prettierrc.json +10 -10
  5. package/DEVELOPER_GUIDE.md +323 -323
  6. package/PUBLISHING.md +333 -0
  7. package/babel.config.js +2 -2
  8. package/core/components/component-loader/component-loader.js +125 -125
  9. package/core/components/component-wrapper/component-wrapper.js +121 -121
  10. package/core/components/external-window/DEVELOPER_GUIDE.md +705 -705
  11. package/core/components/external-window/external-window.js +236 -236
  12. package/core/components/external-window/external-window.test.js +80 -80
  13. package/core/components/extra-info/extra-info-details.js +155 -155
  14. package/core/components/extra-info/extra-info-details.scss +26 -26
  15. package/core/components/extra-info/extra-info.js +134 -134
  16. package/core/components/index.js +12 -12
  17. package/core/components/landing-api/landing-api.js +707 -707
  18. package/core/components/landing-api/landing-api.scss +41 -41
  19. package/core/components/license-management/license-alert.js +97 -97
  20. package/core/components/menu-template-api/menu-template-api.js +321 -321
  21. package/core/components/root-application-api/root-application-api.js +174 -174
  22. package/core/index.js +13 -13
  23. package/core/lib/Store.js +369 -369
  24. package/core/lib/components/application-bootstrap/application-bootstrap.js +115 -115
  25. package/core/lib/components/approval-form/approval-form.js +280 -280
  26. package/core/lib/components/approval-form/approval-form.scss +183 -183
  27. package/core/lib/components/approval-list/approval-list.js +143 -143
  28. package/core/lib/components/approval-list/approval-list.scss +2 -2
  29. package/core/lib/components/approval-list/components/request-card/request-card.js +42 -42
  30. package/core/lib/components/approval-list/components/request-card/request-card.scss +30 -30
  31. package/core/lib/components/camera/camera.js +230 -230
  32. package/core/lib/components/camera/camera.scss +86 -86
  33. package/core/lib/components/comment-block/comment-block.js +138 -138
  34. package/core/lib/components/comment-block/comment-block.scss +3 -3
  35. package/core/lib/components/confirm-modal/confirm-modal.js +82 -82
  36. package/core/lib/components/confirm-modal/confirm-modal.scss +2 -2
  37. package/core/lib/components/consent/consent.js +67 -67
  38. package/core/lib/components/consent/pdf-signature.js +299 -299
  39. package/core/lib/components/consent/signature-pad.js +90 -90
  40. package/core/lib/components/consent/signature-pad.scss +14 -14
  41. package/core/lib/components/file-upload/file-upload.js +133 -133
  42. package/core/lib/components/finger-print-reader/finger-print-reader.js +295 -295
  43. package/core/lib/components/finger-print-reader/finger-print-reader.scss +47 -47
  44. package/core/lib/components/finger-print-search/finger-print-search.js +200 -200
  45. package/core/lib/components/finger-print-search/finger-print-search.scss +47 -47
  46. package/core/lib/components/global-header/animations.js +18 -18
  47. package/core/lib/components/global-header/global-header.js +286 -286
  48. package/core/lib/components/global-header/global-header.scss +397 -397
  49. package/core/lib/components/header/generic-header.js +76 -76
  50. package/core/lib/components/header/generic-header.scss +99 -99
  51. package/core/lib/components/image-preview/image-preview.js +33 -33
  52. package/core/lib/components/image-wrapper/image-wrapper.js +108 -108
  53. package/core/lib/components/image-wrapper/image-wrapper.scss +12 -12
  54. package/core/lib/components/index.js +206 -206
  55. package/core/lib/components/landing/landing.js +403 -403
  56. package/core/lib/components/language-switcher/language-switcher.js +49 -49
  57. package/core/lib/components/menu-context/menu-context.js +69 -69
  58. package/core/lib/components/menu-template/menu-template.js +249 -249
  59. package/core/lib/components/menu-template/menu-template.scss +9 -9
  60. package/core/lib/components/modal-search/modal-search.js +153 -153
  61. package/core/lib/components/modal-search/modal-search.scss +78 -78
  62. package/core/lib/components/modal-wrapper/modal-manager.js +15 -15
  63. package/core/lib/components/modal-wrapper/modal-wrapper.js +108 -108
  64. package/core/lib/components/modal-wrapper/modal-wrapper.scss +13 -13
  65. package/core/lib/components/notice-board/notice-board.js +132 -132
  66. package/core/lib/components/notice-board/notice-board.scss +65 -65
  67. package/core/lib/components/page-container/page-container.js +55 -55
  68. package/core/lib/components/page-container/page-container.scss +8 -8
  69. package/core/lib/components/page-header/page-header.js +23 -23
  70. package/core/lib/components/page-header/page-header.scss +17 -17
  71. package/core/lib/components/pdf-viewer/pdf-viewer.js +56 -56
  72. package/core/lib/components/portlet-table/components/table-actions/table-actions.js +58 -58
  73. package/core/lib/components/portlet-table/components/table-actions/table-actions.scss +1 -1
  74. package/core/lib/components/portlet-table/components/table-data/table-data.js +106 -106
  75. package/core/lib/components/portlet-table/portlet-table.js +63 -63
  76. package/core/lib/components/portlet-table/portlet-table.scss +90 -90
  77. package/core/lib/components/progress-bar/progress-bar.js +58 -58
  78. package/core/lib/components/progress-bar/progress-bar.scss +15 -15
  79. package/core/lib/components/request-form/request-form.js +110 -110
  80. package/core/lib/components/root-application/root-application.js +70 -70
  81. package/core/lib/components/rupee/rupee.js +14 -14
  82. package/core/lib/components/script-input/script-input.js +169 -169
  83. package/core/lib/components/script-input/script-input.scss +8 -8
  84. package/core/lib/components/sidemenu/animations.js +51 -51
  85. package/core/lib/components/sidemenu/sidemenu.js +713 -713
  86. package/core/lib/components/sidemenu/sidemenu.scss +314 -314
  87. package/core/lib/components/spotlight-search/spotlight-search.component.js +635 -635
  88. package/core/lib/components/spotlight-search/spotlight-search.component.scss +78 -78
  89. package/core/lib/components/table-wrapper/table-wrapper.js +135 -135
  90. package/core/lib/components/table-wrapper/table-wrapper.scss +72 -72
  91. package/core/lib/components/ui_elements/Loader.js +12 -12
  92. package/core/lib/components/ui_elements/Notify.js +12 -12
  93. package/core/lib/components/ui_elements/PlaceHolder.js +33 -33
  94. package/core/lib/components/web-camera/web-camera.js +161 -161
  95. package/core/lib/components/web-camera/web-camera.scss +28 -28
  96. package/core/lib/core.md +9 -9
  97. package/core/lib/elements/Elements.md +2 -2
  98. package/core/lib/elements/basic/LoggedUserRedirect.js +21 -21
  99. package/core/lib/elements/basic/PrivateRoute.js +16 -16
  100. package/core/lib/elements/basic/button/Button.md +43 -43
  101. package/core/lib/elements/basic/button/button.js +170 -170
  102. package/core/lib/elements/basic/card/Card.md +15 -15
  103. package/core/lib/elements/basic/card/card.js +40 -40
  104. package/core/lib/elements/basic/card/card.scss +13 -13
  105. package/core/lib/elements/basic/checkbox/checkbox.js +23 -23
  106. package/core/lib/elements/basic/col/col.js +15 -15
  107. package/core/lib/elements/basic/copy-to-clipboard/Readme.md +40 -40
  108. package/core/lib/elements/basic/copy-to-clipboard/copy-to-clipboard.js +61 -61
  109. package/core/lib/elements/basic/country-phone-input/Readme.md +98 -98
  110. package/core/lib/elements/basic/country-phone-input/country-phone-input.js +81 -81
  111. package/core/lib/elements/basic/country-phone-input/phone-input.scss +75 -75
  112. package/core/lib/elements/basic/datepicker/datepicker.js +33 -33
  113. package/core/lib/elements/basic/dragabble-wrapper/draggable-wrapper.js +203 -203
  114. package/core/lib/elements/basic/empty/empty.js +14 -14
  115. package/core/lib/elements/basic/fingerprint-protrected/fingerprint-protected.js +118 -118
  116. package/core/lib/elements/basic/fingerprint-protrected/fingerprint-protected.scss +10 -10
  117. package/core/lib/elements/basic/form/form.js +70 -70
  118. package/core/lib/elements/basic/form/form.scss +3 -3
  119. package/core/lib/elements/basic/image/image.js +45 -45
  120. package/core/lib/elements/basic/image/image.scss +17 -17
  121. package/core/lib/elements/basic/image/readme.md +26 -26
  122. package/core/lib/elements/basic/image-viewer/image-viewer.js +108 -108
  123. package/core/lib/elements/basic/image-viewer/image-viewer.scss +7 -7
  124. package/core/lib/elements/basic/input/input.js +81 -81
  125. package/core/lib/elements/basic/input/readme.md +77 -77
  126. package/core/lib/elements/basic/json-input/json-input.js +51 -51
  127. package/core/lib/elements/basic/menu-dashboard/menu-dashboard.js +216 -216
  128. package/core/lib/elements/basic/menu-dashboard/menu-dashboard.scss +28 -28
  129. package/core/lib/elements/basic/menu-tree/menu-tree.js +127 -127
  130. package/core/lib/elements/basic/modal/modal.js +64 -64
  131. package/core/lib/elements/basic/modal/readme.md +62 -62
  132. package/core/lib/elements/basic/popconfirm/popconfirm.js +17 -17
  133. package/core/lib/elements/basic/popover/popover.js +12 -12
  134. package/core/lib/elements/basic/radio/radio.js +18 -18
  135. package/core/lib/elements/basic/rangepicker/rangepicker.js +141 -141
  136. package/core/lib/elements/basic/rangepicker/rangepicker.scss +24 -24
  137. package/core/lib/elements/basic/rangepicker/readme.md +81 -81
  138. package/core/lib/elements/basic/reference-select/readme.md +18 -18
  139. package/core/lib/elements/basic/reference-select/reference-select.js +337 -337
  140. package/core/lib/elements/basic/row/row.js +15 -15
  141. package/core/lib/elements/basic/select/select.js +46 -46
  142. package/core/lib/elements/basic/select-box/readme.md +52 -52
  143. package/core/lib/elements/basic/select-box/select-box.js +63 -63
  144. package/core/lib/elements/basic/skeleton/readme.md +35 -35
  145. package/core/lib/elements/basic/skeleton/skeleton.js +35 -35
  146. package/core/lib/elements/basic/skeleton/skeleton.scss +53 -53
  147. package/core/lib/elements/basic/space/space.js +12 -12
  148. package/core/lib/elements/basic/switch/readme.md +29 -29
  149. package/core/lib/elements/basic/switch/switch.js +67 -67
  150. package/core/lib/elements/basic/tab/tab.js +14 -14
  151. package/core/lib/elements/basic/table/readme.md +8 -8
  152. package/core/lib/elements/basic/table/table.js +95 -95
  153. package/core/lib/elements/basic/tag/tag.js +63 -63
  154. package/core/lib/elements/basic/tag/tag.scss +2 -2
  155. package/core/lib/elements/basic/timeline/timeline.js +13 -13
  156. package/core/lib/elements/basic/title/readme.md +20 -20
  157. package/core/lib/elements/basic/title/title.js +37 -37
  158. package/core/lib/elements/basic/user-search/user-search.js +192 -192
  159. package/core/lib/elements/complex/barcode/barcode.js +27 -27
  160. package/core/lib/elements/complex/bargraph/bar-graph.js +262 -262
  161. package/core/lib/elements/complex/basic-table/basic-table.js +110 -110
  162. package/core/lib/elements/complex/basic-table/basic-table.scss +4 -4
  163. package/core/lib/elements/complex/date-display/date-display.js +37 -37
  164. package/core/lib/elements/complex/error-boundary/error-boundary.js +29 -29
  165. package/core/lib/elements/complex/google-location-input/map-container-library-load.js +92 -92
  166. package/core/lib/elements/complex/google-map/google-map.js +230 -230
  167. package/core/lib/elements/complex/google-map/google-map.scss +13 -13
  168. package/core/lib/elements/complex/line-graph/line-graph.js +108 -108
  169. package/core/lib/elements/complex/location-search-input/location-search-input.js +100 -100
  170. package/core/lib/elements/complex/pie-chart/pie-chart.js +202 -202
  171. package/core/lib/elements/complex/qr-code/qr-code.js +27 -27
  172. package/core/lib/elements/complex/qrscanner/qrscanner.js +57 -57
  173. package/core/lib/elements/complex/search-debounce/search-debounce.js +37 -37
  174. package/core/lib/elements/complex/statistic-card/dashboard-statistic-card.js +75 -75
  175. package/core/lib/elements/complex/statistic-card/statistic-card.js +28 -28
  176. package/core/lib/elements/index.js +226 -226
  177. package/core/lib/hooks/device-detect.js +25 -25
  178. package/core/lib/hooks/index.js +9 -9
  179. package/core/lib/hooks/use-location.js +33 -33
  180. package/core/lib/hooks/use-otp-timer.js +80 -80
  181. package/core/lib/hooks/use-window-size.js +34 -34
  182. package/core/lib/i18n.js +69 -69
  183. package/core/lib/index.js +106 -106
  184. package/core/lib/introduction.md +73 -73
  185. package/core/lib/js-styleguide.md +4112 -4112
  186. package/core/lib/models/actions/actions.js +127 -127
  187. package/core/lib/models/actions/components/action-detail/action-detail.js +190 -190
  188. package/core/lib/models/actions/components/custom-actions/custom-actions.js +185 -185
  189. package/core/lib/models/attachments/attachments.js +231 -231
  190. package/core/lib/models/base-loader.js +99 -99
  191. package/core/lib/models/base.js +716 -716
  192. package/core/lib/models/branches/branches.js +125 -125
  193. package/core/lib/models/checklists/checklists.js +114 -114
  194. package/core/lib/models/columns/columns.js +169 -169
  195. package/core/lib/models/columns/components/columns-add/columns-add.js +171 -171
  196. package/core/lib/models/comments/comments.js +213 -213
  197. package/core/lib/models/departments/departments.js +107 -107
  198. package/core/lib/models/financial-years/financial_years.js +127 -127
  199. package/core/lib/models/forms/components/form-creator/form-creator.js +665 -665
  200. package/core/lib/models/forms/components/form-creator/form-creator.scss +39 -39
  201. package/core/lib/models/forms/components/form-detail/form-detail.js +224 -224
  202. package/core/lib/models/forms/forms.js +121 -121
  203. package/core/lib/models/index.js +203 -203
  204. package/core/lib/models/invoice-numbers/invoice_numbers.js +204 -204
  205. package/core/lib/models/lookup-types/components/lookup-detail/lookup-detail.js +145 -145
  206. package/core/lib/models/lookup-types/lookup-types.js +113 -113
  207. package/core/lib/models/lookup-values/components/lookup-values-add/lookup-values-add.js +126 -126
  208. package/core/lib/models/lookup-values/lookup-values.js +107 -107
  209. package/core/lib/models/menu-roles/menu-roles.js +127 -127
  210. package/core/lib/models/menus/components/menu-add/menu-add.js +228 -228
  211. package/core/lib/models/menus/components/menu-detail/menu-detail.js +170 -170
  212. package/core/lib/models/menus/components/menu-list/menu-list.js +550 -550
  213. package/core/lib/models/menus/components/menu-list/menu-list.scss +5 -5
  214. package/core/lib/models/menus/components/menu-roles-add/menu-roles-add.js +183 -183
  215. package/core/lib/models/menus/menus.js +499 -499
  216. package/core/lib/models/models/components/model-detail/model-detail.js +137 -137
  217. package/core/lib/models/models/components/models.js +128 -128
  218. package/core/lib/models/modules/modules.js +204 -204
  219. package/core/lib/models/outbox/outbox.js +73 -73
  220. package/core/lib/models/pages/pages.js +107 -107
  221. package/core/lib/models/permissions/permissions.js +71 -71
  222. package/core/lib/models/process/components/process-add/process-add.js +181 -181
  223. package/core/lib/models/process/components/process-dashboard/process-dashboard.js +1068 -1068
  224. package/core/lib/models/process/components/process-dashboard/process-dashboard.scss +66 -66
  225. package/core/lib/models/process/components/process-detail/process-detail.js +140 -140
  226. package/core/lib/models/process/components/process-timeline/process-timeline.js +139 -139
  227. package/core/lib/models/process/components/task-detail/task-detail.js +240 -240
  228. package/core/lib/models/process/components/task-detail/task-detail.scss +27 -27
  229. package/core/lib/models/process/components/task-form/task-form.js +528 -528
  230. package/core/lib/models/process/components/task-form/task-form.scss +7 -7
  231. package/core/lib/models/process/components/task-list/task-list.js +221 -221
  232. package/core/lib/models/process/components/task-list/task-list.scss +14 -14
  233. package/core/lib/models/process/components/task-overview/task-overview.js +299 -299
  234. package/core/lib/models/process/components/task-overview-legacy/task-overview-legacy.js +192 -192
  235. package/core/lib/models/process/components/task-routes/task-routes.js +45 -45
  236. package/core/lib/models/process/components/task-status/task-status.js +175 -175
  237. package/core/lib/models/process/components/task-status/task-status.scss +11 -11
  238. package/core/lib/models/process/process.js +780 -780
  239. package/core/lib/models/process-transactions/process-transactions.js +123 -123
  240. package/core/lib/models/roles/roles.js +106 -106
  241. package/core/lib/models/scripts/scripts.js +111 -111
  242. package/core/lib/models/step-transactions/step-transcations.js +147 -147
  243. package/core/lib/models/steps/components/step-add/step-add.js +261 -261
  244. package/core/lib/models/steps/components/step-detail/step-detail.js +157 -157
  245. package/core/lib/models/steps/steps.js +356 -356
  246. package/core/lib/models/user-preferences/user-preferences.js +83 -83
  247. package/core/lib/models/users/components/user-add/user-add.js +226 -226
  248. package/core/lib/models/users/users.js +119 -119
  249. package/core/lib/modules/business/launch-page/launch-page.js +29 -29
  250. package/core/lib/modules/business/launch-page/launch-page.scss +5 -5
  251. package/core/lib/modules/business/slots/slots.js +231 -231
  252. package/core/lib/modules/business/slots/slots.scss +108 -108
  253. package/core/lib/modules/forms/components/field-customizer/field-customizer.js +138 -138
  254. package/core/lib/modules/forms/components/field-selector/field-selector.js +157 -157
  255. package/core/lib/modules/forms/components/field-selector/field-selector.scss +25 -25
  256. package/core/lib/modules/forms/components/form-display/form-display.js +203 -203
  257. package/core/lib/modules/forms/components/form-display/form-display.scss +9 -9
  258. package/core/lib/modules/forms/components/tab-customizer/tab-customizer.js +124 -124
  259. package/core/lib/modules/generic/generic-add/generic-add.js +213 -213
  260. package/core/lib/modules/generic/generic-detail/generic-detail.js +199 -199
  261. package/core/lib/modules/generic/generic-edit/generic-edit.js +120 -120
  262. package/core/lib/modules/generic/generic-list/ExportReactCSV.js +414 -414
  263. package/core/lib/modules/generic/generic-list/generic-list.js +705 -705
  264. package/core/lib/modules/generic/generic-list/generic-list.scss +68 -68
  265. package/core/lib/modules/generic/generic-upload/generic-upload.js +483 -483
  266. package/core/lib/modules/generic/table-settings/table-settings.js +226 -226
  267. package/core/lib/modules/generic/table-settings/table-settings.scss +37 -37
  268. package/core/lib/modules/index.js +52 -52
  269. package/core/lib/modules/modules-routes/module-routes.js +35 -35
  270. package/core/lib/pages/change-password/change-password.js +204 -204
  271. package/core/lib/pages/change-password/change-password.scss +73 -73
  272. package/core/lib/pages/homepage/homepage.js +53 -53
  273. package/core/lib/pages/index.js +19 -19
  274. package/core/lib/pages/login/commnication-mode-selection.js +46 -46
  275. package/core/lib/pages/login/communication-mode-selection.scss +60 -60
  276. package/core/lib/pages/login/login.js +872 -872
  277. package/core/lib/pages/login/login.scss +353 -353
  278. package/core/lib/pages/login/reset-password.js +124 -124
  279. package/core/lib/pages/login/reset-password.scss +31 -31
  280. package/core/lib/pages/manage-users/manage-users.js +429 -429
  281. package/core/lib/pages/manage-users/manage-users.scss +25 -25
  282. package/core/lib/pages/profile/profile.js +247 -247
  283. package/core/lib/pages/profile/profile.scss +107 -107
  284. package/core/lib/pages/profile/theme-config.js +18 -18
  285. package/core/lib/pages/profile/themes-backup.json +310 -310
  286. package/core/lib/pages/profile/themes.json +254 -254
  287. package/core/lib/pages/register/register.js +176 -176
  288. package/core/lib/pages/register/register.scss +128 -128
  289. package/core/lib/react-styleguide.md +756 -756
  290. package/core/lib/utils/api/api.utils.js +207 -207
  291. package/core/lib/utils/api/readme.md +426 -426
  292. package/core/lib/utils/async.js +35 -35
  293. package/core/lib/utils/common/common.utils.js +237 -237
  294. package/core/lib/utils/common/readme.md +30 -30
  295. package/core/lib/utils/date/date.utils.js +295 -295
  296. package/core/lib/utils/date/readme.md +2 -2
  297. package/core/lib/utils/firebase.support.utils.js +98 -98
  298. package/core/lib/utils/firebase.utils.js +808 -808
  299. package/core/lib/utils/font-awesome.utils.js +168 -168
  300. package/core/lib/utils/form/form.utils.js +255 -255
  301. package/core/lib/utils/generic/generic.utils.js +70 -70
  302. package/core/lib/utils/http/auth.helper.js +95 -95
  303. package/core/lib/utils/http/http.utils.js +186 -186
  304. package/core/lib/utils/http/readme.md +14 -14
  305. package/core/lib/utils/index.js +43 -43
  306. package/core/lib/utils/location/location.utils.js +137 -137
  307. package/core/lib/utils/location/readme.md +18 -18
  308. package/core/lib/utils/modal.utils.js +15 -15
  309. package/core/lib/utils/notification.utils.js +34 -34
  310. package/core/lib/utils/pwa/pwa.utils.js +88 -88
  311. package/core/lib/utils/script.utils.js +235 -235
  312. package/core/lib/utils/setting.utils.js +68 -68
  313. package/core/lib/utils/upload.utils.js +29 -29
  314. package/core/models/Preference/Preferences.js +46 -46
  315. package/core/models/base/base.js +403 -403
  316. package/core/models/base-clone-loader.js +107 -107
  317. package/core/models/base-clone.js +187 -187
  318. package/core/models/base-loader.js +97 -97
  319. package/core/models/core-scripts/core-scripts.js +179 -179
  320. package/core/models/dashboard/dashboard.js +201 -201
  321. package/core/models/detail-loader.js +88 -88
  322. package/core/models/doctor/components/doctor-add/doctor-add.js +432 -432
  323. package/core/models/doctor/components/doctor-add/doctor-add.scss +32 -32
  324. package/core/models/groups.js +82 -82
  325. package/core/models/index.js +100 -100
  326. package/core/models/lookup-types/components/lookup-detail/lookup-detail.js +129 -129
  327. package/core/models/lookup-types/lookup-types.js +96 -96
  328. package/core/models/lookup-values/components/lookup-values-modal/lookup-values-modal.js +95 -95
  329. package/core/models/lookup-values/lookup-values.js +92 -92
  330. package/core/models/menu-roles/components/menu-roles-add/menu-roles-add.js +153 -153
  331. package/core/models/menu-roles/menu-roles.js +158 -158
  332. package/core/models/menus/components/menu-add/menu-add.js +288 -288
  333. package/core/models/menus/components/menu-add/menu-add.scss +31 -31
  334. package/core/models/menus/components/menu-detail/menu-detail.js +263 -263
  335. package/core/models/menus/components/menu-list/menu-list.js +392 -392
  336. package/core/models/menus/components/menu-lists/menu-lists.js +635 -584
  337. package/core/models/menus/components/menu-lists/menu-lists.scss +46 -46
  338. package/core/models/menus/menus.js +338 -338
  339. package/core/models/model-columns.js +121 -121
  340. package/core/models/models/components/model-detail/model-add.js +120 -120
  341. package/core/models/models/components/model-detail/model-detail.js +133 -133
  342. package/core/models/models/models.js +154 -154
  343. package/core/models/pages/components/page-add/page-add.js +163 -163
  344. package/core/models/pages/components/page-add/page-add.scss +30 -30
  345. package/core/models/pages/components/page-details/page-details.js +209 -209
  346. package/core/models/pages/components/page-list/page-list.js +248 -248
  347. package/core/models/pages/pages.js +142 -142
  348. package/core/models/pages.js +142 -142
  349. package/core/models/roles/components/role-add/menu-label.js +14 -14
  350. package/core/models/roles/components/role-add/menu-tree.js +127 -127
  351. package/core/models/roles/components/role-add/role-add.js +222 -222
  352. package/core/models/roles/components/role-add/role-add.scss +4 -4
  353. package/core/models/roles/components/role-list/role-list.js +406 -406
  354. package/core/models/roles/roles.js +196 -196
  355. package/core/models/staff/components/staff-add/staff-add.js +455 -455
  356. package/core/models/user-roles/components/user-roles-add/user-roles-add.js +149 -149
  357. package/core/models/user-roles/user-roles.js +113 -113
  358. package/core/models/users/components/assign-role/assign-role.js +428 -428
  359. package/core/models/users/components/assign-role/assign-role.scss +281 -281
  360. package/core/models/users/components/assign-role/avatar-props.js +45 -45
  361. package/core/models/users/components/user-add/user-add.js +847 -847
  362. package/core/models/users/components/user-add/user-edit.js +110 -110
  363. package/core/models/users/components/user-detail/user-detail.js +236 -236
  364. package/core/models/users/components/user-list/user-list.js +397 -397
  365. package/core/models/users/users.js +379 -379
  366. package/core/modules/Informations/change-info/change-info.js +618 -618
  367. package/core/modules/Informations/change-info/change-info.scss +134 -134
  368. package/core/modules/dashboard/components/dashboard-card/animations.js +64 -64
  369. package/core/modules/dashboard/components/dashboard-card/dashboard-card.js +197 -197
  370. package/core/modules/dashboard/components/dashboard-card/menu-dashboard-card.js +430 -430
  371. package/core/modules/dashboard/components/dashboard-card/menu-dashboard-card.scss +59 -59
  372. package/core/modules/dashboard/components/pop-query-dashboard/pop-query-dashboard.js +66 -66
  373. package/core/modules/generic/components/generic-add/generic-add.js +121 -121
  374. package/core/modules/generic/components/generic-add/generic-add.scss +13 -13
  375. package/core/modules/generic/components/generic-add-modal/generic-add-modal.js +125 -125
  376. package/core/modules/generic/components/generic-add-modal/generic-add-modal.scss +13 -13
  377. package/core/modules/generic/components/generic-detail/generic-detail.js +184 -184
  378. package/core/modules/generic/components/generic-detail/generic-detail.scss +25 -25
  379. package/core/modules/generic/components/generic-edit/generic-edit.js +123 -123
  380. package/core/modules/generic/components/generic-list/generic-list.js +335 -335
  381. package/core/modules/generic/components/generic-list/generic-list.scss +35 -35
  382. package/core/modules/index.js +42 -42
  383. package/core/modules/module-routes/module-routes.js +37 -37
  384. package/core/modules/reporting/components/index.js +6 -6
  385. package/core/modules/reporting/components/reporting-dashboard/README.md +316 -316
  386. package/core/modules/reporting/components/reporting-dashboard/adavance-search/advance-search.js +271 -271
  387. package/core/modules/reporting/components/reporting-dashboard/adavance-search/advance-search.scss +76 -76
  388. package/core/modules/reporting/components/reporting-dashboard/display-columns/build-display-columns.js +90 -90
  389. package/core/modules/reporting/components/reporting-dashboard/display-columns/build-display-columns.test.js +74 -74
  390. package/core/modules/reporting/components/reporting-dashboard/display-columns/display-cell-renderer.js +449 -449
  391. package/core/modules/reporting/components/reporting-dashboard/display-columns/display-cell-renderer.test.js +199 -199
  392. package/core/modules/reporting/components/reporting-dashboard/reporting-dashboard.js +1116 -1116
  393. package/core/modules/reporting/components/reporting-dashboard/reporting-dashboard.scss +215 -215
  394. package/core/modules/reporting/components/reporting-dashboard/reporting-table.js +519 -519
  395. package/core/modules/steps/action-buttons.js +92 -92
  396. package/core/modules/steps/action-buttons.scss +62 -62
  397. package/core/modules/steps/chat-assistant.js +141 -141
  398. package/core/modules/steps/narration.js +192 -192
  399. package/core/modules/steps/openai-realtime.js +275 -275
  400. package/core/modules/steps/progress-storage.js +140 -140
  401. package/core/modules/steps/readme.md +167 -167
  402. package/core/modules/steps/steps.js +1567 -1567
  403. package/core/modules/steps/steps.scss +907 -907
  404. package/core/modules/steps/timeline.js +56 -56
  405. package/core/modules/steps/voice-navigation.js +709 -709
  406. package/core/pages/homepage-api/homepage-api.js +106 -106
  407. package/core/pages/homepage-api/homepage-api.scss +233 -233
  408. package/core/pages/homepage-api/menu-dashboard.js +169 -169
  409. package/core/pages/homepage-api/menu-dashboard.scss +11 -11
  410. package/core/translation.json +53 -53
  411. package/core/translations.json +19 -19
  412. package/core/utils/script.utils.js +129 -129
  413. package/core/utils/settings.utils.js +25 -25
  414. package/eslint.config.mjs +79 -79
  415. package/index.js +35 -35
  416. package/jest.config.js +7 -7
  417. package/jest.setup.js +1 -1
  418. package/package.json +124 -124
  419. package/tsconfig.json +26 -26
  420. package/webpack.config.js +173 -173
@@ -1,618 +1,618 @@
1
- /**
2
- * @description
3
- * @author Sneha
4
- *
5
- * The component used to change information
6
- *
7
- *
8
- */
9
-
10
- import React, { useState, useContext, useEffect } from 'react';
11
-
12
- import { Steps, message } from 'antd';
13
-
14
- import './change-info.scss';
15
-
16
- import { GlobalContext, FormCreator, Card,Button } from '../../../lib';
17
-
18
- import { CoreScripts, Preferences } from '../../../models';
19
-
20
- import PropTypes from 'prop-types';
21
-
22
- /**
23
- *
24
- * @param root0
25
- * @param root0.reportId
26
- * @param root0.preferenceId
27
- * @returns {*}
28
- */
29
- function ChangeInfo({ reportId, preferenceId }) {
30
- //Representing steps
31
-
32
- // Track the curren //Representing steps
33
- const { Step } = Steps;
34
-
35
- // Track the current step in the process
36
- const [currentStep, setCurrentStep] = useState(0);
37
-
38
- // Store details returned by coreScript
39
- const [paramterData, setParameterData] = useState([]);
40
-
41
- // Store title
42
- const [displayColumns, setdisplayColumns] = useState([]);
43
-
44
- // Store titles
45
- const [titleData, setTitleData] = useState();
46
-
47
- // Loading state
48
- const [loading, setLoading] = useState(true);
49
-
50
- // Store patients list
51
- const [information, setInformation] = useState([]);
52
-
53
- // Store selected patients
54
- const [selectedInformation, setSelectedInformation] = useState([]);
55
-
56
- // Retrieve global context data
57
- const { CustomModels = {} } = useContext(GlobalContext);
58
-
59
- const [titleContents, setTitleContents] = useState([]);
60
-
61
- /** Next step */
62
- const next = () => {
63
- setCurrentStep(currentStep + 1);
64
- };
65
-
66
- /** Previous step*/
67
- function prev() {
68
- //If currentstage is 2, beacuse we don't need setSelectedPatients there
69
- if (currentStep === 2) {
70
- // Clear selected patients when going back from step 2
71
- setSelectedInformation([]);
72
- }
73
-
74
- setCurrentStep(currentStep - 1);
75
- }
76
-
77
- /**
78
- * Fetch patient details when the component mountsGo back to the previous step
79
- */
80
- useEffect(() => {
81
- /**Get information */
82
- getInformation();
83
- }, []);
84
-
85
- /**
86
- * Function to fetch patient details from the backend
87
- */
88
- const getInformation = async () => {
89
- //CoreScript Id
90
- let id = reportId.selectId;
91
-
92
- //Getting records from coreScripts corresponding to the id
93
- CoreScripts.getRecord({ id }).then(({ result }) => {
94
- // Prepare input parameters for the form
95
- prepareInputParameters(result.input_parameters);
96
-
97
- // Set details from the fetched data
98
- setdisplayColumns(JSON.parse(result.display_columns));
99
-
100
- /**Fetching data from otherdetails */
101
- let otherDetails = JSON.parse(result.other_details1);
102
-
103
- /**Setting title datas */
104
- setTitleData(otherDetails);
105
- });
106
- };
107
-
108
- /**
109
- * Prepare input parameters for the form
110
- * @param {object} inputParameters
111
- */
112
- const prepareInputParameters = async (inputParameters) => {
113
- setLoading(true);
114
-
115
- // Parse input parameters
116
- let parameters = JSON.parse(inputParameters);
117
-
118
- // Map and set form content based on parameters and URL params
119
- parameters = await parameters.map((record) => {
120
- if (['reference-select', 'reference-search'].indexOf(record.type) !== -1) {
121
- /**Get custom model based on the model name */
122
- let model = CustomModels[record.modelName];
123
-
124
- return { ...record, model };
125
- } else {
126
- return { ...record };
127
- }
128
- });
129
-
130
- setLoading(false);
131
-
132
- // Set details with prepared parameters
133
- setParameterData([...parameters]);
134
- };
135
-
136
- /**
137
- * Handle form submission
138
- * @param {Object} values
139
- */
140
- const handleFormSubmit = async (values) => {
141
- //ID
142
- let id;
143
-
144
- //Formbody
145
- let formBody;
146
-
147
- //If there is selectedPatients we need to update the patient details
148
- if (currentStep === 2) {
149
- //CoreScript Id for updation
150
- id = reportId.editId;
151
-
152
- //Defining formbody
153
- formBody = {
154
- body: {
155
- // Values for replacing
156
- values,
157
-
158
- selectedData: selectedInformation,
159
- },
160
- };
161
-
162
- //Getting coreScript data for updation
163
- await CoreScripts.getUserDetailsLisitng(id, formBody).then((result) => {
164
- // let resultDetails = result;
165
-
166
- //If there is data and message is suceess
167
- if (result && result.message === 'sucess') {
168
- // Update information list
169
- setInformation(result);
170
-
171
- message.success(result.message);
172
-
173
- // Clear selectedData and reset to the first step
174
- setSelectedInformation([]);
175
-
176
- //Setting step back to init
177
- setCurrentStep(0);
178
- } else {
179
- message.warning(result.message);
180
- }
181
-
182
- setLoading(false);
183
- });
184
-
185
- {
186
- /**Else */
187
- }
188
- } else {
189
- /**If there is selectedInformation we need to update the patient details */
190
- formBody = { body: values };
191
-
192
- /**Id for getting coreScrpt data */
193
- id = reportId.selectId;
194
-
195
- //Getting coreScript data for getting
196
- await CoreScripts.getReportingLisitng(id, formBody).then((result) => {
197
- let resultDetails = result[0] || (result?.result && result?.result[0]);
198
-
199
- if (resultDetails) {
200
- // Update information list
201
- setInformation(resultDetails);
202
-
203
- // Proceed to the next step
204
- next();
205
- }
206
-
207
- setLoading(false);
208
- });
209
- }
210
-
211
- setLoading(true);
212
- };
213
-
214
- /**
215
- *
216
- * @param {*} newTitleContents
217
- */
218
- const handleTitleContentsUpdate = (newTitleContents) => {
219
- setTitleContents(newTitleContents);
220
- };
221
-
222
-
223
- /**
224
- * Handle patient selection
225
- * @param {Array} selected
226
- */
227
-
228
- /**
229
- *
230
- * @param selected
231
- */
232
- const handlePatientSelection = (selected) => {
233
- // Update selected patients
234
- setSelectedInformation(selected);
235
- };
236
-
237
- /**
238
- * Render through each stages
239
- *
240
- * @param {number} step
241
- * @returns {JSX.Element} The rendered component corresponding to the current step.
242
- */
243
- const renderSwitch = (step) => {
244
- switch (step) {
245
- case 0:
246
- return (
247
- <InitialContent
248
- selectedInformation={selectedInformation}
249
- next={next}
250
- prev={prev}
251
- fields={paramterData}
252
- selectedData={null}
253
- currentStep={currentStep}
254
- preferenceId={preferenceId}
255
- titleData={titleData}
256
- onSubmit={handleFormSubmit}
257
- onTitleContentsUpdate={handleTitleContentsUpdate}
258
- />
259
- );
260
-
261
- case 1:
262
- return <GuestDetails next={next} prev={prev} displayColumns={displayColumns} information={information} onSelect={handlePatientSelection} titleData={titleData} />;
263
-
264
- case 2:
265
- return (
266
- <>
267
- <div className="change-info-container">
268
- <div className="change-infoheader">{titleContents && titleContents.heading ? titleContents.heading : 'Current information'}</div>
269
-
270
- {/*Looping through selected data */}
271
- {selectedInformation.map((patient, index) => (
272
- <div key={index} className="info-items">
273
- {/** Matching the selected data with the display columns */}
274
- {displayColumns.map((detail, idx) => {
275
- //Display columns fieild
276
- const fieldName = detail.field;
277
-
278
- //MAatchined values
279
- const fieldValue = patient[fieldName];
280
-
281
- return (
282
- <div key={idx} className="info-field">
283
- <span>{detail.title}:</span>
284
-
285
- <span className="value">{fieldValue !== undefined ? fieldValue : 'N/A'}</span>
286
-
287
- {/** Selected data */}
288
- {patient.selected && <span className="selected">(selected)</span>}
289
- </div>
290
- );
291
- })}
292
- </div>
293
- ))}
294
-
295
- </div>
296
- <p>{titleContents?.notes}</p>
297
-
298
- <p>{selectedInformation[0]?.message}</p>
299
- <InitialContent
300
- next={next}
301
- prev={prev}
302
- selectedInformation={selectedInformation}
303
- fields={null}
304
- currentStep={currentStep}
305
- selectedData={selectedInformation}
306
- onSubmit={handleFormSubmit}
307
- preferenceId={preferenceId}
308
- onTitleContentsUpdate={handleTitleContentsUpdate}
309
- />
310
- </>
311
- );
312
-
313
- default:
314
- return (
315
- <InitialContent
316
- selectedInformation={selectedInformation}
317
- next={next}
318
- fields={paramterData}
319
- loading={loading}
320
- currentStep={currentStep}
321
- onSubmit={handleFormSubmit}
322
- onTitleContentsUpdate={handleTitleContentsUpdate}
323
- />
324
- );
325
- }
326
- };
327
-
328
- return (
329
- <Card className="change-profile-head">
330
-
331
- <Card className="change-profile">
332
- <Steps size="small" current={currentStep}>
333
- <Step title="Enter" />
334
-
335
- <Step title="Edit" />
336
-
337
- <Step title="Select" />
338
- </Steps>
339
- </Card>
340
-
341
- <FormContent renderSwitch={renderSwitch} currentStep={currentStep} />
342
- </Card>
343
- );
344
- }
345
-
346
- // Define PropTypes for the component
347
- ChangeInfo.propTypes = {
348
- reportId: PropTypes.object,
349
- preferenceId: PropTypes.number,
350
- };
351
-
352
- export default ChangeInfo;
353
-
354
- /**
355
- *
356
- * @param root0
357
- * @param root0.renderSwitch
358
- * @param root0.currentStep
359
- * @returns {JSX.Element} JSX content
360
- */
361
- function FormContent({ renderSwitch, currentStep }) {
362
- return (
363
- /* Rebder formConetent */
364
- <Card className="formcreator card">{renderSwitch(currentStep)}</Card>
365
- );
366
- }
367
-
368
- FormContent.propTypes = {
369
- renderSwitch: PropTypes.func.isRequired,
370
- currentStep: PropTypes.number,
371
- };
372
-
373
- /**
374
- * @param {Object}root0
375
- * @param root0.next
376
- * @param root0.prev
377
- * @param root0.fields
378
- * @param root0.selectedInformation
379
- * @param root0.titleData
380
- * @param root0.onSubmit
381
- * @param root0.selectedData
382
- * @param root0.currentStep
383
- * @param root0.preferenceId
384
- * @param root0.onTitleContentsUpdate
385
- * @returns {JSX.Element} JSX content
386
- */
387
- function InitialContent({ selectedInformation, next, prev, fields, onSubmit, selectedData, currentStep, preferenceId, titleData, onTitleContentsUpdate }) {
388
- /** @type {string} */
389
-
390
- let formLayout = 'inline';
391
-
392
- // Store preferences
393
- const [preference, setPreference] = useState({});
394
-
395
- const [titleContents, setTitleContents] = useState([]);
396
-
397
- /**
398
- * Fetch patient details if selected data exists.
399
- * @param {*}
400
- * @returns {*}
401
- */
402
- useEffect(() => {
403
- /**Cheaking if there is selectedData */
404
- if (selectedData && selectedData.length > 0) {
405
- getPatientDetail();
406
- }
407
- }, []);
408
-
409
- /**
410
- * Get details
411
- */
412
- const getPatientDetail = async () => {
413
- /** Defining preference id*/
414
- let id = preferenceId;
415
-
416
- Preferences.fillCustomInputData({ id }).then((result) => {
417
- setPreference(result.fields);
418
-
419
- setTitleContents(result)
420
-
421
- // Update the parent with titleContents
422
- if (onTitleContentsUpdate) {
423
- onTitleContentsUpdate(result);
424
- }
425
-
426
- return result;
427
- });
428
-
429
- // Preferences.getRecord({ id }).then(({ result }) => {
430
- // let data = JSON.parse(result.scope_value);
431
-
432
- // setPreference(data.fields);
433
-
434
- // return result;
435
- // });
436
- };
437
-
438
- /**
439
- * Render the form based on the details or preferences fetched
440
- *
441
- * @returns
442
- */
443
- const renderForm = () => {
444
- if ((fields && fields.length > 0) || (preference && preference.length > 0)) {
445
- return (
446
- <FormCreator
447
- selectedInformation={selectedInformation}
448
- layout={formLayout}
449
- initialValues={{ layout: formLayout }}
450
- styles={{ paddingRight: '15px', alignItems: 'center' }}
451
- fields={fields ? fields : preference}
452
- modelIndex="requestId"
453
- model={{ fields: fields ? fields : preference }}
454
- onSubmit={onSubmit}
455
- />
456
- );
457
- }
458
- };
459
-
460
- return (
461
- <div>
462
- {/* We use this page for step 0 and 1 but we need this part only for 0 */}
463
- {currentStep === 0 && titleData && (
464
- <div>
465
- <h4>{titleData.title}</h4>
466
-
467
- <p>{titleData.description}</p>
468
-
469
- <p>{titleData.message}</p>
470
- </div>
471
- )}
472
-
473
- {renderForm()}
474
-
475
- <div>
476
- {/* We use this page for step 0 and 2 but we need bacck button all stages except 0 */}
477
- {currentStep !== 0 && (
478
- <Button type="default" onClick={prev} style={{ marginTop: '20px', marginRight: '10px' }}>
479
- Back
480
- </Button>
481
- )}
482
-
483
- {/* We use this page for step 0 and 2 but we need this part only for 2 */}
484
- {currentStep === 1 && (
485
- <Button type="primary" onClick={next} style={{ marginTop: '20px', marginLeft: '10px' }}>
486
- Next
487
- </Button>
488
- )}
489
- </div>
490
- </div>
491
- );
492
- }
493
-
494
- InitialContent.propTypes = {
495
- next: PropTypes.func.isRequired,
496
- prev: PropTypes.func.isRequired,
497
- fields: PropTypes.array,
498
- onSubmit: PropTypes.func.isRequired,
499
- selectedData: PropTypes.array,
500
- selectedInformation: PropTypes.array.selectedInformation,
501
- currentStep: PropTypes.number.isRequired,
502
- preferenceId: PropTypes.number.isRequired,
503
- titleData: PropTypes.shape({
504
- title: PropTypes.title,
505
- description: PropTypes.description,
506
- message: PropTypes.message,
507
- }),
508
- };
509
-
510
- /**
511
- * Handles the step where users select patients
512
- * @param root0
513
- * @param root0.next
514
- * @param root0.prev
515
- * @param root0.information
516
- * @param root0.onSelect
517
- * @param root0.displayColumns
518
- * @param root0.titleData
519
- * @returns {JSX.Element} The rendered component corresponding to the data
520
- * Render renderAdditionalInfo
521
- */
522
- function GuestDetails({ next, prev, information, onSelect, displayColumns, titleData }) {
523
- // Track selected patients
524
- const [selectedInformation, setSelectedInformation] = useState([]);
525
-
526
- // Track selected checkbox
527
- const [selectedCheckbox, setSelectedCheckbox] = useState();
528
-
529
- /**
530
- *
531
- * @param {*} patient
532
- * @param {*} isChecked
533
- * @param {*} index
534
- */
535
- const handleCheckboxChange = (patient, isChecked, index) => {
536
- /**Cheaking if it is cheaked */
537
- if (isChecked) {
538
- // Set the selected checkbox by index
539
- setSelectedCheckbox(index);
540
-
541
- // Set the selectedInformation to only the current patient
542
- setSelectedInformation([patient]);
543
-
544
- // Trigger the onSelect function with the updated selection
545
- onSelect([patient]);
546
- }
547
- };
548
-
549
- /**
550
- * Render renderAdditionalInfo
551
- * @param {Array} data
552
- * @returns {object} displayColumns
553
- */
554
- const renderAdditionalInfo = (data) => {
555
- /* Matching selected data with the display columns */
556
- return displayColumns.map((detail, index) => {
557
- const fieldName = detail.field;
558
-
559
- return (
560
- <div key={index} className="selected-info-item">
561
- <span className="selected-info-field">{detail.title}:</span>
562
-
563
- <span className="selected-value">{data[fieldName] || 'N/A'}</span>
564
- </div>
565
- );
566
- });
567
- };
568
-
569
- return (
570
- <div className='middle-class'>
571
- <div className='content'><h3>{titleData?.content}</h3></div>
572
- <div>
573
- {/* If the coreScript data contains data */}
574
- {information && information.length > 0 ? (
575
- information.map((data, index) => (
576
- <Card className="change-info card" key={index} style={{ marginBottom: '10px' }}>
577
- <div className="change-info-details">
578
- <div className="change-info-patient-info">
579
- <input
580
- type="radio"
581
- className="patient-radio"
582
- checked={selectedCheckbox === index}
583
- onChange={(e) => handleCheckboxChange(data, e.target.checked, index)}
584
- />
585
- </div>
586
-
587
- <div className="additional-info">{renderAdditionalInfo(data)}</div>
588
- </div>
589
- </Card>
590
- ))
591
- ) : (
592
- <p>No patient data available</p>
593
- )}
594
- </div>
595
- <Button type="default" onClick={prev}>
596
- Back
597
- </Button>
598
-
599
- <Button
600
- type="primary"
601
- onClick={next}
602
- style={{ marginTop: '20px', marginLeft: '10px' }}
603
- // Disable button if no patients are selected
604
- disabled={selectedInformation.length === 0}
605
- >
606
- Edit Details
607
- </Button>
608
- </div>
609
- );
610
- }
611
-
612
- GuestDetails.propTypes = {
613
- next: PropTypes.func.isRequired,
614
- prev: PropTypes.func.isRequired,
615
- onSelect: PropTypes.array,
616
- displayColumns: PropTypes.object,
617
- information: PropTypes.array,
618
- };
1
+ /**
2
+ * @description
3
+ * @author Sneha
4
+ *
5
+ * The component used to change information
6
+ *
7
+ *
8
+ */
9
+
10
+ import React, { useState, useContext, useEffect } from 'react';
11
+
12
+ import { Steps, message } from 'antd';
13
+
14
+ import './change-info.scss';
15
+
16
+ import { GlobalContext, FormCreator, Card,Button } from '../../../lib';
17
+
18
+ import { CoreScripts, Preferences } from '../../../models';
19
+
20
+ import PropTypes from 'prop-types';
21
+
22
+ /**
23
+ *
24
+ * @param root0
25
+ * @param root0.reportId
26
+ * @param root0.preferenceId
27
+ * @returns {*}
28
+ */
29
+ function ChangeInfo({ reportId, preferenceId }) {
30
+ //Representing steps
31
+
32
+ // Track the curren //Representing steps
33
+ const { Step } = Steps;
34
+
35
+ // Track the current step in the process
36
+ const [currentStep, setCurrentStep] = useState(0);
37
+
38
+ // Store details returned by coreScript
39
+ const [paramterData, setParameterData] = useState([]);
40
+
41
+ // Store title
42
+ const [displayColumns, setdisplayColumns] = useState([]);
43
+
44
+ // Store titles
45
+ const [titleData, setTitleData] = useState();
46
+
47
+ // Loading state
48
+ const [loading, setLoading] = useState(true);
49
+
50
+ // Store patients list
51
+ const [information, setInformation] = useState([]);
52
+
53
+ // Store selected patients
54
+ const [selectedInformation, setSelectedInformation] = useState([]);
55
+
56
+ // Retrieve global context data
57
+ const { CustomModels = {} } = useContext(GlobalContext);
58
+
59
+ const [titleContents, setTitleContents] = useState([]);
60
+
61
+ /** Next step */
62
+ const next = () => {
63
+ setCurrentStep(currentStep + 1);
64
+ };
65
+
66
+ /** Previous step*/
67
+ function prev() {
68
+ //If currentstage is 2, beacuse we don't need setSelectedPatients there
69
+ if (currentStep === 2) {
70
+ // Clear selected patients when going back from step 2
71
+ setSelectedInformation([]);
72
+ }
73
+
74
+ setCurrentStep(currentStep - 1);
75
+ }
76
+
77
+ /**
78
+ * Fetch patient details when the component mountsGo back to the previous step
79
+ */
80
+ useEffect(() => {
81
+ /**Get information */
82
+ getInformation();
83
+ }, []);
84
+
85
+ /**
86
+ * Function to fetch patient details from the backend
87
+ */
88
+ const getInformation = async () => {
89
+ //CoreScript Id
90
+ let id = reportId.selectId;
91
+
92
+ //Getting records from coreScripts corresponding to the id
93
+ CoreScripts.getRecord({ id }).then(({ result }) => {
94
+ // Prepare input parameters for the form
95
+ prepareInputParameters(result.input_parameters);
96
+
97
+ // Set details from the fetched data
98
+ setdisplayColumns(JSON.parse(result.display_columns));
99
+
100
+ /**Fetching data from otherdetails */
101
+ let otherDetails = JSON.parse(result.other_details1);
102
+
103
+ /**Setting title datas */
104
+ setTitleData(otherDetails);
105
+ });
106
+ };
107
+
108
+ /**
109
+ * Prepare input parameters for the form
110
+ * @param {object} inputParameters
111
+ */
112
+ const prepareInputParameters = async (inputParameters) => {
113
+ setLoading(true);
114
+
115
+ // Parse input parameters
116
+ let parameters = JSON.parse(inputParameters);
117
+
118
+ // Map and set form content based on parameters and URL params
119
+ parameters = await parameters.map((record) => {
120
+ if (['reference-select', 'reference-search'].indexOf(record.type) !== -1) {
121
+ /**Get custom model based on the model name */
122
+ let model = CustomModels[record.modelName];
123
+
124
+ return { ...record, model };
125
+ } else {
126
+ return { ...record };
127
+ }
128
+ });
129
+
130
+ setLoading(false);
131
+
132
+ // Set details with prepared parameters
133
+ setParameterData([...parameters]);
134
+ };
135
+
136
+ /**
137
+ * Handle form submission
138
+ * @param {Object} values
139
+ */
140
+ const handleFormSubmit = async (values) => {
141
+ //ID
142
+ let id;
143
+
144
+ //Formbody
145
+ let formBody;
146
+
147
+ //If there is selectedPatients we need to update the patient details
148
+ if (currentStep === 2) {
149
+ //CoreScript Id for updation
150
+ id = reportId.editId;
151
+
152
+ //Defining formbody
153
+ formBody = {
154
+ body: {
155
+ // Values for replacing
156
+ values,
157
+
158
+ selectedData: selectedInformation,
159
+ },
160
+ };
161
+
162
+ //Getting coreScript data for updation
163
+ await CoreScripts.getUserDetailsLisitng(id, formBody).then((result) => {
164
+ // let resultDetails = result;
165
+
166
+ //If there is data and message is suceess
167
+ if (result && result.message === 'sucess') {
168
+ // Update information list
169
+ setInformation(result);
170
+
171
+ message.success(result.message);
172
+
173
+ // Clear selectedData and reset to the first step
174
+ setSelectedInformation([]);
175
+
176
+ //Setting step back to init
177
+ setCurrentStep(0);
178
+ } else {
179
+ message.warning(result.message);
180
+ }
181
+
182
+ setLoading(false);
183
+ });
184
+
185
+ {
186
+ /**Else */
187
+ }
188
+ } else {
189
+ /**If there is selectedInformation we need to update the patient details */
190
+ formBody = { body: values };
191
+
192
+ /**Id for getting coreScrpt data */
193
+ id = reportId.selectId;
194
+
195
+ //Getting coreScript data for getting
196
+ await CoreScripts.getReportingLisitng(id, formBody).then((result) => {
197
+ let resultDetails = result[0] || (result?.result && result?.result[0]);
198
+
199
+ if (resultDetails) {
200
+ // Update information list
201
+ setInformation(resultDetails);
202
+
203
+ // Proceed to the next step
204
+ next();
205
+ }
206
+
207
+ setLoading(false);
208
+ });
209
+ }
210
+
211
+ setLoading(true);
212
+ };
213
+
214
+ /**
215
+ *
216
+ * @param {*} newTitleContents
217
+ */
218
+ const handleTitleContentsUpdate = (newTitleContents) => {
219
+ setTitleContents(newTitleContents);
220
+ };
221
+
222
+
223
+ /**
224
+ * Handle patient selection
225
+ * @param {Array} selected
226
+ */
227
+
228
+ /**
229
+ *
230
+ * @param selected
231
+ */
232
+ const handlePatientSelection = (selected) => {
233
+ // Update selected patients
234
+ setSelectedInformation(selected);
235
+ };
236
+
237
+ /**
238
+ * Render through each stages
239
+ *
240
+ * @param {number} step
241
+ * @returns {JSX.Element} The rendered component corresponding to the current step.
242
+ */
243
+ const renderSwitch = (step) => {
244
+ switch (step) {
245
+ case 0:
246
+ return (
247
+ <InitialContent
248
+ selectedInformation={selectedInformation}
249
+ next={next}
250
+ prev={prev}
251
+ fields={paramterData}
252
+ selectedData={null}
253
+ currentStep={currentStep}
254
+ preferenceId={preferenceId}
255
+ titleData={titleData}
256
+ onSubmit={handleFormSubmit}
257
+ onTitleContentsUpdate={handleTitleContentsUpdate}
258
+ />
259
+ );
260
+
261
+ case 1:
262
+ return <GuestDetails next={next} prev={prev} displayColumns={displayColumns} information={information} onSelect={handlePatientSelection} titleData={titleData} />;
263
+
264
+ case 2:
265
+ return (
266
+ <>
267
+ <div className="change-info-container">
268
+ <div className="change-infoheader">{titleContents && titleContents.heading ? titleContents.heading : 'Current information'}</div>
269
+
270
+ {/*Looping through selected data */}
271
+ {selectedInformation.map((patient, index) => (
272
+ <div key={index} className="info-items">
273
+ {/** Matching the selected data with the display columns */}
274
+ {displayColumns.map((detail, idx) => {
275
+ //Display columns fieild
276
+ const fieldName = detail.field;
277
+
278
+ //MAatchined values
279
+ const fieldValue = patient[fieldName];
280
+
281
+ return (
282
+ <div key={idx} className="info-field">
283
+ <span>{detail.title}:</span>
284
+
285
+ <span className="value">{fieldValue !== undefined ? fieldValue : 'N/A'}</span>
286
+
287
+ {/** Selected data */}
288
+ {patient.selected && <span className="selected">(selected)</span>}
289
+ </div>
290
+ );
291
+ })}
292
+ </div>
293
+ ))}
294
+
295
+ </div>
296
+ <p>{titleContents?.notes}</p>
297
+
298
+ <p>{selectedInformation[0]?.message}</p>
299
+ <InitialContent
300
+ next={next}
301
+ prev={prev}
302
+ selectedInformation={selectedInformation}
303
+ fields={null}
304
+ currentStep={currentStep}
305
+ selectedData={selectedInformation}
306
+ onSubmit={handleFormSubmit}
307
+ preferenceId={preferenceId}
308
+ onTitleContentsUpdate={handleTitleContentsUpdate}
309
+ />
310
+ </>
311
+ );
312
+
313
+ default:
314
+ return (
315
+ <InitialContent
316
+ selectedInformation={selectedInformation}
317
+ next={next}
318
+ fields={paramterData}
319
+ loading={loading}
320
+ currentStep={currentStep}
321
+ onSubmit={handleFormSubmit}
322
+ onTitleContentsUpdate={handleTitleContentsUpdate}
323
+ />
324
+ );
325
+ }
326
+ };
327
+
328
+ return (
329
+ <Card className="change-profile-head">
330
+
331
+ <Card className="change-profile">
332
+ <Steps size="small" current={currentStep}>
333
+ <Step title="Enter" />
334
+
335
+ <Step title="Edit" />
336
+
337
+ <Step title="Select" />
338
+ </Steps>
339
+ </Card>
340
+
341
+ <FormContent renderSwitch={renderSwitch} currentStep={currentStep} />
342
+ </Card>
343
+ );
344
+ }
345
+
346
+ // Define PropTypes for the component
347
+ ChangeInfo.propTypes = {
348
+ reportId: PropTypes.object,
349
+ preferenceId: PropTypes.number,
350
+ };
351
+
352
+ export default ChangeInfo;
353
+
354
+ /**
355
+ *
356
+ * @param root0
357
+ * @param root0.renderSwitch
358
+ * @param root0.currentStep
359
+ * @returns {JSX.Element} JSX content
360
+ */
361
+ function FormContent({ renderSwitch, currentStep }) {
362
+ return (
363
+ /* Rebder formConetent */
364
+ <Card className="formcreator card">{renderSwitch(currentStep)}</Card>
365
+ );
366
+ }
367
+
368
+ FormContent.propTypes = {
369
+ renderSwitch: PropTypes.func.isRequired,
370
+ currentStep: PropTypes.number,
371
+ };
372
+
373
+ /**
374
+ * @param {Object}root0
375
+ * @param root0.next
376
+ * @param root0.prev
377
+ * @param root0.fields
378
+ * @param root0.selectedInformation
379
+ * @param root0.titleData
380
+ * @param root0.onSubmit
381
+ * @param root0.selectedData
382
+ * @param root0.currentStep
383
+ * @param root0.preferenceId
384
+ * @param root0.onTitleContentsUpdate
385
+ * @returns {JSX.Element} JSX content
386
+ */
387
+ function InitialContent({ selectedInformation, next, prev, fields, onSubmit, selectedData, currentStep, preferenceId, titleData, onTitleContentsUpdate }) {
388
+ /** @type {string} */
389
+
390
+ let formLayout = 'inline';
391
+
392
+ // Store preferences
393
+ const [preference, setPreference] = useState({});
394
+
395
+ const [titleContents, setTitleContents] = useState([]);
396
+
397
+ /**
398
+ * Fetch patient details if selected data exists.
399
+ * @param {*}
400
+ * @returns {*}
401
+ */
402
+ useEffect(() => {
403
+ /**Cheaking if there is selectedData */
404
+ if (selectedData && selectedData.length > 0) {
405
+ getPatientDetail();
406
+ }
407
+ }, []);
408
+
409
+ /**
410
+ * Get details
411
+ */
412
+ const getPatientDetail = async () => {
413
+ /** Defining preference id*/
414
+ let id = preferenceId;
415
+
416
+ Preferences.fillCustomInputData({ id }).then((result) => {
417
+ setPreference(result.fields);
418
+
419
+ setTitleContents(result)
420
+
421
+ // Update the parent with titleContents
422
+ if (onTitleContentsUpdate) {
423
+ onTitleContentsUpdate(result);
424
+ }
425
+
426
+ return result;
427
+ });
428
+
429
+ // Preferences.getRecord({ id }).then(({ result }) => {
430
+ // let data = JSON.parse(result.scope_value);
431
+
432
+ // setPreference(data.fields);
433
+
434
+ // return result;
435
+ // });
436
+ };
437
+
438
+ /**
439
+ * Render the form based on the details or preferences fetched
440
+ *
441
+ * @returns
442
+ */
443
+ const renderForm = () => {
444
+ if ((fields && fields.length > 0) || (preference && preference.length > 0)) {
445
+ return (
446
+ <FormCreator
447
+ selectedInformation={selectedInformation}
448
+ layout={formLayout}
449
+ initialValues={{ layout: formLayout }}
450
+ styles={{ paddingRight: '15px', alignItems: 'center' }}
451
+ fields={fields ? fields : preference}
452
+ modelIndex="requestId"
453
+ model={{ fields: fields ? fields : preference }}
454
+ onSubmit={onSubmit}
455
+ />
456
+ );
457
+ }
458
+ };
459
+
460
+ return (
461
+ <div>
462
+ {/* We use this page for step 0 and 1 but we need this part only for 0 */}
463
+ {currentStep === 0 && titleData && (
464
+ <div>
465
+ <h4>{titleData.title}</h4>
466
+
467
+ <p>{titleData.description}</p>
468
+
469
+ <p>{titleData.message}</p>
470
+ </div>
471
+ )}
472
+
473
+ {renderForm()}
474
+
475
+ <div>
476
+ {/* We use this page for step 0 and 2 but we need bacck button all stages except 0 */}
477
+ {currentStep !== 0 && (
478
+ <Button type="default" onClick={prev} style={{ marginTop: '20px', marginRight: '10px' }}>
479
+ Back
480
+ </Button>
481
+ )}
482
+
483
+ {/* We use this page for step 0 and 2 but we need this part only for 2 */}
484
+ {currentStep === 1 && (
485
+ <Button type="primary" onClick={next} style={{ marginTop: '20px', marginLeft: '10px' }}>
486
+ Next
487
+ </Button>
488
+ )}
489
+ </div>
490
+ </div>
491
+ );
492
+ }
493
+
494
+ InitialContent.propTypes = {
495
+ next: PropTypes.func.isRequired,
496
+ prev: PropTypes.func.isRequired,
497
+ fields: PropTypes.array,
498
+ onSubmit: PropTypes.func.isRequired,
499
+ selectedData: PropTypes.array,
500
+ selectedInformation: PropTypes.array.selectedInformation,
501
+ currentStep: PropTypes.number.isRequired,
502
+ preferenceId: PropTypes.number.isRequired,
503
+ titleData: PropTypes.shape({
504
+ title: PropTypes.title,
505
+ description: PropTypes.description,
506
+ message: PropTypes.message,
507
+ }),
508
+ };
509
+
510
+ /**
511
+ * Handles the step where users select patients
512
+ * @param root0
513
+ * @param root0.next
514
+ * @param root0.prev
515
+ * @param root0.information
516
+ * @param root0.onSelect
517
+ * @param root0.displayColumns
518
+ * @param root0.titleData
519
+ * @returns {JSX.Element} The rendered component corresponding to the data
520
+ * Render renderAdditionalInfo
521
+ */
522
+ function GuestDetails({ next, prev, information, onSelect, displayColumns, titleData }) {
523
+ // Track selected patients
524
+ const [selectedInformation, setSelectedInformation] = useState([]);
525
+
526
+ // Track selected checkbox
527
+ const [selectedCheckbox, setSelectedCheckbox] = useState();
528
+
529
+ /**
530
+ *
531
+ * @param {*} patient
532
+ * @param {*} isChecked
533
+ * @param {*} index
534
+ */
535
+ const handleCheckboxChange = (patient, isChecked, index) => {
536
+ /**Cheaking if it is cheaked */
537
+ if (isChecked) {
538
+ // Set the selected checkbox by index
539
+ setSelectedCheckbox(index);
540
+
541
+ // Set the selectedInformation to only the current patient
542
+ setSelectedInformation([patient]);
543
+
544
+ // Trigger the onSelect function with the updated selection
545
+ onSelect([patient]);
546
+ }
547
+ };
548
+
549
+ /**
550
+ * Render renderAdditionalInfo
551
+ * @param {Array} data
552
+ * @returns {object} displayColumns
553
+ */
554
+ const renderAdditionalInfo = (data) => {
555
+ /* Matching selected data with the display columns */
556
+ return displayColumns.map((detail, index) => {
557
+ const fieldName = detail.field;
558
+
559
+ return (
560
+ <div key={index} className="selected-info-item">
561
+ <span className="selected-info-field">{detail.title}:</span>
562
+
563
+ <span className="selected-value">{data[fieldName] || 'N/A'}</span>
564
+ </div>
565
+ );
566
+ });
567
+ };
568
+
569
+ return (
570
+ <div className='middle-class'>
571
+ <div className='content'><h3>{titleData?.content}</h3></div>
572
+ <div>
573
+ {/* If the coreScript data contains data */}
574
+ {information && information.length > 0 ? (
575
+ information.map((data, index) => (
576
+ <Card className="change-info card" key={index} style={{ marginBottom: '10px' }}>
577
+ <div className="change-info-details">
578
+ <div className="change-info-patient-info">
579
+ <input
580
+ type="radio"
581
+ className="patient-radio"
582
+ checked={selectedCheckbox === index}
583
+ onChange={(e) => handleCheckboxChange(data, e.target.checked, index)}
584
+ />
585
+ </div>
586
+
587
+ <div className="additional-info">{renderAdditionalInfo(data)}</div>
588
+ </div>
589
+ </Card>
590
+ ))
591
+ ) : (
592
+ <p>No patient data available</p>
593
+ )}
594
+ </div>
595
+ <Button type="default" onClick={prev}>
596
+ Back
597
+ </Button>
598
+
599
+ <Button
600
+ type="primary"
601
+ onClick={next}
602
+ style={{ marginTop: '20px', marginLeft: '10px' }}
603
+ // Disable button if no patients are selected
604
+ disabled={selectedInformation.length === 0}
605
+ >
606
+ Edit Details
607
+ </Button>
608
+ </div>
609
+ );
610
+ }
611
+
612
+ GuestDetails.propTypes = {
613
+ next: PropTypes.func.isRequired,
614
+ prev: PropTypes.func.isRequired,
615
+ onSelect: PropTypes.array,
616
+ displayColumns: PropTypes.object,
617
+ information: PropTypes.array,
618
+ };