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

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,602 +1,602 @@
1
- /**
2
- *
3
- * A Single Dashboard that should be able to manage any process in a business
4
- * according to configred by system .
5
- *
6
- * A process of different steps , each step linked to different roles of users and has a form/page to complete
7
- * that particular step is part of this module .
8
- *
9
- *
10
- *
11
- * @description Component for updating each process
12
- * @author Ashique
13
- *
14
- */
15
-
16
-
17
- import React, { useState, useEffect, useContext } from 'react';
18
-
19
- import { Timeline, Card, Skeleton, Button, Modal, Typography, Form, Select, message, Tag } from 'antd';
20
-
21
- import { Process, ProcessTransactions, Steps } from '../../../';
22
-
23
- import TaskForm from './../task-form/task-form';
24
-
25
- import './process-dashboard.scss';
26
-
27
- import TaskStatus from './../task-status/task-status';
28
-
29
- import DateUtils from '../../../../utils/date/date.utils';
30
-
31
- import { ClockCircleOutlined, CopyOutlined, CheckCircleOutlined, LoadingOutlined, EditOutlined, ReloadOutlined } from '@ant-design/icons';
32
-
33
- import { CopyToClipBoard } from '../../../..';
34
-
35
- import { GlobalContext } from './../../../../Store';
36
-
37
- const { Title } = Typography;
38
-
39
- const { Option } = Select;
40
-
41
- let stepMaster = {
42
- ongoing: {
43
- icon: LoadingOutlined,
44
- color: 'blue'
45
- },
46
- pending: {
47
- icon: ClockCircleOutlined,
48
- color: 'orange'
49
- },
50
- completed: {
51
- icon: CheckCircleOutlined,
52
- color: 'green'
53
- },
54
-
55
- waiting: {
56
- icon: ClockCircleOutlined,
57
- color: 'red'
58
- },
59
-
60
- }
61
-
62
- /**
63
- *
64
- */
65
- export default function ProcessDashboard({ id, identifier, callback = () => { } }) {
66
-
67
- const { user = { locations: [] } } = useContext(GlobalContext);
68
-
69
- const [loading, setLoading] = useState(false);
70
-
71
- const [process, setProcess] = useState([]);
72
-
73
- const [transactionmodal, setTransactionmodal] = useState(false);
74
-
75
- useEffect(() => {
76
-
77
- // We have to load the process for the identified received as a property
78
-
79
- // The process / steps are recorded specific to a an id which can be of any model .
80
- getProcess();
81
-
82
- return () => {
83
-
84
- }
85
-
86
- }, [])
87
-
88
- /**
89
- * Get the process of an identifier
90
- *
91
- * @returns
92
- */
93
- function getProcess() {
94
-
95
- setLoading(true);
96
-
97
- var queries = [{
98
- field: 'modelIdentifier',
99
- value: identifier
100
- }]
101
-
102
- // Get the process with the current status of an id passed .
103
- return Process.getProcessTimeline({ identifier, id }).then((result) => {
104
-
105
- setProcess(result);
106
-
107
- console.log(result);
108
-
109
- setLoading(false);
110
-
111
- });
112
- }
113
-
114
-
115
- /**
116
- * Revert the modal
117
- */
118
- function openRevertModal() {
119
-
120
- setTransactionmodal(true);
121
- }
122
-
123
-
124
- /**
125
- * Close the revert modal
126
- */
127
- function closeRevertModal() {
128
- setTransactionmodal(false);
129
-
130
- }
131
-
132
- return (<div className="process-dashboard card">
133
-
134
- {/*
135
- <div className="page-header">
136
-
137
- <Title level={5}>
138
- Process Dashboard
139
- </Title>
140
-
141
- <div className="actions">
142
-
143
- {
144
- user.isAdmin
145
- &&
146
- <Button size={'small'} onClick={() => { openRevertModal() }}>
147
- <ReloadOutlined />
148
- Revert
149
- </Button>
150
- }
151
-
152
- </div>
153
- </div> */}
154
-
155
- {
156
- loading
157
- ?
158
- <>
159
-
160
- <strong className="process-title">
161
- Loading content ,
162
- </strong>
163
-
164
- <Skeleton />
165
- </>
166
-
167
- :
168
- <>
169
-
170
- {
171
- process.map((records) => {
172
-
173
- // If there is a process transaction record this process has started
174
- let { process_transactions = [] } = records;
175
-
176
- return (<>
177
-
178
- <div className='page-header'>
179
- <div>
180
-
181
- <strong className="process-title">
182
- {records.name}
183
- </strong>
184
-
185
- <p className="process-description">
186
- <small>
187
- {records.description}
188
- </small>
189
- </p>
190
- </div>
191
-
192
- <div className='actions'>
193
-
194
- <CopyToClipBoard id={records.id} record={records} />
195
-
196
-
197
- {
198
- user.isAdmin
199
- &&
200
- <Button size={'small'} onClick={() => { openRevertModal() }}>
201
- <ReloadOutlined />
202
- Revert
203
- </Button>
204
- }
205
-
206
- </div>
207
-
208
- </div>
209
-
210
- {
211
- process_transactions.length
212
- ?
213
- <small className='timeline'>
214
- {/* {DateUtils.displayFirestoreTime(process_transactions[0].start_time)} - {process_transactions[0].completed ? DateUtils.displayFirestoreTime(process_transactions[0].end_time) : 'Pending'} */}
215
- </small>
216
- :
217
- null
218
- }
219
-
220
- <Timeline className="process-timeline">
221
-
222
- {/* Steps List */}
223
- <StepsList id={id} steps={records.steps} callback={getProcess} />
224
- {/* Steps List Ends */}
225
-
226
- </Timeline>
227
- </>)
228
- })
229
- }
230
-
231
- {/* Add Modal */}
232
- <Modal destroyOnClose confirmLoading={loading} title="Revert" visible={transactionmodal} onCancel={() => { closeRevertModal() }} footer={null}>
233
-
234
- <RevertProcessTransaction id={id} process={process} callback={() => {
235
-
236
- closeRevertModal()
237
- }} />
238
-
239
- </Modal>
240
- {/* Add Modal Ends */}
241
-
242
- </>
243
- }
244
-
245
- </div >)
246
-
247
- }
248
-
249
- /**
250
- * The Timeline item that displays a step
251
- */
252
- function StepTimelineItem({ id, color, Icon, step, step_transactions, callback }) {
253
-
254
- const [body, setBody] = useState({});
255
-
256
- const [visible, setVisible] = useState(false);
257
-
258
- const [loading, setLoading] = useState(false);
259
-
260
- const { user = { locations: [] } } = useContext(GlobalContext);
261
-
262
- /**
263
- * Function to open editModal for Step
264
- *
265
- * @param {*} step
266
- */
267
- function openEditModal(step) {
268
-
269
- setVisible(true);
270
-
271
- setBody(step)
272
-
273
- }
274
-
275
- /**
276
- *
277
- * @param {*} step
278
- */
279
- async function startStep(step) {
280
-
281
- // Batch
282
- let app = Process.getFireStoreApp();
283
-
284
- // Starting a batched write
285
- let batch = app.batch();
286
-
287
- let body = {
288
- record_id: id,
289
- model_identifer: 'Candidates'
290
- }
291
-
292
- await Process.startStepBatch({ batch, step, body });
293
-
294
- await batch.commit();
295
-
296
- message.success("Step Started");
297
- }
298
-
299
- /**
300
- *
301
- * @param {*} step
302
- */
303
- async function completeStep(step) {
304
-
305
- // Batch
306
- let app = Process.getFireStoreApp();
307
-
308
- // Starting a batched write
309
- let batch = app.batch();
310
-
311
- let body = {
312
- record_id: id,
313
- model_identifer: 'Candidates'
314
- }
315
-
316
- await Process.stopStepBatch({ batch, step, body });
317
-
318
- message.success("Step Ended");
319
-
320
- }
321
-
322
- /**
323
- *
324
- * @param {*} step
325
- */
326
- function closeModal() {
327
-
328
- setVisible(false);
329
- }
330
-
331
-
332
- return (<Timeline.Item color={color} dot={<Icon />} >
333
-
334
- {/* Timeline Step Template */}
335
- <div className="timeline-content">
336
-
337
- <p className={'timeline-title'}>
338
- {step.name}
339
-
340
- <p className={'timeline-description'}>
341
- <small>
342
- {step.description}
343
- </small>
344
- </p>
345
- </p>
346
-
347
- {/* Actions for a step */}
348
- <div className="actions">
349
-
350
- {user.isAdmin && <>
351
-
352
- <CopyToClipBoard record={step} id={step.id} />
353
-
354
- <Button size={'small'} onClick={() => { openEditModal(step) }}>
355
-
356
- <EditOutlined />
357
-
358
- Edit
359
-
360
- </Button>
361
-
362
- <Button size={'small'} onClick={() => { startStep(step) }}>
363
-
364
- Start
365
-
366
- </Button>
367
-
368
- <Button size={'small'} onClick={() => { completeStep(step) }}>
369
-
370
- Complete
371
-
372
- </Button>
373
-
374
- </>}
375
-
376
- </div>
377
- {/* Actions for a step Ends */}
378
-
379
- </div>
380
- {/* Timeline Step Template Ends */}
381
-
382
- {/* Summary of Step Activity */}
383
- <TaskStatus id={id} color={color} step={step} step_transactions={step_transactions} />
384
- {/* Summary of Step Activity Ends */}
385
-
386
- {/* Form for the Step */}
387
- {step.formEnabled && <Card className="task-form-card">
388
-
389
- <h1>
390
- Form Enabled Value {step.formEnabled} - {step.name}
391
-
392
- </h1>
393
-
394
- <TaskForm
395
- record_id={id}
396
- step={step}
397
-
398
- callback={callback}
399
-
400
- />
401
-
402
- </Card>}
403
- {/* Form for the Step Ends */}
404
-
405
-
406
- {
407
- step.sub_steps.length ?
408
- <>
409
- <Timeline className="process-timeline">
410
-
411
- <StepsList id={id} steps={step.sub_steps} />
412
-
413
- </Timeline>
414
- </>
415
- :
416
- null
417
- }
418
-
419
-
420
- {/* Add Modal */}
421
- <Modal destroyOnClose confirmLoading={loading} title="Edit Step" visible={visible} onCancel={() => { closeModal() }} footer={null}>
422
- <Steps.ModalAddComponent
423
- // match={match}
424
- model={Steps}
425
- additional_queries={[]}
426
- formContent={body}
427
-
428
- callback={() => {
429
- closeModal(true);
430
- }}
431
- />
432
- </Modal>
433
- {/* Add Modal Ends */}
434
-
435
- {/* </>
436
- } */}
437
-
438
- </Timeline.Item>)
439
-
440
- }
441
-
442
-
443
- /**
444
- * List of Steps inside a Timline
445
- */
446
- function StepsList({ id, steps = [], callback }) {
447
-
448
- return (<>
449
-
450
- {
451
- steps.map((step) => {
452
-
453
- let color = stepMaster[step.current_state].color;
454
-
455
- let Icon = stepMaster[step.current_state].icon;
456
-
457
- let step_transactions = false;
458
-
459
- if (step.step_transactions && step.step_transactions.length) {
460
-
461
- step_transactions = step.step_transactions[0];
462
-
463
- }
464
-
465
- return (<>
466
-
467
- {/* Details of the step */}
468
- <StepTimelineItem
469
- id={id}
470
- color={color}
471
- Icon={Icon}
472
- step={step}
473
- step_transactions={step_transactions}
474
-
475
- callback={callback}
476
- />
477
- {/* Details of the step Ends */}
478
-
479
-
480
- {/* Form for the Step */}
481
- {/* {step.formEnabled && <Card className="task-form-card">
482
-
483
- <h1>
484
- Form Enabled Value {step.formEnabled} - {step.name}
485
-
486
- </h1>
487
-
488
- <TaskForm
489
- record_id={id}
490
- step={step}
491
-
492
- // callback={callback}
493
-
494
- />
495
-
496
- </Card>} */}
497
- {/* Form for the Step Ends */}
498
-
499
- </>)
500
- })
501
- }
502
-
503
- </>)
504
-
505
- }
506
-
507
-
508
-
509
-
510
- /**
511
- *
512
- *
513
- * @returns
514
- */
515
- function RevertProcessTransaction({ id, process = [], callback }) {
516
-
517
- // const form = useRef(null)
518
-
519
- const [loading, setLoading] = useState(false);
520
-
521
- const [processtransactions, setProcesstransactions] = useState([])
522
-
523
- useEffect(() => {
524
-
525
- getProcessTransaction();
526
-
527
- return () => {
528
- }
529
- }, [])
530
-
531
- /**
532
- *
533
- * @returns
534
- */
535
- function getProcessTransaction() {
536
-
537
- var queries = [{ field: 'record_id', value: id }];
538
-
539
- return ProcessTransactions.get(queries).then(({ process_transactions }) => {
540
-
541
- setProcesstransactions(process_transactions);
542
-
543
- console.log(process_transactions);
544
-
545
- })
546
- }
547
-
548
- /**
549
- * On Submit of form , Change the process transaction to specific step
550
- */
551
- function onSubmit(values) {
552
-
553
- // Batch
554
- let app = Process.getFireStoreApp();
555
-
556
- // Starting a batched write
557
- let batch = app.batch();
558
-
559
- setLoading(true);
560
-
561
- console.log(values);
562
-
563
- Process.triggerProcessBatch(batch, values.process_id, {}, processtransactions[0].id).then(() => {
564
-
565
- message.success("Reverted case to ", values.process_id);
566
-
567
- setLoading(false);
568
-
569
- callback();
570
-
571
- })
572
- }
573
-
574
- return (<>
575
-
576
- <Title level={4}>
577
- Revert Step
578
- </Title>
579
-
580
- <Form
581
- // form={form}
582
- layout="vertical"
583
- onFinish={onSubmit}>
584
-
585
- <Form.Item label="Process" name="process_id" required>
586
- <Select style={{ width: '100%' }}>
587
-
588
- {process.map((staff) => <Option value={staff.id}>{staff.name}</Option>)}
589
-
590
- </Select>
591
- </Form.Item>
592
-
593
- <Form.Item >
594
- <Button loading={loading} type="primary" htmlType="submit">
595
- Submit
596
- </Button>
597
- </Form.Item>
598
-
599
- </Form>
600
- </>)
601
-
1
+ /**
2
+ *
3
+ * A Single Dashboard that should be able to manage any process in a business
4
+ * according to configred by system .
5
+ *
6
+ * A process of different steps , each step linked to different roles of users and has a form/page to complete
7
+ * that particular step is part of this module .
8
+ *
9
+ *
10
+ *
11
+ * @description Component for updating each process
12
+ * @author Ashique
13
+ *
14
+ */
15
+
16
+
17
+ import React, { useState, useEffect, useContext } from 'react';
18
+
19
+ import { Timeline, Card, Skeleton, Button, Modal, Typography, Form, Select, message, Tag } from 'antd';
20
+
21
+ import { Process, ProcessTransactions, Steps } from '../../../';
22
+
23
+ import TaskForm from './../task-form/task-form';
24
+
25
+ import './process-dashboard.scss';
26
+
27
+ import TaskStatus from './../task-status/task-status';
28
+
29
+ import DateUtils from '../../../../utils/date/date.utils';
30
+
31
+ import { ClockCircleOutlined, CopyOutlined, CheckCircleOutlined, LoadingOutlined, EditOutlined, ReloadOutlined } from '@ant-design/icons';
32
+
33
+ import { CopyToClipBoard } from '../../../..';
34
+
35
+ import { GlobalContext } from './../../../../Store';
36
+
37
+ const { Title } = Typography;
38
+
39
+ const { Option } = Select;
40
+
41
+ let stepMaster = {
42
+ ongoing: {
43
+ icon: LoadingOutlined,
44
+ color: 'blue'
45
+ },
46
+ pending: {
47
+ icon: ClockCircleOutlined,
48
+ color: 'orange'
49
+ },
50
+ completed: {
51
+ icon: CheckCircleOutlined,
52
+ color: 'green'
53
+ },
54
+
55
+ waiting: {
56
+ icon: ClockCircleOutlined,
57
+ color: 'red'
58
+ },
59
+
60
+ }
61
+
62
+ /**
63
+ *
64
+ */
65
+ export default function ProcessDashboard({ id, identifier, callback = () => { } }) {
66
+
67
+ const { user = { locations: [] } } = useContext(GlobalContext);
68
+
69
+ const [loading, setLoading] = useState(false);
70
+
71
+ const [process, setProcess] = useState([]);
72
+
73
+ const [transactionmodal, setTransactionmodal] = useState(false);
74
+
75
+ useEffect(() => {
76
+
77
+ // We have to load the process for the identified received as a property
78
+
79
+ // The process / steps are recorded specific to a an id which can be of any model .
80
+ getProcess();
81
+
82
+ return () => {
83
+
84
+ }
85
+
86
+ }, [])
87
+
88
+ /**
89
+ * Get the process of an identifier
90
+ *
91
+ * @returns
92
+ */
93
+ function getProcess() {
94
+
95
+ setLoading(true);
96
+
97
+ var queries = [{
98
+ field: 'modelIdentifier',
99
+ value: identifier
100
+ }]
101
+
102
+ // Get the process with the current status of an id passed .
103
+ return Process.getProcessTimeline({ identifier, id }).then((result) => {
104
+
105
+ setProcess(result);
106
+
107
+ console.log(result);
108
+
109
+ setLoading(false);
110
+
111
+ });
112
+ }
113
+
114
+
115
+ /**
116
+ * Revert the modal
117
+ */
118
+ function openRevertModal() {
119
+
120
+ setTransactionmodal(true);
121
+ }
122
+
123
+
124
+ /**
125
+ * Close the revert modal
126
+ */
127
+ function closeRevertModal() {
128
+ setTransactionmodal(false);
129
+
130
+ }
131
+
132
+ return (<div className="process-dashboard card">
133
+
134
+ {/*
135
+ <div className="page-header">
136
+
137
+ <Title level={5}>
138
+ Process Dashboard
139
+ </Title>
140
+
141
+ <div className="actions">
142
+
143
+ {
144
+ user.isAdmin
145
+ &&
146
+ <Button size={'small'} onClick={() => { openRevertModal() }}>
147
+ <ReloadOutlined />
148
+ Revert
149
+ </Button>
150
+ }
151
+
152
+ </div>
153
+ </div> */}
154
+
155
+ {
156
+ loading
157
+ ?
158
+ <>
159
+
160
+ <strong className="process-title">
161
+ Loading content ,
162
+ </strong>
163
+
164
+ <Skeleton />
165
+ </>
166
+
167
+ :
168
+ <>
169
+
170
+ {
171
+ process.map((records) => {
172
+
173
+ // If there is a process transaction record this process has started
174
+ let { process_transactions = [] } = records;
175
+
176
+ return (<>
177
+
178
+ <div className='page-header'>
179
+ <div>
180
+
181
+ <strong className="process-title">
182
+ {records.name}
183
+ </strong>
184
+
185
+ <p className="process-description">
186
+ <small>
187
+ {records.description}
188
+ </small>
189
+ </p>
190
+ </div>
191
+
192
+ <div className='actions'>
193
+
194
+ <CopyToClipBoard id={records.id} record={records} />
195
+
196
+
197
+ {
198
+ user.isAdmin
199
+ &&
200
+ <Button size={'small'} onClick={() => { openRevertModal() }}>
201
+ <ReloadOutlined />
202
+ Revert
203
+ </Button>
204
+ }
205
+
206
+ </div>
207
+
208
+ </div>
209
+
210
+ {
211
+ process_transactions.length
212
+ ?
213
+ <small className='timeline'>
214
+ {/* {DateUtils.displayFirestoreTime(process_transactions[0].start_time)} - {process_transactions[0].completed ? DateUtils.displayFirestoreTime(process_transactions[0].end_time) : 'Pending'} */}
215
+ </small>
216
+ :
217
+ null
218
+ }
219
+
220
+ <Timeline className="process-timeline">
221
+
222
+ {/* Steps List */}
223
+ <StepsList id={id} steps={records.steps} callback={getProcess} />
224
+ {/* Steps List Ends */}
225
+
226
+ </Timeline>
227
+ </>)
228
+ })
229
+ }
230
+
231
+ {/* Add Modal */}
232
+ <Modal destroyOnClose confirmLoading={loading} title="Revert" visible={transactionmodal} onCancel={() => { closeRevertModal() }} footer={null}>
233
+
234
+ <RevertProcessTransaction id={id} process={process} callback={() => {
235
+
236
+ closeRevertModal()
237
+ }} />
238
+
239
+ </Modal>
240
+ {/* Add Modal Ends */}
241
+
242
+ </>
243
+ }
244
+
245
+ </div >)
246
+
247
+ }
248
+
249
+ /**
250
+ * The Timeline item that displays a step
251
+ */
252
+ function StepTimelineItem({ id, color, Icon, step, step_transactions, callback }) {
253
+
254
+ const [body, setBody] = useState({});
255
+
256
+ const [visible, setVisible] = useState(false);
257
+
258
+ const [loading, setLoading] = useState(false);
259
+
260
+ const { user = { locations: [] } } = useContext(GlobalContext);
261
+
262
+ /**
263
+ * Function to open editModal for Step
264
+ *
265
+ * @param {*} step
266
+ */
267
+ function openEditModal(step) {
268
+
269
+ setVisible(true);
270
+
271
+ setBody(step)
272
+
273
+ }
274
+
275
+ /**
276
+ *
277
+ * @param {*} step
278
+ */
279
+ async function startStep(step) {
280
+
281
+ // Batch
282
+ let app = Process.getFireStoreApp();
283
+
284
+ // Starting a batched write
285
+ let batch = app.batch();
286
+
287
+ let body = {
288
+ record_id: id,
289
+ model_identifer: 'Candidates'
290
+ }
291
+
292
+ await Process.startStepBatch({ batch, step, body });
293
+
294
+ await batch.commit();
295
+
296
+ message.success("Step Started");
297
+ }
298
+
299
+ /**
300
+ *
301
+ * @param {*} step
302
+ */
303
+ async function completeStep(step) {
304
+
305
+ // Batch
306
+ let app = Process.getFireStoreApp();
307
+
308
+ // Starting a batched write
309
+ let batch = app.batch();
310
+
311
+ let body = {
312
+ record_id: id,
313
+ model_identifer: 'Candidates'
314
+ }
315
+
316
+ await Process.stopStepBatch({ batch, step, body });
317
+
318
+ message.success("Step Ended");
319
+
320
+ }
321
+
322
+ /**
323
+ *
324
+ * @param {*} step
325
+ */
326
+ function closeModal() {
327
+
328
+ setVisible(false);
329
+ }
330
+
331
+
332
+ return (<Timeline.Item color={color} dot={<Icon />} >
333
+
334
+ {/* Timeline Step Template */}
335
+ <div className="timeline-content">
336
+
337
+ <p className={'timeline-title'}>
338
+ {step.name}
339
+
340
+ <p className={'timeline-description'}>
341
+ <small>
342
+ {step.description}
343
+ </small>
344
+ </p>
345
+ </p>
346
+
347
+ {/* Actions for a step */}
348
+ <div className="actions">
349
+
350
+ {user.isAdmin && <>
351
+
352
+ <CopyToClipBoard record={step} id={step.id} />
353
+
354
+ <Button size={'small'} onClick={() => { openEditModal(step) }}>
355
+
356
+ <EditOutlined />
357
+
358
+ Edit
359
+
360
+ </Button>
361
+
362
+ <Button size={'small'} onClick={() => { startStep(step) }}>
363
+
364
+ Start
365
+
366
+ </Button>
367
+
368
+ <Button size={'small'} onClick={() => { completeStep(step) }}>
369
+
370
+ Complete
371
+
372
+ </Button>
373
+
374
+ </>}
375
+
376
+ </div>
377
+ {/* Actions for a step Ends */}
378
+
379
+ </div>
380
+ {/* Timeline Step Template Ends */}
381
+
382
+ {/* Summary of Step Activity */}
383
+ <TaskStatus id={id} color={color} step={step} step_transactions={step_transactions} />
384
+ {/* Summary of Step Activity Ends */}
385
+
386
+ {/* Form for the Step */}
387
+ {step.formEnabled && <Card className="task-form-card">
388
+
389
+ <h1>
390
+ Form Enabled Value {step.formEnabled} - {step.name}
391
+
392
+ </h1>
393
+
394
+ <TaskForm
395
+ record_id={id}
396
+ step={step}
397
+
398
+ callback={callback}
399
+
400
+ />
401
+
402
+ </Card>}
403
+ {/* Form for the Step Ends */}
404
+
405
+
406
+ {
407
+ step.sub_steps.length ?
408
+ <>
409
+ <Timeline className="process-timeline">
410
+
411
+ <StepsList id={id} steps={step.sub_steps} />
412
+
413
+ </Timeline>
414
+ </>
415
+ :
416
+ null
417
+ }
418
+
419
+
420
+ {/* Add Modal */}
421
+ <Modal destroyOnClose confirmLoading={loading} title="Edit Step" visible={visible} onCancel={() => { closeModal() }} footer={null}>
422
+ <Steps.ModalAddComponent
423
+ // match={match}
424
+ model={Steps}
425
+ additional_queries={[]}
426
+ formContent={body}
427
+
428
+ callback={() => {
429
+ closeModal(true);
430
+ }}
431
+ />
432
+ </Modal>
433
+ {/* Add Modal Ends */}
434
+
435
+ {/* </>
436
+ } */}
437
+
438
+ </Timeline.Item>)
439
+
440
+ }
441
+
442
+
443
+ /**
444
+ * List of Steps inside a Timline
445
+ */
446
+ function StepsList({ id, steps = [], callback }) {
447
+
448
+ return (<>
449
+
450
+ {
451
+ steps.map((step) => {
452
+
453
+ let color = stepMaster[step.current_state].color;
454
+
455
+ let Icon = stepMaster[step.current_state].icon;
456
+
457
+ let step_transactions = false;
458
+
459
+ if (step.step_transactions && step.step_transactions.length) {
460
+
461
+ step_transactions = step.step_transactions[0];
462
+
463
+ }
464
+
465
+ return (<>
466
+
467
+ {/* Details of the step */}
468
+ <StepTimelineItem
469
+ id={id}
470
+ color={color}
471
+ Icon={Icon}
472
+ step={step}
473
+ step_transactions={step_transactions}
474
+
475
+ callback={callback}
476
+ />
477
+ {/* Details of the step Ends */}
478
+
479
+
480
+ {/* Form for the Step */}
481
+ {/* {step.formEnabled && <Card className="task-form-card">
482
+
483
+ <h1>
484
+ Form Enabled Value {step.formEnabled} - {step.name}
485
+
486
+ </h1>
487
+
488
+ <TaskForm
489
+ record_id={id}
490
+ step={step}
491
+
492
+ // callback={callback}
493
+
494
+ />
495
+
496
+ </Card>} */}
497
+ {/* Form for the Step Ends */}
498
+
499
+ </>)
500
+ })
501
+ }
502
+
503
+ </>)
504
+
505
+ }
506
+
507
+
508
+
509
+
510
+ /**
511
+ *
512
+ *
513
+ * @returns
514
+ */
515
+ function RevertProcessTransaction({ id, process = [], callback }) {
516
+
517
+ // const form = useRef(null)
518
+
519
+ const [loading, setLoading] = useState(false);
520
+
521
+ const [processtransactions, setProcesstransactions] = useState([])
522
+
523
+ useEffect(() => {
524
+
525
+ getProcessTransaction();
526
+
527
+ return () => {
528
+ }
529
+ }, [])
530
+
531
+ /**
532
+ *
533
+ * @returns
534
+ */
535
+ function getProcessTransaction() {
536
+
537
+ var queries = [{ field: 'record_id', value: id }];
538
+
539
+ return ProcessTransactions.get(queries).then(({ process_transactions }) => {
540
+
541
+ setProcesstransactions(process_transactions);
542
+
543
+ console.log(process_transactions);
544
+
545
+ })
546
+ }
547
+
548
+ /**
549
+ * On Submit of form , Change the process transaction to specific step
550
+ */
551
+ function onSubmit(values) {
552
+
553
+ // Batch
554
+ let app = Process.getFireStoreApp();
555
+
556
+ // Starting a batched write
557
+ let batch = app.batch();
558
+
559
+ setLoading(true);
560
+
561
+ console.log(values);
562
+
563
+ Process.triggerProcessBatch(batch, values.process_id, {}, processtransactions[0].id).then(() => {
564
+
565
+ message.success("Reverted case to ", values.process_id);
566
+
567
+ setLoading(false);
568
+
569
+ callback();
570
+
571
+ })
572
+ }
573
+
574
+ return (<>
575
+
576
+ <Title level={4}>
577
+ Revert Step
578
+ </Title>
579
+
580
+ <Form
581
+ // form={form}
582
+ layout="vertical"
583
+ onFinish={onSubmit}>
584
+
585
+ <Form.Item label="Process" name="process_id" required>
586
+ <Select style={{ width: '100%' }}>
587
+
588
+ {process.map((staff) => <Option value={staff.id}>{staff.name}</Option>)}
589
+
590
+ </Select>
591
+ </Form.Item>
592
+
593
+ <Form.Item >
594
+ <Button loading={loading} type="primary" htmlType="submit">
595
+ Submit
596
+ </Button>
597
+ </Form.Item>
598
+
599
+ </Form>
600
+ </>)
601
+
602
602
  }