ui-soxo-bootstrap-core 2.4.25-dev.41 → 2.4.25-dev.46

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 (394) hide show
  1. package/.babelrc +8 -8
  2. package/.github/workflows/npm-publish.yml +52 -55
  3. package/.husky/pre-commit +11 -11
  4. package/.prettierrc.json +10 -10
  5. package/babel.config.js +2 -2
  6. package/core/components/component-loader/component-loader.js +125 -125
  7. package/core/components/component-wrapper/component-wrapper.js +121 -121
  8. package/core/components/external-window/external-window.js +236 -236
  9. package/core/components/external-window/external-window.test.js +80 -80
  10. package/core/components/extra-info/extra-info-details.js +155 -155
  11. package/core/components/extra-info/extra-info-details.scss +26 -26
  12. package/core/components/extra-info/extra-info.js +134 -134
  13. package/core/components/index.js +20 -20
  14. package/core/components/landing-api/landing-api.js +492 -492
  15. package/core/components/landing-api/landing-api.scss +19 -19
  16. package/core/components/menu-template-api/menu-template-api.js +321 -321
  17. package/core/components/root-application-api/root-application-api.js +174 -174
  18. package/core/index.js +13 -13
  19. package/core/lib/Store.js +365 -365
  20. package/core/lib/components/application-bootstrap/application-bootstrap.js +115 -115
  21. package/core/lib/components/approval-form/approval-form.js +280 -280
  22. package/core/lib/components/approval-form/approval-form.scss +183 -183
  23. package/core/lib/components/approval-list/approval-list.js +143 -143
  24. package/core/lib/components/approval-list/approval-list.scss +2 -2
  25. package/core/lib/components/approval-list/components/request-card/request-card.js +42 -42
  26. package/core/lib/components/approval-list/components/request-card/request-card.scss +30 -30
  27. package/core/lib/components/camera/camera.js +230 -230
  28. package/core/lib/components/camera/camera.scss +86 -86
  29. package/core/lib/components/comment-block/comment-block.js +138 -138
  30. package/core/lib/components/comment-block/comment-block.scss +3 -3
  31. package/core/lib/components/confirm-modal/confirm-modal.js +82 -82
  32. package/core/lib/components/confirm-modal/confirm-modal.scss +2 -2
  33. package/core/lib/components/consent/consent.js +67 -67
  34. package/core/lib/components/consent/pdf-signature.js +299 -299
  35. package/core/lib/components/consent/signature-pad.js +90 -90
  36. package/core/lib/components/consent/signature-pad.scss +14 -14
  37. package/core/lib/components/file-upload/file-upload.js +133 -133
  38. package/core/lib/components/finger-print-reader/finger-print-reader.js +295 -295
  39. package/core/lib/components/finger-print-reader/finger-print-reader.scss +47 -47
  40. package/core/lib/components/finger-print-search/finger-print-search.js +200 -200
  41. package/core/lib/components/finger-print-search/finger-print-search.scss +47 -47
  42. package/core/lib/components/global-header/animations.js +18 -18
  43. package/core/lib/components/global-header/global-header.js +412 -412
  44. package/core/lib/components/global-header/global-header.scss +369 -369
  45. package/core/lib/components/header/generic-header.js +76 -76
  46. package/core/lib/components/header/generic-header.scss +99 -99
  47. package/core/lib/components/image-preview/image-preview.js +33 -33
  48. package/core/lib/components/image-wrapper/image-wrapper.js +108 -108
  49. package/core/lib/components/image-wrapper/image-wrapper.scss +12 -12
  50. package/core/lib/components/index.js +206 -206
  51. package/core/lib/components/landing/landing.js +403 -403
  52. package/core/lib/components/language-switcher/language-switcher.js +49 -49
  53. package/core/lib/components/menu-context/menu-context.js +69 -69
  54. package/core/lib/components/menu-template/menu-template.js +249 -249
  55. package/core/lib/components/menu-template/menu-template.scss +9 -9
  56. package/core/lib/components/modal-search/modal-search.js +153 -153
  57. package/core/lib/components/modal-search/modal-search.scss +78 -78
  58. package/core/lib/components/modal-wrapper/modal-manager.js +15 -15
  59. package/core/lib/components/modal-wrapper/modal-wrapper.js +108 -108
  60. package/core/lib/components/modal-wrapper/modal-wrapper.scss +13 -13
  61. package/core/lib/components/notice-board/notice-board.js +132 -132
  62. package/core/lib/components/notice-board/notice-board.scss +65 -65
  63. package/core/lib/components/page-container/page-container.js +55 -55
  64. package/core/lib/components/page-container/page-container.scss +8 -8
  65. package/core/lib/components/page-header/page-header.js +23 -23
  66. package/core/lib/components/page-header/page-header.scss +17 -17
  67. package/core/lib/components/pdf-viewer/pdf-viewer.js +56 -56
  68. package/core/lib/components/portlet-table/components/table-actions/table-actions.js +58 -58
  69. package/core/lib/components/portlet-table/components/table-actions/table-actions.scss +1 -1
  70. package/core/lib/components/portlet-table/components/table-data/table-data.js +106 -106
  71. package/core/lib/components/portlet-table/portlet-table.js +63 -63
  72. package/core/lib/components/portlet-table/portlet-table.scss +90 -90
  73. package/core/lib/components/progress-bar/progress-bar.js +58 -58
  74. package/core/lib/components/progress-bar/progress-bar.scss +15 -15
  75. package/core/lib/components/request-form/request-form.js +110 -110
  76. package/core/lib/components/root-application/root-application.js +70 -70
  77. package/core/lib/components/rupee/rupee.js +14 -14
  78. package/core/lib/components/script-input/script-input.js +169 -169
  79. package/core/lib/components/script-input/script-input.scss +8 -8
  80. package/core/lib/components/sidemenu/animations.js +51 -51
  81. package/core/lib/components/sidemenu/sidemenu.js +572 -572
  82. package/core/lib/components/sidemenu/sidemenu.scss +277 -277
  83. package/core/lib/components/spotlight-search/spotlight-search.component.js +635 -635
  84. package/core/lib/components/spotlight-search/spotlight-search.component.scss +78 -78
  85. package/core/lib/components/table-wrapper/table-wrapper.js +135 -135
  86. package/core/lib/components/table-wrapper/table-wrapper.scss +72 -72
  87. package/core/lib/components/ui_elements/Loader.js +12 -12
  88. package/core/lib/components/ui_elements/Notify.js +12 -12
  89. package/core/lib/components/ui_elements/PlaceHolder.js +33 -33
  90. package/core/lib/components/web-camera/web-camera.js +161 -161
  91. package/core/lib/components/web-camera/web-camera.scss +28 -28
  92. package/core/lib/core.md +9 -9
  93. package/core/lib/elements/Elements.md +2 -2
  94. package/core/lib/elements/basic/LoggedUserRedirect.js +21 -21
  95. package/core/lib/elements/basic/PrivateRoute.js +16 -16
  96. package/core/lib/elements/basic/button/Button.md +43 -43
  97. package/core/lib/elements/basic/button/button.js +170 -170
  98. package/core/lib/elements/basic/card/Card.md +15 -15
  99. package/core/lib/elements/basic/card/card.js +40 -40
  100. package/core/lib/elements/basic/card/card.scss +13 -13
  101. package/core/lib/elements/basic/checkbox/checkbox.js +23 -23
  102. package/core/lib/elements/basic/col/col.js +15 -15
  103. package/core/lib/elements/basic/copy-to-clipboard/Readme.md +40 -40
  104. package/core/lib/elements/basic/copy-to-clipboard/copy-to-clipboard.js +61 -61
  105. package/core/lib/elements/basic/country-phone-input/Readme.md +98 -98
  106. package/core/lib/elements/basic/country-phone-input/country-phone-input.js +106 -106
  107. package/core/lib/elements/basic/country-phone-input/phone-input.scss +61 -61
  108. package/core/lib/elements/basic/datepicker/datepicker.js +33 -33
  109. package/core/lib/elements/basic/dragabble-wrapper/draggable-wrapper.js +136 -136
  110. package/core/lib/elements/basic/empty/empty.js +14 -14
  111. package/core/lib/elements/basic/fingerprint-protrected/fingerprint-protected.js +118 -118
  112. package/core/lib/elements/basic/fingerprint-protrected/fingerprint-protected.scss +10 -10
  113. package/core/lib/elements/basic/form/form.js +70 -70
  114. package/core/lib/elements/basic/form/form.scss +3 -3
  115. package/core/lib/elements/basic/image/image.js +45 -45
  116. package/core/lib/elements/basic/image/image.scss +17 -17
  117. package/core/lib/elements/basic/image/readme.md +26 -26
  118. package/core/lib/elements/basic/image-viewer/image-viewer.js +108 -108
  119. package/core/lib/elements/basic/image-viewer/image-viewer.scss +7 -7
  120. package/core/lib/elements/basic/input/input.js +81 -81
  121. package/core/lib/elements/basic/input/readme.md +77 -77
  122. package/core/lib/elements/basic/json-input/json-input.js +51 -51
  123. package/core/lib/elements/basic/menu-dashboard/menu-dashboard.js +216 -216
  124. package/core/lib/elements/basic/menu-dashboard/menu-dashboard.scss +28 -28
  125. package/core/lib/elements/basic/menu-tree/menu-tree.js +114 -114
  126. package/core/lib/elements/basic/modal/modal.js +64 -64
  127. package/core/lib/elements/basic/modal/readme.md +62 -62
  128. package/core/lib/elements/basic/popconfirm/popconfirm.js +17 -17
  129. package/core/lib/elements/basic/popover/popover.js +12 -12
  130. package/core/lib/elements/basic/radio/radio.js +18 -18
  131. package/core/lib/elements/basic/rangepicker/rangepicker.js +141 -141
  132. package/core/lib/elements/basic/rangepicker/rangepicker.scss +24 -24
  133. package/core/lib/elements/basic/rangepicker/readme.md +81 -81
  134. package/core/lib/elements/basic/reference-select/readme.md +18 -18
  135. package/core/lib/elements/basic/reference-select/reference-select.js +337 -337
  136. package/core/lib/elements/basic/row/row.js +15 -15
  137. package/core/lib/elements/basic/select/select.js +46 -46
  138. package/core/lib/elements/basic/select-box/readme.md +52 -52
  139. package/core/lib/elements/basic/select-box/select-box.js +63 -63
  140. package/core/lib/elements/basic/skeleton/readme.md +35 -35
  141. package/core/lib/elements/basic/skeleton/skeleton.js +35 -35
  142. package/core/lib/elements/basic/skeleton/skeleton.scss +53 -53
  143. package/core/lib/elements/basic/space/space.js +12 -12
  144. package/core/lib/elements/basic/switch/readme.md +29 -29
  145. package/core/lib/elements/basic/switch/switch.js +67 -67
  146. package/core/lib/elements/basic/tab/tab.js +14 -14
  147. package/core/lib/elements/basic/table/readme.md +8 -8
  148. package/core/lib/elements/basic/table/table.js +100 -100
  149. package/core/lib/elements/basic/tag/tag.js +63 -63
  150. package/core/lib/elements/basic/tag/tag.scss +2 -2
  151. package/core/lib/elements/basic/timeline/timeline.js +13 -13
  152. package/core/lib/elements/basic/title/readme.md +20 -20
  153. package/core/lib/elements/basic/title/title.js +37 -37
  154. package/core/lib/elements/basic/user-search/user-search.js +192 -192
  155. package/core/lib/elements/complex/barcode/barcode.js +27 -27
  156. package/core/lib/elements/complex/bargraph/bar-graph.js +262 -262
  157. package/core/lib/elements/complex/basic-table/basic-table.js +110 -110
  158. package/core/lib/elements/complex/basic-table/basic-table.scss +4 -4
  159. package/core/lib/elements/complex/date-display/date-display.js +37 -37
  160. package/core/lib/elements/complex/error-boundary/error-boundary.js +29 -29
  161. package/core/lib/elements/complex/google-location-input/map-container-library-load.js +92 -92
  162. package/core/lib/elements/complex/google-map/google-map.js +230 -230
  163. package/core/lib/elements/complex/google-map/google-map.scss +13 -13
  164. package/core/lib/elements/complex/line-graph/line-graph.js +108 -108
  165. package/core/lib/elements/complex/location-search-input/location-search-input.js +100 -100
  166. package/core/lib/elements/complex/pie-chart/pie-chart.js +202 -202
  167. package/core/lib/elements/complex/qr-code/qr-code.js +27 -27
  168. package/core/lib/elements/complex/qrscanner/qrscanner.js +57 -57
  169. package/core/lib/elements/complex/search-debounce/search-debounce.js +37 -37
  170. package/core/lib/elements/complex/statistic-card/dashboard-statistic-card.js +75 -75
  171. package/core/lib/elements/complex/statistic-card/statistic-card.js +28 -28
  172. package/core/lib/elements/index.js +226 -226
  173. package/core/lib/hooks/device-detect.js +25 -25
  174. package/core/lib/hooks/index.js +9 -9
  175. package/core/lib/hooks/use-location.js +33 -33
  176. package/core/lib/hooks/use-otp-timer.js +80 -80
  177. package/core/lib/hooks/use-window-size.js +34 -34
  178. package/core/lib/i18n.js +69 -69
  179. package/core/lib/index.js +106 -106
  180. package/core/lib/introduction.md +73 -73
  181. package/core/lib/js-styleguide.md +4112 -4112
  182. package/core/lib/models/actions/actions.js +127 -127
  183. package/core/lib/models/actions/components/action-detail/action-detail.js +190 -190
  184. package/core/lib/models/actions/components/custom-actions/custom-actions.js +185 -185
  185. package/core/lib/models/attachments/attachments.js +231 -231
  186. package/core/lib/models/base-loader.js +99 -99
  187. package/core/lib/models/base.js +716 -716
  188. package/core/lib/models/branches/branches.js +125 -125
  189. package/core/lib/models/checklists/checklists.js +114 -114
  190. package/core/lib/models/columns/columns.js +169 -169
  191. package/core/lib/models/columns/components/columns-add/columns-add.js +171 -171
  192. package/core/lib/models/comments/comments.js +213 -213
  193. package/core/lib/models/departments/departments.js +107 -107
  194. package/core/lib/models/financial-years/financial_years.js +127 -127
  195. package/core/lib/models/forms/components/form-creator/form-creator.js +590 -590
  196. package/core/lib/models/forms/components/form-creator/form-creator.scss +29 -29
  197. package/core/lib/models/forms/components/form-detail/form-detail.js +224 -224
  198. package/core/lib/models/forms/forms.js +121 -121
  199. package/core/lib/models/index.js +203 -203
  200. package/core/lib/models/invoice-numbers/invoice_numbers.js +204 -204
  201. package/core/lib/models/lookup-types/components/lookup-detail/lookup-detail.js +145 -145
  202. package/core/lib/models/lookup-types/lookup-types.js +113 -113
  203. package/core/lib/models/lookup-values/components/lookup-values-add/lookup-values-add.js +126 -126
  204. package/core/lib/models/lookup-values/lookup-values.js +107 -107
  205. package/core/lib/models/menu-roles/menu-roles.js +127 -127
  206. package/core/lib/models/menus/components/menu-add/menu-add.js +228 -228
  207. package/core/lib/models/menus/components/menu-detail/menu-detail.js +170 -170
  208. package/core/lib/models/menus/components/menu-list/menu-list.js +593 -593
  209. package/core/lib/models/menus/components/menu-list/menu-list.scss +5 -5
  210. package/core/lib/models/menus/components/menu-roles-add/menu-roles-add.js +183 -183
  211. package/core/lib/models/menus/menus.js +499 -499
  212. package/core/lib/models/models/components/model-detail/model-detail.js +137 -137
  213. package/core/lib/models/models/components/models.js +128 -128
  214. package/core/lib/models/modules/modules.js +204 -204
  215. package/core/lib/models/outbox/outbox.js +73 -73
  216. package/core/lib/models/pages/pages.js +107 -107
  217. package/core/lib/models/permissions/permissions.js +71 -71
  218. package/core/lib/models/process/components/process-add/process-add.js +181 -181
  219. package/core/lib/models/process/components/process-dashboard/process-dashboard.js +601 -601
  220. package/core/lib/models/process/components/process-dashboard/process-dashboard.scss +62 -62
  221. package/core/lib/models/process/components/process-detail/process-detail.js +140 -140
  222. package/core/lib/models/process/components/process-timeline/process-timeline.js +139 -139
  223. package/core/lib/models/process/components/task-detail/task-detail.js +240 -240
  224. package/core/lib/models/process/components/task-detail/task-detail.scss +27 -27
  225. package/core/lib/models/process/components/task-form/task-form.js +528 -528
  226. package/core/lib/models/process/components/task-form/task-form.scss +7 -7
  227. package/core/lib/models/process/components/task-list/task-list.js +221 -221
  228. package/core/lib/models/process/components/task-list/task-list.scss +14 -14
  229. package/core/lib/models/process/components/task-overview/task-overview.js +299 -299
  230. package/core/lib/models/process/components/task-overview-legacy/task-overview-legacy.js +192 -192
  231. package/core/lib/models/process/components/task-routes/task-routes.js +45 -45
  232. package/core/lib/models/process/components/task-status/task-status.js +175 -175
  233. package/core/lib/models/process/components/task-status/task-status.scss +11 -11
  234. package/core/lib/models/process/process.js +780 -780
  235. package/core/lib/models/process-transactions/process-transactions.js +123 -123
  236. package/core/lib/models/roles/roles.js +106 -106
  237. package/core/lib/models/scripts/scripts.js +111 -111
  238. package/core/lib/models/step-transactions/step-transcations.js +147 -147
  239. package/core/lib/models/steps/components/step-add/step-add.js +261 -261
  240. package/core/lib/models/steps/components/step-detail/step-detail.js +157 -157
  241. package/core/lib/models/steps/steps.js +356 -356
  242. package/core/lib/models/user-preferences/user-preferences.js +83 -83
  243. package/core/lib/models/users/components/user-add/user-add.js +226 -226
  244. package/core/lib/models/users/users.js +119 -119
  245. package/core/lib/modules/business/launch-page/launch-page.js +29 -29
  246. package/core/lib/modules/business/launch-page/launch-page.scss +5 -5
  247. package/core/lib/modules/business/slots/slots.js +231 -231
  248. package/core/lib/modules/business/slots/slots.scss +108 -108
  249. package/core/lib/modules/forms/components/field-customizer/field-customizer.js +138 -138
  250. package/core/lib/modules/forms/components/field-selector/field-selector.js +157 -157
  251. package/core/lib/modules/forms/components/field-selector/field-selector.scss +25 -25
  252. package/core/lib/modules/forms/components/form-display/form-display.js +203 -203
  253. package/core/lib/modules/forms/components/form-display/form-display.scss +9 -9
  254. package/core/lib/modules/forms/components/tab-customizer/tab-customizer.js +124 -124
  255. package/core/lib/modules/generic/generic-add/generic-add.js +213 -213
  256. package/core/lib/modules/generic/generic-detail/generic-detail.js +199 -199
  257. package/core/lib/modules/generic/generic-edit/generic-edit.js +120 -120
  258. package/core/lib/modules/generic/generic-list/ExportReactCSV.js +62 -62
  259. package/core/lib/modules/generic/generic-list/generic-list.js +705 -705
  260. package/core/lib/modules/generic/generic-list/generic-list.scss +34 -34
  261. package/core/lib/modules/generic/generic-upload/generic-upload.js +483 -483
  262. package/core/lib/modules/generic/table-settings/table-settings.js +226 -226
  263. package/core/lib/modules/generic/table-settings/table-settings.scss +37 -37
  264. package/core/lib/modules/index.js +52 -52
  265. package/core/lib/modules/modules-routes/module-routes.js +35 -35
  266. package/core/lib/pages/change-password/change-password.js +211 -211
  267. package/core/lib/pages/change-password/change-password.scss +76 -76
  268. package/core/lib/pages/homepage/homepage.js +53 -53
  269. package/core/lib/pages/index.js +19 -19
  270. package/core/lib/pages/login/login.js +735 -735
  271. package/core/lib/pages/login/login.scss +458 -458
  272. package/core/lib/pages/manage-users/manage-users.js +429 -429
  273. package/core/lib/pages/manage-users/manage-users.scss +25 -25
  274. package/core/lib/pages/profile/profile.js +247 -247
  275. package/core/lib/pages/profile/profile.scss +107 -107
  276. package/core/lib/pages/profile/theme-config.js +18 -18
  277. package/core/lib/pages/profile/themes-backup.json +310 -310
  278. package/core/lib/pages/profile/themes.json +254 -254
  279. package/core/lib/pages/register/register.js +176 -176
  280. package/core/lib/pages/register/register.scss +128 -128
  281. package/core/lib/react-styleguide.md +756 -756
  282. package/core/lib/utils/api/api.utils.js +188 -188
  283. package/core/lib/utils/api/readme.md +426 -426
  284. package/core/lib/utils/async.js +35 -35
  285. package/core/lib/utils/common/common.utils.js +123 -123
  286. package/core/lib/utils/common/readme.md +30 -30
  287. package/core/lib/utils/date/date.utils.js +295 -295
  288. package/core/lib/utils/date/readme.md +2 -2
  289. package/core/lib/utils/firebase.support.utils.js +98 -98
  290. package/core/lib/utils/firebase.utils.js +808 -808
  291. package/core/lib/utils/form/form.utils.js +255 -255
  292. package/core/lib/utils/generic/generic.utils.js +69 -69
  293. package/core/lib/utils/http/auth.helper.js +95 -95
  294. package/core/lib/utils/http/http.utils.js +157 -157
  295. package/core/lib/utils/http/readme.md +14 -14
  296. package/core/lib/utils/index.js +45 -45
  297. package/core/lib/utils/location/location.utils.js +137 -137
  298. package/core/lib/utils/location/readme.md +18 -18
  299. package/core/lib/utils/modal.utils.js +15 -15
  300. package/core/lib/utils/notification.utils.js +34 -34
  301. package/core/lib/utils/pwa/pwa.utils.js +88 -88
  302. package/core/lib/utils/script.utils.js +235 -235
  303. package/core/lib/utils/setting.utils.js +68 -68
  304. package/core/lib/utils/upload.utils.js +29 -29
  305. package/core/models/Preference/Preferences.js +46 -46
  306. package/core/models/base/base.js +399 -399
  307. package/core/models/base-clone-loader.js +107 -107
  308. package/core/models/base-clone.js +187 -187
  309. package/core/models/base-loader.js +97 -97
  310. package/core/models/core-scripts/core-scripts.js +150 -150
  311. package/core/models/dashboard/dashboard.js +201 -201
  312. package/core/models/detail-loader.js +88 -88
  313. package/core/models/doctor/components/doctor-add/doctor-add.js +422 -422
  314. package/core/models/doctor/components/doctor-add/doctor-add.scss +32 -32
  315. package/core/models/groups.js +82 -82
  316. package/core/models/index.js +100 -100
  317. package/core/models/lookup-types/components/lookup-detail/lookup-detail.js +129 -129
  318. package/core/models/lookup-types/lookup-types.js +96 -96
  319. package/core/models/lookup-values/components/lookup-values-modal/lookup-values-modal.js +95 -95
  320. package/core/models/lookup-values/lookup-values.js +92 -92
  321. package/core/models/menu-roles/components/menu-roles-add/menu-roles-add.js +153 -153
  322. package/core/models/menu-roles/menu-roles.js +158 -158
  323. package/core/models/menus/components/menu-add/menu-add.js +288 -288
  324. package/core/models/menus/components/menu-add/menu-add.scss +31 -31
  325. package/core/models/menus/components/menu-detail/menu-detail.js +263 -263
  326. package/core/models/menus/components/menu-list/menu-list.js +392 -392
  327. package/core/models/menus/components/menu-lists/menu-lists.js +585 -585
  328. package/core/models/menus/components/menu-lists/menu-lists.scss +46 -46
  329. package/core/models/menus/menus.js +291 -291
  330. package/core/models/model-columns.js +121 -121
  331. package/core/models/models/components/model-detail/model-add.js +120 -120
  332. package/core/models/models/components/model-detail/model-detail.js +133 -133
  333. package/core/models/models/models.js +154 -154
  334. package/core/models/pages/components/page-add/page-add.js +163 -163
  335. package/core/models/pages/components/page-add/page-add.scss +30 -30
  336. package/core/models/pages/components/page-details/page-details.js +209 -209
  337. package/core/models/pages/components/page-list/page-list.js +248 -248
  338. package/core/models/pages/pages.js +142 -142
  339. package/core/models/pages.js +142 -142
  340. package/core/models/roles/components/role-add/role-add.js +312 -312
  341. package/core/models/roles/components/role-add/role-add.scss +4 -4
  342. package/core/models/roles/components/role-list/role-list.js +386 -386
  343. package/core/models/roles/roles.js +205 -205
  344. package/core/models/staff/components/staff-add/staff-add.js +468 -464
  345. package/core/models/user-roles/components/user-roles-add/user-roles-add.js +149 -149
  346. package/core/models/user-roles/user-roles.js +99 -99
  347. package/core/models/users/components/assign-role/assign-role.js +300 -298
  348. package/core/models/users/components/assign-role/assign-role.scss +117 -117
  349. package/core/models/users/components/user-add/user-add.js +853 -853
  350. package/core/models/users/components/user-add/user-edit.js +89 -89
  351. package/core/models/users/components/user-detail/user-detail.js +236 -236
  352. package/core/models/users/components/user-list/user-list.js +397 -397
  353. package/core/models/users/users.js +353 -353
  354. package/core/modules/Informations/change-info/change-info.js +618 -618
  355. package/core/modules/Informations/change-info/change-info.scss +134 -134
  356. package/core/modules/dashboard/components/dashboard-card/animations.js +64 -64
  357. package/core/modules/dashboard/components/dashboard-card/dashboard-card.js +197 -197
  358. package/core/modules/dashboard/components/dashboard-card/menu-dashboard-card.js +430 -430
  359. package/core/modules/dashboard/components/dashboard-card/menu-dashboard-card.scss +59 -59
  360. package/core/modules/dashboard/components/pop-query-dashboard/pop-query-dashboard.js +66 -66
  361. package/core/modules/generic/components/generic-add/generic-add.js +121 -121
  362. package/core/modules/generic/components/generic-add/generic-add.scss +13 -13
  363. package/core/modules/generic/components/generic-add-modal/generic-add-modal.js +125 -125
  364. package/core/modules/generic/components/generic-add-modal/generic-add-modal.scss +13 -13
  365. package/core/modules/generic/components/generic-detail/generic-detail.js +184 -184
  366. package/core/modules/generic/components/generic-detail/generic-detail.scss +25 -25
  367. package/core/modules/generic/components/generic-edit/generic-edit.js +123 -123
  368. package/core/modules/generic/components/generic-list/generic-list.js +335 -335
  369. package/core/modules/generic/components/generic-list/generic-list.scss +35 -35
  370. package/core/modules/index.js +42 -42
  371. package/core/modules/module-routes/module-routes.js +37 -37
  372. package/core/modules/reporting/components/index.js +6 -6
  373. package/core/modules/reporting/components/reporting-dashboard/reporting-dashboard.js +1223 -1223
  374. package/core/modules/reporting/components/reporting-dashboard/reporting-dashboard.scss +171 -171
  375. package/core/modules/steps/action-buttons.js +76 -76
  376. package/core/modules/steps/action-buttons.scss +15 -15
  377. package/core/modules/steps/steps.js +379 -379
  378. package/core/modules/steps/steps.scss +159 -159
  379. package/core/modules/steps/timeline.js +54 -54
  380. package/core/pages/homepage-api/homepage-api.js +106 -106
  381. package/core/pages/homepage-api/homepage-api.scss +233 -233
  382. package/core/pages/homepage-api/menu-dashboard.js +169 -169
  383. package/core/pages/homepage-api/menu-dashboard.scss +11 -11
  384. package/core/translation.json +53 -53
  385. package/core/translations.json +19 -19
  386. package/core/utils/script.utils.js +129 -129
  387. package/core/utils/settings.utils.js +25 -25
  388. package/eslint.config.mjs +79 -79
  389. package/index.js +35 -35
  390. package/jest.config.js +7 -7
  391. package/jest.setup.js +1 -1
  392. package/package.json +123 -123
  393. package/tsconfig.json +26 -26
  394. package/webpack.config.js +173 -173
@@ -1,572 +1,572 @@
1
- /**
2
- *
3
- * Sidemenu component
4
- *
5
- * @author Ashique Mohammed
6
- * @co-author Sneha
7
- *
8
- *
9
- */
10
-
11
- import React, { useState, useEffect, useContext } from 'react';
12
-
13
- import { animationControls, motion, useAnimation } from 'framer-motion';
14
-
15
- import { GlobalContext } from './../../Store';
16
-
17
- import { Menu, message, Skeleton, Space, Popover } from 'antd';
18
-
19
- import FirebaseUtils from './../../utils/firebase.utils';
20
-
21
- import { useHistory } from 'react-router-dom';
22
-
23
- import { useTranslation, Trans } from 'react-i18next';
24
-
25
- import { Menus } from '../../models';
26
-
27
- import './sidemenu.scss';
28
-
29
- const { SubMenu } = Menu;
30
-
31
- /**
32
- *
33
- * @param {*} collapsed
34
- * @param {*} icon
35
- * @param {*} caption
36
- * @returns
37
- */
38
- function CollapsedIconMenu({ menu, collapsed, icon, caption }) {
39
- // Import t and i18n from useTranslation
40
- const { t, i18n } = useTranslation();
41
- const { state } = useContext(GlobalContext);
42
- const [isMobile, setIsMobile] = useState(false);
43
-
44
- useEffect(() => {
45
- const handleResize = () => {
46
- setIsMobile(window.innerWidth < 768); // Common breakpoint for mobile
47
- };
48
-
49
- handleResize(); // Set initial value
50
- window.addEventListener('resize', handleResize);
51
-
52
- return () => window.removeEventListener('resize', handleResize);
53
- }, []);
54
-
55
- const menuText = t(caption);
56
- const menuContent = (
57
- <>
58
- {/* If value of collapsed is false show caption & icon else hiding caption and showing only icon*/}
59
- {!collapsed ? (
60
- <div className="menu-collapsed">
61
- <div>
62
- {menu && menu.image_path ? <img style={{ width: '25px' }} src={menu.image_path}></img> : <i className={`fa-solid fas ${icon}`} />}
63
- </div>
64
-
65
- <div style={{ color: state.theme.colors.leftSectionColor }}>
66
- <span className="caption">
67
- {/* {caption} */}
68
- {/* <Trans i18nKey="Appointments"></Trans> */}
69
- {t(`${caption}`)}
70
- </span>
71
- </div>
72
- </div>
73
- ) : (
74
- <div className="menu-collapsed">
75
- <span className="anticon">
76
- {menu && menu.image_path ? <img style={{ width: '25px' }} src={menu.image_path}></img> : <i className={`fa-solid fas ${icon}`} />}
77
- </span>
78
-
79
- <span style={{ color: state.theme.colors.colorPrimaryText, paddingLeft: '6px' }}>
80
- {/* <>{caption}</> */}
81
- {t(`${caption}`)}
82
- </span>
83
- </div>
84
- )}
85
- </>
86
- );
87
-
88
- // On mobile, or when the menu is collapsed (based on original logic), don't show the popover tooltip.
89
- return isMobile || collapsed ? menuContent : <Popover content={menuText} placement="right">{menuContent}</Popover>;
90
- }
91
-
92
- export default function SideMenu({ loading, modules = [], callback, appSettings, collapsed }) {
93
- const { brandLogo, footerLogo, renderCustomHeader = () => {} } = appSettings;
94
-
95
- let history = useHistory();
96
-
97
- // const [selected, setSelected] = useState([1]);
98
-
99
- const [selectedKeys, setSelectedKeys] = useState([]);
100
- const [openKeys, setOpenKeys] = useState([]);
101
- const [menu, setMenu] = useState({});
102
-
103
- const { user = { locations: [] }, dispatch, state } = useContext(GlobalContext);
104
-
105
- useEffect(() => {
106
- // Here we have to consider three cases now ,
107
- // One is firebase for which it is primarly designed for
108
- // Then Nura Old Schema
109
- // Saudi New Schema
110
- // Bringing all to one structure is the ideal
111
- // if (user.role || user.ID) {
112
- // setLoading(false);
113
- // }
114
- }, [user]);
115
-
116
- // Keep current menu item selected after reload or navigation
117
- useEffect(() => {
118
- const currentPath = history.location.pathname;
119
- setSelectedKeys([currentPath]);
120
- }, [history.location.pathname]);
121
-
122
- /**
123
- * Logout Function
124
- */
125
- async function handleLogout() {
126
- let dbPtrValue = appSettings.headers.db_ptr;
127
- const isEnvThemeTrue = process.env.REACT_APP_THEME === 'true';
128
-
129
- // Only clear localStorage if theme is not 'true'
130
- if (!isEnvThemeTrue) {
131
- localStorage.clear();
132
- }
133
-
134
- // localStorage.clear();
135
-
136
- if (process.env.REACT_APP_PRIMARY_BACKEND === 'SQL') {
137
- // const result = Users.logout()
138
- localStorage.clear();
139
-
140
- localStorage.setItem('db_ptr', dbPtrValue);
141
-
142
- let userInfo = {
143
- dms: {},
144
- locations: [],
145
- ...{ loggedCheckDone: true },
146
- };
147
-
148
- dispatch({ type: 'user', payload: userInfo });
149
-
150
- history.push('/login');
151
-
152
- message.success('You have logged out successfully.');
153
- } else {
154
- FirebaseUtils.logout().then(() => {
155
- history.push('/login');
156
-
157
- message.success('You have logged out successfully.');
158
- });
159
- }
160
- }
161
-
162
- /**
163
- * Menu Click Function
164
- */
165
-
166
- // const onMenuClick = (menu, index) => {
167
- // setSelected([index]);
168
-
169
- // history.push(menu.path);
170
-
171
- // setMenu(menu);
172
-
173
- // callback();
174
- // };
175
-
176
- const onMenuClick = (menu, index) => {
177
- const key = menu.path || `menu-${menu.id || index}`;
178
-
179
- if (menu.isRoot) {
180
- setOpenKeys([]);
181
- }
182
-
183
- setSelectedKeys([key]);
184
-
185
- if (menu.path) {
186
- history.push(menu.path);
187
- }
188
-
189
- setMenu(menu);
190
- if (callback) callback();
191
- };
192
-
193
- /**
194
- * Controls submenu open/close behavior.
195
- *
196
- * - Detects the most recently opened menu key.
197
- * - When opening a submenu, keeps only its full parent path expanded
198
- * (accordion behavior).
199
- * - When closing a submenu, updates state without recalculating paths.
200
- *
201
- * @param {string[]} keys - Currently open menu keys from the Menu component.
202
- *
203
- * Assumptions:
204
- * - Menu keys are stable and unique.
205
- * - Only one menu branch should be open at a time.
206
- */
207
- const onOpenChange = (keys) => {
208
- const latestOpenKey = keys.find((k) => !openKeys.includes(k));
209
-
210
- if (!latestOpenKey) {
211
- setOpenKeys(keys);
212
- return;
213
- }
214
-
215
- const findPath = (items) => {
216
- const sortedItems = Menus.screenMenus(items, 'order');
217
- for (const item of sortedItems) {
218
- const key = String(item.id || item.path || item.caption);
219
- if (key === latestOpenKey) {
220
- return [key];
221
- }
222
- if (item.sub_menus) {
223
- const childPath = findPath(item.sub_menus);
224
- if (childPath) {
225
- return [key, ...childPath];
226
- }
227
- }
228
- }
229
- return null;
230
- };
231
-
232
- const path = findPath(modules);
233
- if (path) {
234
- setOpenKeys(path);
235
- } else {
236
- setOpenKeys(keys);
237
- }
238
- };
239
-
240
- /**
241
- * Function renders the footer logo
242
- *
243
- * @param {*} footerLogo
244
- */
245
- function renderFooter(footerLogo) {
246
- return (
247
- <div className={`sidebar-footer ${!collapsed ? 'open' : 'close'}`}>
248
- <img className="footer-logo" src={footerLogo} alt={'footer-logo'} />
249
- </div>
250
- );
251
- }
252
-
253
- let icon;
254
-
255
- let index = 0;
256
-
257
- useEffect(() => {
258
- // Dynamically set the CSS variables based on the current theme
259
- // document.documentElement.style.setProperty('--custom-bg-color', state.theme.colors.leftSectionBackground);
260
- // document.documentElement.style.setProperty('--custom-text-color', state.theme.colors.colorText);
261
- }, [state.theme]);
262
-
263
- const rootSubmenuKeys = Menus.screenMenus(modules, 'order').map((m) => m.id || m.path || m.caption);
264
-
265
- return (
266
- <div className="sidemenu">
267
- {loading ? (
268
- <Space className="side-loader">
269
- <Skeleton.Avatar />
270
- <Skeleton.Button />
271
- {/* <Skeleton.Input /> */}
272
- </Space>
273
- ) : (
274
- <div
275
- className="intro"
276
- style={{ backgroundColor: state.theme.colors.leftSectionBackground, borderBottom: `2px solid ${state.theme.colors.borderColor}` }}
277
- >
278
- {/* Logo Bar */}
279
- <div className="logo-wrapper">
280
- {/* Changing the size of logo bar according to the value of collapsed */}
281
- <img
282
- className={`sidemenu-brand-logo ${!collapsed ? 'open' : 'close'}`}
283
- onClick={() => {
284
- history.push('/');
285
- }}
286
- src={brandLogo}
287
- alt="Logo"
288
- />
289
-
290
- {/* <button class="openbtn" onclick={()=>{openNav()}}>☰</button> */}
291
-
292
- {/* If value of collapsed is true show version else not showing */}
293
-
294
- {!collapsed && process.env.REACT_APP_package_version && (
295
- <small
296
- style={{
297
- color: state.theme.colors.leftSectionColor,
298
- }}
299
- >
300
- {process.env.REACT_APP_package_version}
301
- </small>
302
- )}
303
- </div>
304
- {/* Logo Bar Ends */}
305
-
306
- {/* If value of collapsed is true render header else not rendering */}
307
-
308
- {!collapsed ? renderCustomHeader() : ''}
309
- </div>
310
- )}
311
-
312
- {/* Intro Component */}
313
- {/* Intro Component Ends */}
314
-
315
- {/* Search for Queries */}
316
-
317
- {/* <div className="menu-search">
318
-
319
- <small level={5}>Search</small>
320
-
321
- <Input placeholder="Search" />
322
- </div> */}
323
-
324
- {/* Search for Queries Ends */}
325
-
326
- <div className={`menu-item ${!collapsed ? 'open' : 'close'}`} style={{ backgroundColor: state.theme.colors.leftSectionBackground }}>
327
- {loading ? (
328
- <></>
329
- ) : (
330
- <Menu
331
- // selectedKeys={[selected]}
332
- // style={{ width: 256 }}
333
- // defaultSelectedKeys={selected}
334
- // defaultOpenKeys={['']}
335
- inlineCollapsed={collapsed}
336
- mode="inline"
337
- theme={process.env.REACT_APP_THEME}
338
- selectedKeys={selectedKeys}
339
- openKeys={openKeys}
340
- onOpenChange={onOpenChange}
341
- style={{ backgroundColor: state.theme.colors.leftSectionBackground, color: state.theme.colors.leftSectionColor }}
342
- // theme={''}
343
- >
344
- {/* <Menu.Item
345
- onClick={() => {
346
- setSelected([1]);
347
- history.push("/");
348
- setMenu({ caption: "Home" });
349
- callback();
350
- }}
351
- key="home-menu"
352
- >
353
- If value of collapsed is true show caption & icon else hiding caption and showing only icon
354
-
355
- <CollapsedIconMenu
356
- menu={menu}
357
- caption="Home"
358
- icon="fa-solid fa-house"
359
- collapsed={collapsed}
360
- />
361
- </Menu.Item> */}
362
-
363
- {/* {
364
- Menus.screenMenus(modules).map((menu, index) => {
365
-
366
- return <MenuItem history={history} menu={menu} index={index} />
367
- })
368
- } */}
369
-
370
- {Menus.screenMenus(modules, 'order')
371
-
372
- .filter((record) => {
373
- icon = record;
374
-
375
- if (record.id) {
376
- if (record.is_visible) {
377
- return true;
378
- }
379
-
380
- if (record.icon_name) {
381
- return true;
382
- } else {
383
- return false;
384
- }
385
- } else {
386
- return true;
387
- }
388
- })
389
- .map((menu, index) => {
390
- // return <MenuItem menu={menu} index={index} />
391
-
392
- let sub_menus = menu && menu.sub_menus ? Menus.screenMenus(menu.sub_menus) : [];
393
-
394
- if (menu && sub_menus && sub_menus.length) {
395
- // let randomIndex = parseInt(Math.random() * 10000000000);
396
-
397
- return (
398
- <SubMenu
399
- className="popup"
400
- style={{ color: state.theme.colors.leftSectionColor }}
401
- // key={`first-level-${randomIndex}-${menu.caption}`}
402
-
403
- key={menu.id || menu.path || menu.caption}
404
- title={
405
- <>
406
- <CollapsedIconMenu
407
- menu={menu}
408
- caption={menu.caption}
409
- icon={menu.icon_name || 'fa-solid fas fa-user'}
410
- collapsed={collapsed}
411
- />
412
- </>
413
- }
414
- >
415
- {sub_menus.map((submenu, innerIndex) => {
416
- // let randomIndex = parseInt(Math.random() * 10000000000);
417
-
418
- let third_menus = submenu && submenu.sub_menus ? Menus.screenMenus(submenu.sub_menus) : [];
419
-
420
- if (third_menus && third_menus.length) {
421
- return (
422
- <SubMenu
423
- className="popup"
424
- // key={`second-level-${randomIndex}-${submenu.id}`}
425
-
426
- key={submenu.id || submenu.path || submenu.caption}
427
- title={
428
- <span>
429
- <CollapsedIconMenu
430
- menu={menu}
431
- caption={submenu.caption}
432
- icon={submenu.icon_name || 'fa-solid fas fa-user'}
433
- collapsed={collapsed}
434
- />
435
- </span>
436
- }
437
- >
438
- {third_menus.map((menu) => {
439
- // let randomIndex = parseInt(Math.random() * 10000000000);
440
-
441
- return (
442
- <Menu.Item
443
- // onClick={() => {
444
- // onMenuClick(menu, index);
445
- // }}
446
- onClick={() => {
447
- onMenuClick({ ...menu, parentKey: submenu.path || submenu.caption }, index);
448
- }}
449
- // key={`second-level-${randomIndex}-${index}`}
450
-
451
- key={menu.path || menu.caption}
452
- >
453
- <CollapsedIconMenu
454
- menu={menu}
455
- caption={menu.caption}
456
- icon={menu.icon_name || 'fa-solid fas fa-user'}
457
- collapsed={collapsed}
458
- />
459
- </Menu.Item>
460
- );
461
- })}
462
- </SubMenu>
463
- );
464
- } else {
465
- // let randomIndex = parseInt(Math.random() * 10000000000);
466
-
467
- return (
468
- <Menu.Item
469
- // onClick={() => {
470
- // onMenuClick(submenu, index);
471
- // }}
472
- onClick={() => {
473
- onMenuClick({ ...submenu, parentKey: menu.path || menu.caption }, index);
474
- }}
475
- // key={`first-level-${randomIndex}-${innerIndex}`}
476
- key={submenu.path || submenu.caption}
477
- >
478
- <CollapsedIconMenu
479
- menu={menu}
480
- caption={submenu.caption}
481
- icon={submenu.icon_name || 'fa-solid fas fa-user'}
482
- collapsed={collapsed}
483
- />
484
- </Menu.Item>
485
- );
486
- }
487
- })}
488
- </SubMenu>
489
- );
490
- } else {
491
- // let randomIndex = parseInt(Math.random() * 10000000000);
492
-
493
- return (
494
- <Menu.Item
495
- // onClick={() => {
496
- // onMenuClick(menu, index);
497
- // }}
498
-
499
- onClick={() => {
500
- onMenuClick({ ...menu, parentKey: menu.path || menu.caption, isRoot: true }, index);
501
- }}
502
- // key={`${menu.id}-${randomIndex}`}
503
- key={menu.path || menu.caption}
504
- >
505
- <CollapsedIconMenu menu={menu} caption={menu.caption} icon={menu.icon_name || 'fa-solid fas fa-user'} collapsed={collapsed} />
506
- </Menu.Item>
507
- );
508
- }
509
- })}
510
-
511
- {loading ? (
512
- <div class="skeleton-wrapper"></div>
513
- ) : (
514
- <Menu.Item onClick={handleLogout} key="logout-button">
515
- <CollapsedIconMenu caption="Logout" icon="fa-solid fas fa-user" collapsed={collapsed} />
516
- </Menu.Item>
517
- )}
518
- </Menu>
519
- )}
520
-
521
- {/* Footer Logo */}
522
- {/* {renderFooter(footerLogo)} */}
523
- {/* Footer Logo Ends */}
524
- </div>
525
- </div>
526
- );
527
- }
528
-
529
- /**
530
- * The Menu Item Takes a menu and creates more
531
- * sub menus
532
- */
533
- function MenuItem({ menu, index, history }) {
534
- function renderMenus({ menu, index }) {
535
- let sub_menus = [];
536
-
537
- if (menu.sub_menus) {
538
- sub_menus = Menus.screenMenus(menu.sub_menus);
539
- }
540
-
541
- if (menu && sub_menus && sub_menus.length) {
542
- // return 'hello';
543
- return (
544
- <SubMenu
545
- key={menu.id}
546
- title={
547
- <span>
548
- <span>{menu.caption}</span>
549
- </span>
550
- }
551
- >
552
- {menu.sub_menus.map((menu, index) => {
553
- return <MenuItem menu={menu} index={menu.id} />;
554
- })}
555
- </SubMenu>
556
- );
557
- } else {
558
- return (
559
- <Menu.Item
560
- onClick={() => {
561
- history.push(menu.path);
562
- }}
563
- key={`${menu.id}`}
564
- >
565
- {menu.caption} {menu.id}
566
- </Menu.Item>
567
- );
568
- }
569
- }
570
-
571
- return renderMenus({ menu, index });
572
- }
1
+ /**
2
+ *
3
+ * Sidemenu component
4
+ *
5
+ * @author Ashique Mohammed
6
+ * @co-author Sneha
7
+ *
8
+ *
9
+ */
10
+
11
+ import React, { useState, useEffect, useContext } from 'react';
12
+
13
+ import { animationControls, motion, useAnimation } from 'framer-motion';
14
+
15
+ import { GlobalContext } from './../../Store';
16
+
17
+ import { Menu, message, Skeleton, Space, Popover } from 'antd';
18
+
19
+ import FirebaseUtils from './../../utils/firebase.utils';
20
+
21
+ import { useHistory } from 'react-router-dom';
22
+
23
+ import { useTranslation, Trans } from 'react-i18next';
24
+
25
+ import { Menus } from '../../models';
26
+
27
+ import './sidemenu.scss';
28
+
29
+ const { SubMenu } = Menu;
30
+
31
+ /**
32
+ *
33
+ * @param {*} collapsed
34
+ * @param {*} icon
35
+ * @param {*} caption
36
+ * @returns
37
+ */
38
+ function CollapsedIconMenu({ menu, collapsed, icon, caption }) {
39
+ // Import t and i18n from useTranslation
40
+ const { t, i18n } = useTranslation();
41
+ const { state } = useContext(GlobalContext);
42
+ const [isMobile, setIsMobile] = useState(false);
43
+
44
+ useEffect(() => {
45
+ const handleResize = () => {
46
+ setIsMobile(window.innerWidth < 768); // Common breakpoint for mobile
47
+ };
48
+
49
+ handleResize(); // Set initial value
50
+ window.addEventListener('resize', handleResize);
51
+
52
+ return () => window.removeEventListener('resize', handleResize);
53
+ }, []);
54
+
55
+ const menuText = t(caption);
56
+ const menuContent = (
57
+ <>
58
+ {/* If value of collapsed is false show caption & icon else hiding caption and showing only icon*/}
59
+ {!collapsed ? (
60
+ <div className="menu-collapsed">
61
+ <div>
62
+ {menu && menu.image_path ? <img style={{ width: '25px' }} src={menu.image_path}></img> : <i className={`fa-solid fas ${icon}`} />}
63
+ </div>
64
+
65
+ <div style={{ color: state.theme.colors.leftSectionColor }}>
66
+ <span className="caption">
67
+ {/* {caption} */}
68
+ {/* <Trans i18nKey="Appointments"></Trans> */}
69
+ {t(`${caption}`)}
70
+ </span>
71
+ </div>
72
+ </div>
73
+ ) : (
74
+ <div className="menu-collapsed">
75
+ <span className="anticon">
76
+ {menu && menu.image_path ? <img style={{ width: '25px' }} src={menu.image_path}></img> : <i className={`fa-solid fas ${icon}`} />}
77
+ </span>
78
+
79
+ <span style={{ color: state.theme.colors.colorPrimaryText, paddingLeft: '6px' }}>
80
+ {/* <>{caption}</> */}
81
+ {t(`${caption}`)}
82
+ </span>
83
+ </div>
84
+ )}
85
+ </>
86
+ );
87
+
88
+ // On mobile, or when the menu is collapsed (based on original logic), don't show the popover tooltip.
89
+ return isMobile || collapsed ? menuContent : <Popover content={menuText} placement="right">{menuContent}</Popover>;
90
+ }
91
+
92
+ export default function SideMenu({ loading, modules = [], callback, appSettings, collapsed }) {
93
+ const { brandLogo, footerLogo, renderCustomHeader = () => {} } = appSettings;
94
+
95
+ let history = useHistory();
96
+
97
+ // const [selected, setSelected] = useState([1]);
98
+
99
+ const [selectedKeys, setSelectedKeys] = useState([]);
100
+ const [openKeys, setOpenKeys] = useState([]);
101
+ const [menu, setMenu] = useState({});
102
+
103
+ const { user = { locations: [] }, dispatch, state } = useContext(GlobalContext);
104
+
105
+ useEffect(() => {
106
+ // Here we have to consider three cases now ,
107
+ // One is firebase for which it is primarly designed for
108
+ // Then Nura Old Schema
109
+ // Saudi New Schema
110
+ // Bringing all to one structure is the ideal
111
+ // if (user.role || user.ID) {
112
+ // setLoading(false);
113
+ // }
114
+ }, [user]);
115
+
116
+ // Keep current menu item selected after reload or navigation
117
+ useEffect(() => {
118
+ const currentPath = history.location.pathname;
119
+ setSelectedKeys([currentPath]);
120
+ }, [history.location.pathname]);
121
+
122
+ /**
123
+ * Logout Function
124
+ */
125
+ async function handleLogout() {
126
+ let dbPtrValue = appSettings.headers.db_ptr;
127
+ const isEnvThemeTrue = process.env.REACT_APP_THEME === 'true';
128
+
129
+ // Only clear localStorage if theme is not 'true'
130
+ if (!isEnvThemeTrue) {
131
+ localStorage.clear();
132
+ }
133
+
134
+ // localStorage.clear();
135
+
136
+ if (process.env.REACT_APP_PRIMARY_BACKEND === 'SQL') {
137
+ // const result = Users.logout()
138
+ localStorage.clear();
139
+
140
+ localStorage.setItem('db_ptr', dbPtrValue);
141
+
142
+ let userInfo = {
143
+ dms: {},
144
+ locations: [],
145
+ ...{ loggedCheckDone: true },
146
+ };
147
+
148
+ dispatch({ type: 'user', payload: userInfo });
149
+
150
+ history.push('/login');
151
+
152
+ message.success('You have logged out successfully.');
153
+ } else {
154
+ FirebaseUtils.logout().then(() => {
155
+ history.push('/login');
156
+
157
+ message.success('You have logged out successfully.');
158
+ });
159
+ }
160
+ }
161
+
162
+ /**
163
+ * Menu Click Function
164
+ */
165
+
166
+ // const onMenuClick = (menu, index) => {
167
+ // setSelected([index]);
168
+
169
+ // history.push(menu.path);
170
+
171
+ // setMenu(menu);
172
+
173
+ // callback();
174
+ // };
175
+
176
+ const onMenuClick = (menu, index) => {
177
+ const key = menu.path || `menu-${menu.id || index}`;
178
+
179
+ if (menu.isRoot) {
180
+ setOpenKeys([]);
181
+ }
182
+
183
+ setSelectedKeys([key]);
184
+
185
+ if (menu.path) {
186
+ history.push(menu.path);
187
+ }
188
+
189
+ setMenu(menu);
190
+ if (callback) callback();
191
+ };
192
+
193
+ /**
194
+ * Controls submenu open/close behavior.
195
+ *
196
+ * - Detects the most recently opened menu key.
197
+ * - When opening a submenu, keeps only its full parent path expanded
198
+ * (accordion behavior).
199
+ * - When closing a submenu, updates state without recalculating paths.
200
+ *
201
+ * @param {string[]} keys - Currently open menu keys from the Menu component.
202
+ *
203
+ * Assumptions:
204
+ * - Menu keys are stable and unique.
205
+ * - Only one menu branch should be open at a time.
206
+ */
207
+ const onOpenChange = (keys) => {
208
+ const latestOpenKey = keys.find((k) => !openKeys.includes(k));
209
+
210
+ if (!latestOpenKey) {
211
+ setOpenKeys(keys);
212
+ return;
213
+ }
214
+
215
+ const findPath = (items) => {
216
+ const sortedItems = Menus.screenMenus(items, 'order');
217
+ for (const item of sortedItems) {
218
+ const key = String(item.id || item.path || item.caption);
219
+ if (key === latestOpenKey) {
220
+ return [key];
221
+ }
222
+ if (item.sub_menus) {
223
+ const childPath = findPath(item.sub_menus);
224
+ if (childPath) {
225
+ return [key, ...childPath];
226
+ }
227
+ }
228
+ }
229
+ return null;
230
+ };
231
+
232
+ const path = findPath(modules);
233
+ if (path) {
234
+ setOpenKeys(path);
235
+ } else {
236
+ setOpenKeys(keys);
237
+ }
238
+ };
239
+
240
+ /**
241
+ * Function renders the footer logo
242
+ *
243
+ * @param {*} footerLogo
244
+ */
245
+ function renderFooter(footerLogo) {
246
+ return (
247
+ <div className={`sidebar-footer ${!collapsed ? 'open' : 'close'}`}>
248
+ <img className="footer-logo" src={footerLogo} alt={'footer-logo'} />
249
+ </div>
250
+ );
251
+ }
252
+
253
+ let icon;
254
+
255
+ let index = 0;
256
+
257
+ useEffect(() => {
258
+ // Dynamically set the CSS variables based on the current theme
259
+ // document.documentElement.style.setProperty('--custom-bg-color', state.theme.colors.leftSectionBackground);
260
+ // document.documentElement.style.setProperty('--custom-text-color', state.theme.colors.colorText);
261
+ }, [state.theme]);
262
+
263
+ const rootSubmenuKeys = Menus.screenMenus(modules, 'order').map((m) => m.id || m.path || m.caption);
264
+
265
+ return (
266
+ <div className="sidemenu">
267
+ {loading ? (
268
+ <Space className="side-loader">
269
+ <Skeleton.Avatar />
270
+ <Skeleton.Button />
271
+ {/* <Skeleton.Input /> */}
272
+ </Space>
273
+ ) : (
274
+ <div
275
+ className="intro"
276
+ style={{ backgroundColor: state.theme.colors.leftSectionBackground, borderBottom: `2px solid ${state.theme.colors.borderColor}` }}
277
+ >
278
+ {/* Logo Bar */}
279
+ <div className="logo-wrapper">
280
+ {/* Changing the size of logo bar according to the value of collapsed */}
281
+ <img
282
+ className={`sidemenu-brand-logo ${!collapsed ? 'open' : 'close'}`}
283
+ onClick={() => {
284
+ history.push('/');
285
+ }}
286
+ src={brandLogo}
287
+ alt="Logo"
288
+ />
289
+
290
+ {/* <button class="openbtn" onclick={()=>{openNav()}}>☰</button> */}
291
+
292
+ {/* If value of collapsed is true show version else not showing */}
293
+
294
+ {!collapsed && process.env.REACT_APP_package_version && (
295
+ <small
296
+ style={{
297
+ color: state.theme.colors.leftSectionColor,
298
+ }}
299
+ >
300
+ {process.env.REACT_APP_package_version}
301
+ </small>
302
+ )}
303
+ </div>
304
+ {/* Logo Bar Ends */}
305
+
306
+ {/* If value of collapsed is true render header else not rendering */}
307
+
308
+ {!collapsed ? renderCustomHeader() : ''}
309
+ </div>
310
+ )}
311
+
312
+ {/* Intro Component */}
313
+ {/* Intro Component Ends */}
314
+
315
+ {/* Search for Queries */}
316
+
317
+ {/* <div className="menu-search">
318
+
319
+ <small level={5}>Search</small>
320
+
321
+ <Input placeholder="Search" />
322
+ </div> */}
323
+
324
+ {/* Search for Queries Ends */}
325
+
326
+ <div className={`menu-item ${!collapsed ? 'open' : 'close'}`} style={{ backgroundColor: state.theme.colors.leftSectionBackground }}>
327
+ {loading ? (
328
+ <></>
329
+ ) : (
330
+ <Menu
331
+ // selectedKeys={[selected]}
332
+ // style={{ width: 256 }}
333
+ // defaultSelectedKeys={selected}
334
+ // defaultOpenKeys={['']}
335
+ inlineCollapsed={collapsed}
336
+ mode="inline"
337
+ theme={process.env.REACT_APP_THEME}
338
+ selectedKeys={selectedKeys}
339
+ openKeys={openKeys}
340
+ onOpenChange={onOpenChange}
341
+ style={{ backgroundColor: state.theme.colors.leftSectionBackground, color: state.theme.colors.leftSectionColor }}
342
+ // theme={''}
343
+ >
344
+ {/* <Menu.Item
345
+ onClick={() => {
346
+ setSelected([1]);
347
+ history.push("/");
348
+ setMenu({ caption: "Home" });
349
+ callback();
350
+ }}
351
+ key="home-menu"
352
+ >
353
+ If value of collapsed is true show caption & icon else hiding caption and showing only icon
354
+
355
+ <CollapsedIconMenu
356
+ menu={menu}
357
+ caption="Home"
358
+ icon="fa-solid fa-house"
359
+ collapsed={collapsed}
360
+ />
361
+ </Menu.Item> */}
362
+
363
+ {/* {
364
+ Menus.screenMenus(modules).map((menu, index) => {
365
+
366
+ return <MenuItem history={history} menu={menu} index={index} />
367
+ })
368
+ } */}
369
+
370
+ {Menus.screenMenus(modules, 'order')
371
+
372
+ .filter((record) => {
373
+ icon = record;
374
+
375
+ if (record.id) {
376
+ if (record.is_visible) {
377
+ return true;
378
+ }
379
+
380
+ if (record.icon_name) {
381
+ return true;
382
+ } else {
383
+ return false;
384
+ }
385
+ } else {
386
+ return true;
387
+ }
388
+ })
389
+ .map((menu, index) => {
390
+ // return <MenuItem menu={menu} index={index} />
391
+
392
+ let sub_menus = menu && menu.sub_menus ? Menus.screenMenus(menu.sub_menus) : [];
393
+
394
+ if (menu && sub_menus && sub_menus.length) {
395
+ // let randomIndex = parseInt(Math.random() * 10000000000);
396
+
397
+ return (
398
+ <SubMenu
399
+ className="popup"
400
+ style={{ color: state.theme.colors.leftSectionColor }}
401
+ // key={`first-level-${randomIndex}-${menu.caption}`}
402
+
403
+ key={menu.id || menu.path || menu.caption}
404
+ title={
405
+ <>
406
+ <CollapsedIconMenu
407
+ menu={menu}
408
+ caption={menu.caption}
409
+ icon={menu.icon_name || 'fa-solid fas fa-user'}
410
+ collapsed={collapsed}
411
+ />
412
+ </>
413
+ }
414
+ >
415
+ {sub_menus.map((submenu, innerIndex) => {
416
+ // let randomIndex = parseInt(Math.random() * 10000000000);
417
+
418
+ let third_menus = submenu && submenu.sub_menus ? Menus.screenMenus(submenu.sub_menus) : [];
419
+
420
+ if (third_menus && third_menus.length) {
421
+ return (
422
+ <SubMenu
423
+ className="popup"
424
+ // key={`second-level-${randomIndex}-${submenu.id}`}
425
+
426
+ key={submenu.id || submenu.path || submenu.caption}
427
+ title={
428
+ <span>
429
+ <CollapsedIconMenu
430
+ menu={menu}
431
+ caption={submenu.caption}
432
+ icon={submenu.icon_name || 'fa-solid fas fa-user'}
433
+ collapsed={collapsed}
434
+ />
435
+ </span>
436
+ }
437
+ >
438
+ {third_menus.map((menu) => {
439
+ // let randomIndex = parseInt(Math.random() * 10000000000);
440
+
441
+ return (
442
+ <Menu.Item
443
+ // onClick={() => {
444
+ // onMenuClick(menu, index);
445
+ // }}
446
+ onClick={() => {
447
+ onMenuClick({ ...menu, parentKey: submenu.path || submenu.caption }, index);
448
+ }}
449
+ // key={`second-level-${randomIndex}-${index}`}
450
+
451
+ key={menu.path || menu.caption}
452
+ >
453
+ <CollapsedIconMenu
454
+ menu={menu}
455
+ caption={menu.caption}
456
+ icon={menu.icon_name || 'fa-solid fas fa-user'}
457
+ collapsed={collapsed}
458
+ />
459
+ </Menu.Item>
460
+ );
461
+ })}
462
+ </SubMenu>
463
+ );
464
+ } else {
465
+ // let randomIndex = parseInt(Math.random() * 10000000000);
466
+
467
+ return (
468
+ <Menu.Item
469
+ // onClick={() => {
470
+ // onMenuClick(submenu, index);
471
+ // }}
472
+ onClick={() => {
473
+ onMenuClick({ ...submenu, parentKey: menu.path || menu.caption }, index);
474
+ }}
475
+ // key={`first-level-${randomIndex}-${innerIndex}`}
476
+ key={submenu.path || submenu.caption}
477
+ >
478
+ <CollapsedIconMenu
479
+ menu={menu}
480
+ caption={submenu.caption}
481
+ icon={submenu.icon_name || 'fa-solid fas fa-user'}
482
+ collapsed={collapsed}
483
+ />
484
+ </Menu.Item>
485
+ );
486
+ }
487
+ })}
488
+ </SubMenu>
489
+ );
490
+ } else {
491
+ // let randomIndex = parseInt(Math.random() * 10000000000);
492
+
493
+ return (
494
+ <Menu.Item
495
+ // onClick={() => {
496
+ // onMenuClick(menu, index);
497
+ // }}
498
+
499
+ onClick={() => {
500
+ onMenuClick({ ...menu, parentKey: menu.path || menu.caption, isRoot: true }, index);
501
+ }}
502
+ // key={`${menu.id}-${randomIndex}`}
503
+ key={menu.path || menu.caption}
504
+ >
505
+ <CollapsedIconMenu menu={menu} caption={menu.caption} icon={menu.icon_name || 'fa-solid fas fa-user'} collapsed={collapsed} />
506
+ </Menu.Item>
507
+ );
508
+ }
509
+ })}
510
+
511
+ {loading ? (
512
+ <div class="skeleton-wrapper"></div>
513
+ ) : (
514
+ <Menu.Item onClick={handleLogout} key="logout-button">
515
+ <CollapsedIconMenu caption="Logout" icon="fa-solid fas fa-user" collapsed={collapsed} />
516
+ </Menu.Item>
517
+ )}
518
+ </Menu>
519
+ )}
520
+
521
+ {/* Footer Logo */}
522
+ {/* {renderFooter(footerLogo)} */}
523
+ {/* Footer Logo Ends */}
524
+ </div>
525
+ </div>
526
+ );
527
+ }
528
+
529
+ /**
530
+ * The Menu Item Takes a menu and creates more
531
+ * sub menus
532
+ */
533
+ function MenuItem({ menu, index, history }) {
534
+ function renderMenus({ menu, index }) {
535
+ let sub_menus = [];
536
+
537
+ if (menu.sub_menus) {
538
+ sub_menus = Menus.screenMenus(menu.sub_menus);
539
+ }
540
+
541
+ if (menu && sub_menus && sub_menus.length) {
542
+ // return 'hello';
543
+ return (
544
+ <SubMenu
545
+ key={menu.id}
546
+ title={
547
+ <span>
548
+ <span>{menu.caption}</span>
549
+ </span>
550
+ }
551
+ >
552
+ {menu.sub_menus.map((menu, index) => {
553
+ return <MenuItem menu={menu} index={menu.id} />;
554
+ })}
555
+ </SubMenu>
556
+ );
557
+ } else {
558
+ return (
559
+ <Menu.Item
560
+ onClick={() => {
561
+ history.push(menu.path);
562
+ }}
563
+ key={`${menu.id}`}
564
+ >
565
+ {menu.caption} {menu.id}
566
+ </Menu.Item>
567
+ );
568
+ }
569
+ }
570
+
571
+ return renderMenus({ menu, index });
572
+ }