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,430 @@
1
+ import { useState, useEffect } from 'react';
2
+
3
+ import { Modal, Skeleton, Alert, Typography, Button, Drawer } from 'antd';
4
+
5
+ import { Dashboard } from './../../../../models/';
6
+
7
+ import PopQueryDashboard from '../pop-query-dashboard/pop-query-dashboard';
8
+
9
+ import { StatisticCard, BasicTable, ExtraInfoDetail } from './../../../../lib';
10
+
11
+ import ReportingDashboard from '../../../reporting/components/reporting-dashboard/reporting-dashboard';
12
+
13
+ import DashboardStatisticCard from '../../../../lib/elements/complex/statistic-card/dashboard-statistic-card';
14
+
15
+ /** Title */
16
+ const { Title } = Typography;
17
+
18
+ /**
19
+ * Dashboard Card
20
+ *
21
+ * @param {*} param0
22
+ * @returns {string}
23
+ */
24
+ export default function MenuDashboardCard({ record, selectedCardId, scope, dbPtr, callback, onSelect, style, handleHide, homePage }) {
25
+ const isSelected = selectedCardId === record.id;
26
+
27
+ const [visible, setVisible] = useState(false);
28
+ const [popquery, setPopquery] = useState(false);
29
+
30
+ const [loading, setLoading] = useState(true);
31
+
32
+ const [result, setResult] = useState({});
33
+
34
+ const [showDrawer, setShowDrawer] = useState(false);
35
+
36
+ const [otherDetails, setOtherDetails] = useState({});
37
+ /**
38
+ * useEffect Hook
39
+ *
40
+ * Executes the `executeQuery` function when the component mounts.
41
+ */
42
+
43
+ useEffect(() => {
44
+ executeQuery(record.id);
45
+ }, []);
46
+
47
+ /**
48
+ * Executes the dashboard query and sets the result state with the fetched data.
49
+ * Handles both success and error responses.
50
+ *
51
+ * @param {string|number} id - The ID used to execute the query and fetch dashboard data.
52
+ * @returns {void} This function does not return anything.
53
+ */
54
+ async function executeQuery(id) {
55
+ setLoading(true);
56
+ if (dbPtr) {
57
+ dbPtr = dbPtr;
58
+ } else {
59
+ dbPtr = localStorage.db_ptr;
60
+ }
61
+
62
+ // Execute dashboard
63
+ try {
64
+ let response = await Dashboard.execDashboard(id, scope, dbPtr);
65
+
66
+ let reportData = {};
67
+
68
+ if (response.result) {
69
+ reportData = response.result[0];
70
+ } else {
71
+ if (response[0]) {
72
+ reportData = response[0];
73
+ }
74
+ }
75
+ if (reportData.length > 0) {
76
+ setResult(reportData);
77
+ } else {
78
+ // handleHide();
79
+ }
80
+
81
+ setLoading(false);
82
+ // })
83
+ } catch (error) {
84
+ setResult({ error: 'Error' });
85
+ }
86
+ }
87
+
88
+ /**
89
+ * Parses `other_details` from the record and applies styles.
90
+ * If `other_details` exists, it is parsed as JSON; otherwise, an empty object is used.
91
+ *
92
+ * @type {Object}
93
+ */
94
+ let styles = {};
95
+
96
+ if (record.other_details) {
97
+ styles = JSON.parse(record.other_details);
98
+ }
99
+
100
+ /**
101
+ * Opens a pop-up modal and passes the record to the callback function.
102
+ *
103
+ * @param {Object} record - The record data to be passed.
104
+ * @returns {void} This function does not return anything.
105
+ */
106
+
107
+ function viewPopQueryModal(record) {
108
+ let otherDetails;
109
+
110
+ if (record.other_details) {
111
+ otherDetails = JSON.parse(record.other_details);
112
+ }
113
+
114
+ if (otherDetails?.script_id) {
115
+ //If viewMode = 'modal' → open modal
116
+ if (otherDetails?.viewMode === 'modal') {
117
+ setVisible(true);
118
+ //If viewMode = 'drawer' → open drawer
119
+ } else if (otherDetails?.viewMode === 'drawer') {
120
+ setShowDrawer(true);
121
+ // callback(record, scope)
122
+ } else {
123
+ //Otherwise → fallback callback
124
+ callback(record);
125
+ }
126
+ //No script_id but has viewMode → set popquery
127
+ } else if (otherDetails?.viewMode) {
128
+ // No script_id but has viewMode
129
+ setPopquery(true);
130
+ } else {
131
+ // Default
132
+ callback(record);
133
+ }
134
+
135
+ setOtherDetails(otherDetails);
136
+ onSelect();
137
+ }
138
+
139
+ /**
140
+ *
141
+ */
142
+ // function executePopQuery() { }
143
+
144
+ var props = {};
145
+ /**
146
+ * Stores component properties, including the loading state.
147
+ *
148
+ * @type {Object}
149
+ */
150
+
151
+ if (loading) {
152
+ props.loading = true;
153
+ }
154
+ function onCancel() {
155
+ setVisible(false);
156
+ }
157
+
158
+ /**
159
+ * Convert nested style objects into a valid CSS string.
160
+ * @param {*} parentClass
161
+ * @param {*} nestedStyles
162
+ * @returns
163
+ */
164
+ const convertNestedStylesToCSS = (parentClass, nestedStyles) => {
165
+ let css = '';
166
+ // Iterate through each child selector and its corresponding style object
167
+ for (const [childSelector, styleObj] of Object.entries(nestedStyles)) {
168
+ if (typeof styleObj !== 'object') continue;
169
+
170
+ const fullSelector = `${parentClass} ${childSelector}`;
171
+ const rules = Object.entries(styleObj)
172
+ .map(([key, value]) => `${key.replace(/([A-Z])/g, '-$1').toLowerCase()}:${value};`)
173
+ .join(' ');
174
+ css += `${fullSelector} { ${rules} }\n`;
175
+ }
176
+ // Append the formatted CSS block
177
+ return css;
178
+ };
179
+
180
+ /**
181
+ * defaultStyles for the cards
182
+ */
183
+ const defaultStyles = {
184
+ '.menu-dashboard-card': {
185
+ '.text-section': {
186
+ fontSize: '13px',
187
+ textAlign: 'justify',
188
+ },
189
+ '.table-section': {
190
+ width: '100%',
191
+ },
192
+ height: '11px',
193
+ // minWidth: '130px',
194
+ padding: '17px 7px',
195
+ fontSize: '10px',
196
+ display: 'flex',
197
+ alignItems: 'center',
198
+ justifyContent: 'center',
199
+ // margin: '10px',
200
+ cursor: 'pointer',
201
+ borderRadius:'30px',
202
+ boxShadow: "0 0.5px 0.5px rgba(0,0,0,0.08)",
203
+
204
+ '&.selected': {
205
+ border: '2px solid #b1ceeb',
206
+ },
207
+
208
+ '.statistic-card-container': {
209
+ '.ant-statistic-title': {
210
+ color: 'rgba(0, 0, 0, 0.45)',
211
+ fontSize: '10px',
212
+ marginBottom: '0px',
213
+ },
214
+ '.ant-statistic-content': {
215
+ color: 'rgba(0, 0, 0, 0.85)',
216
+ fontSize: '10px',
217
+ display: 'flex',
218
+ justifyContent: 'center',
219
+ },
220
+ '.ant-statistic':{
221
+ display: 'flex',
222
+ justifyContent: 'space-between',
223
+ alignItems: 'center',
224
+ gap:'5px'
225
+ }
226
+ },
227
+ },
228
+ };
229
+ // Extract nested styles for the ".statistic-card-container"
230
+ // from the deeply nested style object (if available).
231
+ const nestedStyles = styles?.style?.['.menu-dashboard']?.['.menu-dashboard-card']?.['.statistic-card-container'];
232
+
233
+ // Generate the dynamic CSS string using convertNestedStylesToCSS.
234
+ // 1. Base selector: ".statistic-card-container"
235
+ // 2. Styles: Use `nestedStyles` if available,
236
+ // otherwise fall back to default styles from `defaultStyles`.
237
+ const dynamicCSS = convertNestedStylesToCSS(
238
+ '.statistic-card-container',
239
+ nestedStyles || defaultStyles['.menu-dashboard-card']?.['.statistic-card-container'] || {}
240
+ );
241
+ /**
242
+ * Renders different dashboard tiles based on the `tiletypeptr` of the record.
243
+ *
244
+ * @param {Object} record - The record containing the tile information and tile type.
245
+ * @returns {JSX.Element | string} The rendered dashboard tile component or an empty string.
246
+ */
247
+ let span = 24;
248
+ function displayDashboardTile(record) {
249
+ switch (record.tiletypeptr) {
250
+ case 'BASIC': {
251
+ if (homePage) {
252
+
253
+ return (
254
+ <div className={`menu-dashboard-card card ${isSelected ? 'selected' : ''}`} onClick={() => viewPopQueryModal(record)} style={{padding:"14px 20px",width:"320px",border: "1px solid rgb(239 ,230 ,230)" ,boxShadow: "0 0.5px 0.5px rgba(0,0,0,0.08)"}}>
255
+ <Title
256
+ // Apply styles for the ".text-section"
257
+ // Priority: use custom styles from `styles` if provided,
258
+ // otherwise fallback to default styles
259
+ style={
260
+ styles?.style?.['.menu-dashboard']?.['.menu-dashboard-card']?.['.text-section'] ||
261
+ defaultStyles['.menu-dashboard-card']?.['.text-section']
262
+ }
263
+ >
264
+ {record.text}
265
+ </Title>
266
+ {/* <StatisticCard result={result[0]} {...props} /> */}
267
+ {/* for home dashboard */}
268
+ <DashboardStatisticCard result={result[0]} {...props} />
269
+ </div>
270
+ );
271
+ } else {
272
+ return (
273
+ <div
274
+ // Inline style merging:
275
+ // 1. Base styles → from `styles` object if available, otherwise from `defaultStyles`
276
+ // 2. If the card is selected → merge "&.selected" styles (custom or default)
277
+ className={`menu-dashboard-card card ${isSelected ? 'selected' : ''}`}
278
+ onClick={() => viewPopQueryModal(record)}
279
+ style={{
280
+ ...(styles?.style?.['.menu-dashboard']?.['.menu-dashboard-card'] || defaultStyles['.menu-dashboard-card']),
281
+ ...(isSelected
282
+ ? styles?.style?.['.menu-dashboard']?.['.menu-dashboard-card']?.['&.selected'] ||
283
+ defaultStyles['.menu-dashboard-card']?.['&.selected'] ||
284
+ {}
285
+ : {}),
286
+ }}
287
+ >
288
+ {dynamicCSS && <style dangerouslySetInnerHTML={{ __html: dynamicCSS }} />}
289
+ <div className="statistic-card-container selected">
290
+ <StatisticCard result={result[0]} {...props} />
291
+ </div>
292
+ </div>
293
+ );
294
+ }
295
+ }
296
+ case 'TABLE':
297
+ return (
298
+ // Apply styles for the ".table-section"
299
+ // Priority: use custom styles from `styles` if present,
300
+ // otherwise fall back to default styles
301
+ <div style={styles?.style?.['.menu-dashboard']?.['.table-section'] || defaultStyles['.menu-dashboard-card']?.['.table-section']}>
302
+ <Title
303
+ // Apply styles for the ".text-section"
304
+ // Priority: use custom styles from `styles` if provided,
305
+ // otherwise fallback to default styles
306
+ style={
307
+ styles?.style?.['.menu-dashboard']?.['.menu-dashboard-card']?.['.text-section'] ||
308
+ defaultStyles['.menu-dashboard-card']?.['.text-section']
309
+ }
310
+ >
311
+ {record.text}
312
+ </Title>
313
+ <BasicTable styles={styles} result={result} {...props} />
314
+ {styles?.action ? (
315
+ <span
316
+ style={{ display: 'flex', justifyContent: 'flex-end', cursor: 'pointer', fontWeight: 'bold', fontSize: '16px' }}
317
+ className="link"
318
+ onClick={() => viewPopQueryModal(record)}
319
+ >
320
+ View
321
+ </span>
322
+ ) : null}
323
+ </div>
324
+ );
325
+
326
+ case 'LINEGPH':
327
+ return null;
328
+ // return <BarGraph data={result} {...props} />;
329
+
330
+ default:
331
+ return '';
332
+ }
333
+ }
334
+
335
+ function onClose() {
336
+ setShowDrawer(false);
337
+ }
338
+ function onCancelPopQuery() {
339
+ setPopquery(false);
340
+ }
341
+
342
+ return (
343
+ <>
344
+ {loading ? (
345
+ // <Skeleton />
346
+ <Skeleton
347
+ active
348
+ title={false}
349
+ paragraph={{ rows: 1, width: ['80%', '50%'] }}
350
+ style={{ width: 100, padding: 20 }}
351
+ />
352
+ ) : (
353
+ <>
354
+ {result.length > 0 ? (
355
+ <>
356
+ {/* <div className='text-section'> */}
357
+
358
+ {/* </div> */}
359
+
360
+ <div>
361
+ <div className="text-section">
362
+ {/* <Title
363
+ // Apply styles for the ".text-section"
364
+ // Priority: use custom styles from `styles` if provided,
365
+ // otherwise fallback to default styles
366
+ style={
367
+ styles?.style?.['.menu-dashboard']?.['.menu-dashboard-card']?.['.text-section'] ||
368
+ defaultStyles['.menu-dashboard-card']?.['.text-section']
369
+ }
370
+ >
371
+ {record.text}
372
+ </Title> */}
373
+ </div>
374
+ <div>
375
+ {result.error ? (
376
+ <>
377
+ <Alert message="Error loading values" type="error" showIcon />
378
+ </>
379
+ ) : (
380
+ // <>{loading ? <Skeleton /> : {(result.length ?displayDashboardTile(record)}:null)}</>
381
+ <> {loading ? <Skeleton /> : result.length ? displayDashboardTile(record) : null}</>
382
+ )}
383
+ </div>
384
+ </div>
385
+ </>
386
+ ) : null}
387
+ </>
388
+ )}
389
+ {/* Render reporting dashboard inside the modal */}
390
+ <Modal
391
+ width="80%"
392
+ destroyOnClose={true}
393
+ visible={visible}
394
+ title={record.text}
395
+ footer={null}
396
+ okText="Create"
397
+ cancelText="Cancel"
398
+ onCancel={onCancel}
399
+ onOk={() => {}}
400
+ >
401
+ <ReportingDashboard reportId={otherDetails.script_id}></ReportingDashboard>
402
+ </Modal>
403
+ {/** end */}
404
+ {/* Render the PopQueryDashboard inside the modal */}
405
+ <Modal
406
+ width="80%"
407
+ destroyOnClose={true}
408
+ visible={popquery}
409
+ title={record.text}
410
+ footer={null}
411
+ okText="Create"
412
+ cancelText="Cancel"
413
+ onCancel={onCancelPopQuery}
414
+ onOk={() => {}}
415
+ >
416
+ <PopQueryDashboard record={record} id={record.id} />
417
+ </Modal>
418
+ {/** end */}
419
+ <>
420
+ {/* Inside the drawer, render ReportingDashboard
421
+ Passing `reportId` and `scope` as props */}
422
+ {showDrawer ? (
423
+ <Drawer width={'85%'} title={otherDetails?.groupcaption} onClose={onClose} open={showDrawer}>
424
+ <ReportingDashboard reportId={otherDetails.script_id} scope={scope}></ReportingDashboard>
425
+ </Drawer>
426
+ ) : null}
427
+ </>
428
+ </>
429
+ );
430
+ }
@@ -0,0 +1,60 @@
1
+ .menu-dashboard-card {
2
+ height: 50px;
3
+ min-width: 97px;
4
+ padding: 2px;
5
+ font-size: 10px;
6
+ display: flex;
7
+ align-items: center;
8
+ justify-content: center;
9
+ margin: 10px;
10
+ cursor: pointer;
11
+ &.selected {
12
+ border: 2px solid #b1ceeb;
13
+ }
14
+ .statistic-card-container {
15
+ .ant-statistic-title {
16
+ color: rgba(0, 0, 0, 0.45);
17
+ font-size: 10px;
18
+ }
19
+ .ant-statistic-content {
20
+ color: rgba(0, 0, 0, 0.85);
21
+ font-size: 10px;
22
+ display: flex;
23
+ justify-content: center;
24
+
25
+ }
26
+ }
27
+ }
28
+
29
+ .status {
30
+ display: inline-flex;
31
+ align-items: center;
32
+ background-color: #fee2e2;
33
+ color: #b91c1c;
34
+ padding: 4px 12px;
35
+ border-radius: 999px;
36
+ font-size: 14px;
37
+ font-weight: 500;
38
+ }
39
+
40
+ .status-dot {
41
+ width: 8px;
42
+ height: 8px;
43
+ background-color: #dc2626;
44
+ border-radius: 50%;
45
+ display: inline-block;
46
+ margin-right: 6px;
47
+ }
48
+
49
+ .read-note-btn {
50
+ background-color: #e0f2fe;
51
+ color: #2563eb;
52
+ border: none;
53
+ padding: 4px 12px;
54
+ border-radius: 8px;
55
+ font-size: 13px;
56
+ cursor: pointer;
57
+ margin-top: 22px;
58
+ margin-left: 20px;
59
+ height: 25px;
60
+ }
@@ -0,0 +1,66 @@
1
+
2
+ import React, { useEffect, useState } from "react";
3
+
4
+ import { Dashboard } from './../../../../models/'
5
+
6
+ import { BasicTable } from './../../../../lib'
7
+
8
+ import { Skeleton, Empty } from "antd";
9
+
10
+
11
+ export default function PopQueryDashboard({ record, id }) {
12
+
13
+ const [loading, setLoading] = useState(false);
14
+
15
+ const [result, setResult] = useState([[], 0]);
16
+
17
+ useEffect(() => {
18
+
19
+ setLoading(true);
20
+
21
+ Dashboard.execPopQuery(id)
22
+ .then((response) => {
23
+
24
+ let reportData = {};
25
+
26
+ if (response.result) {
27
+
28
+ reportData = response.result[0];
29
+
30
+ } else {
31
+
32
+ if (response && response[0]) {
33
+
34
+ reportData = response[0];
35
+
36
+ } else {
37
+
38
+ reportData = response;
39
+
40
+ }
41
+
42
+ }
43
+
44
+ setResult(reportData)
45
+
46
+ setLoading(false);
47
+
48
+
49
+ console.log(record.tiletypeptr, result);
50
+ })
51
+ .catch(() => {
52
+ // setResult({ error: 'Error' });
53
+ });
54
+ }, []);
55
+
56
+ return <>
57
+
58
+ {loading ? (
59
+ <Skeleton active />
60
+ ) : (
61
+ <>
62
+ {result.length ? <BasicTable result={result} /> : <Empty />}
63
+ </>
64
+ )}
65
+ </>;
66
+ }
@@ -0,0 +1,121 @@
1
+ import React, { useState, useEffect } from 'react';
2
+
3
+ import { Typography, Space, message, Card, Button } from 'antd';
4
+
5
+ import { FormCreator } from './../../../../lib';
6
+
7
+ import { ModelColumnsAPI } from '../../../../models';
8
+
9
+ import './generic-add.scss';
10
+
11
+ const { Title } = Typography;
12
+
13
+ const GenericAdd = ({ model, callback, formContent }) => {
14
+
15
+ const [config, setConfig] = useState({ fields: [] })
16
+
17
+ useEffect(() => {
18
+
19
+ if (model.id) {
20
+
21
+ loadModelColumns();
22
+
23
+ } else {
24
+
25
+ // let model = {
26
+ // fields: result.result
27
+ // }
28
+
29
+ setConfig(model)
30
+ }
31
+
32
+ }, []);
33
+
34
+ /**
35
+ * Load all the model columns
36
+ */
37
+ function loadModelColumns() {
38
+
39
+ ModelColumnsAPI.getFormColumns(model.id).then((result) => {
40
+
41
+ console.log(result);
42
+
43
+ let model = {
44
+ fields: result.result
45
+ }
46
+
47
+ setConfig(model)
48
+
49
+ console.log(model + "hello")
50
+
51
+ })
52
+ }
53
+
54
+ /**
55
+ *
56
+ */
57
+ function onSubmit(values) {
58
+
59
+ if (formContent && formContent.id) {
60
+
61
+ // save the data to the model
62
+ return model
63
+ .update({ id, values, user })
64
+ .then(() => {
65
+ message.success('Operation Successful');
66
+ })
67
+ .catch(() => {
68
+ message.error('Operation Failed');
69
+ });
70
+
71
+ } else {
72
+
73
+ // save the data to the model
74
+ return model
75
+ .add({ values })
76
+ .then(() => {
77
+ message.success('Operation Successful');
78
+ })
79
+ .catch(() => {
80
+ message.error('Operation Failed');
81
+ });
82
+ }
83
+
84
+ }
85
+
86
+ return (
87
+ <div className="generic-add">
88
+ {/* Table Header */}
89
+ <div className="table-header">
90
+ <div className="table-title">
91
+ <Title level={4}>{model.name}</Title>
92
+
93
+ {/* <p>{loading ? 'Loading records' : `${records[model.name].length} records`}</p> */}
94
+ </div>
95
+
96
+ <div className="table-bar">
97
+ {/* Table Filters */}
98
+ <div className="table-filters"></div>
99
+ {/* Table Filters Ends */}
100
+
101
+ <div className="table-actions">
102
+ <div className="button-container">
103
+ <Space size="small">
104
+ {/* <Button type="secondary" size={'small'}>
105
+ Cancel
106
+ </Button> */}
107
+ </Space>
108
+ </div>
109
+ </div>
110
+ </div>
111
+ </div>
112
+ {/* Table Header Ends */}
113
+
114
+ <Card className="detail-content">
115
+ <FormCreator fields={config.fields} model={config} onSubmit={onSubmit} />
116
+ </Card>
117
+ </div>
118
+ );
119
+ };
120
+
121
+ export default GenericAdd;
@@ -0,0 +1,13 @@
1
+ .generic-add {
2
+
3
+ margin: 0px 10px;
4
+
5
+
6
+ .table-header {
7
+ .table-bar {
8
+ display: flex;
9
+ justify-content: space-between;
10
+ margin: 5px 0px;
11
+ }
12
+ }
13
+ }