@wavemaker-ai/react-runtime 1.0.0-rc.309 → 1.0.0-rc.314

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 (574) hide show
  1. package/.npmignore +4 -0
  2. package/actions/base-action.js +12 -29
  3. package/actions/login-action.js +35 -52
  4. package/actions/logout-action.js +21 -38
  5. package/actions/navigation-action.js +251 -346
  6. package/actions/notification-action.js +121 -149
  7. package/actions/timer-action.js +95 -151
  8. package/actions/toast-provider.js +62 -76
  9. package/actions/toast.js +95 -91
  10. package/actions/toast.service.js +59 -79
  11. package/actions/types/index.js +6 -9
  12. package/components/advanced/carousel/index.js +358 -366
  13. package/components/advanced/carousel/props.js +0 -5
  14. package/components/advanced/carousel/template.js +102 -80
  15. package/components/advanced/login/index.js +227 -285
  16. package/components/advanced/login/props.js +0 -5
  17. package/components/advanced/marquee/index.js +169 -163
  18. package/components/advanced/marquee/props.js +0 -5
  19. package/components/basic/anchor/index.js +207 -187
  20. package/components/basic/anchor/props.js +0 -5
  21. package/components/basic/audio/index.js +110 -72
  22. package/components/basic/audio/props.js +0 -5
  23. package/components/basic/html/index.js +163 -203
  24. package/components/basic/html/props.js +0 -5
  25. package/components/basic/html/utils.js +30 -28
  26. package/components/basic/icon/index.js +98 -84
  27. package/components/basic/icon/props.js +0 -5
  28. package/components/basic/iframe/iframe.utils.js +7 -16
  29. package/components/basic/iframe/index.js +97 -103
  30. package/components/basic/iframe/props.js +0 -5
  31. package/components/basic/label/index.js +156 -134
  32. package/components/basic/label/props.js +0 -5
  33. package/components/basic/message/index.js +129 -113
  34. package/components/basic/message/props.js +0 -5
  35. package/components/basic/picture/index.js +156 -127
  36. package/components/basic/picture/props.js +0 -5
  37. package/components/basic/progress-bar/index.js +240 -176
  38. package/components/basic/progress-bar/props.js +5 -31
  39. package/components/basic/progress-circle/index.js +166 -183
  40. package/components/basic/progress-circle/props.js +14 -34
  41. package/components/basic/richtexteditor/index.js +430 -396
  42. package/components/basic/richtexteditor/props.js +0 -5
  43. package/components/basic/search/index.js +812 -931
  44. package/components/basic/search/props.js +0 -5
  45. package/components/basic/search/providers.js +233 -380
  46. package/components/basic/spinner/index.js +210 -200
  47. package/components/basic/spinner/props.js +4 -22
  48. package/components/basic/tile/index.js +73 -81
  49. package/components/basic/tile/props.js +0 -5
  50. package/components/basic/tree/Components/TreeNodeComponent.js +238 -170
  51. package/components/basic/tree/hooks/useTreePartialNodeApi.js +143 -135
  52. package/components/basic/tree/index.js +378 -454
  53. package/components/basic/tree/props.js +0 -5
  54. package/components/basic/tree/utils.js +129 -185
  55. package/components/basic/video/index.js +161 -107
  56. package/components/basic/video/props.js +0 -5
  57. package/components/chart/index.js +42 -50
  58. package/components/chart/props.js +31 -37
  59. package/components/chart/src/ChartRenderer.js +172 -154
  60. package/components/chart/src/chart.js +391 -213
  61. package/components/chart/src/chartStyles.generated.js +6 -14
  62. package/components/chart/src/chartUtils.js +228 -272
  63. package/components/chart/src/constants.d.ts +13 -0
  64. package/components/chart/src/constants.js +316 -90
  65. package/components/chart/src/d3Setup.js +11 -30
  66. package/components/chart/src/dataUtils.js +362 -446
  67. package/components/chart/src/formatUtils.js +47 -38
  68. package/components/chart/src/index.js +11 -19
  69. package/components/chart/src/nvd3Source.generated.js +5 -13
  70. package/components/chart/src/pieDonutResponsiveLayout.d.ts +5 -0
  71. package/components/chart/src/pieDonutResponsiveLayout.js +76 -96
  72. package/components/chart/src/types.js +0 -5
  73. package/components/common/AppSpinner.js +17 -33
  74. package/components/common/app-spinner.js +11 -22
  75. package/components/common/customTemplate/index.d.ts +3 -0
  76. package/components/common/customTemplate/index.js +6 -0
  77. package/components/common/customTemplate/props.d.ts +20 -0
  78. package/components/common/customTemplate/props.js +0 -0
  79. package/components/common/customTemplate/template.d.ts +3 -0
  80. package/components/common/customTemplate/template.js +27 -0
  81. package/components/common/customTemplate/useCustomTemplate.d.ts +8 -0
  82. package/components/common/customTemplate/useCustomTemplate.js +17 -0
  83. package/components/common/customTemplate/utils.d.ts +6 -0
  84. package/components/common/customTemplate/utils.js +12 -0
  85. package/components/common/index.js +4 -12
  86. package/components/constants.js +81 -77
  87. package/components/container/accordion/accordion-pane/index.js +105 -118
  88. package/components/container/accordion/accordion-pane/props.js +5 -21
  89. package/components/container/accordion/index.js +225 -243
  90. package/components/container/accordion/props.js +5 -16
  91. package/components/container/index.js +214 -150
  92. package/components/container/layout-grid/grid-column/index.js +68 -43
  93. package/components/container/layout-grid/grid-column/props.js +0 -5
  94. package/components/container/layout-grid/grid-row/index.js +12 -29
  95. package/components/container/layout-grid/grid-row/props.js +0 -5
  96. package/components/container/layout-grid/index.js +53 -38
  97. package/components/container/layout-grid/props.js +0 -5
  98. package/components/container/linear-layout/index.js +56 -60
  99. package/components/container/linear-layout/linear-layout-item/index.js +43 -47
  100. package/components/container/linear-layout/linear-layout-item/props.js +0 -5
  101. package/components/container/linear-layout/props.js +0 -5
  102. package/components/container/panel/components/panel-content/index.js +7 -16
  103. package/components/container/panel/components/panel-header/index.js +166 -146
  104. package/components/container/panel/components/panel-header/props.js +0 -5
  105. package/components/container/panel/hooks.js +76 -102
  106. package/components/container/panel/index.js +289 -252
  107. package/components/container/panel/props.js +0 -5
  108. package/components/container/props.js +0 -5
  109. package/components/container/repeat-template/index.js +65 -44
  110. package/components/container/repeat-template/props.js +0 -5
  111. package/components/container/tabs/index.js +517 -526
  112. package/components/container/tabs/props.js +5 -28
  113. package/components/container/tabs/tab-pane/index.js +105 -100
  114. package/components/container/tabs/tab-pane/props.js +0 -5
  115. package/components/container/tabs/utils.js +30 -35
  116. package/components/container/wizard/WizardContext.js +9 -11
  117. package/components/container/wizard/components/StepComponents.js +76 -99
  118. package/components/container/wizard/components/WizardStep.js +107 -85
  119. package/components/container/wizard/index.js +791 -921
  120. package/components/container/wizard/props.js +0 -5
  121. package/components/container/wizard/utils.js +97 -131
  122. package/components/container/wizard/wizard-action/index.js +41 -81
  123. package/components/container/wizard/wizard-step/index.js +140 -120
  124. package/components/data/card/card-actions/index.js +13 -31
  125. package/components/data/card/card-content/index.js +27 -36
  126. package/components/data/card/card-footer/index.js +13 -31
  127. package/components/data/card/index.js +192 -199
  128. package/components/data/card/props.js +0 -5
  129. package/components/data/form/base-form/constant.js +5 -8
  130. package/components/data/form/base-form/hooks/index.js +26 -77
  131. package/components/data/form/base-form/hooks/useFormDataSync.js +106 -212
  132. package/components/data/form/base-form/hooks/useFormOperations.js +109 -161
  133. package/components/data/form/base-form/hooks/useFormSubmission.js +220 -280
  134. package/components/data/form/base-form/hooks/useFormValidation.js +119 -168
  135. package/components/data/form/base-form/hooks/useParentFormRelationship.js +67 -103
  136. package/components/data/form/base-form/index.js +531 -646
  137. package/components/data/form/base-form/props.js +74 -151
  138. package/components/data/form/base-form/utils.js +210 -323
  139. package/components/data/form/dynamic-fields/constant.js +43 -53
  140. package/components/data/form/dynamic-fields/index.js +135 -144
  141. package/components/data/form/dynamic-fields/props.js +0 -5
  142. package/components/data/form/dynamic-fields/utils.js +99 -158
  143. package/components/data/form/form-action/index.js +107 -85
  144. package/components/data/form/form-body/index.js +52 -26
  145. package/components/data/form/form-context.js +43 -59
  146. package/components/data/form/form-controller/hooks/index.js +43 -57
  147. package/components/data/form/form-controller/props.js +5 -8
  148. package/components/data/form/form-controller/utils.js +54 -49
  149. package/components/data/form/form-controller/validation-contrustor.js +203 -426
  150. package/components/data/form/form-controller/withFormController.js +319 -269
  151. package/components/data/form/form-dynamic-section/index.js +47 -41
  152. package/components/data/form/form-dynamic-section/props.js +0 -5
  153. package/components/data/form/form-field/base-field.js +97 -109
  154. package/components/data/form/form-field/index.js +91 -82
  155. package/components/data/form/form-field/props.js +0 -5
  156. package/components/data/form/form-footer/index.js +52 -25
  157. package/components/data/form/form-header/index.js +61 -58
  158. package/components/data/form/index.js +95 -74
  159. package/components/data/form/props.js +0 -5
  160. package/components/data/list/components/GroupHeader.js +34 -33
  161. package/components/data/list/components/GroupedListItems.js +108 -104
  162. package/components/data/list/components/ListContainer.js +22 -27
  163. package/components/data/list/components/ListDND.js +193 -185
  164. package/components/data/list/components/ListHeader.js +32 -49
  165. package/components/data/list/components/ListItem.js +153 -146
  166. package/components/data/list/components/ListItemWithTemplate.js +87 -105
  167. package/components/data/list/components/ListItems.js +180 -194
  168. package/components/data/list/components/ListPagination.js +127 -153
  169. package/components/data/list/components/LoadMoreButton.js +25 -33
  170. package/components/data/list/components/NoDataMessage.js +9 -22
  171. package/components/data/list/components/StandardListItems.js +79 -85
  172. package/components/data/list/components/index.js +31 -119
  173. package/components/data/list/components/props.js +0 -5
  174. package/components/data/list/hooks/index.js +22 -75
  175. package/components/data/list/hooks/props.js +0 -5
  176. package/components/data/list/hooks/useCurrentPageItems.js +20 -38
  177. package/components/data/list/hooks/useGroupedData.js +19 -33
  178. package/components/data/list/hooks/useListData.js +17 -47
  179. package/components/data/list/hooks/useListEffects.js +168 -237
  180. package/components/data/list/hooks/useListEventHandlers.js +301 -285
  181. package/components/data/list/hooks/useListPagination.js +90 -136
  182. package/components/data/list/hooks/useListState.js +49 -91
  183. package/components/data/list/hooks/useListStateManager.js +104 -159
  184. package/components/data/list/hooks/usePaginatedGroupedData.js +74 -110
  185. package/components/data/list/index.d.ts +1 -0
  186. package/components/data/list/index.js +579 -621
  187. package/components/data/list/props.d.ts +4 -0
  188. package/components/data/list/props.js +0 -5
  189. package/components/data/list/templates/media-template.js +29 -50
  190. package/components/data/list/utils/constants.js +20 -32
  191. package/components/data/list/utils/list-helpers.d.ts +2 -1
  192. package/components/data/list/utils/list-helpers.js +71 -115
  193. package/components/data/list/utils/list-widget-methods.js +56 -76
  194. package/components/data/list/utils/widget-instance-utils.js +20 -57
  195. package/components/data/live-filter/index.js +219 -271
  196. package/components/data/live-filter/props.js +5 -12
  197. package/components/data/live-form/index.js +68 -91
  198. package/components/data/live-form/props.js +5 -12
  199. package/components/data/pagination/components/BasicPagination.js +124 -104
  200. package/components/data/pagination/components/ClassicPagination.js +167 -190
  201. package/components/data/pagination/components/InlinePagination.js +97 -98
  202. package/components/data/pagination/components/LoadingComponent.js +17 -30
  203. package/components/data/pagination/components/PageSizeSelector.js +176 -169
  204. package/components/data/pagination/components/PagerNavigation.js +84 -105
  205. package/components/data/pagination/components/TotalRecords.js +48 -47
  206. package/components/data/pagination/components/index.js +14 -47
  207. package/components/data/pagination/components/props.js +0 -5
  208. package/components/data/pagination/hooks/index.js +6 -19
  209. package/components/data/pagination/hooks/props.js +0 -5
  210. package/components/data/pagination/hooks/useNavigationSize.js +12 -21
  211. package/components/data/pagination/hooks/usePagination.js +702 -905
  212. package/components/data/pagination/index.js +336 -389
  213. package/components/data/table/components/AddNewRow.js +122 -154
  214. package/components/data/table/components/EditableCell.js +68 -75
  215. package/components/data/table/components/FieldValidationError.js +19 -20
  216. package/components/data/table/components/RowCells.js +97 -80
  217. package/components/data/table/components/RowExpansionButton.js +43 -39
  218. package/components/data/table/components/SummaryCell.js +54 -88
  219. package/components/data/table/components/SummaryRow.js +45 -52
  220. package/components/data/table/components/SummaryRowFooter.js +35 -42
  221. package/components/data/table/components/TableBody.js +222 -218
  222. package/components/data/table/components/TableDataRow.js +113 -106
  223. package/components/data/table/components/TableFilters.js +391 -390
  224. package/components/data/table/components/TableFooterActions.js +25 -32
  225. package/components/data/table/components/TableHeader.js +460 -435
  226. package/components/data/table/components/TablePanelHeading.js +157 -181
  227. package/components/data/table/components/index.js +27 -95
  228. package/components/data/table/hooks/index.js +21 -230
  229. package/components/data/table/hooks/use-edited-rows.js +59 -94
  230. package/components/data/table/hooks/useCellState.js +58 -83
  231. package/components/data/table/hooks/useCustomExpressionColumns.js +65 -86
  232. package/components/data/table/hooks/useDynamicColumns.js +59 -92
  233. package/components/data/table/hooks/useEditingState.js +30 -41
  234. package/components/data/table/hooks/useFormWidget.js +163 -172
  235. package/components/data/table/hooks/usePaginationState.js +67 -77
  236. package/components/data/table/hooks/usePanelStructure.js +47 -41
  237. package/components/data/table/hooks/useResponsiveColumns.js +14 -20
  238. package/components/data/table/hooks/useRowExpansion.js +131 -127
  239. package/components/data/table/hooks/useRowHandlers.js +56 -69
  240. package/components/data/table/hooks/useRowSelection.js +249 -329
  241. package/components/data/table/hooks/useServerSideSorting.js +109 -175
  242. package/components/data/table/hooks/useTableColumns.js +322 -331
  243. package/components/data/table/hooks/useTableData.js +111 -166
  244. package/components/data/table/hooks/useTableEdit.js +526 -564
  245. package/components/data/table/hooks/useTableEffects.js +60 -107
  246. package/components/data/table/hooks/useTableFilter.js +244 -237
  247. package/components/data/table/hooks/useTableInitialization.js +44 -76
  248. package/components/data/table/hooks/useTableState.js +39 -61
  249. package/components/data/table/hooks/useTableStateManager.js +295 -468
  250. package/components/data/table/index.js +1553 -1713
  251. package/components/data/table/live-table/index.js +157 -219
  252. package/components/data/table/props.js +0 -5
  253. package/components/data/table/table-action/index.js +97 -75
  254. package/components/data/table/table-column/index.js +48 -42
  255. package/components/data/table/table-group/index.js +7 -25
  256. package/components/data/table/table-row/index.js +63 -55
  257. package/components/data/table/table-row-action/index.js +102 -77
  258. package/components/data/table/utils/buildSelectionColumns.js +86 -137
  259. package/components/data/table/utils/columnBuilder.js +116 -158
  260. package/components/data/table/utils/columnProxy.js +48 -66
  261. package/components/data/table/utils/columnWidthDistribution.js +40 -64
  262. package/components/data/table/utils/constants.js +92 -40
  263. package/components/data/table/utils/crud-handlers.js +292 -473
  264. package/components/data/table/utils/dynamic-columns.js +99 -144
  265. package/components/data/table/utils/groupHeaderUtils.js +36 -61
  266. package/components/data/table/utils/index.d.ts +8 -5
  267. package/components/data/table/utils/index.js +419 -639
  268. package/components/data/table/utils/renderDisplayCell.js +127 -169
  269. package/components/data/table/utils/script-page-size-broadcast.js +17 -29
  270. package/components/data/table/utils/selectionUtils.js +59 -113
  271. package/components/data/table/utils/table-helpers.js +38 -74
  272. package/components/data/table/utils/validation.js +35 -78
  273. package/components/data/table/utils/widgetMapping.d.ts +5 -0
  274. package/components/data/table/utils/widgetMapping.js +41 -0
  275. package/components/data/types.js +112 -112
  276. package/components/data/utils/field-data-utils.js +38 -42
  277. package/components/data/utils/filter-field-util.js +42 -44
  278. package/components/data/utils/index.js +112 -111
  279. package/components/dialogs/alert-dialog/index.js +83 -78
  280. package/components/dialogs/alert-dialog/props.js +0 -5
  281. package/components/dialogs/confirm-dialog/index.js +102 -92
  282. package/components/dialogs/confirm-dialog/props.js +0 -5
  283. package/components/dialogs/dialog/index.js +93 -69
  284. package/components/dialogs/dialog/props.js +0 -5
  285. package/components/dialogs/dialog-actions/index.js +12 -26
  286. package/components/dialogs/dialog-actions/props.js +0 -5
  287. package/components/dialogs/dialog-body/index.js +13 -30
  288. package/components/dialogs/dialog-body/props.js +0 -5
  289. package/components/dialogs/dialog-content/index.js +48 -41
  290. package/components/dialogs/dialog-content/props.js +0 -5
  291. package/components/dialogs/dialog-header/index.js +88 -101
  292. package/components/dialogs/dialog-header/props.js +0 -5
  293. package/components/dialogs/iframe-dialog/index.js +136 -128
  294. package/components/dialogs/iframe-dialog/props.js +0 -5
  295. package/components/dialogs/index.js +104 -101
  296. package/components/dialogs/login-dialog/index.js +285 -347
  297. package/components/dialogs/login-dialog/props.js +0 -5
  298. package/components/dialogs/page-dialog/index.js +95 -86
  299. package/components/dialogs/page-dialog/props.js +0 -5
  300. package/components/dialogs/props.js +0 -5
  301. package/components/dialogs/withDialogWrapper.js +110 -83
  302. package/components/form/button/index.js +296 -245
  303. package/components/form/button/props.js +0 -5
  304. package/components/form/button-group/index.js +80 -69
  305. package/components/form/button-group/props.js +0 -5
  306. package/components/input/calendar/index.js +409 -362
  307. package/components/input/calendar/props.js +0 -5
  308. package/components/input/calendar/utils.js +164 -172
  309. package/components/input/chips/SortableChip/index.js +109 -100
  310. package/components/input/chips/SortableChip/props.js +0 -5
  311. package/components/input/chips/index.js +663 -570
  312. package/components/input/chips/props.js +0 -5
  313. package/components/input/chips/utils.js +131 -122
  314. package/components/input/color-picker/index.js +536 -594
  315. package/components/input/color-picker/props.js +0 -5
  316. package/components/input/composite/index.js +71 -110
  317. package/components/input/composite/props.js +0 -5
  318. package/components/input/currency/index.js +277 -224
  319. package/components/input/currency/props.js +0 -5
  320. package/components/input/default/checkbox/index.js +329 -250
  321. package/components/input/default/checkbox/props.js +0 -5
  322. package/components/input/default/checkboxset/index.d.ts +2 -0
  323. package/components/input/default/checkboxset/index.js +529 -446
  324. package/components/input/default/checkboxset/props.d.ts +4 -0
  325. package/components/input/default/checkboxset/props.js +0 -5
  326. package/components/input/default/checkboxset/utils.js +15 -25
  327. package/components/input/default/radioset/index.d.ts +2 -0
  328. package/components/input/default/radioset/index.js +409 -350
  329. package/components/input/default/radioset/props.d.ts +6 -0
  330. package/components/input/default/radioset/props.js +0 -5
  331. package/components/input/default/switch/index.js +494 -458
  332. package/components/input/default/switch/prop.js +0 -5
  333. package/components/input/epoch/date/components/DatePickerPopover.js +242 -193
  334. package/components/input/epoch/date/index.js +638 -518
  335. package/components/input/epoch/date/props.js +0 -5
  336. package/components/input/epoch/date/styled.js +61 -70
  337. package/components/input/epoch/date/utils.js +67 -115
  338. package/components/input/epoch/datetime/index.js +758 -695
  339. package/components/input/epoch/datetime/props.js +0 -5
  340. package/components/input/epoch/datetime/utils.js +121 -186
  341. package/components/input/epoch/time/index.js +441 -415
  342. package/components/input/epoch/time/props.js +0 -5
  343. package/components/input/epoch/time/utils.js +101 -112
  344. package/components/input/fileupload/Utils.js +70 -97
  345. package/components/input/fileupload/components/ListItems.js +132 -130
  346. package/components/input/fileupload/components/MultiUpload.js +80 -77
  347. package/components/input/fileupload/components/SingleUpload.js +57 -57
  348. package/components/input/fileupload/index.js +253 -178
  349. package/components/input/fileupload/props.js +0 -5
  350. package/components/input/fileupload/useFileUpload.js +209 -258
  351. package/components/input/number/index.js +434 -393
  352. package/components/input/number/props.js +0 -5
  353. package/components/input/rating/index.js +401 -394
  354. package/components/input/rating/props.js +0 -5
  355. package/components/input/select/index.js +408 -463
  356. package/components/input/select/props.js +0 -5
  357. package/components/input/slider/index.js +339 -332
  358. package/components/input/slider/props.js +0 -5
  359. package/components/input/text/index.d.ts +3 -3
  360. package/components/input/text/index.js +438 -475
  361. package/components/input/text/props.d.ts +1 -1
  362. package/components/input/text/props.js +0 -5
  363. package/components/input/text/util.js +82 -222
  364. package/components/input/textarea/index.js +322 -358
  365. package/components/input/textarea/props.js +0 -5
  366. package/components/input/upload/index.js +135 -131
  367. package/components/input/upload/props.js +0 -5
  368. package/components/input/util/index.js +9 -11
  369. package/components/layout/footer/index.js +12 -35
  370. package/components/layout/footer/props.js +0 -5
  371. package/components/layout/header/index.js +12 -38
  372. package/components/layout/header/props.js +0 -5
  373. package/components/layout/leftnav/index.js +38 -44
  374. package/components/layout/leftnav/props.js +0 -5
  375. package/components/layout/rightnav/index.js +12 -36
  376. package/components/layout/rightnav/props.js +0 -5
  377. package/components/layout/topnav/index.js +24 -38
  378. package/components/layout/topnav/props.js +0 -5
  379. package/components/navbar/index.js +119 -98
  380. package/components/navbar/nav/index.js +236 -232
  381. package/components/navbar/nav/props.js +0 -5
  382. package/components/navbar/nav-item/index.js +74 -65
  383. package/components/navbar/nav-item/props.js +0 -5
  384. package/components/navigation/breadcrumb/index.js +38 -61
  385. package/components/navigation/breadcrumb/props.js +0 -5
  386. package/components/navigation/menu/components/ListItems.js +76 -67
  387. package/components/navigation/menu/constants.js +27 -42
  388. package/components/navigation/menu/hooks/useHoverState.hook.js +20 -47
  389. package/components/navigation/menu/hooks/useKeyboardMovements.hook.js +34 -28
  390. package/components/navigation/menu/hooks/useTransformedDataset.hook.js +21 -14
  391. package/components/navigation/menu/index.js +911 -846
  392. package/components/navigation/menu/props.js +0 -5
  393. package/components/navigation/menu/utils/action-task.js +6 -9
  394. package/components/navigation/menu/utils/role-filter.js +41 -56
  395. package/components/navigation/popover/index.js +191 -205
  396. package/components/navigation/popover/props.js +5 -8
  397. package/components/page/content/index.js +9 -31
  398. package/components/page/content/props.js +0 -5
  399. package/components/page/error-boundary/index.js +115 -105
  400. package/components/page/error-boundary/props.js +0 -5
  401. package/components/page/index.js +84 -102
  402. package/components/page/page-content/index.js +21 -30
  403. package/components/page/page-content/props.js +0 -5
  404. package/components/page/partial/index.js +50 -45
  405. package/components/page/partial/props.js +0 -5
  406. package/components/page/partial-container/index.js +81 -107
  407. package/components/page/partial-container/props.d.ts +1 -1
  408. package/components/page/partial-container/props.js +0 -5
  409. package/components/page/props.js +0 -5
  410. package/components/page/toast-container/index.js +20 -41
  411. package/components/page/toast-container/props.js +0 -5
  412. package/components/prefab/container/index.js +60 -53
  413. package/components/prefab/container/props.js +0 -5
  414. package/components/prefab/index.js +76 -61
  415. package/components/prefab/props.js +0 -5
  416. package/context/AppContext.d.ts +1 -1
  417. package/context/AppContext.js +17 -18
  418. package/context/AppSpinnerProvider.js +19 -34
  419. package/context/LayoutProvider.js +54 -57
  420. package/context/LocalizationProvider.js +34 -49
  421. package/context/PrefabContext.js +68 -119
  422. package/context/WidgetProvider.js +160 -166
  423. package/core/app-config.js +0 -1
  424. package/core/app.service.js +200 -327
  425. package/core/appVariablesStore.js +10 -15
  426. package/core/appstore.js +37 -53
  427. package/core/constants/currency-constant.js +81 -83
  428. package/core/constants/events.js +34 -44
  429. package/core/constants/index.js +21 -31
  430. package/core/dialog.service.js +52 -72
  431. package/core/event-notifier.js +94 -131
  432. package/core/formatter/array-formatters.js +18 -32
  433. package/core/formatter/date-formatters.js +140 -204
  434. package/core/formatter/index.js +64 -117
  435. package/core/formatter/number-formatters.js +115 -159
  436. package/core/formatter/security-formatters.js +233 -283
  437. package/core/formatter/string-formatters.js +23 -45
  438. package/core/formatter/types.js +12 -18
  439. package/core/formatters.js +6 -24
  440. package/core/proxy-service.js +242 -306
  441. package/core/script-registry.js +87 -134
  442. package/core/security.service.js +8 -11
  443. package/core/util/compare.js +13 -25
  444. package/core/util/dom.js +32 -63
  445. package/core/util/index.d.ts +5 -0
  446. package/core/util/index.js +95 -95
  447. package/core/util/safe-is-equal.js +42 -94
  448. package/core/util/security.js +114 -153
  449. package/core/util/utils.d.ts +8 -1
  450. package/core/util/utils.js +124 -132
  451. package/core/widget-observer.js +34 -61
  452. package/higherOrder/BaseApp.js +327 -500
  453. package/higherOrder/BaseAppProps.js +0 -5
  454. package/higherOrder/BaseDateTime.js +277 -231
  455. package/higherOrder/BasePage.js +479 -735
  456. package/higherOrder/BasePartial.js +87 -114
  457. package/higherOrder/BasePrefab.js +190 -206
  458. package/higherOrder/DataNav.js +287 -302
  459. package/higherOrder/helper.js +62 -48
  460. package/higherOrder/props.js +0 -5
  461. package/higherOrder/withBaseWrapper.js +123 -168
  462. package/higherOrder/withStandalone.js +28 -26
  463. package/hooks/useAccess.js +113 -289
  464. package/hooks/useAppConfig.js +15 -40
  465. package/hooks/useAuth.js +256 -495
  466. package/hooks/useDataSourceSubscription.d.ts +3 -3
  467. package/hooks/useDataSourceSubscription.js +99 -109
  468. package/hooks/useDebounce.js +28 -56
  469. package/hooks/useDeviceVisibility.js +14 -23
  470. package/hooks/useHttp.d.ts +1 -0
  471. package/hooks/useHttp.js +318 -493
  472. package/libs/index.js +4 -13
  473. package/libs/prefab/index.js +6 -20
  474. package/mui-config/theme-provider.js +9 -17
  475. package/mui-config/theme.js +6 -9
  476. package/package-lock.json +822 -3191
  477. package/package.json +3 -19
  478. package/providers/AppProviders.js +21 -24
  479. package/runtime-dynamic/App.js +65 -93
  480. package/runtime-dynamic/app-initializer.js +207 -400
  481. package/runtime-dynamic/components/ErrorBoundary.js +59 -76
  482. package/runtime-dynamic/components/PageWrapper.js +23 -35
  483. package/runtime-dynamic/components/PrefabPreview.js +40 -69
  484. package/runtime-dynamic/components/partial-content.d.ts +2 -3
  485. package/runtime-dynamic/components/partial-content.js +66 -48
  486. package/runtime-dynamic/components/prefab-content.js +37 -30
  487. package/runtime-dynamic/components/use-dynamic-component.js +62 -150
  488. package/runtime-dynamic/factories/build-base-page-like-component.js +44 -58
  489. package/runtime-dynamic/factories/dynamic-component.d.ts +9 -0
  490. package/runtime-dynamic/factories/dynamic-component.js +83 -0
  491. package/runtime-dynamic/factories/prefab-factory.js +60 -81
  492. package/runtime-dynamic/factories/startup-info.js +12 -25
  493. package/runtime-dynamic/factories/utils.d.ts +1 -9
  494. package/runtime-dynamic/factories/utils.js +47 -130
  495. package/runtime-dynamic/index.js +56 -191
  496. package/runtime-dynamic/main.js +42 -70
  497. package/runtime-dynamic/preview-mode.js +14 -29
  498. package/runtime-dynamic/preview-navigation.js +21 -30
  499. package/runtime-dynamic/preview-path.d.ts +5 -0
  500. package/runtime-dynamic/preview-path.js +13 -0
  501. package/runtime-dynamic/preview-resource-base.js +15 -31
  502. package/runtime-dynamic/registry/component-registry.js +269 -334
  503. package/runtime-dynamic/registry/custom-widget-registry.js +11 -15
  504. package/runtime-dynamic/registry/index.js +24 -63
  505. package/runtime-dynamic/registry/store.d.ts +1 -0
  506. package/runtime-dynamic/registry/store.js +18 -23
  507. package/runtime-dynamic/routes.js +53 -81
  508. package/runtime-dynamic/services/app-extension-provider.js +17 -44
  509. package/runtime-dynamic/services/autolayout-inject.d.ts +4 -0
  510. package/runtime-dynamic/services/autolayout-inject.js +27 -0
  511. package/runtime-dynamic/services/cache.js +27 -33
  512. package/runtime-dynamic/services/compile-render.d.ts +9 -0
  513. package/runtime-dynamic/services/compile-render.js +142 -0
  514. package/runtime-dynamic/services/component-ref-provider.js +70 -124
  515. package/runtime-dynamic/services/css-scoping.js +27 -28
  516. package/runtime-dynamic/services/fragment-url.js +37 -50
  517. package/runtime-dynamic/services/index.js +48 -152
  518. package/runtime-dynamic/services/markup-transpiler.d.ts +2 -2
  519. package/runtime-dynamic/services/markup-transpiler.js +39 -231
  520. package/runtime-dynamic/services/prefab-resources.js +42 -130
  521. package/runtime-dynamic/services/resource-manager.d.ts +2 -1
  522. package/runtime-dynamic/services/resource-manager.js +32 -63
  523. package/runtime-dynamic/services/script-executor.js +50 -61
  524. package/runtime-dynamic/services/variable-factory.js +141 -184
  525. package/runtime-dynamic/services/variable-registry.js +69 -115
  526. package/runtime-dynamic/services/variable-transpiler.js +73 -103
  527. package/runtime-dynamic/shims/next-image.js +79 -50
  528. package/runtime-dynamic/shims/next-link.js +58 -32
  529. package/runtime-dynamic/shims/next-navigation.js +17 -34
  530. package/runtime-dynamic/utils/index.d.ts +2 -0
  531. package/runtime-dynamic/utils/index.js +22 -24
  532. package/store/bindActions/i18nActions.js +16 -18
  533. package/store/index.js +29 -35
  534. package/store/middleware/navigationMiddleware.js +25 -45
  535. package/store/middleware/pendingTabNavigationIntentMiddleware.js +20 -25
  536. package/store/slices/appConfigSlice.js +65 -94
  537. package/store/slices/authSlice.js +317 -471
  538. package/store/slices/i18nSlice.js +169 -168
  539. package/store/slices/navigationSlice.js +22 -20
  540. package/store/util/resolve-path.d.ts +1 -0
  541. package/store/util/resolve-path.js +7 -0
  542. package/store/viewport.service.js +150 -194
  543. package/types/index.js +10 -15
  544. package/utils/attr.js +198 -41
  545. package/utils/custom-expression/index.js +55 -151
  546. package/utils/custom-expression/parser.js +106 -182
  547. package/utils/dataset-util.js +113 -154
  548. package/utils/eval-expression.js +10 -19
  549. package/utils/form-state.util.js +60 -118
  550. package/utils/form-utils.js +49 -190
  551. package/utils/format-util.js +113 -184
  552. package/utils/layoutsize-util.js +11 -17
  553. package/utils/lib-error-skipper.js +54 -52
  554. package/utils/page-params-util.js +50 -40
  555. package/utils/pending-tab-navigation-intent.js +7 -17
  556. package/utils/resource-url.js +8 -19
  557. package/utils/state-persistance.js +136 -253
  558. package/utils/style-utils.d.ts +2 -0
  559. package/utils/style-utils.js +25 -74
  560. package/utils/transformedDataset-utils.js +353 -381
  561. package/utils/widget-cleanup-util.js +42 -74
  562. package/utils/widgets.js +19 -31
  563. package/variables/base-variable.js +117 -166
  564. package/variables/constants.js +5 -8
  565. package/variables/crud-variable.js +150 -181
  566. package/variables/live-variable.d.ts +1 -1
  567. package/variables/live-variable.js +140 -174
  568. package/variables/metadata.service.js +74 -116
  569. package/variables/model-variable.js +68 -78
  570. package/variables/service-variable.js +171 -285
  571. package/wm-namespace.js +11 -14
  572. package/components/chart/src/css.d.js +0 -1
  573. package/tsconfig.declaration.tsbuildinfo +0 -1
  574. package/types/global.d.js +0 -3
@@ -1,27 +1,25 @@
1
- "use strict";
2
-
3
- var _typeof = require("@babel/runtime/helpers/typeof");
4
- Object.defineProperty(exports, "__esModule", {
5
- value: true
6
- });
7
- exports.TableFilterRow = exports.GlobalSearchFilter = void 0;
8
- var _react = _interopRequireWildcard(require("react"));
9
- var _material = require("@mui/material");
10
- var _lodashEs = require("lodash-es");
11
- var _utils = require("@wavemaker-ai/react-runtime/components/data/utils");
12
- function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function _interopRequireWildcard(e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, "default": e }; if (null === e || "object" != _typeof(e) && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (var _t2 in e) "default" !== _t2 && {}.hasOwnProperty.call(e, _t2) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, _t2)) && (i.get || i.set) ? o(f, _t2, i) : f[_t2] = e[_t2]); return f; })(e, t); }
13
- var __jsx = _react["default"].createElement;
14
- // Constants
15
- var ACTION_COLUMN_IDS = ["actions", "row-operations", "multiSelect", "radioSelect", "row-index"];
16
- var DEFAULT_MATCH_MODE = "anywhereignorecase";
17
- var DATA_TYPES = {
1
+ import { jsx, jsxs } from "react/jsx-runtime";
2
+ import { memo, useState, useEffect, useRef, useMemo, useCallback } from "react";
3
+ import { Box, Input, Menu } from "@mui/material";
4
+ import { filter, map, includes, get, isEmpty, defaultTo } from "lodash-es";
5
+ import {
6
+ getMatchModeTypesMap,
7
+ getMatchModeMsgs
8
+ } from "../../utils";
9
+ const ACTION_COLUMN_IDS = [
10
+ "actions",
11
+ "row-operations",
12
+ "multiSelect",
13
+ "radioSelect",
14
+ "row-index"
15
+ ];
16
+ const DEFAULT_MATCH_MODE = "anywhereignorecase";
17
+ const DATA_TYPES = {
18
18
  NUMBER: "number",
19
19
  DATE: "date",
20
20
  STRING: "string"
21
21
  };
22
-
23
- // Menu popup styles for Bootstrap dropdown compatibility
24
- var MENU_POPUP_STYLES = {
22
+ const MENU_POPUP_STYLES = {
25
23
  paper: {
26
24
  style: {
27
25
  zIndex: 1040,
@@ -31,32 +29,23 @@ var MENU_POPUP_STYLES = {
31
29
  }
32
30
  }
33
31
  };
34
- var MENU_LIST_STYLES = {
35
- style: {
36
- padding: 0
37
- }
32
+ const MENU_LIST_STYLES = {
33
+ style: { padding: 0 }
38
34
  };
39
-
40
- // Utility: Get data type from widget configuration
41
- var getDataType = function getDataType(widgetType, editInputType) {
42
- // Check edit input type first
35
+ const getDataType = (widgetType, editInputType) => {
43
36
  if (editInputType === DATA_TYPES.NUMBER) return DATA_TYPES.NUMBER;
44
- if ((0, _lodashEs.includes)(["date", "datetime-local", "time"], editInputType)) {
37
+ if (includes(["date", "datetime-local", "time"], editInputType)) {
45
38
  return DATA_TYPES.DATE;
46
39
  }
47
-
48
- // Check widget type
49
- if ((0, _lodashEs.includes)(["number", "currency", "integer"], widgetType)) {
40
+ if (includes(["number", "currency", "integer"], widgetType)) {
50
41
  return DATA_TYPES.NUMBER;
51
42
  }
52
- if ((0, _lodashEs.includes)(["date", "datetime", "time", "timestamp"], widgetType)) {
43
+ if (includes(["date", "datetime", "time", "timestamp"], widgetType)) {
53
44
  return DATA_TYPES.DATE;
54
45
  }
55
46
  return DATA_TYPES.STRING;
56
47
  };
57
-
58
- // Utility: Get input group CSS class based on data type
59
- var getInputGroupClass = function getInputGroupClass(dataType) {
48
+ const getInputGroupClass = (dataType) => {
60
49
  switch (dataType) {
61
50
  case DATA_TYPES.NUMBER:
62
51
  return "input-group number input-group-sm";
@@ -66,364 +55,376 @@ var getInputGroupClass = function getInputGroupClass(dataType) {
66
55
  return "input-group text input-group-sm";
67
56
  }
68
57
  };
69
-
70
- // Utility: Check if column should be filtered
71
- var isFilterableColumn = function isFilterableColumn(column) {
72
- var columnId = (0, _lodashEs.defaultTo)(column.id, column.accessorKey);
73
- var isActionColumn = (0, _lodashEs.includes)(ACTION_COLUMN_IDS, columnId) || column.isRowIndex;
74
- return !isActionColumn && column.enableColumnFilter !== false && !(0, _lodashEs.isEmpty)(column.accessorKey);
58
+ const isFilterableColumn = (column) => {
59
+ const columnId = defaultTo(column.id, column.accessorKey);
60
+ const isActionColumn = includes(ACTION_COLUMN_IDS, columnId) || column.isRowIndex;
61
+ return !isActionColumn && column.enableColumnFilter !== false && !isEmpty(column.accessorKey);
75
62
  };
76
-
77
- // Utility: Shallow comparison helper for memo
78
- var shallowEqual = function shallowEqual(prev, next, keys) {
79
- return keys.every(function (key) {
80
- return prev[key] === next[key];
81
- });
63
+ const shallowEqual = (prev, next, keys) => {
64
+ return keys.every((key) => prev[key] === next[key]);
82
65
  };
83
- var GlobalSearchFilter = exports.GlobalSearchFilter = /*#__PURE__*/(0, _react.memo)(function (_ref) {
84
- var value = _ref.value,
85
- onChange = _ref.onChange,
86
- selectedColumn = _ref.selectedColumn,
87
- onColumnChange = _ref.onColumnChange,
88
- columns = _ref.columns,
89
- _ref$searchLabel = _ref.searchLabel,
90
- searchLabel = _ref$searchLabel === void 0 ? "Search" : _ref$searchLabel,
91
- name = _ref.name,
92
- _ref$filteronkeypress = _ref.filteronkeypress,
93
- filteronkeypress = _ref$filteronkeypress === void 0 ? false : _ref$filteronkeypress,
94
- listener = _ref.listener;
95
- // Local state for input value
96
- var _useState = (0, _react.useState)(value),
97
- inputValue = _useState[0],
98
- setInputValue = _useState[1];
99
- // Local state for selected column to prevent immediate API calls
100
- var _useState2 = (0, _react.useState)(selectedColumn),
101
- localSelectedColumn = _useState2[0],
102
- setLocalSelectedColumn = _useState2[1];
103
-
104
- // Update local value when prop changes
105
- (0, _react.useEffect)(function () {
106
- setInputValue(value);
107
- }, [value]);
108
-
109
- // Update local column when prop changes
110
- (0, _react.useEffect)(function () {
111
- setLocalSelectedColumn(selectedColumn);
112
- }, [selectedColumn]);
113
- var clearLocalSearchControls = (0, _react.useCallback)(function () {
114
- setInputValue("");
115
- setLocalSelectedColumn("");
116
- }, []);
117
- (0, _react.useEffect)(function () {
118
- if (listener !== null && listener !== void 0 && listener.onChange && name) {
119
- listener.onChange(name, {
120
- clearFilter: clearLocalSearchControls
121
- });
122
- }
123
- }, [clearLocalSearchControls, name]);
124
-
125
- // Filter searchable columns - memoize to prevent recalculation
126
- var searchableColumns = (0, _react.useMemo)(function () {
127
- return (0, _lodashEs.filter)((0, _lodashEs.defaultTo)(columns, []), function (col) {
128
- return !(0, _lodashEs.isEmpty)(col === null || col === void 0 ? void 0 : col.accessorKey) && !(0, _lodashEs.includes)(ACTION_COLUMN_IDS, col === null || col === void 0 ? void 0 : col.id);
129
- });
130
- }, [columns]);
131
-
132
- // Apply filter with current column selection
133
- var applyFilter = (0, _react.useCallback)(function (value) {
134
- onChange(value);
135
- if (localSelectedColumn !== selectedColumn) {
136
- onColumnChange(localSelectedColumn);
137
- }
138
- }, [onChange, onColumnChange, localSelectedColumn, selectedColumn]);
139
- var handleColumnChange = (0, _react.useCallback)(function (e) {
140
- var newColumn = e.target.value;
141
- setLocalSelectedColumn(newColumn);
142
-
143
- // If filteronkeypress is true, apply filter immediately when column changes
144
- if (filteronkeypress && inputValue) {
145
- onColumnChange(newColumn);
146
- onChange(inputValue);
147
- }
148
- }, [filteronkeypress, inputValue, onColumnChange, onChange]);
149
- var handleSearch = (0, _react.useCallback)(function () {
150
- applyFilter(inputValue);
151
- }, [applyFilter, inputValue]);
152
- var handleInputChange = (0, _react.useCallback)(function (e) {
153
- var newValue = e.target.value;
154
- setInputValue(newValue);
155
-
156
- // If filteronkeypress is true, apply filter on every keystroke
157
- if (filteronkeypress) {
158
- applyFilter(newValue);
159
- }
160
- }, [filteronkeypress, applyFilter]);
161
- var handleKeyDown = (0, _react.useCallback)(function (e) {
162
- if (e.key === "Enter") {
163
- e.preventDefault();
164
- // Only trigger search manually if filteronkeypress is false
165
- if (!filteronkeypress) {
166
- handleSearch();
167
- }
168
- }
169
- }, [filteronkeypress, handleSearch]);
170
- return __jsx(_material.Box, {
171
- component: "form",
172
- className: "form-search form-inline",
173
- onSubmit: function onSubmit(e) {
174
- return e.preventDefault();
175
- }
176
- }, __jsx(_material.Box, {
177
- className: "form-group form-group-sm"
178
- }, __jsx(_material.Input, {
179
- type: "text",
180
- className: "form-control app-textbox",
181
- placeholder: searchLabel,
182
- value: inputValue,
183
- onChange: handleInputChange,
184
- onKeyDown: handleKeyDown,
185
- size: "small",
186
- sx: {
187
- "& input::placeholder": {
188
- color: "text.secondary",
189
- opacity: 0.7,
190
- fontWeight: "normal"
66
+ const GlobalSearchFilter = memo(
67
+ ({
68
+ value,
69
+ onChange,
70
+ selectedColumn,
71
+ onColumnChange,
72
+ columns,
73
+ searchLabel = "Search",
74
+ name,
75
+ filteronkeypress = false,
76
+ listener
77
+ }) => {
78
+ const [inputValue, setInputValue] = useState(value);
79
+ const [localSelectedColumn, setLocalSelectedColumn] = useState(selectedColumn);
80
+ useEffect(() => {
81
+ setInputValue(value);
82
+ }, [value]);
83
+ useEffect(() => {
84
+ setLocalSelectedColumn(selectedColumn);
85
+ }, [selectedColumn]);
86
+ const clearLocalSearchControls = useCallback(() => {
87
+ setInputValue("");
88
+ setLocalSelectedColumn("");
89
+ }, []);
90
+ useEffect(() => {
91
+ if ((listener == null ? void 0 : listener.onChange) && name) {
92
+ listener.onChange(name, { clearFilter: clearLocalSearchControls });
191
93
  }
192
- }
193
- })), __jsx(_material.Box, {
194
- className: "input-append input-group input-group-sm",
195
- component: "div"
196
- }, __jsx(_material.Box, {
197
- component: "select",
198
- name: "wm-datatable",
199
- "data-element": "dgFilterValue",
200
- className: "form-control app-select input-sm",
201
- value: localSelectedColumn,
202
- onChange: handleColumnChange
203
- }, __jsx("option", {
204
- value: "",
205
- className: "placeholder"
206
- }, "Select Field"), (0, _lodashEs.map)(searchableColumns, function (column, index) {
207
- return __jsx("option", {
208
- key: (0, _lodashEs.defaultTo)(column.id, column.accessorKey),
209
- value: column.accessorKey,
210
- "data-coldef-index": index
211
- }, column.header);
212
- })), __jsx(_material.Box, {
213
- component: "span",
214
- className: "input-group-addon"
215
- }, __jsx(_material.Box, {
216
- component: "button",
217
- type: "button",
218
- "data-element": "dgSearchButton",
219
- className: "app-search-button",
220
- title: searchLabel,
221
- onClick: handleSearch
222
- }, __jsx(_material.Box, {
223
- component: "i",
224
- className: "wi wi-search"
225
- })))));
226
- }, function (prevProps, nextProps) {
227
- return shallowEqual(prevProps, nextProps, ["value", "selectedColumn", "columns", "searchLabel", "name", "filteronkeypress", "onChange", "onColumnChange"]);
228
- });
94
+ }, [clearLocalSearchControls, name]);
95
+ const searchableColumns = useMemo(
96
+ () => filter(
97
+ defaultTo(columns, []),
98
+ (col) => !isEmpty(col == null ? void 0 : col.accessorKey) && !includes(ACTION_COLUMN_IDS, col == null ? void 0 : col.id)
99
+ ),
100
+ [columns]
101
+ );
102
+ const applyFilter = useCallback(
103
+ (value2) => {
104
+ onChange(value2);
105
+ if (localSelectedColumn !== selectedColumn) {
106
+ onColumnChange(localSelectedColumn);
107
+ }
108
+ },
109
+ [onChange, onColumnChange, localSelectedColumn, selectedColumn]
110
+ );
111
+ const handleColumnChange = useCallback(
112
+ (e) => {
113
+ const newColumn = e.target.value;
114
+ setLocalSelectedColumn(newColumn);
115
+ if (filteronkeypress && inputValue) {
116
+ onColumnChange(newColumn);
117
+ onChange(inputValue);
118
+ }
119
+ },
120
+ [filteronkeypress, inputValue, onColumnChange, onChange]
121
+ );
122
+ const handleSearch = useCallback(() => {
123
+ applyFilter(inputValue);
124
+ }, [applyFilter, inputValue]);
125
+ const handleInputChange = useCallback(
126
+ (e) => {
127
+ const newValue = e.target.value;
128
+ setInputValue(newValue);
129
+ if (filteronkeypress) {
130
+ applyFilter(newValue);
131
+ }
132
+ },
133
+ [filteronkeypress, applyFilter]
134
+ );
135
+ const handleKeyDown = useCallback(
136
+ (e) => {
137
+ if (e.key === "Enter") {
138
+ e.preventDefault();
139
+ if (!filteronkeypress) {
140
+ handleSearch();
141
+ }
142
+ }
143
+ },
144
+ [filteronkeypress, handleSearch]
145
+ );
146
+ return /* @__PURE__ */ jsxs(Box, { component: "form", className: "form-search form-inline", onSubmit: (e) => e.preventDefault(), children: [
147
+ /* @__PURE__ */ jsx(Box, { className: "form-group form-group-sm", children: /* @__PURE__ */ jsx(
148
+ Input,
149
+ {
150
+ type: "text",
151
+ className: "form-control app-textbox",
152
+ placeholder: searchLabel,
153
+ value: inputValue,
154
+ onChange: handleInputChange,
155
+ onKeyDown: handleKeyDown,
156
+ size: "small",
157
+ sx: {
158
+ "& input::placeholder": {
159
+ color: "text.secondary",
160
+ opacity: 0.7,
161
+ fontWeight: "normal"
162
+ }
163
+ }
164
+ }
165
+ ) }),
166
+ /* @__PURE__ */ jsxs(Box, { className: "input-append input-group input-group-sm", component: "div", children: [
167
+ /* @__PURE__ */ jsxs(
168
+ Box,
169
+ {
170
+ component: "select",
171
+ name: "wm-datatable",
172
+ "data-element": "dgFilterValue",
173
+ className: "form-control app-select input-sm",
174
+ value: localSelectedColumn,
175
+ onChange: handleColumnChange,
176
+ children: [
177
+ /* @__PURE__ */ jsx("option", { value: "", className: "placeholder", children: "Select Field" }),
178
+ map(searchableColumns, (column, index) => /* @__PURE__ */ jsx(
179
+ "option",
180
+ {
181
+ value: column.accessorKey,
182
+ "data-coldef-index": index,
183
+ children: column.header
184
+ },
185
+ defaultTo(column.id, column.accessorKey)
186
+ ))
187
+ ]
188
+ }
189
+ ),
190
+ /* @__PURE__ */ jsx(Box, { component: "span", className: "input-group-addon", children: /* @__PURE__ */ jsx(
191
+ Box,
192
+ {
193
+ component: "button",
194
+ type: "button",
195
+ "data-element": "dgSearchButton",
196
+ className: "app-search-button",
197
+ title: searchLabel,
198
+ onClick: handleSearch,
199
+ children: /* @__PURE__ */ jsx(Box, { component: "i", className: "wi wi-search" })
200
+ }
201
+ ) })
202
+ ] })
203
+ ] });
204
+ },
205
+ (prevProps, nextProps) => shallowEqual(prevProps, nextProps, [
206
+ "value",
207
+ "selectedColumn",
208
+ "columns",
209
+ "searchLabel",
210
+ "name",
211
+ "filteronkeypress",
212
+ "onChange",
213
+ "onColumnChange"
214
+ ])
215
+ );
229
216
  GlobalSearchFilter.displayName = "GlobalSearchFilter";
230
- // Component to handle individual column filter with local state
231
- var ColumnFilterCell = /*#__PURE__*/(0, _react.memo)(function (_ref2) {
232
- var columnId = _ref2.columnId,
233
- value = _ref2.value,
234
- onChange = _ref2.onChange,
235
- widgetType = _ref2.widgetType,
236
- columnMeta = _ref2.columnMeta,
237
- columnAccessorKey = _ref2.columnAccessorKey,
238
- listener = _ref2.listener,
239
- renderFormWidget = _ref2.renderFormWidget,
240
- onMatchModeChange = _ref2.onMatchModeChange;
241
- var _useState3 = (0, _react.useState)(value),
242
- localValue = _useState3[0],
243
- setLocalValue = _useState3[1];
244
- var _useState4 = (0, _react.useState)(null),
245
- anchorEl = _useState4[0],
246
- setAnchorEl = _useState4[1];
247
- var _useState5 = (0, _react.useState)(DEFAULT_MATCH_MODE),
248
- selectedMatchMode = _useState5[0],
249
- setSelectedMatchMode = _useState5[1];
250
- var filterButtonRef = (0, _react.useRef)(null);
251
-
252
- // Sync local value with prop changes
253
- (0, _react.useEffect)(function () {
254
- setLocalValue(value);
255
- }, [value]);
256
-
257
- // Memoize data type, match modes, and CSS classes
258
- var dataType = (0, _react.useMemo)(function () {
259
- return getDataType(widgetType, columnMeta.editinputtype);
260
- }, [widgetType, columnMeta.editinputtype]);
261
- var matchModes = (0, _react.useMemo)(function () {
262
- var matchModeMap = (0, _utils.getMatchModeTypesMap)();
263
- return (0, _lodashEs.get)(matchModeMap, dataType, (0, _lodashEs.get)(matchModeMap, "default", []));
264
- }, [dataType]);
265
- var matchModeMessages = (0, _react.useMemo)(function () {
266
- return (0, _utils.getMatchModeMsgs)(listener === null || listener === void 0 ? void 0 : listener.appLocale);
267
- }, [listener === null || listener === void 0 ? void 0 : listener.appLocale]);
268
- var inputGroupClass = (0, _react.useMemo)(function () {
269
- return getInputGroupClass(dataType);
270
- }, [dataType]);
271
-
272
- // Event handlers
273
- var handleApplyFilter = (0, _react.useCallback)(function (e) {
274
- var inputValue = (0, _lodashEs.defaultTo)(e.target.value, localValue);
275
- if (inputValue !== value) {
276
- onChange(columnId, inputValue, selectedMatchMode);
277
- }
278
- }, [localValue, value, columnId, selectedMatchMode, onChange]);
279
- var handleKeyDown = (0, _react.useCallback)(function (e) {
280
- if (e.key === "Enter") {
281
- e.preventDefault();
282
- handleApplyFilter(e);
283
- }
284
- e.stopPropagation();
285
- }, [handleApplyFilter]);
286
- var handleFilterIconClick = (0, _react.useCallback)(function (e) {
287
- e.stopPropagation();
288
- setAnchorEl(filterButtonRef.current);
289
- }, []);
290
- var handleClosePopover = (0, _react.useCallback)(function () {
291
- setAnchorEl(null);
292
- }, []);
293
- var handleMatchModeSelect = (0, _react.useCallback)(function (matchMode) {
294
- setSelectedMatchMode(matchMode);
295
- onMatchModeChange === null || onMatchModeChange === void 0 || onMatchModeChange(columnId, matchMode);
296
- if (localValue) {
297
- onChange(columnId, localValue, matchMode);
298
- }
299
- handleClosePopover();
300
- }, [columnId, localValue, onChange, onMatchModeChange, handleClosePopover]);
301
- var handleClearFilterIconClick = (0, _react.useCallback)(function () {
302
- onChange(columnId, "", selectedMatchMode);
303
- setLocalValue("");
304
- }, [columnId, selectedMatchMode, onChange]);
305
- var handleLocalValueChange = (0, _react.useCallback)(function (value) {
306
- setLocalValue(value);
307
- }, []);
308
- return __jsx("div", {
309
- "data-col-identifier": columnAccessorKey,
310
- className: inputGroupClass
311
- }, __jsx(_material.Box, {
312
- component: "div",
313
- tabIndex: 0,
314
- onBlur: handleApplyFilter,
315
- onKeyDown: handleKeyDown,
316
- onClick: function onClick(e) {
317
- return e.stopPropagation();
318
- }
319
- }, renderFormWidget(columnId, widgetType, localValue, handleLocalValueChange, {
320
- placeholder: "",
321
- sessionKey: "filter_".concat(columnId),
322
- column: columnMeta
323
- })), __jsx("span", {
324
- className: "input-group-addon filter-clear-icon"
325
- }, __jsx(_material.Box, {
326
- hidden: (0, _lodashEs.isEmpty)(localValue),
327
- component: "button",
328
- type: "button",
329
- className: "btn-transparent btn app-button",
330
- "aria-haspopup": "true",
331
- "aria-expanded": Boolean(anchorEl),
332
- onClick: handleClearFilterIconClick
333
- }, __jsx("i", {
334
- className: "app-icon wi wi-clear"
335
- }))), __jsx(_material.Box, {
336
- component: "span",
337
- className: "input-group-addon"
338
- }, __jsx(_material.Box, {
339
- ref: filterButtonRef,
340
- component: "button",
341
- type: "button",
342
- className: "btn-transparent btn app-button",
343
- "aria-haspopup": "true",
344
- "aria-expanded": Boolean(anchorEl),
345
- onClick: handleFilterIconClick
346
- }, __jsx(_material.Box, {
347
- component: "i",
348
- className: "app-icon wi wi-filter-list"
349
- })), __jsx(_material.Menu, {
350
- anchorEl: anchorEl,
351
- open: Boolean(anchorEl),
352
- onClose: handleClosePopover,
353
- anchorOrigin: {
354
- vertical: "bottom",
355
- horizontal: "right"
356
- },
357
- transformOrigin: {
358
- vertical: "top",
359
- horizontal: "right"
360
- },
361
- slotProps: MENU_POPUP_STYLES,
362
- MenuListProps: MENU_LIST_STYLES
363
- }, __jsx(_material.Box, {
364
- className: "dropdown open show"
365
- }, __jsx(_material.Box, {
366
- component: "ul",
367
- className: "matchmode-dropdown dropdown-menu"
368
- }, (0, _lodashEs.map)(matchModes, function (mode) {
369
- return __jsx(_material.Box, {
370
- key: mode,
371
- component: "li",
372
- className: selectedMatchMode === mode ? "active" : ""
373
- }, __jsx(_material.Box, {
374
- component: "a",
375
- href: "javascript:void(0);",
376
- onClick: function onClick() {
377
- return handleMatchModeSelect(mode);
217
+ const ColumnFilterCell = memo(
218
+ ({
219
+ columnId,
220
+ value,
221
+ onChange,
222
+ widgetType,
223
+ columnMeta,
224
+ columnAccessorKey,
225
+ listener,
226
+ renderFormWidget,
227
+ onMatchModeChange
228
+ }) => {
229
+ const [localValue, setLocalValue] = useState(value);
230
+ const [anchorEl, setAnchorEl] = useState(null);
231
+ const [selectedMatchMode, setSelectedMatchMode] = useState(DEFAULT_MATCH_MODE);
232
+ const filterButtonRef = useRef(null);
233
+ useEffect(() => {
234
+ setLocalValue(value);
235
+ }, [value]);
236
+ const dataType = useMemo(
237
+ () => getDataType(widgetType, columnMeta.editinputtype),
238
+ [widgetType, columnMeta.editinputtype]
239
+ );
240
+ const matchModes = useMemo(() => {
241
+ const matchModeMap = getMatchModeTypesMap();
242
+ return get(matchModeMap, dataType, get(matchModeMap, "default", []));
243
+ }, [dataType]);
244
+ const matchModeMessages = useMemo(
245
+ () => getMatchModeMsgs(listener == null ? void 0 : listener.appLocale),
246
+ [listener == null ? void 0 : listener.appLocale]
247
+ );
248
+ const inputGroupClass = useMemo(() => getInputGroupClass(dataType), [dataType]);
249
+ const handleApplyFilter = useCallback(
250
+ (e) => {
251
+ const inputValue = defaultTo(e.target.value, localValue);
252
+ if (inputValue !== value) {
253
+ onChange(columnId, inputValue, selectedMatchMode);
254
+ }
378
255
  },
379
- sx: {
380
- cursor: "pointer",
381
- textDecoration: "none"
382
- }
383
- }, (0, _lodashEs.get)(matchModeMessages, mode, mode)));
384
- }))))));
385
- }, function (prevProps, nextProps) {
386
- return shallowEqual(prevProps, nextProps, ["columnId", "value", "widgetType", "columnMeta", "columnAccessorKey", "onChange", "renderFormWidget", "onMatchModeChange"]);
387
- });
256
+ [localValue, value, columnId, selectedMatchMode, onChange]
257
+ );
258
+ const handleKeyDown = useCallback(
259
+ (e) => {
260
+ if (e.key === "Enter") {
261
+ e.preventDefault();
262
+ handleApplyFilter(e);
263
+ }
264
+ e.stopPropagation();
265
+ },
266
+ [handleApplyFilter]
267
+ );
268
+ const handleFilterIconClick = useCallback((e) => {
269
+ e.stopPropagation();
270
+ setAnchorEl(filterButtonRef.current);
271
+ }, []);
272
+ const handleClosePopover = useCallback(() => {
273
+ setAnchorEl(null);
274
+ }, []);
275
+ const handleMatchModeSelect = useCallback(
276
+ (matchMode) => {
277
+ setSelectedMatchMode(matchMode);
278
+ onMatchModeChange == null ? void 0 : onMatchModeChange(columnId, matchMode);
279
+ if (localValue) {
280
+ onChange(columnId, localValue, matchMode);
281
+ }
282
+ handleClosePopover();
283
+ },
284
+ [columnId, localValue, onChange, onMatchModeChange, handleClosePopover]
285
+ );
286
+ const handleClearFilterIconClick = useCallback(() => {
287
+ onChange(columnId, "", selectedMatchMode);
288
+ setLocalValue("");
289
+ }, [columnId, selectedMatchMode, onChange]);
290
+ const handleLocalValueChange = useCallback((value2) => {
291
+ setLocalValue(value2);
292
+ }, []);
293
+ return /* @__PURE__ */ jsxs("div", { "data-col-identifier": columnAccessorKey, className: inputGroupClass, children: [
294
+ /* @__PURE__ */ jsx(
295
+ Box,
296
+ {
297
+ component: "div",
298
+ tabIndex: 0,
299
+ onBlur: handleApplyFilter,
300
+ onKeyDown: handleKeyDown,
301
+ onClick: (e) => e.stopPropagation(),
302
+ children: renderFormWidget(columnId, widgetType, localValue, handleLocalValueChange, {
303
+ placeholder: "",
304
+ sessionKey: `filter_${columnId}`,
305
+ column: columnMeta
306
+ })
307
+ }
308
+ ),
309
+ /* @__PURE__ */ jsx("span", { className: "input-group-addon filter-clear-icon", children: /* @__PURE__ */ jsx(
310
+ Box,
311
+ {
312
+ hidden: isEmpty(localValue),
313
+ component: "button",
314
+ type: "button",
315
+ className: "btn-transparent btn app-button",
316
+ "aria-haspopup": "true",
317
+ "aria-expanded": Boolean(anchorEl),
318
+ onClick: handleClearFilterIconClick,
319
+ children: /* @__PURE__ */ jsx("i", { className: "app-icon wi wi-clear" })
320
+ }
321
+ ) }),
322
+ /* @__PURE__ */ jsxs(Box, { component: "span", className: "input-group-addon", children: [
323
+ /* @__PURE__ */ jsx(
324
+ Box,
325
+ {
326
+ ref: filterButtonRef,
327
+ component: "button",
328
+ type: "button",
329
+ className: "btn-transparent btn app-button",
330
+ "aria-haspopup": "true",
331
+ "aria-expanded": Boolean(anchorEl),
332
+ onClick: handleFilterIconClick,
333
+ children: /* @__PURE__ */ jsx(Box, { component: "i", className: "app-icon wi wi-filter-list" })
334
+ }
335
+ ),
336
+ /* @__PURE__ */ jsx(
337
+ Menu,
338
+ {
339
+ anchorEl,
340
+ open: Boolean(anchorEl),
341
+ onClose: handleClosePopover,
342
+ anchorOrigin: { vertical: "bottom", horizontal: "right" },
343
+ transformOrigin: { vertical: "top", horizontal: "right" },
344
+ slotProps: MENU_POPUP_STYLES,
345
+ MenuListProps: MENU_LIST_STYLES,
346
+ children: /* @__PURE__ */ jsx(Box, { className: "dropdown open show", children: /* @__PURE__ */ jsx(Box, { component: "ul", className: "matchmode-dropdown dropdown-menu", children: map(matchModes, (mode) => /* @__PURE__ */ jsx(
347
+ Box,
348
+ {
349
+ component: "li",
350
+ className: selectedMatchMode === mode ? "active" : "",
351
+ children: /* @__PURE__ */ jsx(
352
+ Box,
353
+ {
354
+ component: "a",
355
+ href: "javascript:void(0);",
356
+ onClick: () => handleMatchModeSelect(mode),
357
+ sx: { cursor: "pointer", textDecoration: "none" },
358
+ children: get(matchModeMessages, mode, mode)
359
+ }
360
+ )
361
+ },
362
+ mode
363
+ )) }) })
364
+ }
365
+ )
366
+ ] })
367
+ ] });
368
+ },
369
+ (prevProps, nextProps) => shallowEqual(prevProps, nextProps, [
370
+ "columnId",
371
+ "value",
372
+ "widgetType",
373
+ "columnMeta",
374
+ "columnAccessorKey",
375
+ "onChange",
376
+ "renderFormWidget",
377
+ "onMatchModeChange"
378
+ ])
379
+ );
388
380
  ColumnFilterCell.displayName = "ColumnFilterCell";
389
- var TableFilterRow = exports.TableFilterRow = /*#__PURE__*/(0, _react.memo)(function (_ref3) {
390
- var columns = _ref3.columns,
391
- columnFilters = _ref3.columnFilters,
392
- onColumnFilterChange = _ref3.onColumnFilterChange,
393
- filterMode = _ref3.filterMode,
394
- renderFormWidget = _ref3.renderFormWidget,
395
- listener = _ref3.listener;
396
- if (filterMode !== "multicolumn") {
397
- return null;
398
- }
399
- return __jsx("tr", {
400
- className: "table-filter-row"
401
- }, (0, _lodashEs.map)(columns, function (column, index) {
402
- var columnId = (0, _lodashEs.defaultTo)(column.id, column.accessorKey);
403
-
404
- // Skip non-filterable columns
405
- if (!isFilterableColumn(column)) {
406
- return __jsx("th", {
407
- key: columnId
408
- });
381
+ const TableFilterRow = memo(
382
+ ({
383
+ columns,
384
+ columnFilters,
385
+ onColumnFilterChange,
386
+ filterMode,
387
+ renderFormWidget,
388
+ listener
389
+ }) => {
390
+ if (filterMode !== "multicolumn") {
391
+ return null;
409
392
  }
410
- var columnMeta = (0, _lodashEs.defaultTo)(column.meta, {});
411
- var widgetType = (0, _lodashEs.defaultTo)(columnMeta.editWidgetType, (0, _lodashEs.defaultTo)(columnMeta.widgetType, "text"));
412
- return __jsx("th", {
413
- key: columnId,
414
- "data-col-id": index + 1
415
- }, __jsx(ColumnFilterCell, {
416
- columnId: columnId,
417
- value: (0, _lodashEs.get)(columnFilters, [columnId, "value"], ""),
418
- onChange: onColumnFilterChange,
419
- widgetType: widgetType,
420
- columnMeta: columnMeta,
421
- columnAccessorKey: column.accessorKey,
422
- renderFormWidget: renderFormWidget,
423
- listener: listener
424
- }));
425
- }));
426
- }, function (prevProps, nextProps) {
427
- return shallowEqual(prevProps, nextProps, ["columns", "columnFilters", "filterMode", "onColumnFilterChange", "renderFormWidget"]);
428
- });
429
- TableFilterRow.displayName = "TableFilterRow";
393
+ return /* @__PURE__ */ jsx("tr", { className: "table-filter-row", children: map(columns, (column, index) => {
394
+ const columnId = defaultTo(column.id, column.accessorKey);
395
+ if (!isFilterableColumn(column)) {
396
+ return /* @__PURE__ */ jsx("th", {}, columnId);
397
+ }
398
+ const columnMeta = defaultTo(column.meta, {});
399
+ const widgetType = defaultTo(
400
+ columnMeta.editWidgetType,
401
+ defaultTo(columnMeta.widgetType, "text")
402
+ );
403
+ return /* @__PURE__ */ jsx("th", { "data-col-id": index + 1, children: /* @__PURE__ */ jsx(
404
+ ColumnFilterCell,
405
+ {
406
+ columnId,
407
+ value: get(columnFilters, [columnId, "value"], ""),
408
+ onChange: onColumnFilterChange,
409
+ widgetType,
410
+ columnMeta,
411
+ columnAccessorKey: column.accessorKey,
412
+ renderFormWidget,
413
+ listener
414
+ }
415
+ ) }, columnId);
416
+ }) });
417
+ },
418
+ (prevProps, nextProps) => shallowEqual(prevProps, nextProps, [
419
+ "columns",
420
+ "columnFilters",
421
+ "filterMode",
422
+ "onColumnFilterChange",
423
+ "renderFormWidget"
424
+ ])
425
+ );
426
+ TableFilterRow.displayName = "TableFilterRow";
427
+ export {
428
+ GlobalSearchFilter,
429
+ TableFilterRow
430
+ };