ui-soxo-bootstrap-core 2.4.24

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 (429) hide show
  1. package/.babelrc +9 -0
  2. package/.github/workflows/npm-publish.yml +33 -0
  3. package/.husky/pre-commit +12 -0
  4. package/.prettierrc.json +11 -0
  5. package/babel.config.js +3 -0
  6. package/core/assets/images/vector.png +0 -0
  7. package/core/components/component-loader/component-loader.js +125 -0
  8. package/core/components/component-wrapper/component-wrapper.js +122 -0
  9. package/core/components/extra-info/extra-info-details.js +172 -0
  10. package/core/components/extra-info/extra-info-details.scss +27 -0
  11. package/core/components/extra-info/extra-info.js +134 -0
  12. package/core/components/index.js +18 -0
  13. package/core/components/landing-api/landing-api.js +492 -0
  14. package/core/components/landing-api/landing-api.scss +19 -0
  15. package/core/components/menu-template-api/menu-template-api.js +321 -0
  16. package/core/components/root-application-api/root-application-api.js +174 -0
  17. package/core/components/root-application-api/root-application.api.scss +0 -0
  18. package/core/index.js +14 -0
  19. package/core/lib/Store.js +363 -0
  20. package/core/lib/assets/Tick-icon.png +0 -0
  21. package/core/lib/assets/blue-slate-theme.png +0 -0
  22. package/core/lib/assets/dark-theme.png +0 -0
  23. package/core/lib/assets/deep-purple-theme.png +0 -0
  24. package/core/lib/assets/light-theme.png +0 -0
  25. package/core/lib/assets/nura-theme.png +0 -0
  26. package/core/lib/assets/plant.png +0 -0
  27. package/core/lib/assets/welcome-image.png +0 -0
  28. package/core/lib/assets/white-haze-theme.png +0 -0
  29. package/core/lib/components/application-bootstrap/application-bootstrap.js +115 -0
  30. package/core/lib/components/application-bootstrap/application-bootstrap.scss +0 -0
  31. package/core/lib/components/approval-form/approval-form.js +280 -0
  32. package/core/lib/components/approval-form/approval-form.scss +184 -0
  33. package/core/lib/components/approval-list/approval-list.js +143 -0
  34. package/core/lib/components/approval-list/approval-list.scss +3 -0
  35. package/core/lib/components/approval-list/components/request-card/request-card.js +43 -0
  36. package/core/lib/components/approval-list/components/request-card/request-card.scss +31 -0
  37. package/core/lib/components/camera/camera.js +231 -0
  38. package/core/lib/components/camera/camera.scss +86 -0
  39. package/core/lib/components/comment-block/comment-block.js +139 -0
  40. package/core/lib/components/comment-block/comment-block.scss +3 -0
  41. package/core/lib/components/confirm-modal/confirm-modal.js +82 -0
  42. package/core/lib/components/confirm-modal/confirm-modal.scss +3 -0
  43. package/core/lib/components/consent/consent.js +67 -0
  44. package/core/lib/components/consent/consent.scss +0 -0
  45. package/core/lib/components/consent/pdf-signature.js +299 -0
  46. package/core/lib/components/consent/signature-pad.js +90 -0
  47. package/core/lib/components/consent/signature-pad.scss +14 -0
  48. package/core/lib/components/file-upload/file-upload.js +133 -0
  49. package/core/lib/components/finger-print-reader/finger-print-reader.js +296 -0
  50. package/core/lib/components/finger-print-reader/finger-print-reader.scss +47 -0
  51. package/core/lib/components/finger-print-search/finger-print-search.js +200 -0
  52. package/core/lib/components/finger-print-search/finger-print-search.scss +47 -0
  53. package/core/lib/components/global-header/animations.js +18 -0
  54. package/core/lib/components/global-header/global-header.js +413 -0
  55. package/core/lib/components/global-header/global-header.scss +369 -0
  56. package/core/lib/components/header/generic-header.js +76 -0
  57. package/core/lib/components/header/generic-header.scss +99 -0
  58. package/core/lib/components/image-preview/image-preview.js +33 -0
  59. package/core/lib/components/image-wrapper/image-wrapper.js +108 -0
  60. package/core/lib/components/image-wrapper/image-wrapper.scss +13 -0
  61. package/core/lib/components/index.js +203 -0
  62. package/core/lib/components/landing/landing.js +404 -0
  63. package/core/lib/components/landing/landing.scss +0 -0
  64. package/core/lib/components/language-switcher/language-switcher.js +50 -0
  65. package/core/lib/components/menu-context/menu-context.js +70 -0
  66. package/core/lib/components/menu-template/menu-template.js +250 -0
  67. package/core/lib/components/menu-template/menu-template.scss +9 -0
  68. package/core/lib/components/modal-search/modal-search.js +153 -0
  69. package/core/lib/components/modal-search/modal-search.scss +79 -0
  70. package/core/lib/components/modal-wrapper/modal-manager.js +16 -0
  71. package/core/lib/components/modal-wrapper/modal-wrapper.js +108 -0
  72. package/core/lib/components/modal-wrapper/modal-wrapper.scss +14 -0
  73. package/core/lib/components/notice-board/notice-board.js +132 -0
  74. package/core/lib/components/notice-board/notice-board.scss +65 -0
  75. package/core/lib/components/page-container/page-container.js +55 -0
  76. package/core/lib/components/page-container/page-container.scss +8 -0
  77. package/core/lib/components/page-header/page-header.js +23 -0
  78. package/core/lib/components/page-header/page-header.scss +18 -0
  79. package/core/lib/components/pdf-viewer/pdf-viewer.js +56 -0
  80. package/core/lib/components/portlet-table/components/table-actions/table-actions.js +58 -0
  81. package/core/lib/components/portlet-table/components/table-actions/table-actions.scss +1 -0
  82. package/core/lib/components/portlet-table/components/table-data/table-data.js +107 -0
  83. package/core/lib/components/portlet-table/components/table-data/table-data.scss +0 -0
  84. package/core/lib/components/portlet-table/portlet-table.js +63 -0
  85. package/core/lib/components/portlet-table/portlet-table.scss +90 -0
  86. package/core/lib/components/progress-bar/progress-bar.js +58 -0
  87. package/core/lib/components/progress-bar/progress-bar.scss +15 -0
  88. package/core/lib/components/request-form/request-form.js +110 -0
  89. package/core/lib/components/request-form/request-form.scss +0 -0
  90. package/core/lib/components/root-application/root-application.js +70 -0
  91. package/core/lib/components/rupee/rupee.js +14 -0
  92. package/core/lib/components/script-input/script-input.js +169 -0
  93. package/core/lib/components/script-input/script-input.scss +8 -0
  94. package/core/lib/components/sidemenu/animations.js +52 -0
  95. package/core/lib/components/sidemenu/sidemenu.js +617 -0
  96. package/core/lib/components/sidemenu/sidemenu.scss +264 -0
  97. package/core/lib/components/spotlight-search/spotlight-search.component.js +636 -0
  98. package/core/lib/components/spotlight-search/spotlight-search.component.scss +78 -0
  99. package/core/lib/components/table-wrapper/table-wrapper.js +136 -0
  100. package/core/lib/components/table-wrapper/table-wrapper.scss +72 -0
  101. package/core/lib/components/ui_elements/Loader.js +13 -0
  102. package/core/lib/components/ui_elements/Notify.js +13 -0
  103. package/core/lib/components/ui_elements/PlaceHolder.js +34 -0
  104. package/core/lib/components/web-camera/web-camera.js +162 -0
  105. package/core/lib/components/web-camera/web-camera.scss +28 -0
  106. package/core/lib/core.md +9 -0
  107. package/core/lib/elements/Elements.md +3 -0
  108. package/core/lib/elements/basic/LoggedUserRedirect.js +21 -0
  109. package/core/lib/elements/basic/PrivateRoute.js +16 -0
  110. package/core/lib/elements/basic/button/Button.md +43 -0
  111. package/core/lib/elements/basic/button/button.js +170 -0
  112. package/core/lib/elements/basic/button/button.scss +0 -0
  113. package/core/lib/elements/basic/card/Card.md +15 -0
  114. package/core/lib/elements/basic/card/card.js +40 -0
  115. package/core/lib/elements/basic/card/card.scss +14 -0
  116. package/core/lib/elements/basic/checkbox/checkbox.js +23 -0
  117. package/core/lib/elements/basic/col/col.js +16 -0
  118. package/core/lib/elements/basic/copy-to-clipboard/Readme.md +40 -0
  119. package/core/lib/elements/basic/copy-to-clipboard/copy-to-clipboard.js +62 -0
  120. package/core/lib/elements/basic/country-phone-input/Readme.md +98 -0
  121. package/core/lib/elements/basic/country-phone-input/country-phone-input.js +107 -0
  122. package/core/lib/elements/basic/country-phone-input/phone-input.scss +62 -0
  123. package/core/lib/elements/basic/datepicker/datepicker.js +33 -0
  124. package/core/lib/elements/basic/dragabble-wrapper/draggable-wrapper.js +61 -0
  125. package/core/lib/elements/basic/empty/empty.js +15 -0
  126. package/core/lib/elements/basic/fingerprint-protrected/fingerprint-protected.js +118 -0
  127. package/core/lib/elements/basic/fingerprint-protrected/fingerprint-protected.scss +10 -0
  128. package/core/lib/elements/basic/form/Readme.md +0 -0
  129. package/core/lib/elements/basic/form/form.js +70 -0
  130. package/core/lib/elements/basic/form/form.scss +4 -0
  131. package/core/lib/elements/basic/image/image.js +45 -0
  132. package/core/lib/elements/basic/image/image.scss +17 -0
  133. package/core/lib/elements/basic/image/readme.md +26 -0
  134. package/core/lib/elements/basic/image-viewer/image-viewer.js +109 -0
  135. package/core/lib/elements/basic/image-viewer/image-viewer.scss +8 -0
  136. package/core/lib/elements/basic/input/input.js +81 -0
  137. package/core/lib/elements/basic/input/readme.md +77 -0
  138. package/core/lib/elements/basic/json-input/json-input.js +51 -0
  139. package/core/lib/elements/basic/menu-dashboard/menu-dashboard.js +216 -0
  140. package/core/lib/elements/basic/menu-dashboard/menu-dashboard.scss +28 -0
  141. package/core/lib/elements/basic/modal/modal.js +64 -0
  142. package/core/lib/elements/basic/modal/readme.md +62 -0
  143. package/core/lib/elements/basic/popconfirm/popconfirm.js +18 -0
  144. package/core/lib/elements/basic/popover/popover.js +13 -0
  145. package/core/lib/elements/basic/radio/radio.js +18 -0
  146. package/core/lib/elements/basic/rangepicker/rangepicker.js +51 -0
  147. package/core/lib/elements/basic/rangepicker/rangepicker.scss +18 -0
  148. package/core/lib/elements/basic/rangepicker/readme.md +82 -0
  149. package/core/lib/elements/basic/reference-select/readme.md +19 -0
  150. package/core/lib/elements/basic/reference-select/reference-select.js +337 -0
  151. package/core/lib/elements/basic/row/row.js +16 -0
  152. package/core/lib/elements/basic/select/select.js +47 -0
  153. package/core/lib/elements/basic/select-box/readme.md +53 -0
  154. package/core/lib/elements/basic/select-box/select-box.js +63 -0
  155. package/core/lib/elements/basic/skeleton/readme.md +35 -0
  156. package/core/lib/elements/basic/skeleton/skeleton.js +36 -0
  157. package/core/lib/elements/basic/skeleton/skeleton.scss +53 -0
  158. package/core/lib/elements/basic/space/space.js +13 -0
  159. package/core/lib/elements/basic/switch/readme.md +29 -0
  160. package/core/lib/elements/basic/switch/switch.js +58 -0
  161. package/core/lib/elements/basic/tab/tab.js +15 -0
  162. package/core/lib/elements/basic/table/readme.md +9 -0
  163. package/core/lib/elements/basic/table/table.js +100 -0
  164. package/core/lib/elements/basic/table/table.scss +0 -0
  165. package/core/lib/elements/basic/tag/tag.js +63 -0
  166. package/core/lib/elements/basic/tag/tag.scss +3 -0
  167. package/core/lib/elements/basic/timeline/timeline.js +14 -0
  168. package/core/lib/elements/basic/title/readme.md +20 -0
  169. package/core/lib/elements/basic/title/title.js +38 -0
  170. package/core/lib/elements/basic/title/title.scss +0 -0
  171. package/core/lib/elements/basic/user-search/user-search.js +192 -0
  172. package/core/lib/elements/complex/barcode/barcode.js +27 -0
  173. package/core/lib/elements/complex/bargraph/bar-graph.js +262 -0
  174. package/core/lib/elements/complex/basic-table/basic-table.js +111 -0
  175. package/core/lib/elements/complex/basic-table/basic-table.scss +4 -0
  176. package/core/lib/elements/complex/date-display/date-display.js +37 -0
  177. package/core/lib/elements/complex/error-boundary/error-boundary.js +29 -0
  178. package/core/lib/elements/complex/google-location-input/map-container-library-load.js +93 -0
  179. package/core/lib/elements/complex/google-map/google-map.js +230 -0
  180. package/core/lib/elements/complex/google-map/google-map.scss +13 -0
  181. package/core/lib/elements/complex/line-graph/line-graph.js +108 -0
  182. package/core/lib/elements/complex/location-search-input/location-search-input.js +100 -0
  183. package/core/lib/elements/complex/maps/maps.js +0 -0
  184. package/core/lib/elements/complex/pie-chart/pie-chart.js +203 -0
  185. package/core/lib/elements/complex/qr-code/qr-code.js +27 -0
  186. package/core/lib/elements/complex/qrscanner/qrscanner.js +57 -0
  187. package/core/lib/elements/complex/search-debounce/search-debounce.js +37 -0
  188. package/core/lib/elements/complex/statistic-card/dashboard-statistic-card.js +76 -0
  189. package/core/lib/elements/complex/statistic-card/statistic-card.js +28 -0
  190. package/core/lib/elements/index.js +226 -0
  191. package/core/lib/hooks/device-detect.js +26 -0
  192. package/core/lib/hooks/index.js +19 -0
  193. package/core/lib/hooks/use-location.js +33 -0
  194. package/core/lib/hooks/use-window-size.js +34 -0
  195. package/core/lib/i18n.js +70 -0
  196. package/core/lib/index.js +106 -0
  197. package/core/lib/introduction.md +74 -0
  198. package/core/lib/js-styleguide.md +4112 -0
  199. package/core/lib/models/actions/actions.js +128 -0
  200. package/core/lib/models/actions/components/action-detail/action-detail.js +190 -0
  201. package/core/lib/models/actions/components/action-detail/action-detail.scss +0 -0
  202. package/core/lib/models/actions/components/custom-actions/custom-actions.js +186 -0
  203. package/core/lib/models/actions/components/custom-actions/custom-actions.scss +0 -0
  204. package/core/lib/models/attachments/attachments.js +231 -0
  205. package/core/lib/models/base-loader.js +99 -0
  206. package/core/lib/models/base.js +716 -0
  207. package/core/lib/models/branches/branches.js +125 -0
  208. package/core/lib/models/checklists/checklists.js +115 -0
  209. package/core/lib/models/columns/columns.js +169 -0
  210. package/core/lib/models/columns/components/columns-add/columns-add.js +172 -0
  211. package/core/lib/models/columns/components/columns-add/columns-add.scss +0 -0
  212. package/core/lib/models/comments/comments.js +213 -0
  213. package/core/lib/models/departments/departments.js +107 -0
  214. package/core/lib/models/financial-years/financial_years.js +127 -0
  215. package/core/lib/models/forms/components/form-creator/form-creator.js +624 -0
  216. package/core/lib/models/forms/components/form-creator/form-creator.scss +30 -0
  217. package/core/lib/models/forms/components/form-detail/form-detail.js +224 -0
  218. package/core/lib/models/forms/components/form-detail/form-detail.scss +0 -0
  219. package/core/lib/models/forms/forms.js +122 -0
  220. package/core/lib/models/index.js +203 -0
  221. package/core/lib/models/invoice-numbers/invoice_numbers.js +204 -0
  222. package/core/lib/models/lookup-types/components/lookup-detail/lookup-detail.js +145 -0
  223. package/core/lib/models/lookup-types/components/lookup-detail/lookup-detail.scss +0 -0
  224. package/core/lib/models/lookup-types/lookup-types.js +113 -0
  225. package/core/lib/models/lookup-values/components/lookup-values-add/lookup-values-add.js +126 -0
  226. package/core/lib/models/lookup-values/components/lookup-values-add/lookup-values-add.scss +0 -0
  227. package/core/lib/models/lookup-values/lookup-values.js +107 -0
  228. package/core/lib/models/menu-roles/menu-roles.js +127 -0
  229. package/core/lib/models/menus/components/menu-add/menu-add.js +228 -0
  230. package/core/lib/models/menus/components/menu-add/menu-add.scss +0 -0
  231. package/core/lib/models/menus/components/menu-detail/menu-detail.js +170 -0
  232. package/core/lib/models/menus/components/menu-detail/menu-detail.scss +0 -0
  233. package/core/lib/models/menus/components/menu-list/menu-list.js +593 -0
  234. package/core/lib/models/menus/components/menu-list/menu-list.scss +6 -0
  235. package/core/lib/models/menus/components/menu-roles-add/menu-roles-add.js +183 -0
  236. package/core/lib/models/menus/components/menu-roles-add/menu-roles-add.scss +0 -0
  237. package/core/lib/models/menus/menus.js +499 -0
  238. package/core/lib/models/models/components/model-detail/model-detail.js +137 -0
  239. package/core/lib/models/models/components/model-detail/model-detail.scss +0 -0
  240. package/core/lib/models/models/components/models.js +128 -0
  241. package/core/lib/models/modules/modules.js +204 -0
  242. package/core/lib/models/outbox/outbox.js +73 -0
  243. package/core/lib/models/pages/pages.js +107 -0
  244. package/core/lib/models/permissions/permissions.js +71 -0
  245. package/core/lib/models/process/components/process-add/process-add.js +181 -0
  246. package/core/lib/models/process/components/process-add/process-add.scss +0 -0
  247. package/core/lib/models/process/components/process-dashboard/process-dashboard.js +602 -0
  248. package/core/lib/models/process/components/process-dashboard/process-dashboard.scss +62 -0
  249. package/core/lib/models/process/components/process-detail/process-detail.js +140 -0
  250. package/core/lib/models/process/components/process-detail/process-detail.scss +0 -0
  251. package/core/lib/models/process/components/process-timeline/process-timeline.js +140 -0
  252. package/core/lib/models/process/components/task-detail/task-detail.js +240 -0
  253. package/core/lib/models/process/components/task-detail/task-detail.scss +27 -0
  254. package/core/lib/models/process/components/task-form/task-form.js +529 -0
  255. package/core/lib/models/process/components/task-form/task-form.scss +7 -0
  256. package/core/lib/models/process/components/task-list/task-list.js +221 -0
  257. package/core/lib/models/process/components/task-list/task-list.scss +14 -0
  258. package/core/lib/models/process/components/task-overview/task-overview.js +300 -0
  259. package/core/lib/models/process/components/task-overview/task-overview.scss +0 -0
  260. package/core/lib/models/process/components/task-overview-legacy/task-overview-legacy.js +192 -0
  261. package/core/lib/models/process/components/task-overview-legacy/task-overview.scss +0 -0
  262. package/core/lib/models/process/components/task-routes/task-routes.js +45 -0
  263. package/core/lib/models/process/components/task-status/task-status.js +176 -0
  264. package/core/lib/models/process/components/task-status/task-status.scss +11 -0
  265. package/core/lib/models/process/process.js +781 -0
  266. package/core/lib/models/process-transactions/process-transactions.js +124 -0
  267. package/core/lib/models/roles/roles.js +106 -0
  268. package/core/lib/models/scripts/scripts.js +111 -0
  269. package/core/lib/models/step-transactions/step-transcations.js +148 -0
  270. package/core/lib/models/steps/components/step-add/step-add.js +261 -0
  271. package/core/lib/models/steps/components/step-add/step-add.scss +0 -0
  272. package/core/lib/models/steps/components/step-detail/step-detail.js +157 -0
  273. package/core/lib/models/steps/components/step-detail/step-detail.scss +0 -0
  274. package/core/lib/models/steps/steps.js +357 -0
  275. package/core/lib/models/user-preferences/user-preferences.js +83 -0
  276. package/core/lib/models/users/components/user-add/user-add.js +226 -0
  277. package/core/lib/models/users/components/user-add/user-add.scss +0 -0
  278. package/core/lib/models/users/users.js +120 -0
  279. package/core/lib/modules/business/launch-page/launch-page.js +29 -0
  280. package/core/lib/modules/business/launch-page/launch-page.scss +6 -0
  281. package/core/lib/modules/business/slots/slots.js +231 -0
  282. package/core/lib/modules/business/slots/slots.scss +108 -0
  283. package/core/lib/modules/forms/components/field-customizer/field-customizer.js +139 -0
  284. package/core/lib/modules/forms/components/field-customizer/field-customizer.scss +0 -0
  285. package/core/lib/modules/forms/components/field-selector/field-selector.js +157 -0
  286. package/core/lib/modules/forms/components/field-selector/field-selector.scss +25 -0
  287. package/core/lib/modules/forms/components/form-display/form-display.js +203 -0
  288. package/core/lib/modules/forms/components/form-display/form-display.scss +9 -0
  289. package/core/lib/modules/forms/components/tab-customizer/tab-customizer.js +125 -0
  290. package/core/lib/modules/forms/components/tab-customizer/tab-customizer.scss +0 -0
  291. package/core/lib/modules/generic/generic-add/generic-add.js +213 -0
  292. package/core/lib/modules/generic/generic-add/generic-add.scss +0 -0
  293. package/core/lib/modules/generic/generic-detail/generic-detail.js +199 -0
  294. package/core/lib/modules/generic/generic-detail/generic-detail.scss +0 -0
  295. package/core/lib/modules/generic/generic-edit/generic-edit.js +120 -0
  296. package/core/lib/modules/generic/generic-edit/generic-edit.scss +0 -0
  297. package/core/lib/modules/generic/generic-list/ExportReactCSV.js +62 -0
  298. package/core/lib/modules/generic/generic-list/generic-list.js +705 -0
  299. package/core/lib/modules/generic/generic-list/generic-list.scss +34 -0
  300. package/core/lib/modules/generic/generic-upload/generic-upload.js +484 -0
  301. package/core/lib/modules/generic/generic-upload/generic-upload.scss +0 -0
  302. package/core/lib/modules/generic/table-settings/table-settings.js +226 -0
  303. package/core/lib/modules/generic/table-settings/table-settings.scss +37 -0
  304. package/core/lib/modules/index.js +52 -0
  305. package/core/lib/modules/modules-routes/module-routes.js +35 -0
  306. package/core/lib/modules/modules-routes/module-routes.scss +0 -0
  307. package/core/lib/pages/change-password/change-password.js +211 -0
  308. package/core/lib/pages/change-password/change-password.scss +76 -0
  309. package/core/lib/pages/homepage/homepage.js +53 -0
  310. package/core/lib/pages/index.js +20 -0
  311. package/core/lib/pages/login/login.js +617 -0
  312. package/core/lib/pages/login/login.scss +346 -0
  313. package/core/lib/pages/manage-users/manage-users.js +429 -0
  314. package/core/lib/pages/manage-users/manage-users.scss +26 -0
  315. package/core/lib/pages/profile/profile.js +247 -0
  316. package/core/lib/pages/profile/profile.scss +107 -0
  317. package/core/lib/pages/profile/theme-config.js +18 -0
  318. package/core/lib/pages/profile/themes-backup.json +311 -0
  319. package/core/lib/pages/profile/themes.json +254 -0
  320. package/core/lib/pages/register/register.js +177 -0
  321. package/core/lib/pages/register/register.scss +128 -0
  322. package/core/lib/react-styleguide.md +757 -0
  323. package/core/lib/utils/api/api.utils.js +188 -0
  324. package/core/lib/utils/api/readme.md +426 -0
  325. package/core/lib/utils/async.js +36 -0
  326. package/core/lib/utils/common/common.utils.js +123 -0
  327. package/core/lib/utils/common/readme.md +30 -0
  328. package/core/lib/utils/date/date.utils.js +295 -0
  329. package/core/lib/utils/date/readme.md +2 -0
  330. package/core/lib/utils/firebase.support.utils.js +99 -0
  331. package/core/lib/utils/firebase.utils.js +808 -0
  332. package/core/lib/utils/form/Form.md +0 -0
  333. package/core/lib/utils/form/form.utils.js +256 -0
  334. package/core/lib/utils/generic/generic.utils.js +69 -0
  335. package/core/lib/utils/http/auth.helper.js +95 -0
  336. package/core/lib/utils/http/http.utils.js +157 -0
  337. package/core/lib/utils/http/readme.md +14 -0
  338. package/core/lib/utils/index.js +46 -0
  339. package/core/lib/utils/location/location.utils.js +137 -0
  340. package/core/lib/utils/location/readme.md +18 -0
  341. package/core/lib/utils/modal.utils.js +16 -0
  342. package/core/lib/utils/notification.utils.js +35 -0
  343. package/core/lib/utils/pwa/pwa.utils.js +88 -0
  344. package/core/lib/utils/script.utils.js +235 -0
  345. package/core/lib/utils/setting.utils.js +69 -0
  346. package/core/lib/utils/upload.utils.js +30 -0
  347. package/core/models/Preference/Preferences.js +46 -0
  348. package/core/models/base/base.js +399 -0
  349. package/core/models/base-clone-loader.js +107 -0
  350. package/core/models/base-clone.js +187 -0
  351. package/core/models/base-loader.js +97 -0
  352. package/core/models/core-scripts/core-scripts.js +150 -0
  353. package/core/models/dashboard/dashboard.js +187 -0
  354. package/core/models/detail-loader.js +88 -0
  355. package/core/models/groups.js +82 -0
  356. package/core/models/index.js +94 -0
  357. package/core/models/lookup-types/components/lookup-detail/lookup-detail.js +129 -0
  358. package/core/models/lookup-types/lookup-types.js +96 -0
  359. package/core/models/lookup-values/components/lookup-values-modal/lookup-values-modal.js +95 -0
  360. package/core/models/lookup-values/components/lookup-values-modal/lookup-values-modal.scss +0 -0
  361. package/core/models/lookup-values/lookup-values.js +92 -0
  362. package/core/models/menu-roles/components/menu-roles-add/menu-roles-add.js +153 -0
  363. package/core/models/menu-roles/components/menu-roles-add/menu-roles-add.scss +0 -0
  364. package/core/models/menu-roles/menu-roles.js +158 -0
  365. package/core/models/menus/components/menu-add/menu-add.js +325 -0
  366. package/core/models/menus/components/menu-add/menu-add.scss +31 -0
  367. package/core/models/menus/components/menu-detail/menu-detail.js +263 -0
  368. package/core/models/menus/components/menu-list/menu-list.js +392 -0
  369. package/core/models/menus/components/menu-lists/menu-lists.js +429 -0
  370. package/core/models/menus/components/menu-lists/menu-lists.scss +41 -0
  371. package/core/models/menus/menus.js +291 -0
  372. package/core/models/model-columns.js +121 -0
  373. package/core/models/models/components/model-detail/model-add.js +120 -0
  374. package/core/models/models/components/model-detail/model-detail.js +133 -0
  375. package/core/models/models/components/model-detail/model-detail.scss +0 -0
  376. package/core/models/models/models.js +154 -0
  377. package/core/models/pages/components/page-add/page-add.js +163 -0
  378. package/core/models/pages/components/page-add/page-add.scss +31 -0
  379. package/core/models/pages/components/page-details/page-details.js +210 -0
  380. package/core/models/pages/components/page-list/page-list.js +248 -0
  381. package/core/models/pages/pages.js +142 -0
  382. package/core/models/pages/pages.scss +0 -0
  383. package/core/models/pages.js +142 -0
  384. package/core/models/roles/components/role-add/role-add.js +248 -0
  385. package/core/models/roles/components/role-list/role-list.js +408 -0
  386. package/core/models/roles/roles.js +188 -0
  387. package/core/models/user-roles/components/user-roles-add/user-roles-add.js +149 -0
  388. package/core/models/user-roles/components/user-roles-add/user-roles-add.scss +0 -0
  389. package/core/models/user-roles/user-roles.js +99 -0
  390. package/core/models/users/components/user-add/user-add.js +458 -0
  391. package/core/models/users/components/user-detail/user-detail.js +236 -0
  392. package/core/models/users/components/user-detail/user-detail.scss +0 -0
  393. package/core/models/users/components/user-list/user-list.js +397 -0
  394. package/core/models/users/users.js +185 -0
  395. package/core/modules/Informations/change-info/change-info.js +618 -0
  396. package/core/modules/Informations/change-info/change-info.scss +135 -0
  397. package/core/modules/dashboard/components/dashboard-card/animations.js +65 -0
  398. package/core/modules/dashboard/components/dashboard-card/dashboard-card.js +197 -0
  399. package/core/modules/dashboard/components/dashboard-card/menu-dashboard-card.js +430 -0
  400. package/core/modules/dashboard/components/dashboard-card/menu-dashboard-card.scss +60 -0
  401. package/core/modules/dashboard/components/pop-query-dashboard/pop-query-dashboard.js +66 -0
  402. package/core/modules/generic/components/generic-add/generic-add.js +121 -0
  403. package/core/modules/generic/components/generic-add/generic-add.scss +13 -0
  404. package/core/modules/generic/components/generic-add-modal/generic-add-modal.js +125 -0
  405. package/core/modules/generic/components/generic-add-modal/generic-add-modal.scss +13 -0
  406. package/core/modules/generic/components/generic-detail/generic-detail.js +184 -0
  407. package/core/modules/generic/components/generic-detail/generic-detail.scss +25 -0
  408. package/core/modules/generic/components/generic-edit/generic-edit.js +123 -0
  409. package/core/modules/generic/components/generic-edit/generic-edit.scss +0 -0
  410. package/core/modules/generic/components/generic-list/generic-list.js +335 -0
  411. package/core/modules/generic/components/generic-list/generic-list.scss +35 -0
  412. package/core/modules/index.js +54 -0
  413. package/core/modules/module-routes/module-routes.js +37 -0
  414. package/core/modules/module-routes/module-routes.scss +0 -0
  415. package/core/modules/reporting/components/reporting-dashboard/reporting-dashboard.js +1101 -0
  416. package/core/modules/reporting/components/reporting-dashboard/reporting-dashboard.scss +171 -0
  417. package/core/pages/homepage-api/homepage-api.js +106 -0
  418. package/core/pages/homepage-api/homepage-api.scss +234 -0
  419. package/core/pages/homepage-api/menu-dashboard.js +169 -0
  420. package/core/pages/homepage-api/menu-dashboard.scss +12 -0
  421. package/core/translation.json +54 -0
  422. package/core/translations.json +20 -0
  423. package/core/utils/script.utils.js +130 -0
  424. package/core/utils/settings.utils.js +26 -0
  425. package/eslint.config.mjs +79 -0
  426. package/index.js +36 -0
  427. package/package.json +118 -0
  428. package/tsconfig.json +27 -0
  429. package/webpack.config.js +174 -0
@@ -0,0 +1,70 @@
1
+ /**
2
+ *
3
+ * Store as an initial local store for the app
4
+ *
5
+ * All the data that is needed accross the app like user, openProperties etc goes from here.
6
+ *
7
+ */
8
+
9
+ import React, { useEffect, useState, createContext, useReducer } from 'react';
10
+
11
+
12
+
13
+ /**
14
+ * Initial State to be stored
15
+ * accross the app
16
+ *
17
+ * For now maintaining only user data
18
+ *
19
+ * #todo Compare the setup with state manager utility
20
+ *
21
+ */
22
+ const initialState = {
23
+ menu: {}
24
+ };
25
+
26
+ /**
27
+ * Context for sharing state accross app
28
+ */
29
+ export const MenuGlobalContext = createContext(initialState);
30
+
31
+ let app = {};
32
+
33
+ /**
34
+ * Provider links the reducer and context
35
+ */
36
+ export const GlobalMenuProvider = ({ children, menu }) => {
37
+
38
+ // console.log(menu);
39
+
40
+ // Store that is accessible accross the app
41
+ // let store = { user: state.user, slot: state.slot, dispatch: dispatch, selectedLocation: state.selectedLocation }
42
+ let store = {
43
+ menu
44
+ };
45
+
46
+ return (<MenuGlobalContext.Provider value={store}>
47
+ {children}
48
+ </MenuGlobalContext.Provider>)
49
+
50
+ }
51
+
52
+ /**
53
+ * Reducer for managing the state
54
+ *
55
+ * @param state
56
+ * @param action
57
+ */
58
+ export const AppReducer = (state, action) => {
59
+
60
+ switch (action.type) {
61
+
62
+
63
+ case 'menu':
64
+
65
+ return { ...state, menu: action.payload };
66
+
67
+ default:
68
+ return state;
69
+ }
70
+ }
@@ -0,0 +1,250 @@
1
+ import React, { useState, Suspense, useEffect, lazy, Component } from 'react';
2
+
3
+ import { BaseLoader } from './../../../lib/models/';
4
+
5
+ import { GlobalContext } from '../../Store';
6
+
7
+ import { GlobalMenuProvider } from './../menu-context/menu-context';
8
+
9
+ import './menu-template.scss';
10
+
11
+ export default class MenuTemplate extends Component {
12
+
13
+ constructor(props) {
14
+
15
+ super(props);
16
+
17
+ this.state = {
18
+ loading: false,
19
+ model: null,
20
+ view: [],
21
+ component: null,
22
+ };
23
+
24
+ this.loadedComponent = () => null;
25
+ this.loadedModel = () => null;
26
+ this.menuDetail = () => { };
27
+ }
28
+
29
+ /**
30
+ *
31
+ */
32
+ componentDidMount() {
33
+
34
+ // console.log("Initialising menu", menu.name);
35
+
36
+ var genericComponents = require('./../../modules/');
37
+
38
+ var genericModels = require('./../../models/')
39
+
40
+ const { menu, callback, CustomComponents, CustomModels } = this.props;
41
+
42
+ var allComponents = {
43
+ ...genericComponents,
44
+ ...CustomComponents,
45
+ }
46
+
47
+ var allModels = {
48
+ ...genericModels,
49
+ ...CustomModels
50
+ }
51
+
52
+ let BaseModel = new BaseLoader(menu.model);
53
+
54
+ if (menu && menu.page && ((menu.page.identifier) || (menu.page.path))) {
55
+
56
+ let identifier = menu.page.identifier || menu.page.path;
57
+
58
+ if (identifier && allComponents[identifier]) {
59
+
60
+ this.loadedComponent = allComponents[identifier]
61
+
62
+ }
63
+ }
64
+
65
+
66
+ if (menu && menu.model_id) {
67
+
68
+ if (menu.model_id && allModels[menu.model.name]) {
69
+
70
+ this.loadedModel = allModels[menu.model.name]
71
+
72
+ } else {
73
+
74
+ // BaseModel = this.loadedModel[menu.model.name];
75
+
76
+ this.loadedModel = BaseModel
77
+
78
+ }
79
+ }
80
+
81
+ callback({ menu, model: this.loadedModel });
82
+
83
+ this.setState({ loading: true, component: this.loadedComponent, model: this.loadedModel });
84
+
85
+ }
86
+
87
+ render() {
88
+
89
+ const { props } = this;
90
+
91
+ const { menu } = this.props;
92
+
93
+ const { loading, model, menuDetail } = this.state;
94
+
95
+ const ComponentLoaderForParticulatMenu = this.loadedComponent;
96
+
97
+ // Parse the attrbutes for the menu to customize the menu
98
+ let attributes = {};
99
+
100
+ if (menu.attributes) {
101
+ if (typeof menu.attributes === 'string') {
102
+
103
+ attributes = JSON.parse(menu.attributes);
104
+ }
105
+ }
106
+
107
+ const { user, state } = useContext(GlobalContext);
108
+
109
+ return (
110
+ <div className="menu-template" style={{ background: state.theme.colors.colorTableBg }}>
111
+ {loading && ComponentLoaderForParticulatMenu && model ? (
112
+ <GlobalMenuProvider menu={menu}>
113
+
114
+ {/* Page Container */}
115
+ {/* # Note
116
+
117
+ Page Container can be bought here but here but have to bind with the refresh
118
+ action in the page . This would need to pass the handle as reference to the child
119
+ This should avoid use of page container in every component
120
+
121
+
122
+ // Make sure note to make overruse this area
123
+
124
+ */}
125
+ {/* <PageContainer menu={menu} title={menu.caption}> */}
126
+
127
+ {/* We extend the menu template to mould the components to control access to the page */}
128
+ {/* <FingerprintProtected menu={menu}> */}
129
+
130
+ <ComponentLoaderForParticulatMenu
131
+ {...props}
132
+ menu={menu}
133
+ model={model}
134
+
135
+ {...attributes}
136
+
137
+ {...props}
138
+ menuDetail={menuDetail}
139
+ />
140
+
141
+ {/* </FingerprintProtected> */}
142
+
143
+ {/* </PageContainer> */}
144
+
145
+ </GlobalMenuProvider>
146
+
147
+ ) : null}
148
+ </div>
149
+ );
150
+ }
151
+ }
152
+
153
+
154
+
155
+
156
+
157
+ // import LoadAsyncComponent from './../../Async/async';
158
+
159
+ // export default function MenuTemplate({ menu, ...props }) {
160
+
161
+
162
+ // const [loading, setLoading] = useState(false);
163
+
164
+ // // Model
165
+ // const [model, setModel] = useState(() => null);
166
+
167
+ // const [view, setView] = useState([]);
168
+
169
+ // const [component, setComponent] = useState(() => null);
170
+
171
+ // useEffect(() => {
172
+ // // if (menu) {
173
+ // // }
174
+
175
+ // async function loadComponent() {
176
+ // // Path to the component
177
+ // // let path = menu.page.path;
178
+ // console.log(menu);
179
+
180
+ // const BaseModel = new BaseLoader(menu.model);
181
+
182
+ // // Load the component with path
183
+ // let loadedComponent = LoadAsyncComponent(() => require(`./../../../business/common/${menu.page.path}`));
184
+
185
+ // let loadedModel = require('./../../../models/');
186
+
187
+ // // const DynamicComponent = lazy(() => import(`./${component_path}`).catch(() => {}));
188
+ // //
189
+
190
+ // // let path = 'modules/common/resources/generic/generic-list/generic-list'
191
+
192
+ // // const DynamicComponent = lazy(() => import(`./../../../${path}`).catch(() => {}));
193
+
194
+ // // var component_url = `./../../../` + `/business/common/resources/generic/generic-list/generic-list`;
195
+
196
+ // // loadedcomponent = require(`${component_path}`);
197
+
198
+ // // loadedcomponent = LoadAsyncComponent(() => require(`${component_path}`));
199
+
200
+ // // var component_url = '/src/business/common/resources/generic/generic-list/generic-list';
201
+
202
+ // // loadedcomponent = await import(component_url);
203
+
204
+ // // loadedcomponent = DynamicComponent;
205
+
206
+ // // Load the models
207
+ // // loadedModel = require('./../../../models/');
208
+
209
+ // setComponent(loadedComponent);
210
+
211
+ // setModel(BaseModel);
212
+ // // setModel(loadedModel[menu.model.name]);
213
+
214
+ // setLoading(true);
215
+
216
+ // // list promises from menu
217
+ // // const componentPromises = [menu].map(async (menu) => {
218
+ // // console.log(menu.page.path);
219
+
220
+ // // const View = await importView(menu.page.path);
221
+
222
+ // // console.log(View);
223
+
224
+ // // return <View key={''} {...menu} />;
225
+ // // });
226
+
227
+ // // Promise.all(componentPromises).then(setView);
228
+ // }
229
+
230
+ // loadComponent();
231
+ // }, []);
232
+
233
+ // const ComponentLoaderForParticulatMenu = component;
234
+
235
+ // // const View = view;
236
+
237
+ // console.log(ComponentLoaderForParticulatMenu);
238
+
239
+ // return (
240
+ // // <Suspense fallback={<div>Loading...</div>}>{OtherComponent ? <OtherComponent menu={menu} model={model} {...props} menuDetail={menuDetail} /> : null}</Suspense>
241
+ // // <div className="menu-template">
242
+ // // {View && model ? <View.default.WrappedComponent menu={menu} model={model} {...props} menuDetail={menuDetail} /> : null}
243
+ // // </div>
244
+ // loading && ComponentLoaderForParticulatMenu && model ? (
245
+ // <ComponentLoaderForParticulatMenu menu={menu} model={model} {...props} menuDetail={menuDetail} />
246
+ // ) : null
247
+ // );
248
+ // }
249
+
250
+ // const DynamicComponent = (subreddit) => lazy(() => import(`${subreddit}`).catch(() => {}));
@@ -0,0 +1,9 @@
1
+ .menu-template {
2
+ margin-top:53px;
3
+ padding: 8px;
4
+
5
+ @media only screen and (max-width: 768px) {
6
+ padding: 16px;
7
+ }
8
+ // height: 100%;
9
+ }
@@ -0,0 +1,153 @@
1
+ import React, { useState, useContext } from "react";
2
+
3
+ import { Link } from "react-router-dom";
4
+
5
+ import "./modal-search.scss";
6
+
7
+ import FirebaseUtils from "./../../utils/firebase.utils";
8
+
9
+ import { Modal, Input, Card } from "antd";
10
+
11
+ import { GlobalContext } from "./../../Store";
12
+
13
+ import {
14
+ SearchOutlined,
15
+ BulbOutlined,
16
+ UserOutlined,
17
+ RightOutlined,
18
+ } from "@ant-design/icons";
19
+
20
+ export default function ModalSearch() {
21
+ const { user } = useContext(GlobalContext);
22
+ //Hooks
23
+ const [isModalVisible, setIsModalVisible] = useState(false);
24
+
25
+ const [isResultsVisible, setResultsVisible] = useState(false);
26
+
27
+ const [results, setResults] = useState([]);
28
+
29
+ const [location, setLocation] = useState(user.locations[0]);
30
+
31
+ const [inputCount, setinputCount] = useState(10);
32
+
33
+ //Modal methods
34
+ const showModal = () => {
35
+ setIsModalVisible(true);
36
+ };
37
+
38
+ const handleOk = () => {
39
+ setIsModalVisible(false);
40
+ };
41
+
42
+ const handleCancel = () => {
43
+ setIsModalVisible(false);
44
+ setResultsVisible(false);
45
+ };
46
+ const getResults = (query) => {
47
+ var queries = [
48
+ {
49
+ field: "Contact Number",
50
+ value: query,
51
+ },
52
+ ];
53
+
54
+ FirebaseUtils.getAllListing(
55
+ queries,
56
+ "bookings",
57
+ "bookings",
58
+ "bookingId"
59
+ ).then((result) => {
60
+ setResults(
61
+ result.all.filter((booking) => {
62
+ return !booking.isCancelled;
63
+ })
64
+ );
65
+ });
66
+ };
67
+
68
+ //Handle search query
69
+ const handleOnInputChange = (e) => {
70
+ setResultsVisible(true);
71
+ //Trigger getResults() only when 10 characters are given
72
+ setinputCount(e.target.value.length);
73
+ if (e.target.value.length == 10) {
74
+ getResults(e.target.value);
75
+ } else {
76
+ setResultsVisible(false);
77
+ }
78
+ };
79
+
80
+ //Results to render
81
+ let itemsToRender;
82
+ if (results) {
83
+ itemsToRender = results.map((item) => {
84
+ return (
85
+ <ul className="results-list">
86
+ <li key={item["Booking No"]}>
87
+ <span>
88
+ <UserOutlined style={{ paddingRight: "10px" }} />
89
+ {item["Name of the Customer"]}
90
+ </span>
91
+ <span>
92
+ <Link
93
+ to={`/${location}/bookings/${item["Booking No"]}`}
94
+ onClick={handleOk}
95
+ >
96
+ View Booking <RightOutlined />
97
+ </Link>
98
+ </span>
99
+ </li>
100
+ </ul>
101
+ );
102
+ });
103
+ }
104
+
105
+ return (
106
+ <>
107
+ <span className="show-search">
108
+ <SearchOutlined style={{ marginRight: "1em" }} onClick={showModal} />
109
+ </span>
110
+ <Modal
111
+ visible={isModalVisible}
112
+ onOk={handleOk}
113
+ onCancel={handleCancel}
114
+ footer={[]}
115
+ className="spotlight-container spotlight-search"
116
+ >
117
+ <Input
118
+ size="large"
119
+ placeholder=""
120
+ autoFocus="on"
121
+ maxLength="10"
122
+ prefix={<SearchOutlined />}
123
+ onChange={handleOnInputChange}
124
+ placeholder={"Type to search"}
125
+ className={`search-box ${isResultsVisible ? "bottom-border-no-radius" : ""
126
+ }`}
127
+
128
+ />
129
+ <Card
130
+ className={`${isResultsVisible ? "visible-item" : "hidden-item"}`}
131
+ >
132
+ {itemsToRender.length != 0 ? (
133
+ itemsToRender
134
+ ) : (
135
+
136
+ <span className="light-text">No Results</span>
137
+ )}
138
+ </Card>
139
+ <span
140
+ className={`spotlight-search-tip ${isResultsVisible ? "hidden-item" : "visible-item"
141
+ }`}
142
+
143
+ >
144
+ {" "}
145
+ <BulbOutlined style={{ marginRight: "10px" }} />
146
+ {inputCount != 10
147
+ ? `Enter ${10 - inputCount} more numbers`
148
+ : "Search by phone number"}
149
+ </span>
150
+ </Modal>
151
+ </>
152
+ );
153
+ }
@@ -0,0 +1,79 @@
1
+ .spotlight-search
2
+ {
3
+ .ant-modal-content {
4
+ background-color: transparent !important;
5
+ box-shadow: none !important;
6
+ &:focus {
7
+ outline: none;
8
+ }
9
+ }
10
+ .ant-modal-body {
11
+ padding: 0px !important;
12
+ background-color: transparent;
13
+ }
14
+
15
+ .search-box {
16
+ border-radius: 0.5rem !important;
17
+ border: none !important;
18
+ padding: 0.8em 1.2em !important;
19
+ }
20
+
21
+ .show-search{
22
+ margin-right: 1em;
23
+ }
24
+
25
+ .ant-modal-close {
26
+ display: none !important;
27
+ }
28
+ .ant-card {
29
+ border-radius: 0em 0em 0.5em 0.5em !important;
30
+ }
31
+ .ant-modal-footer {
32
+ display: none;
33
+ }
34
+ .bottom-border-no-radius {
35
+ border-radius: 0.5em 0.5em 0em 0em !important;
36
+ }
37
+ .visible-item {
38
+ display: block;
39
+ }
40
+ .hidden-item {
41
+ display: none;
42
+ }
43
+ .spotlight-container {
44
+ display: flex;
45
+ flex-direction: column;
46
+ }
47
+ .spotlight-search-tip {
48
+ position: absolute;
49
+ width: 500px;
50
+ left: 0;
51
+ top: 4.5em;
52
+ font-weight: bold;
53
+ color: #fff;
54
+ }
55
+ .ant-card-body {
56
+ padding-top: 0.5em !important;
57
+ }
58
+ .results-list {
59
+ list-style: none;
60
+ padding: 0;
61
+ margin: 0;
62
+ li {
63
+ font-weight: bold;
64
+ padding: 0.5em 0em 0.5em 0;
65
+ border-bottom: 1px solid #f5f5f5;
66
+ width: 100%;
67
+ display: flex;
68
+ justify-content: space-between;
69
+ &:last-child {
70
+ border: none;
71
+ padding-bottom: 0;
72
+ }
73
+ }
74
+ }
75
+ .light-text {
76
+ color: grey;
77
+ font-weight: bold;
78
+ }
79
+ }
@@ -0,0 +1,16 @@
1
+
2
+ module.exports = {
3
+ _currentGlobalLoader: null,
4
+ registerModal: function (ref) {
5
+ this._currentGlobalLoader = ref;
6
+ },
7
+ openModal: function ({ ...args }) {
8
+ if (this._currentGlobalLoader) {
9
+ this._currentGlobalLoader.openModal({ ...args });
10
+ }
11
+ },
12
+ closeModal: function ({ ...args }) {
13
+ this._currentGlobalLoader.closeModal({ ...args });
14
+ }
15
+
16
+ }
@@ -0,0 +1,108 @@
1
+ /**
2
+ * Modal wrapper
3
+ * Accepts various props such as isVisible(boolean), headerText, modalHeader, modalBody, modalFooter, closeModal(function)
4
+ * To render header, either pass modalHeader component or header text
5
+ * rest modalBody and modalFooter is optional
6
+ *
7
+ * e.g.
8
+ * <ModalWrap
9
+ * isVisible={isVisible}
10
+ * headerText="tesfh"
11
+ * modalBody={() => (<h1> hudgdub</h1>)}
12
+ * closeModal={() => this.setState({ isVisible: false })}
13
+ * />
14
+ */
15
+
16
+ import React, { Component } from 'react';
17
+
18
+ import { Modal } from 'antd';
19
+
20
+ import './modal-wrapper.scss';
21
+
22
+ export default class ModalWrapper extends Component {
23
+
24
+ constructor(props) {
25
+
26
+ super(props);
27
+
28
+ this.state = {
29
+ ...props,
30
+ modals: [] // Array maintained for opening multiple modals at the same time
31
+ }
32
+ }
33
+
34
+ unsafe_componentwillreceiveprops(nextProps) {
35
+ if (this.state.isVisible != nextProps.isVisible) {
36
+ this.setState({ isVisible: nextProps.isVisible });
37
+ }
38
+ }
39
+
40
+ openModal = ({ ...args }) => {
41
+ let { modals } = this.state;
42
+ args.isVisible = true;
43
+ var index = modals.push({ ...args })
44
+ this.setState({ modals });
45
+ }
46
+
47
+
48
+ closeModal = (modal, key) => {
49
+ let { modals } = this.state;
50
+
51
+ modals.splice(key, 1);
52
+
53
+ this.setState({ modals });
54
+ }
55
+
56
+
57
+ render() {
58
+
59
+ const { modals, size = 'lg' } = this.state;
60
+
61
+ return (
62
+ <div className="modals-wrapper">
63
+ {
64
+ modals.map((modal, key) =>
65
+
66
+ <Modal key={key} size={size} isOpen={modal.isVisible} toggle={() => {
67
+ console.log(modal, key);
68
+ this.closeModal(modal, key)
69
+ }
70
+ } className={modal.className} backdrop={this.state.backdrop}>
71
+
72
+ {/* {
73
+ modal.modalHeader ?
74
+ <ModalHeader toggle={() => {
75
+ console.log(modal, key);
76
+ this.closeModal(modal, key)
77
+ }}>{modal.modalHeader()}</ModalHeader>
78
+ :
79
+ modal.headerText ?
80
+ <ModalHeader toggle={() => {
81
+ this.closeModal(modal, key)
82
+
83
+
84
+ }}>{modal.headerText}</ModalHeader>
85
+ : null
86
+ } */}
87
+
88
+ {
89
+ modal.modalBody &&
90
+ // <ModalBody>
91
+ modal.modalBody()
92
+ // </ModalBody>
93
+ }
94
+
95
+ {/* {
96
+ modal.modalFooter &&
97
+ <ModalFooter>
98
+ {modal.modalFooter()}
99
+ </ModalFooter>
100
+ } */}
101
+ </Modal>
102
+ )
103
+ }
104
+
105
+ </div>
106
+ )
107
+ }
108
+ }
@@ -0,0 +1,14 @@
1
+
2
+ .modal-body {
3
+ background: whitesmoke;
4
+ .form-settings {
5
+ position: absolute; // top: -5%;
6
+ top: -45px;
7
+ // right: 5%;
8
+ right: 60px;
9
+ }
10
+ }
11
+
12
+ .modal-backdrop.show{
13
+ opacity: .92;
14
+ }