@wavemaker-ai/react-runtime 1.0.0-rc.647499 → 1.0.0-rc.647565

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 +808 -3177
  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,658 +1,575 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
- var _typeof3 = require("@babel/runtime/helpers/typeof");
5
- Object.defineProperty(exports, "__esModule", {
6
- value: true
7
- });
8
- exports["default"] = exports.WmSearch = void 0;
9
- var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
10
- var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
11
- var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
12
- var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
13
- var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
14
- var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
15
- var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
16
- var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
17
- var _react = _interopRequireWildcard(require("react"));
18
- var _clsx = _interopRequireDefault(require("clsx"));
19
- var _image = _interopRequireDefault(require("next/image"));
20
- var _debounce = _interopRequireDefault(require("lodash-es/debounce"));
21
- var _isPlainObject = _interopRequireDefault(require("lodash-es/isPlainObject"));
22
- var _Typography = _interopRequireDefault(require("@mui/material/Typography"));
23
- var _IconButton = _interopRequireDefault(require("@mui/material/IconButton"));
24
- var _MenuItem = _interopRequireDefault(require("@mui/material/MenuItem"));
25
- var _MenuList = _interopRequireDefault(require("@mui/material/MenuList"));
26
- var _ClickAwayListener = _interopRequireDefault(require("@mui/material/ClickAwayListener"));
27
- var _Paper = _interopRequireDefault(require("@mui/material/Paper"));
28
- var _Popper = _interopRequireDefault(require("@mui/material/Popper"));
29
- var _CircularProgress = _interopRequireDefault(require("@mui/material/CircularProgress"));
30
- var _dompurify = _interopRequireDefault(require("dompurify"));
31
- var _material = require("@mui/material");
32
- var _withBaseWrapper = _interopRequireDefault(require("@wavemaker-ai/react-runtime/higherOrder/withBaseWrapper"));
33
- var _transformedDatasetUtils = require("@wavemaker-ai/react-runtime/utils/transformedDataset-utils");
34
- var _providers = require("./providers");
35
- var _withFormController = _interopRequireDefault(require("@wavemaker-ai/react-runtime/components/data/form/form-controller/withFormController"));
36
- var _withStandalone = _interopRequireDefault(require("@wavemaker-ai/react-runtime/higherOrder/withStandalone"));
37
- var _excluded = ["showclear", "debouncetime", "searchkey", "searchon", "matchmode", "minchars", "limit", "tabindex", "placeholder", "dropup", "readonly", "datavalue", "dataset", "datafield", "displayfield", "disabled", "autofocus", "type", "showsearchicon", "showbackbutton", "imagewidth", "width", "displaylabel", "displayimagesrc", "displayexpression", "datacompletemsg", "loadingdatamsg", "clearsearchiconclass", "backsearchiconclass", "searchiconclass", "navsearchbar", "className", "shortcutkey", "required", "hint", "arialabel", "onBeforeservicecall", "onBlur", "onChange", "onFocus", "onSelect", "onSubmit", "onClear", "onSearch", "onDatasetready", "styles", "name", "listener", "value", "datasetItems", "selectedItems", "displayValue", "groupedData", "handleHeaderClick", "toggleAllHeaders", "isDestroyed", "validation", "casesensitive", "isUpdateRequired", "onQuerySearch", "getDisplayExpression", "standalone", "viewParent", "destroy", "clearSearch"];
38
- 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" != _typeof3(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); }
39
- var __jsx = _react["default"].createElement;
40
- function _createForOfIteratorHelper(r, e) { var t = "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (!t) { if (Array.isArray(r) || (t = _unsupportedIterableToArray(r)) || e && r && "number" == typeof r.length) { t && (r = t); var _n = 0, F = function F() {}; return { s: F, n: function n() { return _n >= r.length ? { done: !0 } : { done: !1, value: r[_n++] }; }, e: function e(r) { throw r; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var o, a = !0, u = !1; return { s: function s() { t = t.call(r); }, n: function n() { var r = t.next(); return a = r.done, r; }, e: function e(r) { u = !0, o = r; }, f: function f() { try { a || null == t["return"] || t["return"](); } finally { if (u) throw o; } } }; }
41
- function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } }
42
- function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; }
43
- function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
44
- function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2["default"])(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
45
- var DEFAULT_CLASS = "app-search input-group";
46
- var Search = /*#__PURE__*/_react["default"].forwardRef(function (props, ref) {
47
- var _props$showclear = props.showclear,
48
- showclear = _props$showclear === void 0 ? false : _props$showclear,
49
- _props$debouncetime = props.debouncetime,
50
- debouncetime = _props$debouncetime === void 0 ? 250 : _props$debouncetime,
51
- searchkey = props.searchkey,
52
- _props$searchon = props.searchon,
53
- searchon = _props$searchon === void 0 ? "typing" : _props$searchon,
54
- _props$matchmode = props.matchmode,
55
- matchmode = _props$matchmode === void 0 ? "contains" : _props$matchmode,
56
- _props$minchars = props.minchars,
57
- minchars = _props$minchars === void 0 ? 1 : _props$minchars,
58
- _props$limit = props.limit,
59
- limit = _props$limit === void 0 ? 10 : _props$limit,
60
- _props$tabindex = props.tabindex,
61
- tabindex = _props$tabindex === void 0 ? 0 : _props$tabindex,
62
- _props$placeholder = props.placeholder,
63
- placeholder = _props$placeholder === void 0 ? "Search" : _props$placeholder,
64
- _props$dropup = props.dropup,
65
- dropup = _props$dropup === void 0 ? false : _props$dropup,
66
- _props$readonly = props.readonly,
67
- readonly = _props$readonly === void 0 ? false : _props$readonly,
68
- datavalue = props.datavalue,
69
- _props$dataset = props.dataset,
70
- dataset = _props$dataset === void 0 ? [] : _props$dataset,
71
- _props$datafield = props.datafield,
72
- datafield = _props$datafield === void 0 ? "All Fields" : _props$datafield,
73
- displayfield = props.displayfield,
74
- _props$disabled = props.disabled,
75
- disabled = _props$disabled === void 0 ? false : _props$disabled,
76
- _props$autofocus = props.autofocus,
77
- autofocus = _props$autofocus === void 0 ? false : _props$autofocus,
78
- _props$type = props.type,
79
- type = _props$type === void 0 ? "search" : _props$type,
80
- _props$showsearchicon = props.showsearchicon,
81
- showsearchicon = _props$showsearchicon === void 0 ? true : _props$showsearchicon,
82
- _props$showbackbutton = props.showbackbutton,
83
- showbackbutton = _props$showbackbutton === void 0 ? false : _props$showbackbutton,
84
- _props$imagewidth = props.imagewidth,
85
- imagewidth = _props$imagewidth === void 0 ? "16px" : _props$imagewidth,
86
- width = props.width,
87
- displaylabel = props.displaylabel,
88
- displayimagesrc = props.displayimagesrc,
89
- displayexpression = props.displayexpression,
90
- _props$datacompletems = props.datacompletemsg,
91
- datacompletemsg = _props$datacompletems === void 0 ? "No more data to load" : _props$datacompletems,
92
- _props$loadingdatamsg = props.loadingdatamsg,
93
- loadingdatamsg = _props$loadingdatamsg === void 0 ? "Loading items..." : _props$loadingdatamsg,
94
- _props$clearsearchico = props.clearsearchiconclass,
95
- clearsearchiconclass = _props$clearsearchico === void 0 ? "wi wi-close" : _props$clearsearchico,
96
- _props$backsearchicon = props.backsearchiconclass,
97
- backsearchiconclass = _props$backsearchicon === void 0 ? "wi wi-arrow-left" : _props$backsearchicon,
98
- _props$searchiconclas = props.searchiconclass,
99
- searchiconclass = _props$searchiconclas === void 0 ? "sl-search wm-sl-l" : _props$searchiconclas,
100
- _props$navsearchbar = props.navsearchbar,
101
- navsearchbar = _props$navsearchbar === void 0 ? false : _props$navsearchbar,
102
- className = props.className,
103
- shortcutkey = props.shortcutkey,
104
- required = props.required,
105
- hint = props.hint,
106
- _props$arialabel = props.arialabel,
107
- arialabel = _props$arialabel === void 0 ? "Search field" : _props$arialabel,
108
- onBeforeservicecall = props.onBeforeservicecall,
109
- onBlur = props.onBlur,
110
- onChange = props.onChange,
111
- onFocus = props.onFocus,
112
- onSelect = props.onSelect,
113
- onSubmit = props.onSubmit,
114
- onClear = props.onClear,
115
- onSearch = props.onSearch,
116
- onDatasetready = props.onDatasetready,
117
- _props$styles = props.styles,
118
- styles = _props$styles === void 0 ? {} : _props$styles,
119
- name = props.name,
120
- listener = props.listener,
121
- value = props.value,
122
- datasetItems = props.datasetItems,
123
- selectedItems = props.selectedItems,
124
- displayValue = props.displayValue,
125
- initialGroupedData = props.groupedData,
126
- handleHeaderClick = props.handleHeaderClick,
127
- toggleAllHeaders = props.toggleAllHeaders,
128
- isDestroyed = props.isDestroyed,
129
- validation = props.validation,
130
- _props$casesensitive = props.casesensitive,
131
- casesensitive = _props$casesensitive === void 0 ? false : _props$casesensitive,
132
- isUpdateRequired = props.isUpdateRequired,
133
- onQuerySearch = props.onQuerySearch,
134
- getDisplayExpression = props.getDisplayExpression,
135
- _props$standalone = props.standalone,
136
- standalone = _props$standalone === void 0 ? false : _props$standalone,
137
- viewParent = props.viewParent,
138
- destroy = props.destroy,
139
- clearSearch = props.clearSearch,
140
- restProps = (0, _objectWithoutProperties2["default"])(props, _excluded);
141
- var debouncedSearchRef = (0, _react.useRef)(null);
142
- var debouncedSearchItemRef = (0, _react.useRef)(null);
143
- var getDataSourceRef = (0, _react.useRef)(null);
144
- var searchRef = (0, _react.useRef)(null);
145
- var inputRef = (0, _react.useRef)(null);
146
- var dropdownRef = (0, _react.useRef)(null);
147
- var searchButtonRef = (0, _react.useRef)(null);
148
- var listRef = (0, _react.useRef)(null);
149
- var initializedRef = (0, _react.useRef)(false);
150
- var isLoadingNextPageRef = (0, _react.useRef)(false); // Track if pagination request is in progress
151
- var _useState = (0, _react.useState)(typeof datavalue === "string" ? datavalue : ""),
152
- query = _useState[0],
153
- setQuery = _useState[1];
154
- var _useState2 = (0, _react.useState)(false),
155
- isOpen = _useState2[0],
156
- setIsOpen = _useState2[1];
157
- var _useState3 = (0, _react.useState)(false),
158
- loadingItems = _useState3[0],
159
- setLoadingItems = _useState3[1];
160
- var _useState4 = (0, _react.useState)(false),
161
- isScrolled = _useState4[0],
162
- setIsScrolled = _useState4[1];
163
- var _useState5 = (0, _react.useState)(1),
164
- page = _useState5[0],
165
- setPage = _useState5[1];
166
- var _useState6 = (0, _react.useState)([]),
167
- formattedDataset = _useState6[0],
168
- setFormattedDataset = _useState6[1];
169
- var _useState7 = (0, _react.useState)({}),
170
- groupedData = _useState7[0],
171
- setGroupedData = _useState7[1];
172
- var _useState8 = (0, _react.useState)(type === "autocomplete"),
173
- listenQuery = _useState8[0],
174
- setListenQuery = _useState8[1]; // Only listen for autocomplete type
175
- var _useState9 = (0, _react.useState)(false),
176
- menuOpen = _useState9[0],
177
- setMenuOpen = _useState9[1]; // Track menu open state separately
178
- var _useState0 = (0, _react.useState)(true),
179
- hasMoreData = _useState0[0],
180
- setHasMoreData = _useState0[1]; // Track if there's more data to load
181
- var _useState1 = (0, _react.useState)(null),
182
- selectedItem = _useState1[0],
183
- setSelectedItem = _useState1[1]; // Track the selected item
184
- var _useState10 = (0, _react.useState)(undefined),
185
- updateRequired = _useState10[0],
186
- setUpdateRequired = _useState10[1];
187
- var dataProvider = (0, _react.useMemo)(function () {
188
- return new _providers.DataProvider();
189
- }, []);
190
-
191
- // Note: Don't pass groupby to transformDataset - let getGroupedData handle grouping
192
- // transformDataset with groupby produces {key: groupKey, data: [...]} structure
193
- // which is incompatible with getGroupedData expecting {dataObject: {...}} structure
194
- var normalizedData = (0, _react.useMemo)(function () {
195
- return (0, _transformedDatasetUtils.transformDataset)(dataset, datafield, displayfield, displaylabel, displayexpression, props.orderby, undefined,
196
- // Don't pre-group - getGroupedData will handle it
197
- props.dataPath);
198
- }, [dataset, datafield, displayfield, displaylabel, displayexpression, props.orderby, props.dataPath]);
199
- (0, _react.useEffect)(function () {
200
- // Handle clearing when datavalue becomes undefined or null
201
- if (datavalue === undefined || datavalue === null || datavalue === "") {
1
+ var __defProp = Object.defineProperty;
2
+ var __defProps = Object.defineProperties;
3
+ var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
4
+ var __getOwnPropSymbols = Object.getOwnPropertySymbols;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __propIsEnum = Object.prototype.propertyIsEnumerable;
7
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
8
+ var __spreadValues = (a, b) => {
9
+ for (var prop in b || (b = {}))
10
+ if (__hasOwnProp.call(b, prop))
11
+ __defNormalProp(a, prop, b[prop]);
12
+ if (__getOwnPropSymbols)
13
+ for (var prop of __getOwnPropSymbols(b)) {
14
+ if (__propIsEnum.call(b, prop))
15
+ __defNormalProp(a, prop, b[prop]);
16
+ }
17
+ return a;
18
+ };
19
+ var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
20
+ var __objRest = (source, exclude) => {
21
+ var target = {};
22
+ for (var prop in source)
23
+ if (__hasOwnProp.call(source, prop) && exclude.indexOf(prop) < 0)
24
+ target[prop] = source[prop];
25
+ if (source != null && __getOwnPropSymbols)
26
+ for (var prop of __getOwnPropSymbols(source)) {
27
+ if (exclude.indexOf(prop) < 0 && __propIsEnum.call(source, prop))
28
+ target[prop] = source[prop];
29
+ }
30
+ return target;
31
+ };
32
+ import { Fragment, jsx, jsxs } from "react/jsx-runtime";
33
+ import React, { useEffect, useRef, useState, useCallback, useMemo, startTransition } from "react";
34
+ import clsx from "clsx";
35
+ import Image from "next/image";
36
+ import debounce from "lodash-es/debounce";
37
+ import isPlainObject from "lodash-es/isPlainObject";
38
+ import Typography from "@mui/material/Typography";
39
+ import IconButton from "@mui/material/IconButton";
40
+ import MenuItem from "@mui/material/MenuItem";
41
+ import MenuList from "@mui/material/MenuList";
42
+ import ClickAwayListener from "@mui/material/ClickAwayListener";
43
+ import Paper from "@mui/material/Paper";
44
+ import Popper from "@mui/material/Popper";
45
+ import CircularProgress from "@mui/material/CircularProgress";
46
+ import DOMPurify from "dompurify";
47
+ import { Box, Button } from "@mui/material";
48
+ import withBaseWrapper from "../../../higherOrder/withBaseWrapper";
49
+ import { transformDataset } from "../../../utils/transformedDataset-utils";
50
+ import { DataProvider, LocalDataProvider } from "./providers";
51
+ import withFormController from "../../data/form/form-controller/withFormController";
52
+ import withStandalone from "../../../higherOrder/withStandalone";
53
+ import {
54
+ CustomTemplateCaption,
55
+ useCustomTemplate
56
+ } from "../../common/customTemplate";
57
+ const DEFAULT_CLASS = "app-search input-group";
58
+ const Search = React.forwardRef((props, ref) => {
59
+ const _a = props, {
60
+ showclear = false,
61
+ debouncetime = 250,
62
+ searchkey,
63
+ searchon = "typing",
64
+ matchmode = "contains",
65
+ minchars = 1,
66
+ limit = 10,
67
+ tabindex = 0,
68
+ placeholder = "Search",
69
+ dropup = false,
70
+ readonly = false,
71
+ datavalue,
72
+ dataset = [],
73
+ datafield = "All Fields",
74
+ displayfield,
75
+ disabled = false,
76
+ autofocus = false,
77
+ type = "search",
78
+ showsearchicon: showsearchicon = true,
79
+ showbackbutton = false,
80
+ imagewidth: imagewidth = "16px",
81
+ width,
82
+ displaylabel: displaylabel,
83
+ displayimagesrc,
84
+ displayexpression,
85
+ datacompletemsg = "No more data to load",
86
+ loadingdatamsg = "Loading items...",
87
+ clearsearchiconclass = "wi wi-close",
88
+ backsearchiconclass = "wi wi-arrow-left",
89
+ searchiconclass = "sl-search wm-sl-l",
90
+ navsearchbar = false,
91
+ className,
92
+ shortcutkey,
93
+ required,
94
+ hint,
95
+ arialabel = "Search field",
96
+ onBeforeservicecall,
97
+ onBlur,
98
+ onChange,
99
+ onFocus,
100
+ onSelect,
101
+ onSubmit,
102
+ onClear,
103
+ onSearch,
104
+ onDatasetready,
105
+ styles: styles = {},
106
+ name,
107
+ listener,
108
+ content,
109
+ value,
110
+ datasetItems: datasetItems,
111
+ selectedItems,
112
+ displayValue,
113
+ groupedData: initialGroupedData,
114
+ handleHeaderClick,
115
+ toggleAllHeaders,
116
+ isDestroyed,
117
+ validation,
118
+ casesensitive = false,
119
+ isUpdateRequired: isUpdateRequired,
120
+ onQuerySearch,
121
+ getDisplayExpression,
122
+ standalone = false,
123
+ viewParent,
124
+ destroy,
125
+ clearSearch
126
+ } = _a, restProps = __objRest(_a, [
127
+ "showclear",
128
+ "debouncetime",
129
+ "searchkey",
130
+ "searchon",
131
+ "matchmode",
132
+ "minchars",
133
+ "limit",
134
+ "tabindex",
135
+ "placeholder",
136
+ "dropup",
137
+ "readonly",
138
+ "datavalue",
139
+ "dataset",
140
+ "datafield",
141
+ "displayfield",
142
+ "disabled",
143
+ "autofocus",
144
+ "type",
145
+ // Changed default to 'search'
146
+ "showsearchicon",
147
+ "showbackbutton",
148
+ // Added with default false
149
+ "imagewidth",
150
+ "width",
151
+ // Added width prop
152
+ "displaylabel",
153
+ "displayimagesrc",
154
+ "displayexpression",
155
+ "datacompletemsg",
156
+ "loadingdatamsg",
157
+ "clearsearchiconclass",
158
+ "backsearchiconclass",
159
+ "searchiconclass",
160
+ "navsearchbar",
161
+ "className",
162
+ "shortcutkey",
163
+ "required",
164
+ "hint",
165
+ "arialabel",
166
+ "onBeforeservicecall",
167
+ "onBlur",
168
+ "onChange",
169
+ "onFocus",
170
+ "onSelect",
171
+ "onSubmit",
172
+ "onClear",
173
+ "onSearch",
174
+ "onDatasetready",
175
+ // Added onDatasetready callback
176
+ "styles",
177
+ "name",
178
+ "listener",
179
+ "content",
180
+ "value",
181
+ // Extract props that should not be spread to DOM elements
182
+ "datasetItems",
183
+ "selectedItems",
184
+ "displayValue",
185
+ "groupedData",
186
+ "handleHeaderClick",
187
+ "toggleAllHeaders",
188
+ "isDestroyed",
189
+ "validation",
190
+ "casesensitive",
191
+ // Default to case-insensitive
192
+ "isUpdateRequired",
193
+ "onQuerySearch",
194
+ "getDisplayExpression",
195
+ "standalone",
196
+ "viewParent",
197
+ "destroy",
198
+ "clearSearch"
199
+ ]);
200
+ const debouncedSearchRef = useRef(null);
201
+ const debouncedSearchItemRef = useRef(null);
202
+ const getDataSourceRef = useRef(
203
+ null
204
+ );
205
+ const searchRef = useRef(null);
206
+ const inputRef = useRef(null);
207
+ const dropdownRef = useRef(null);
208
+ const searchButtonRef = useRef(null);
209
+ const listRef = useRef(null);
210
+ const initializedRef = useRef(false);
211
+ const isLoadingNextPageRef = useRef(false);
212
+ const [query, setQuery] = useState(typeof datavalue === "string" ? datavalue : "");
213
+ const [isOpen, setIsOpen] = useState(false);
214
+ const [loadingItems, setLoadingItems] = useState(false);
215
+ const [isScrolled, setIsScrolled] = useState(false);
216
+ const [page, setPage] = useState(1);
217
+ const [formattedDataset, setFormattedDataset] = useState([]);
218
+ const [groupedData, setGroupedData] = useState({});
219
+ const [listenQuery, setListenQuery] = useState(type === "autocomplete");
220
+ const [menuOpen, setMenuOpen] = useState(false);
221
+ const [hasMoreData, setHasMoreData] = useState(true);
222
+ const [selectedItem, setSelectedItem] = useState(null);
223
+ const [updateRequired, setUpdateRequired] = useState(void 0);
224
+ const { templateName, setTemplate } = useCustomTemplate({ content, name });
225
+ const dataProvider = useMemo(() => new DataProvider(), []);
226
+ const normalizedData = useMemo(
227
+ () => transformDataset(
228
+ dataset,
229
+ datafield,
230
+ displayfield,
231
+ displaylabel,
232
+ displayexpression,
233
+ props.orderby,
234
+ void 0,
235
+ // Don't pre-group - getGroupedData will handle it
236
+ props.dataPath
237
+ ),
238
+ [
239
+ dataset,
240
+ datafield,
241
+ displayfield,
242
+ displaylabel,
243
+ displayexpression,
244
+ props.orderby,
245
+ props.dataPath
246
+ ]
247
+ );
248
+ useEffect(() => {
249
+ var _a2;
250
+ if (datavalue === void 0 || datavalue === null || datavalue === "") {
202
251
  setQuery("");
203
252
  setSelectedItem(null);
204
253
  setFormattedDataset([]);
205
254
  return;
206
255
  }
207
- if (((0, _isPlainObject["default"])(datavalue) || Array.isArray(datavalue)) && searchkey && Object.keys(datavalue).length > 0) {
208
- var _value = Array.isArray(datavalue) ? datavalue[0] : datavalue;
209
- if (_value) {
210
- var key = searchkey.split(",")[0] || searchkey;
211
- var item = (getDisplayExpression === null || getDisplayExpression === void 0 ? void 0 : getDisplayExpression(_value)) || _value[key];
256
+ if ((isPlainObject(datavalue) || Array.isArray(datavalue)) && searchkey && Object.keys(datavalue).length > 0) {
257
+ const value2 = Array.isArray(datavalue) ? datavalue[0] : datavalue;
258
+ if (value2) {
259
+ const key = searchkey.split(",")[0] || searchkey;
260
+ const item = (getDisplayExpression == null ? void 0 : getDisplayExpression(value2)) || value2[key];
212
261
  if (item) {
213
262
  setQuery(item);
214
- handleUpdateDatavalue(_value);
263
+ handleUpdateDatavalue(value2);
215
264
  }
216
265
  }
217
266
  } else if (datafield !== "All Fields" && datafield) {
218
- var findItem = normalizedData === null || normalizedData === void 0 ? void 0 : normalizedData.find(function (item) {
219
- return item.value === datavalue;
220
- });
267
+ let findItem = normalizedData == null ? void 0 : normalizedData.find((item) => item.value === datavalue);
221
268
  if (findItem) {
222
- var _displayValue = (getDisplayExpression === null || getDisplayExpression === void 0 ? void 0 : getDisplayExpression(getSelectedItem(findItem))) || findItem.label;
223
- setQuery(_displayValue);
269
+ let displayValue2 = (getDisplayExpression == null ? void 0 : getDisplayExpression(getSelectedItem(findItem))) || findItem.label;
270
+ setQuery(displayValue2);
224
271
  handleUpdateDatavalue(findItem);
225
272
  } else {
226
- var _debouncedSearchItemR;
227
- (_debouncedSearchItemR = debouncedSearchItemRef.current) === null || _debouncedSearchItemR === void 0 || _debouncedSearchItemR.call(debouncedSearchItemRef, datavalue);
273
+ (_a2 = debouncedSearchItemRef.current) == null ? void 0 : _a2.call(debouncedSearchItemRef, datavalue);
228
274
  }
229
- }
230
- // do not remove this code specifically handled for chips component for clearing the query.
231
- else if (!(0, _isPlainObject["default"])(datavalue)) {
275
+ } else if (!isPlainObject(datavalue)) {
232
276
  setQuery(datavalue);
233
277
  }
234
278
  }, [datavalue]);
235
-
236
- // Combine width with other styles
237
- var searchStyle = _objectSpread({
238
- width: width
279
+ const searchStyle = __spreadValues({
280
+ width
239
281
  }, styles);
240
-
241
- // Create dataProvider instance
242
-
243
- // Initialize debounced searchItem function
244
- (0, _react.useEffect)(function () {
245
- // Cancel previous debounced function if it exists
282
+ useEffect(() => {
246
283
  if (debouncedSearchItemRef.current) {
247
284
  debouncedSearchItemRef.current.cancel();
248
285
  }
249
-
250
- // Create debounced version of searchItem
251
- debouncedSearchItemRef.current = (0, _debounce["default"])(/*#__PURE__*/function () {
252
- var _ref = (0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee(value) {
253
- var response, key, findItem, _displayValue2;
254
- return _regenerator["default"].wrap(function _callee$(_context) {
255
- while (1) switch (_context.prev = _context.next) {
256
- case 0:
257
- _context.next = 2;
258
- return dataProvider === null || dataProvider === void 0 ? void 0 : dataProvider.invokeVariable(props, value);
259
- case 2:
260
- response = _context.sent;
261
- if (!(response && response.length > 0)) {
262
- _context.next = 9;
263
- break;
264
- }
265
- key = (searchkey === null || searchkey === void 0 ? void 0 : searchkey.split(",")[0]) || searchkey;
266
- if (key) {
267
- _context.next = 7;
268
- break;
269
- }
270
- return _context.abrupt("return");
271
- case 7:
272
- findItem = response.find(function (item) {
273
- return item[key] == value;
274
- });
275
- if (findItem && Object.keys(findItem).length > 0) {
276
- _displayValue2 = (getDisplayExpression === null || getDisplayExpression === void 0 ? void 0 : getDisplayExpression(getSelectedItem(findItem))) || findItem[key];
277
- setQuery(_displayValue2);
278
- }
279
- case 9:
280
- case "end":
281
- return _context.stop();
282
- }
283
- }, _callee);
284
- }));
285
- return function (_x) {
286
- return _ref.apply(this, arguments);
287
- };
288
- }(), 200);
289
-
290
- // Cleanup: cancel debounced function on unmount or dependency change
291
- return function () {
286
+ debouncedSearchItemRef.current = debounce(async (value2) => {
287
+ const response = await (dataProvider == null ? void 0 : dataProvider.invokeVariable(props, value2));
288
+ if (response && response.length > 0) {
289
+ let key = (searchkey == null ? void 0 : searchkey.split(",")[0]) || searchkey;
290
+ if (!key) return;
291
+ const findItem = response.find((item) => item[key] == value2);
292
+ if (findItem && Object.keys(findItem).length > 0) {
293
+ let displayValue2 = (getDisplayExpression == null ? void 0 : getDisplayExpression(getSelectedItem(findItem))) || findItem[key];
294
+ setQuery(displayValue2);
295
+ }
296
+ }
297
+ }, 200);
298
+ return () => {
292
299
  if (debouncedSearchItemRef.current) {
293
300
  debouncedSearchItemRef.current.cancel();
294
301
  }
295
302
  };
296
303
  }, [dataProvider, props, searchkey, getDisplayExpression]);
297
-
298
- // Focus input on mount
299
- (0, _react.useEffect)(function () {
304
+ useEffect(() => {
305
+ var _a2;
300
306
  if (autofocus) {
301
- var _inputRef$current;
302
- (_inputRef$current = inputRef.current) === null || _inputRef$current === void 0 || _inputRef$current.focus();
307
+ (_a2 = inputRef.current) == null ? void 0 : _a2.focus();
303
308
  }
304
309
  if (listener && listener.onChange) {
305
310
  listener.onChange(name, {
306
- clearSearch: handleClearSearch
311
+ clearSearch: handleClearSearch,
312
+ setTemplate
307
313
  });
308
314
  }
309
315
  }, []);
310
-
311
- // Handle shortcut key
312
- (0, _react.useEffect)(function () {
313
- var handleShortcutKey = function handleShortcutKey(event) {
316
+ useEffect(() => {
317
+ const handleShortcutKey = (event) => {
318
+ var _a2;
314
319
  if (shortcutkey && event.key.toLowerCase() === shortcutkey.toLowerCase()) {
315
- var _inputRef$current2;
316
320
  event.preventDefault();
317
- (_inputRef$current2 = inputRef.current) === null || _inputRef$current2 === void 0 || _inputRef$current2.focus();
321
+ (_a2 = inputRef.current) == null ? void 0 : _a2.focus();
318
322
  }
319
323
  };
320
324
  window.addEventListener("keydown", handleShortcutKey);
321
- return function () {
322
- return window.removeEventListener("keydown", handleShortcutKey);
323
- };
325
+ return () => window.removeEventListener("keydown", handleShortcutKey);
324
326
  }, [shortcutkey]);
325
-
326
- // Process and prepare dataset for autocomplete type since it list should be loaded immediately when the component is mounted
327
- (0, _react.useEffect)(function () {
328
- // For autocomplete type load data immediately
327
+ useEffect(() => {
329
328
  if (type === "autocomplete") {
330
329
  getDataSource("");
331
330
  }
332
- // Update listen query state when type changes
333
331
  setListenQuery(type === "autocomplete");
334
332
  }, [type]);
335
- (0, _react.useEffect)(function () {
336
- if (type !== "autocomplete" || !(normalizedData !== null && normalizedData !== void 0 && normalizedData.length)) {
333
+ useEffect(() => {
334
+ if (type !== "autocomplete" || !(normalizedData == null ? void 0 : normalizedData.length)) {
337
335
  return;
338
336
  }
339
- (0, _react.startTransition)(function () {
337
+ startTransition(() => {
340
338
  setFormattedDataset(normalizedData);
341
- if (props !== null && props !== void 0 && props.groupby) {
339
+ if (props == null ? void 0 : props.groupby) {
342
340
  setGroupedData(getGroupedData(normalizedData));
343
341
  }
344
342
  });
345
343
  }, [normalizedData]);
346
- var getGroupedData = (0, _react.useCallback)(function (data) {
347
- if (props !== null && props !== void 0 && props.groupby && data !== null && data !== void 0 && data.length) {
348
- var result = {};
349
- data.forEach(function (item) {
350
- var _item$dataObject;
351
- if (!(props !== null && props !== void 0 && props.groupby)) {
352
- return;
353
- }
354
- var groupKey = item[props === null || props === void 0 ? void 0 : props.groupby] || (item === null || item === void 0 || (_item$dataObject = item.dataObject) === null || _item$dataObject === void 0 ? void 0 : _item$dataObject[props === null || props === void 0 ? void 0 : props.groupby]) || "ungrouped";
355
- if (!result[groupKey]) {
356
- result[groupKey] = [];
357
- }
358
- result[groupKey].push(item);
344
+ const getGroupedData = useCallback(
345
+ (data) => {
346
+ if ((props == null ? void 0 : props.groupby) && (data == null ? void 0 : data.length)) {
347
+ const result = {};
348
+ data.forEach((item) => {
349
+ var _a2;
350
+ if (!(props == null ? void 0 : props.groupby)) {
351
+ return;
352
+ }
353
+ const groupKey = item[props == null ? void 0 : props.groupby] || ((_a2 = item == null ? void 0 : item.dataObject) == null ? void 0 : _a2[props == null ? void 0 : props.groupby]) || "ungrouped";
354
+ if (!result[groupKey]) {
355
+ result[groupKey] = [];
356
+ }
357
+ result[groupKey].push(item);
358
+ });
359
+ return result;
360
+ }
361
+ return { ungrouped: data };
362
+ },
363
+ [props == null ? void 0 : props.groupby]
364
+ );
365
+ const getDataSource = useCallback(
366
+ async (query2, nextPage) => {
367
+ if (nextPage && isLoadingNextPageRef.current) {
368
+ return [];
369
+ }
370
+ if (!query2 && (type === "search" || type === "autocomplete" && !nextPage)) {
371
+ setFormattedDataset([]);
372
+ setIsOpen(false);
373
+ setMenuOpen(false);
374
+ return [];
375
+ }
376
+ const dataConfig = __spreadProps(__spreadValues({}, props), {
377
+ dataset: normalizedData,
378
+ datafield: datafield || "All Fields",
379
+ query: query2,
380
+ matchMode: matchmode,
381
+ casesensitive: false,
382
+ searchKey: searchkey,
383
+ isformfield: false,
384
+ page: nextPage ? page + 1 : 1,
385
+ isLocalFilter: true,
386
+ onBeforeservicecall,
387
+ groupby: props.groupby,
388
+ orderby: props.orderby,
389
+ limit
359
390
  });
360
- return result;
361
- }
362
- return {
363
- ungrouped: data
364
- };
365
- }, [props === null || props === void 0 ? void 0 : props.groupby]);
366
- var getDataSource = (0, _react.useCallback)(/*#__PURE__*/function () {
367
- var _ref2 = (0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee2(query, nextPage) {
368
- var dataConfig, _isUpdateRequired, _response, dataSet, localDataProvider, response, data, isLastPage;
369
- return _regenerator["default"].wrap(function _callee2$(_context2) {
370
- while (1) switch (_context2.prev = _context2.next) {
371
- case 0:
372
- if (!(nextPage && isLoadingNextPageRef.current)) {
373
- _context2.next = 2;
374
- break;
375
- }
376
- return _context2.abrupt("return", []);
377
- case 2:
378
- if (!(!query && (type === "search" || type === "autocomplete" && !nextPage))) {
379
- _context2.next = 7;
380
- break;
381
- }
382
- setFormattedDataset([]);
383
- setIsOpen(false);
384
- setMenuOpen(false);
385
- return _context2.abrupt("return", []);
386
- case 7:
387
- dataConfig = _objectSpread(_objectSpread({}, props), {}, {
388
- dataset: normalizedData,
389
- datafield: datafield || "All Fields",
390
- query: query,
391
- matchMode: matchmode,
392
- casesensitive: false,
393
- searchKey: searchkey,
394
- isformfield: false,
395
- page: nextPage ? page + 1 : 1,
396
- isLocalFilter: true,
397
- onBeforeservicecall: onBeforeservicecall,
398
- groupby: props.groupby,
399
- orderby: props.orderby,
400
- limit: limit
401
- }); // Set loading flag for pagination requests
402
- if (nextPage) {
403
- isLoadingNextPageRef.current = true;
404
- setPage(function (prev) {
405
- return prev + 1;
406
- });
407
- }
408
- _context2.prev = 9;
409
- setLoadingItems(true);
410
- _isUpdateRequired = updateRequired;
411
- if (searchkey && updateRequired === undefined) {
412
- _isUpdateRequired = dataProvider.init(dataConfig);
413
- setUpdateRequired(_isUpdateRequired);
414
- }
415
-
416
- // Handle remote search if required
417
- if (!(searchkey && _isUpdateRequired)) {
418
- _context2.next = 32;
419
- break;
420
- }
421
- _context2.prev = 14;
422
- _context2.next = 17;
423
- return dataProvider === null || dataProvider === void 0 ? void 0 : dataProvider.invokeVariable(dataConfig, query);
424
- case 17:
425
- _response = _context2.sent;
426
- if (!_response) {
427
- _context2.next = 23;
428
- break;
429
- }
430
- dataSet = Array.isArray(_response) ? _response : [_response];
431
- if (!nextPage) {
432
- setFormattedDataset(dataSet);
433
- setGroupedData(getGroupedData(dataSet));
434
- } else {
435
- setFormattedDataset(function (prev) {
436
- var updatedDataset = [].concat((0, _toConsumableArray2["default"])(prev), (0, _toConsumableArray2["default"])(dataSet));
437
- setGroupedData(getGroupedData(updatedDataset));
438
- return updatedDataset;
439
- });
440
- }
441
-
442
- // Update UI state based on results
443
- if (dataSet.length > 0) {
444
- setIsOpen(true);
445
- setMenuOpen(true);
446
- } else {
447
- setIsOpen(false);
448
- setMenuOpen(false);
391
+ if (nextPage) {
392
+ isLoadingNextPageRef.current = true;
393
+ setPage((prev) => prev + 1);
394
+ }
395
+ try {
396
+ setLoadingItems(true);
397
+ let isUpdateRequired2 = updateRequired;
398
+ if (searchkey && updateRequired === void 0) {
399
+ isUpdateRequired2 = dataProvider.init(dataConfig);
400
+ setUpdateRequired(isUpdateRequired2);
401
+ }
402
+ if (searchkey && isUpdateRequired2) {
403
+ try {
404
+ const response2 = await (dataProvider == null ? void 0 : dataProvider.invokeVariable(dataConfig, query2));
405
+ if (response2) {
406
+ const dataSet = Array.isArray(response2) ? response2 : [response2];
407
+ if (!nextPage) {
408
+ setFormattedDataset(dataSet);
409
+ setGroupedData(getGroupedData(dataSet));
410
+ } else {
411
+ setFormattedDataset((prev) => {
412
+ const updatedDataset = [...prev, ...dataSet];
413
+ setGroupedData(getGroupedData(updatedDataset));
414
+ return updatedDataset;
415
+ });
416
+ }
417
+ if (dataSet.length > 0) {
418
+ setIsOpen(true);
419
+ setMenuOpen(true);
420
+ } else {
421
+ setIsOpen(false);
422
+ setMenuOpen(false);
423
+ }
424
+ return dataSet;
449
425
  }
450
- return _context2.abrupt("return", dataSet);
451
- case 23:
452
- _context2.next = 31;
453
- break;
454
- case 25:
455
- _context2.prev = 25;
456
- _context2.t0 = _context2["catch"](14);
426
+ } catch (error) {
457
427
  setLoadingItems(false);
458
428
  setIsOpen(false);
459
429
  setMenuOpen(false);
460
- // Reset scroll flag on error so user can try again
461
- if (nextPage) {
462
- setIsScrolled(false);
463
- }
464
- // TODO: call a toast here
465
- case 31:
466
- return _context2.abrupt("return", []);
467
- case 32:
468
- if (!(!normalizedData || normalizedData.length === 0)) {
469
- _context2.next = 34;
470
- break;
471
- }
472
- return _context2.abrupt("return", []);
473
- case 34:
474
- localDataProvider = new _providers.LocalDataProvider();
475
- _context2.next = 37;
476
- return localDataProvider.filter(dataConfig);
477
- case 37:
478
- response = _context2.sent;
479
- data = response.data, isLastPage = response.isLastPage; // Update hasMoreData state based on results
480
- setHasMoreData(data.length > 0 && !isLastPage);
481
- if (!nextPage) {
482
- setFormattedDataset(data);
483
- setGroupedData(getGroupedData(data));
484
- } else {
485
- setFormattedDataset(function (prev) {
486
- var updatedDataset = [].concat((0, _toConsumableArray2["default"])(prev), (0, _toConsumableArray2["default"])(data));
487
- setGroupedData(getGroupedData(updatedDataset));
488
- return updatedDataset;
489
- });
490
- }
491
-
492
- // Show dropdown if we have results
493
- if (data.length > 0) {
494
- setIsOpen(true);
495
- setMenuOpen(true);
496
- }
497
-
498
- // Call onDatasetready callback if provided
499
- if (onDatasetready && (standalone || listener !== null && listener !== void 0 && listener.Widgets && name && name in listener.Widgets)) {
500
- onDatasetready(name != null && listener !== null && listener !== void 0 && listener.Widgets && name in listener.Widgets ? listener.Widgets[name] : props, data);
501
- }
502
- return _context2.abrupt("return", data);
503
- case 46:
504
- _context2.prev = 46;
505
- _context2.t1 = _context2["catch"](9);
506
- console.error("Error fetching data:", _context2.t1);
507
- return _context2.abrupt("return", []);
508
- case 50:
509
- _context2.prev = 50;
510
- setLoadingItems(false);
511
- // Reset pagination loading flag and scroll state
512
430
  if (nextPage) {
513
- isLoadingNextPageRef.current = false;
514
431
  setIsScrolled(false);
515
432
  }
516
- return _context2.finish(50);
517
- case 54:
518
- case "end":
519
- return _context2.stop();
433
+ }
434
+ return [];
520
435
  }
521
- }, _callee2, null, [[9, 46, 50, 54], [14, 25]]);
522
- }));
523
- return function (_x2, _x3) {
524
- return _ref2.apply(this, arguments);
525
- };
526
- }(), [dataset, datafield, matchmode, searchkey, limit, onBeforeservicecall, page, formattedDataset, getGroupedData, type, onDatasetready, standalone, listener === null || listener === void 0 ? void 0 : listener.Widgets, name]);
527
-
528
- // Keep ref updated with latest getDataSource
529
- (0, _react.useEffect)(function () {
436
+ if (!normalizedData || normalizedData.length === 0) {
437
+ return [];
438
+ }
439
+ const localDataProvider = new LocalDataProvider();
440
+ const response = await localDataProvider.filter(dataConfig);
441
+ const { data, isLastPage } = response;
442
+ setHasMoreData(data.length > 0 && !isLastPage);
443
+ if (!nextPage) {
444
+ setFormattedDataset(data);
445
+ setGroupedData(getGroupedData(data));
446
+ } else {
447
+ setFormattedDataset((prev) => {
448
+ const updatedDataset = [...prev, ...data];
449
+ setGroupedData(getGroupedData(updatedDataset));
450
+ return updatedDataset;
451
+ });
452
+ }
453
+ if (data.length > 0) {
454
+ setIsOpen(true);
455
+ setMenuOpen(true);
456
+ }
457
+ if (onDatasetready && (standalone || (listener == null ? void 0 : listener.Widgets) && name && name in listener.Widgets)) {
458
+ onDatasetready(
459
+ name != null && (listener == null ? void 0 : listener.Widgets) && name in listener.Widgets ? listener.Widgets[name] : props,
460
+ data
461
+ );
462
+ }
463
+ return data;
464
+ } catch (error) {
465
+ console.error("Error fetching data:", error);
466
+ return [];
467
+ } finally {
468
+ setLoadingItems(false);
469
+ if (nextPage) {
470
+ isLoadingNextPageRef.current = false;
471
+ setIsScrolled(false);
472
+ }
473
+ }
474
+ },
475
+ [
476
+ dataset,
477
+ datafield,
478
+ matchmode,
479
+ searchkey,
480
+ limit,
481
+ onBeforeservicecall,
482
+ page,
483
+ formattedDataset,
484
+ getGroupedData,
485
+ type,
486
+ onDatasetready,
487
+ standalone,
488
+ listener == null ? void 0 : listener.Widgets,
489
+ name
490
+ ]
491
+ );
492
+ useEffect(() => {
530
493
  getDataSourceRef.current = getDataSource;
531
494
  }, [getDataSource]);
532
-
533
- // Initialize or update the debounced function when dependencies change
534
- // Note: Using ref for getDataSource to prevent debounced function recreation on every render
535
- (0, _react.useEffect)(function () {
536
- // Cancel previous debounced function if it exists
495
+ useEffect(() => {
537
496
  if (debouncedSearchRef.current) {
538
497
  debouncedSearchRef.current.cancel();
539
498
  }
540
-
541
- // Create new debounced function - uses ref to always get latest getDataSource
542
- debouncedSearchRef.current = (0, _debounce["default"])(/*#__PURE__*/function () {
543
- var _ref3 = (0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee3(query) {
544
- var _getDataSourceRef$cur, data;
545
- return _regenerator["default"].wrap(function _callee3$(_context3) {
546
- while (1) switch (_context3.prev = _context3.next) {
547
- case 0:
548
- if (query) {
549
- _context3.next = 5;
550
- break;
551
- }
552
- setFormattedDataset([]);
553
- setIsOpen(false);
554
- setMenuOpen(false);
555
- return _context3.abrupt("return");
556
- case 5:
557
- if (!(query.length >= minchars)) {
558
- _context3.next = 25;
559
- break;
560
- }
561
- _context3.prev = 6;
562
- setLoadingItems(true);
563
- // Use ref to get latest getDataSource function
564
- _context3.next = 10;
565
- return (_getDataSourceRef$cur = getDataSourceRef.current) === null || _getDataSourceRef$cur === void 0 ? void 0 : _getDataSourceRef$cur.call(getDataSourceRef, query);
566
- case 10:
567
- _context3.t0 = _context3.sent;
568
- if (_context3.t0) {
569
- _context3.next = 13;
570
- break;
571
- }
572
- _context3.t0 = [];
573
- case 13:
574
- data = _context3.t0;
575
- setLoadingItems(false);
576
-
577
- // Update the formatted dataset first
578
- setFormattedDataset(data);
579
-
580
- // Then update visibility based on results
581
- if (data && data.length > 0) {
582
- setIsOpen(true);
583
- setMenuOpen(true);
584
- } else {
585
- setIsOpen(false);
586
- setMenuOpen(false);
587
- }
588
- _context3.next = 25;
589
- break;
590
- case 19:
591
- _context3.prev = 19;
592
- _context3.t1 = _context3["catch"](6);
593
- console.error("Error in search:", _context3.t1);
594
- setLoadingItems(false);
595
- setIsOpen(false);
596
- setMenuOpen(false);
597
- case 25:
598
- case "end":
599
- return _context3.stop();
499
+ debouncedSearchRef.current = debounce(async (query2) => {
500
+ var _a2;
501
+ if (!query2) {
502
+ setFormattedDataset([]);
503
+ setIsOpen(false);
504
+ setMenuOpen(false);
505
+ return;
506
+ }
507
+ if (query2.length >= minchars) {
508
+ try {
509
+ setLoadingItems(true);
510
+ const data = await ((_a2 = getDataSourceRef.current) == null ? void 0 : _a2.call(getDataSourceRef, query2)) || [];
511
+ setLoadingItems(false);
512
+ setFormattedDataset(data);
513
+ if (data && data.length > 0) {
514
+ setIsOpen(true);
515
+ setMenuOpen(true);
516
+ } else {
517
+ setIsOpen(false);
518
+ setMenuOpen(false);
600
519
  }
601
- }, _callee3, null, [[6, 19]]);
602
- }));
603
- return function (_x4) {
604
- return _ref3.apply(this, arguments);
605
- };
606
- }(), debouncetime);
607
-
608
- // Cleanup: cancel debounced function on unmount or dependency change
609
- return function () {
520
+ } catch (error) {
521
+ console.error("Error in search:", error);
522
+ setLoadingItems(false);
523
+ setIsOpen(false);
524
+ setMenuOpen(false);
525
+ }
526
+ }
527
+ }, debouncetime);
528
+ return () => {
610
529
  if (debouncedSearchRef.current) {
611
530
  debouncedSearchRef.current.cancel();
612
531
  }
613
532
  };
614
- }, [minchars, debouncetime]); // Removed getDataSource - now using ref
615
-
616
- // listen to query change and trigger debounced search
617
- (0, _react.useEffect)(function () {
533
+ }, [minchars, debouncetime]);
534
+ useEffect(() => {
535
+ var _a2;
618
536
  if (query && (type === "autocomplete" && listenQuery || type === "search" && searchon === "typing")) {
619
- var _debouncedSearchRef$c;
620
- // Call the persisted debounced function
621
- (_debouncedSearchRef$c = debouncedSearchRef.current) === null || _debouncedSearchRef$c === void 0 || _debouncedSearchRef$c.call(debouncedSearchRef, query);
537
+ (_a2 = debouncedSearchRef.current) == null ? void 0 : _a2.call(debouncedSearchRef, query);
622
538
  }
623
539
  }, [query, type, listenQuery, searchon]);
624
540
  function clearDataValue() {
625
- var _listener$onChange;
626
- listener === null || listener === void 0 || (_listener$onChange = listener.onChange) === null || _listener$onChange === void 0 || _listener$onChange.call(listener, props.fieldName || name, {
541
+ var _a2;
542
+ (_a2 = listener == null ? void 0 : listener.onChange) == null ? void 0 : _a2.call(listener, props.fieldName || name, {
627
543
  datavalue: ""
628
544
  });
629
545
  }
630
-
631
- // Simplify handleInputChange to only update query
632
- var handleInputChange = function handleInputChange(event) {
633
- var _event$target;
546
+ const handleInputChange = (event) => {
547
+ var _a2;
634
548
  if (readonly || disabled) {
635
549
  return;
636
550
  }
637
- var queryValue = (event === null || event === void 0 || (_event$target = event.target) === null || _event$target === void 0 ? void 0 : _event$target.value) || "";
551
+ const queryValue = ((_a2 = event == null ? void 0 : event.target) == null ? void 0 : _a2.value) || "";
638
552
  setQuery(queryValue);
639
-
640
- // Call onChange handlers (standalone apps have no listener.Widgets; chips use arg 3/4)
641
- if (onChange && (standalone || listener !== null && listener !== void 0 && listener.Widgets && name && name in listener.Widgets)) {
642
- onChange(event, name != null && listener !== null && listener !== void 0 && listener.Widgets && name in listener.Widgets ? listener.Widgets[name] : props, queryValue, queryValue);
553
+ if (onChange && (standalone || (listener == null ? void 0 : listener.Widgets) && name && name in listener.Widgets)) {
554
+ onChange(
555
+ event,
556
+ name != null && (listener == null ? void 0 : listener.Widgets) && name in listener.Widgets ? listener.Widgets[name] : props,
557
+ queryValue,
558
+ queryValue
559
+ );
643
560
  }
644
-
645
- // Handle empty query - for autocomplete show all options, for search close dropdown
646
561
  if (!queryValue) {
647
562
  setSelectedItem(null);
648
- if (onClear && (standalone || listener !== null && listener !== void 0 && listener.Widgets && name && name in listener.Widgets)) {
649
- onClear(event, name != null && listener !== null && listener !== void 0 && listener.Widgets && name in listener.Widgets ? listener.Widgets[name] : props);
563
+ if (onClear && (standalone || (listener == null ? void 0 : listener.Widgets) && name && name in listener.Widgets)) {
564
+ onClear(
565
+ event,
566
+ name != null && (listener == null ? void 0 : listener.Widgets) && name in listener.Widgets ? listener.Widgets[name] : props
567
+ );
650
568
  }
651
569
  clearDataValue();
652
- // For autocomplete type, show all options when query is cleared
653
570
  if (type === "autocomplete" && normalizedData && normalizedData.length > 0) {
654
571
  setFormattedDataset(normalizedData);
655
- if (props !== null && props !== void 0 && props.groupby) {
572
+ if (props == null ? void 0 : props.groupby) {
656
573
  setGroupedData(getGroupedData(normalizedData));
657
574
  }
658
575
  setIsOpen(true);
@@ -665,25 +582,24 @@ var Search = /*#__PURE__*/_react["default"].forwardRef(function (props, ref) {
665
582
  return;
666
583
  }
667
584
  };
668
- var handleKeyDown = function handleKeyDown(event) {
585
+ const handleKeyDown = (event) => {
586
+ var _a2;
669
587
  if (event.key === "Enter") {
670
- // If dropdown is open and we have items
671
588
  if (menuOpen && formattedDataset.length > 0) {
672
- var _dropdownRef$current;
673
- var matches = ((_dropdownRef$current = dropdownRef.current) === null || _dropdownRef$current === void 0 ? void 0 : _dropdownRef$current.querySelectorAll("li")) || [];
589
+ const matches = ((_a2 = dropdownRef.current) == null ? void 0 : _a2.querySelectorAll("li")) || [];
674
590
  if (matches.length > 0) {
675
- var firstMatch = matches[0];
591
+ const firstMatch = matches[0];
676
592
  handleMatchSelect(firstMatch);
677
593
  }
678
594
  } else {
679
- // For search type with searchon=iconclick or no searchon specified
680
595
  if (type === "search" && (!searchon || searchon === "onsearchiconclick")) {
681
596
  handleSearchClick(event);
682
597
  }
683
-
684
- // Fire onSubmit if provided
685
- if (onSubmit && (standalone || listener !== null && listener !== void 0 && listener.Widgets && name && name in listener.Widgets)) {
686
- onSubmit(event, name != null && listener !== null && listener !== void 0 && listener.Widgets && name in listener.Widgets ? listener.Widgets[name] : props);
598
+ if (onSubmit && (standalone || (listener == null ? void 0 : listener.Widgets) && name && name in listener.Widgets)) {
599
+ onSubmit(
600
+ event,
601
+ name != null && (listener == null ? void 0 : listener.Widgets) && name in listener.Widgets ? listener.Widgets[name] : props
602
+ );
687
603
  }
688
604
  if (props.isSearchInChips) {
689
605
  setQuery("");
@@ -697,37 +613,36 @@ var Search = /*#__PURE__*/_react["default"].forwardRef(function (props, ref) {
697
613
  setMenuOpen(false);
698
614
  }
699
615
  };
700
- (0, _react.useEffect)(function () {
701
- var handler = function handler(event) {
702
- // Use currentTarget to always refer to the element on which the event listener is registered
703
- var target = event.currentTarget;
704
- // Consider it "at the bottom" if within 1px of the bottom (to deal with floating point inaccuracies)
616
+ useEffect(() => {
617
+ const handler = (event) => {
618
+ const target = event.currentTarget;
705
619
  if (target.scrollHeight - target.scrollTop - target.clientHeight <= 1) {
706
- // Cast a synthetic event that looks like React's UIEvent if needed, otherwise just call with event
707
620
  handleScroll(event);
708
621
  }
709
622
  };
710
623
  if (listRef.current) {
711
624
  listRef.current.addEventListener("scroll", handler);
712
625
  }
713
- return function () {
626
+ return () => {
714
627
  if (listRef.current) {
715
628
  listRef.current.removeEventListener("scroll", handler);
716
629
  }
717
630
  };
718
631
  }, [hasMoreData]);
719
- var handleClearSearch = function handleClearSearch(event) {
720
- var _inputRef$current3;
632
+ const handleClearSearch = (event) => {
633
+ var _a2;
721
634
  setQuery("");
722
635
  setSelectedItem(null);
723
- if (onClear && (standalone || listener !== null && listener !== void 0 && listener.Widgets && name && name in listener.Widgets)) {
724
- onClear(event, name != null && listener !== null && listener !== void 0 && listener.Widgets && name in listener.Widgets ? listener.Widgets[name] : props);
636
+ if (onClear && (standalone || (listener == null ? void 0 : listener.Widgets) && name && name in listener.Widgets)) {
637
+ onClear(
638
+ event,
639
+ name != null && (listener == null ? void 0 : listener.Widgets) && name in listener.Widgets ? listener.Widgets[name] : props
640
+ );
725
641
  }
726
642
  clearDataValue();
727
- // For autocomplete type, show all options after clearing
728
643
  if (type === "autocomplete" && normalizedData && normalizedData.length > 0) {
729
644
  setFormattedDataset(normalizedData);
730
- if (props !== null && props !== void 0 && props.groupby) {
645
+ if (props == null ? void 0 : props.groupby) {
731
646
  setGroupedData(getGroupedData(normalizedData));
732
647
  }
733
648
  setIsOpen(true);
@@ -737,115 +652,106 @@ var Search = /*#__PURE__*/_react["default"].forwardRef(function (props, ref) {
737
652
  setIsOpen(false);
738
653
  setMenuOpen(false);
739
654
  }
740
-
741
- // Focus back on input
742
- (_inputRef$current3 = inputRef.current) === null || _inputRef$current3 === void 0 || _inputRef$current3.focus();
655
+ (_a2 = inputRef.current) == null ? void 0 : _a2.focus();
743
656
  };
744
- var handleClickAway = function handleClickAway(e) {
657
+ const handleClickAway = (e) => {
745
658
  if (isOpen) {
746
659
  setIsOpen(false);
747
660
  setMenuOpen(false);
748
661
  handleBlur(e);
749
662
  }
750
663
  };
751
- var handleFocus = function handleFocus(event) {
752
- // For autocomplete type - show all options on focus
664
+ const handleFocus = (event) => {
753
665
  if (type === "autocomplete") {
754
- // If we already have results, show them
755
666
  if (formattedDataset.length > 0 && !selectedItem) {
756
667
  setIsOpen(true);
757
668
  setMenuOpen(true);
758
- }
759
- // Show all data on focus (use normalizedData which is already computed)
760
- else if (normalizedData && normalizedData.length > 0) {
669
+ } else if (normalizedData && normalizedData.length > 0) {
761
670
  setFormattedDataset(normalizedData);
762
- // Update grouped data if groupby is specified
763
- if (props !== null && props !== void 0 && props.groupby) {
671
+ if (props == null ? void 0 : props.groupby) {
764
672
  setGroupedData(getGroupedData(normalizedData));
765
673
  }
766
674
  setIsOpen(true);
767
675
  setMenuOpen(true);
768
676
  }
769
677
  }
770
- if (onFocus && (standalone || listener !== null && listener !== void 0 && listener.Widgets && name && name in listener.Widgets)) {
771
- onFocus(event, name != null && listener !== null && listener !== void 0 && listener.Widgets && name in listener.Widgets ? listener.Widgets[name] : props);
678
+ if (onFocus && (standalone || (listener == null ? void 0 : listener.Widgets) && name && name in listener.Widgets)) {
679
+ onFocus(
680
+ event,
681
+ name != null && (listener == null ? void 0 : listener.Widgets) && name in listener.Widgets ? listener.Widgets[name] : props
682
+ );
772
683
  }
773
684
  };
774
- var handleBlur = function handleBlur(event) {
775
- // Don't close dropdown immediately to allow click events on menu items
776
- setTimeout(function () {
777
- var _dropdownRef$current2, _searchButtonRef$curr;
778
- var activeElement = document.activeElement;
779
- if (document.activeElement !== dropdownRef.current && !((_dropdownRef$current2 = dropdownRef.current) !== null && _dropdownRef$current2 !== void 0 && _dropdownRef$current2.contains(activeElement)) && !((_searchButtonRef$curr = searchButtonRef.current) !== null && _searchButtonRef$curr !== void 0 && _searchButtonRef$curr.contains(activeElement))) {
685
+ const handleBlur = (event) => {
686
+ setTimeout(() => {
687
+ var _a2, _b;
688
+ const activeElement = document.activeElement;
689
+ if (document.activeElement !== dropdownRef.current && !((_a2 = dropdownRef.current) == null ? void 0 : _a2.contains(activeElement)) && !((_b = searchButtonRef.current) == null ? void 0 : _b.contains(activeElement))) {
780
690
  setIsOpen(false);
781
691
  setMenuOpen(false);
782
692
  }
783
693
  }, 200);
784
- if (onBlur && (standalone || listener !== null && listener !== void 0 && listener.Widgets && name && name in listener.Widgets)) {
785
- onBlur(event, name != null && listener !== null && listener !== void 0 && listener.Widgets && name in listener.Widgets ? listener.Widgets[name] : props);
694
+ if (onBlur && (standalone || (listener == null ? void 0 : listener.Widgets) && name && name in listener.Widgets)) {
695
+ onBlur(
696
+ event,
697
+ name != null && (listener == null ? void 0 : listener.Widgets) && name in listener.Widgets ? listener.Widgets[name] : props
698
+ );
786
699
  }
787
700
  };
788
- var handleSearchClick = function handleSearchClick(event) {
701
+ const handleSearchClick = (event) => {
789
702
  event.preventDefault();
790
703
  event.stopPropagation();
791
- // Reset hasMoreData state before new search
792
704
  setHasMoreData(true);
793
-
794
- // For search type with searchon=iconclick or no searchon specified
795
705
  if (type === "search" && (!searchon || searchon === "onsearchiconclick")) {
796
- // First set loading state
797
706
  setLoadingItems(true);
798
707
  getDataSource(query);
799
708
  }
800
- if (onSearch && (standalone || listener !== null && listener !== void 0 && listener.Widgets && name && name in listener.Widgets)) {
801
- onSearch(event, name != null && listener !== null && listener !== void 0 && listener.Widgets && name in listener.Widgets ? listener.Widgets[name] : props);
709
+ if (onSearch && (standalone || (listener == null ? void 0 : listener.Widgets) && name && name in listener.Widgets)) {
710
+ onSearch(
711
+ event,
712
+ name != null && (listener == null ? void 0 : listener.Widgets) && name in listener.Widgets ? listener.Widgets[name] : props
713
+ );
802
714
  }
803
715
  };
804
- var handleFocusNextItem = function handleFocusNextItem() {
805
- var _dropdownRef$current3;
806
- // For autocomplete type, open dropdown if closed and no item is selected
716
+ const handleFocusNextItem = () => {
717
+ var _a2;
807
718
  if (type === "autocomplete" && !menuOpen && query.length >= minchars && !selectedItem) {
808
719
  setIsOpen(true);
809
720
  setMenuOpen(true);
810
-
811
- // Load data if not loaded
812
721
  if (formattedDataset.length === 0) {
813
722
  getDataSource(query);
814
723
  }
815
724
  }
816
-
817
- // Focus on first menu item
818
- var matches = ((_dropdownRef$current3 = dropdownRef.current) === null || _dropdownRef$current3 === void 0 ? void 0 : _dropdownRef$current3.querySelectorAll("li")) || [];
725
+ const matches = ((_a2 = dropdownRef.current) == null ? void 0 : _a2.querySelectorAll("li")) || [];
819
726
  if (matches.length > 0) {
820
- var firstMatch = matches[0];
727
+ const firstMatch = matches[0];
821
728
  firstMatch.focus();
822
729
  }
823
730
  };
824
731
  function handleUpdateDatavalue(item) {
825
- var updatedItem = getSelectedItem(item);
826
- var value = datafield === "All Fields" ? updatedItem : updatedItem === null || updatedItem === void 0 ? void 0 : updatedItem[datafield];
827
- if (listener !== null && listener !== void 0 && listener.onChange) {
732
+ const updatedItem = getSelectedItem(item);
733
+ const value2 = datafield === "All Fields" ? updatedItem : updatedItem == null ? void 0 : updatedItem[datafield];
734
+ if (listener == null ? void 0 : listener.onChange) {
828
735
  listener.onChange(props.fieldName || name, {
829
- datavalue: value
736
+ datavalue: value2
830
737
  });
831
738
  }
832
739
  }
833
740
  function getSelectedItem(item) {
834
- var _item$dataObject2;
835
- return (item === null || item === void 0 || (_item$dataObject2 = item.dataObject) === null || _item$dataObject2 === void 0 ? void 0 : _item$dataObject2.dataObject) || (item === null || item === void 0 ? void 0 : item.dataObject) || item;
741
+ var _a2;
742
+ return ((_a2 = item == null ? void 0 : item.dataObject) == null ? void 0 : _a2.dataObject) || (item == null ? void 0 : item.dataObject) || item;
836
743
  }
837
- var handleMatchSelect = function handleMatchSelect(match) {
744
+ const handleMatchSelect = (match) => {
745
+ var _a2, _b;
838
746
  if (readonly || disabled) {
839
747
  return;
840
748
  }
841
- var itemData = match.getAttribute("data-item");
749
+ const itemData = match.getAttribute("data-item");
842
750
  if (!itemData) return;
843
751
  try {
844
- var item = JSON.parse(itemData);
845
- var _selectedItem = getSelectedItem(item);
846
-
847
- // Set display value in input
848
- var displayVal = (getDisplayExpression === null || getDisplayExpression === void 0 ? void 0 : getDisplayExpression(_selectedItem)) || item.displayValue || item.label;
752
+ const item = JSON.parse(itemData);
753
+ const selectedItem2 = getSelectedItem(item);
754
+ const displayVal = (getDisplayExpression == null ? void 0 : getDisplayExpression(selectedItem2)) || item.displayValue || item.label;
849
755
  if (props.isSearchInChips) {
850
756
  setQuery("");
851
757
  } else {
@@ -853,55 +759,65 @@ var Search = /*#__PURE__*/_react["default"].forwardRef(function (props, ref) {
853
759
  }
854
760
  setIsOpen(false);
855
761
  setMenuOpen(false);
856
- setSelectedItem(item); // Set the selected item
857
- setFormattedDataset([]); // Clear the dropdown dataset
858
- if (onChange && (standalone || listener !== null && listener !== void 0 && listener.Widgets && name && name in listener.Widgets)) {
859
- var _item$dataObject3, _item$dataObject4;
860
- onChange(undefined, name != null && listener !== null && listener !== void 0 && listener.Widgets && name in listener.Widgets ? listener.Widgets[name] : props, (_item$dataObject3 = item.dataObject) === null || _item$dataObject3 === void 0 ? void 0 : _item$dataObject3.value, (_item$dataObject4 = item.dataObject) === null || _item$dataObject4 === void 0 ? void 0 : _item$dataObject4.value);
762
+ setSelectedItem(item);
763
+ setFormattedDataset([]);
764
+ if (onChange && (standalone || (listener == null ? void 0 : listener.Widgets) && name && name in listener.Widgets)) {
765
+ onChange(
766
+ void 0,
767
+ name != null && (listener == null ? void 0 : listener.Widgets) && name in listener.Widgets ? listener.Widgets[name] : props,
768
+ (_a2 = item.dataObject) == null ? void 0 : _a2.value,
769
+ (_b = item.dataObject) == null ? void 0 : _b.value
770
+ );
861
771
  }
862
772
  if (!props.isSearchInChips) {
863
773
  handleUpdateDatavalue(item);
864
774
  }
865
-
866
- // Trigger onSelect callback if provided
867
- if (onSelect && (standalone || listener !== null && listener !== void 0 && listener.Widgets && name && name in listener.Widgets)) {
868
- onSelect(new MouseEvent("click"), props, _selectedItem);
869
- props.onSubmit && !props.isSearchInChips && props.onSubmit(new MouseEvent("click"), props);
775
+ if (onSelect && (standalone || (listener == null ? void 0 : listener.Widgets) && name && name in listener.Widgets)) {
776
+ onSelect(
777
+ new MouseEvent("click"),
778
+ props,
779
+ selectedItem2
780
+ );
781
+ props.onSubmit && !props.isSearchInChips && props.onSubmit(
782
+ new MouseEvent("click"),
783
+ props
784
+ );
870
785
  }
871
786
  } catch (error) {
872
787
  console.error("Error parsing item data:", error);
873
788
  }
874
789
  };
875
- var handleMenuItemClick = function handleMenuItemClick(event, item) {
790
+ const handleMenuItemClick = (event, item) => {
876
791
  handleMatchSelect(event.currentTarget);
877
792
  };
878
- var handleScroll = function handleScroll(event) {
793
+ const handleScroll = (event) => {
879
794
  if (!loadingItems && !isScrolled && !isLoadingNextPageRef.current && hasMoreData && !selectedItem) {
880
- var target = event.target;
795
+ const target = event.target;
881
796
  if (target.scrollHeight - target.scrollTop <= target.clientHeight + 50) {
882
797
  setIsScrolled(true);
883
798
  getDataSource(query, true);
884
799
  }
885
800
  }
886
801
  };
887
- var renderGroupDivider = function renderGroupDivider(groupKey) {
802
+ const renderGroupDivider = (groupKey) => {
888
803
  if (props.groupby && groupKey !== "ungrouped") {
889
- return __jsx(_MenuItem["default"], {
890
- key: "header-".concat(groupKey),
891
- onClick: handleMenuItemClick,
892
- dense: true,
893
- className: "list-group-header"
894
- }, __jsx(_Typography["default"], {
895
- variant: "h4",
896
- className: "group-title wm-search-group-title"
897
- }, groupKey));
804
+ return /* @__PURE__ */ jsx(
805
+ MenuItem,
806
+ {
807
+ onClick: handleMenuItemClick,
808
+ dense: true,
809
+ className: "list-group-header",
810
+ children: /* @__PURE__ */ jsx(Typography, { variant: "h4", className: "group-title wm-search-group-title", children: groupKey })
811
+ },
812
+ `header-${groupKey}`
813
+ );
898
814
  }
899
815
  return null;
900
816
  };
901
- var prepareDataItem = function prepareDataItem(item, index) {
902
- // Handle primitive values
903
- if ((0, _typeof2["default"])(item) !== "object" || item === null) {
904
- var stringValue = String(item);
817
+ const prepareDataItem = (item, index) => {
818
+ var _a2, _b, _c, _d, _e;
819
+ if (typeof item !== "object" || item === null) {
820
+ const stringValue = String(item);
905
821
  return {
906
822
  key: index,
907
823
  value: item,
@@ -911,35 +827,19 @@ var Search = /*#__PURE__*/_react["default"].forwardRef(function (props, ref) {
911
827
  dataObject: item
912
828
  };
913
829
  }
914
-
915
- // Return if already normalized
916
- var isNormalized = ["key", "value", "label", "displayValue"].every(function (prop) {
917
- return item.hasOwnProperty(prop);
918
- });
830
+ const isNormalized = ["key", "value", "label", "displayValue"].every(
831
+ (prop) => item.hasOwnProperty(prop)
832
+ );
919
833
  if (isNormalized) return item;
920
-
921
- // Helper to find first valid field value
922
- var findFieldValue = function findFieldValue(fields, fallback) {
923
- var _iterator = _createForOfIteratorHelper(fields.filter(Boolean)),
924
- _step;
925
- try {
926
- for (_iterator.s(); !(_step = _iterator.n()).done;) {
927
- var field = _step.value;
928
- if (field && item.hasOwnProperty(field) && item[field] != null && item[field] !== "") {
929
- return item[field];
930
- }
834
+ const findFieldValue = (fields, fallback) => {
835
+ for (const field of fields.filter(Boolean)) {
836
+ if (field && item.hasOwnProperty(field) && item[field] != null && item[field] !== "") {
837
+ return item[field];
931
838
  }
932
- } catch (err) {
933
- _iterator.e(err);
934
- } finally {
935
- _iterator.f();
936
839
  }
937
840
  return fallback;
938
841
  };
939
-
940
- // Get display value with priority: displayexpression > field names > first object value
941
- var getDisplayValue = function getDisplayValue() {
942
- // Try displayexpression first
842
+ const getDisplayValue = () => {
943
843
  if (displayexpression && typeof displayexpression === "function") {
944
844
  try {
945
845
  return displayexpression(item.dataObject ? item.dataObject : item);
@@ -947,112 +847,119 @@ var Search = /*#__PURE__*/_react["default"].forwardRef(function (props, ref) {
947
847
  console.warn("Error executing displayexpression:", e);
948
848
  }
949
849
  }
950
-
951
- // Try predefined field names
952
- var displayFields = [displaylabel, displayfield, "label", "name", "title", "text", "displayValue", "display"];
953
- var fieldValue = findFieldValue(displayFields);
850
+ const displayFields = [
851
+ displaylabel,
852
+ displayfield,
853
+ "label",
854
+ "name",
855
+ "title",
856
+ "text",
857
+ "displayValue",
858
+ "display"
859
+ ];
860
+ const fieldValue = findFieldValue(displayFields);
954
861
  if (fieldValue != null) return String(fieldValue);
955
-
956
- // Fallback to first object value
957
- var firstValue = !(props.groupby && props.isSearchInChips) && Object.values(item).find(function (val) {
958
- return val != null;
959
- });
862
+ const firstValue = !(props.groupby && props.isSearchInChips) && Object.values(item).find((val) => val != null);
960
863
  return firstValue ? String(firstValue) : "";
961
864
  };
962
- var displayValue = getDisplayValue();
963
- var keyFields = [datafield && datafield !== "All Fields" ? datafield : null, "id", "key", "value"];
964
- var keyValue = findFieldValue(keyFields, index);
965
- var imageSrc = null;
865
+ const displayValue2 = getDisplayValue();
866
+ const keyFields = [
867
+ datafield && datafield !== "All Fields" ? datafield : null,
868
+ "id",
869
+ "key",
870
+ "value"
871
+ ];
872
+ const keyValue = findFieldValue(keyFields, index);
873
+ let imageSrc = null;
966
874
  if (typeof displayimagesrc === "function") {
967
- var _ref4, _item$dataObject$data, _item$dataObject5;
968
- imageSrc = displayimagesrc((_ref4 = (_item$dataObject$data = item === null || item === void 0 || (_item$dataObject5 = item.dataObject) === null || _item$dataObject5 === void 0 ? void 0 : _item$dataObject5.dataObject) !== null && _item$dataObject$data !== void 0 ? _item$dataObject$data : item === null || item === void 0 ? void 0 : item.dataObject) !== null && _ref4 !== void 0 ? _ref4 : item);
875
+ imageSrc = displayimagesrc((_c = (_b = (_a2 = item == null ? void 0 : item.dataObject) == null ? void 0 : _a2.dataObject) != null ? _b : item == null ? void 0 : item.dataObject) != null ? _c : item);
969
876
  } else {
970
- var _item$dataObject6, _item$dataObject7;
971
- imageSrc = displayimagesrc && (_item$dataObject6 = item.dataObject) !== null && _item$dataObject6 !== void 0 && _item$dataObject6[displayimagesrc] ? (_item$dataObject7 = item.dataObject) === null || _item$dataObject7 === void 0 ? void 0 : _item$dataObject7[displayimagesrc] : null;
877
+ imageSrc = displayimagesrc && ((_d = item.dataObject) == null ? void 0 : _d[displayimagesrc]) ? (_e = item.dataObject) == null ? void 0 : _e[displayimagesrc] : null;
972
878
  }
973
879
  return {
974
880
  key: keyValue,
975
881
  value: item,
976
- label: displayValue,
977
- displayValue: displayValue,
882
+ label: displayValue2,
883
+ displayValue: displayValue2,
978
884
  displayImage: imageSrc,
979
885
  dataObject: item
980
886
  };
981
887
  };
982
-
983
- // Add this helper function to highlight matching text
984
- var highlightMatch = function highlightMatch(text, query) {
985
- if (!query || !text) return text;
888
+ const highlightMatch = (text, query2) => {
889
+ if (!query2 || !text) return text;
986
890
  try {
987
- var parts = text.split(new RegExp("(".concat(query, ")"), "gi"));
988
- return parts.map(function (part, index) {
989
- if (part.toLowerCase() === query.toLowerCase()) {
990
- return __jsx("strong", {
991
- key: index,
992
- className: "wm-search-match-highlight"
993
- }, part);
891
+ const parts = text.split(new RegExp(`(${query2})`, "gi"));
892
+ return parts.map((part, index) => {
893
+ if (part.toLowerCase() === query2.toLowerCase()) {
894
+ return /* @__PURE__ */ jsx("strong", { className: "wm-search-match-highlight", children: part }, index);
994
895
  }
995
896
  return part;
996
897
  });
997
898
  } catch (e) {
998
- // If there's any error in regex, return original text
999
899
  return text;
1000
900
  }
1001
901
  };
1002
-
1003
- // Update the renderItem function to use highlighting
1004
- var renderItem = function renderItem(item, query, index) {
1005
- // Convert raw data item to our format
1006
- var dataItem = prepareDataItem(item, index);
1007
-
1008
- // Get the display text
1009
- var displayText = typeof dataItem.displayValue === "string" ? _dompurify["default"].sanitize(dataItem.displayValue) : String(dataItem.label);
902
+ const renderItem = (item, query2, index) => {
903
+ const dataItem = prepareDataItem(item, index);
904
+ const displayText = typeof dataItem.displayValue === "string" ? DOMPurify.sanitize(dataItem.displayValue) : String(dataItem.label);
1010
905
  function handleClick(event) {
1011
906
  handleMenuItemClick(event, dataItem);
1012
907
  }
1013
- return __jsx(_MenuItem["default"], {
1014
- key: "item-".concat(index, "-").concat(dataItem.key),
1015
- onClick: handleClick,
1016
- "data-item": JSON.stringify(dataItem),
1017
- dense: true,
1018
- className: "search-dropdown-item wm-search-dropdown-item"
1019
- }, __jsx(_material.Box, {
1020
- component: "a",
1021
- className: "wm-search-item-link"
1022
- }, dataItem.displayImage && __jsx(_image["default"], {
1023
- src: dataItem.displayImage,
1024
- alt: "",
1025
- width: parseInt(imagewidth) || 16,
1026
- height: parseInt(imagewidth) || 16,
1027
- className: "wm-search-item-image"
1028
- }), __jsx(_material.Box, {
1029
- component: "span",
1030
- className: "",
1031
- title: displayText
1032
- }, getDisplayExpression ? highlightMatch(getDisplayExpression(getSelectedItem(item)), query) : highlightMatch(displayText, query))));
908
+ return /* @__PURE__ */ jsx(
909
+ MenuItem,
910
+ {
911
+ onClick: handleClick,
912
+ "data-item": JSON.stringify(dataItem),
913
+ dense: true,
914
+ className: "search-dropdown-item wm-search-dropdown-item",
915
+ children: /* @__PURE__ */ jsx(
916
+ Box,
917
+ {
918
+ component: "a",
919
+ className: clsx("wm-search-item-link", templateName && "customTemplate"),
920
+ children: templateName ? /* @__PURE__ */ jsx(Box, { component: "div", children: /* @__PURE__ */ jsx(
921
+ CustomTemplateCaption,
922
+ {
923
+ templateName,
924
+ item: dataItem,
925
+ index,
926
+ widgetName: name,
927
+ listener
928
+ }
929
+ ) }) : /* @__PURE__ */ jsxs(Fragment, { children: [
930
+ dataItem.displayImage && /* @__PURE__ */ jsx(
931
+ Image,
932
+ {
933
+ src: dataItem.displayImage,
934
+ alt: "",
935
+ width: parseInt(imagewidth) || 16,
936
+ height: parseInt(imagewidth) || 16,
937
+ className: "wm-search-item-image"
938
+ }
939
+ ),
940
+ /* @__PURE__ */ jsx(Box, { component: "span", className: "", title: displayText, children: getDisplayExpression ? highlightMatch(getDisplayExpression(getSelectedItem(item)), query2) : highlightMatch(displayText, query2) })
941
+ ] })
942
+ }
943
+ )
944
+ },
945
+ `item-${index}-${dataItem.key}`
946
+ );
1033
947
  };
1034
-
1035
- // Update renderItems to handle non-array cases
1036
- var renderItems = function renderItems() {
1037
- var itemCount = 0;
1038
-
1039
- // If we have grouped data, render by groups
948
+ const renderItems = () => {
949
+ let itemCount = 0;
1040
950
  if (props.groupby) {
1041
- var groupKeys = Object.keys(groupedData || {});
951
+ const groupKeys = Object.keys(groupedData || {});
1042
952
  if (groupKeys.length === 0) {
1043
953
  return null;
1044
954
  }
1045
- var renderedItems = [];
1046
- groupKeys.forEach(function (groupKey) {
1047
- // Add group divider if needed
1048
- var divider = renderGroupDivider(groupKey);
955
+ const renderedItems = [];
956
+ groupKeys.forEach((groupKey) => {
957
+ const divider = renderGroupDivider(groupKey);
1049
958
  if (divider) {
1050
959
  renderedItems.push(divider);
1051
960
  }
1052
-
1053
- // Add items for this group
1054
- var groupItems = (groupedData === null || groupedData === void 0 ? void 0 : groupedData[groupKey]) || [];
1055
- groupItems.forEach(function (item) {
961
+ const groupItems = (groupedData == null ? void 0 : groupedData[groupKey]) || [];
962
+ groupItems.forEach((item) => {
1056
963
  if (itemCount < limit) {
1057
964
  renderedItems.push(renderItem(item, query, itemCount));
1058
965
  itemCount++;
@@ -1061,197 +968,171 @@ var Search = /*#__PURE__*/_react["default"].forwardRef(function (props, ref) {
1061
968
  });
1062
969
  return renderedItems;
1063
970
  }
1064
-
1065
- // Ensure formattedDataset is an array before mapping
1066
- var formattedArray = Array.isArray(formattedDataset) ? formattedDataset : [];
1067
- return formattedArray.map(function (item, index) {
971
+ const formattedArray = Array.isArray(formattedDataset) ? formattedDataset : [];
972
+ return formattedArray.map((item, index) => {
1068
973
  return renderItem(item, query, index);
1069
- }).filter(Boolean); // Remove null values
974
+ }).filter(Boolean);
1070
975
  };
1071
- var renderClearButton = function renderClearButton() {
1072
- if (showclear && query !== "") {
1073
- return __jsx(_material.Button, {
1074
- className: (0, _clsx["default"])("btn btn-icon form-control-feedback clear-btn show-btn clear-btn", {
1075
- "show-btn": !!query
1076
- }),
1077
- "aria-label": "Clear",
1078
- onClick: handleClearSearch,
1079
- size: "small"
1080
- }, __jsx(_material.Box, {
1081
- component: "i",
1082
- className: "app-icon ".concat(clearsearchiconclass)
1083
- }));
976
+ const renderClearButton = () => /* @__PURE__ */ jsx(
977
+ Button,
978
+ {
979
+ type: "button",
980
+ className: clsx("btn btn-icon form-control-feedback clear-btn", {
981
+ "show-btn": !!query
982
+ }),
983
+ "aria-label": "Clear",
984
+ onClick: handleClearSearch,
985
+ size: "small",
986
+ children: /* @__PURE__ */ jsx(Box, { component: "i", className: `app-icon ${clearsearchiconclass}` })
1084
987
  }
1085
- return null;
1086
- };
1087
- var renderSearchIcon = function renderSearchIcon() {
988
+ );
989
+ const renderSearchIcon = () => {
1088
990
  if (showsearchicon) {
1089
- return __jsx(_material.Button, {
1090
- ref: searchButtonRef,
1091
- className: "app-search-button btn btn-icon",
1092
- title: "search",
1093
- type: "button",
1094
- onClick: handleSearchClick,
1095
- disabled: disabled,
1096
- size: "small"
1097
- }, __jsx(_material.Box, {
1098
- component: "i",
1099
- className: "app-icon ".concat(searchiconclass)
1100
- }));
991
+ return /* @__PURE__ */ jsx(
992
+ Button,
993
+ {
994
+ ref: searchButtonRef,
995
+ className: "app-search-button btn btn-icon",
996
+ title: "search",
997
+ type: "button",
998
+ onClick: handleSearchClick,
999
+ disabled,
1000
+ size: "small",
1001
+ children: /* @__PURE__ */ jsx(Box, { component: "i", className: `app-icon ${searchiconclass}` })
1002
+ }
1003
+ );
1101
1004
  }
1102
1005
  return null;
1103
1006
  };
1104
- var renderBackButton = function renderBackButton() {
1007
+ const renderBackButton = () => {
1105
1008
  if (showbackbutton && backsearchiconclass) {
1106
- return __jsx(_IconButton["default"], {
1107
- className: "back-btn",
1108
- "aria-label": "Back",
1109
- onClick: handleClearSearch,
1110
- size: "small"
1111
- }, __jsx(_material.Box, {
1112
- component: "span",
1113
- className: "app-icon ".concat(backsearchiconclass)
1114
- }), __jsx(_material.Box, {
1115
- component: "span",
1116
- className: "sr-only"
1117
- }, "Back button"));
1009
+ return /* @__PURE__ */ jsxs(IconButton, { className: "back-btn", "aria-label": "Back", onClick: handleClearSearch, size: "small", children: [
1010
+ /* @__PURE__ */ jsx(Box, { component: "span", className: `app-icon ${backsearchiconclass}` }),
1011
+ /* @__PURE__ */ jsx(Box, { component: "span", className: "sr-only", children: "Back button" })
1012
+ ] });
1118
1013
  }
1119
1014
  return null;
1120
1015
  };
1121
- var renderLoadingIndicator = function renderLoadingIndicator() {
1016
+ const renderLoadingIndicator = () => {
1122
1017
  if (loadingItems) {
1123
- return __jsx(_Typography["default"], {
1124
- variant: "body2",
1125
- className: "dropdown-status"
1126
- }, __jsx("span", {
1127
- className: "wm-search-loading-spinner"
1128
- }, __jsx(_CircularProgress["default"], {
1129
- size: 20,
1130
- color: "primary"
1131
- })), loadingdatamsg);
1018
+ return /* @__PURE__ */ jsxs(Typography, { variant: "body2", className: "dropdown-status", children: [
1019
+ /* @__PURE__ */ jsx("span", { className: "wm-search-loading-spinner", children: /* @__PURE__ */ jsx(CircularProgress, { size: 20, color: "primary" }) }),
1020
+ loadingdatamsg
1021
+ ] });
1132
1022
  }
1133
1023
  return null;
1134
1024
  };
1135
- var renderNoResultsMessage = function renderNoResultsMessage() {
1025
+ const renderNoResultsMessage = () => {
1136
1026
  if (!loadingItems && formattedDataset.length === 0 && query !== "" && !selectedItem) {
1137
- return __jsx(_Typography["default"], {
1138
- variant: "body2",
1139
- className: "dropdown-status wm-search-dropdown-message"
1140
- }, "No results found");
1027
+ return /* @__PURE__ */ jsx(Typography, { variant: "body2", className: "dropdown-status wm-search-dropdown-message", children: "No results found" });
1141
1028
  }
1142
1029
  return null;
1143
1030
  };
1144
- var renderCompletionMessage = function renderCompletionMessage() {
1145
- // Show "No more data to load" message when there are results but no more data to load
1031
+ const renderCompletionMessage = () => {
1146
1032
  if (!loadingItems && formattedDataset.length > 0 && !selectedItem) {
1147
- return __jsx(_Typography["default"], {
1148
- variant: "body2",
1149
- className: "dropdown-status wm-search-dropdown-completion"
1150
- }, datacompletemsg);
1033
+ return /* @__PURE__ */ jsx(Typography, { variant: "body2", className: "dropdown-status wm-search-dropdown-completion", children: datacompletemsg });
1151
1034
  }
1152
1035
  return null;
1153
1036
  };
1154
- var renderDropdown = function renderDropdown() {
1155
- var _searchRef$current;
1156
- // Don't show dropdown if an item is selected or if menu is not open
1037
+ const renderDropdown = () => {
1038
+ var _a2;
1157
1039
  if (!isOpen || !menuOpen || selectedItem) return null;
1158
- return __jsx(_Popper["default"], {
1159
- open: isOpen && menuOpen,
1160
- anchorEl: inputRef.current,
1161
- placement: dropup ? "top-start" : "bottom-start",
1162
- className: "wm-search-popper",
1163
- style: {
1164
- width: (_searchRef$current = searchRef.current) === null || _searchRef$current === void 0 ? void 0 : _searchRef$current.clientWidth
1040
+ return /* @__PURE__ */ jsx(
1041
+ Popper,
1042
+ {
1043
+ open: isOpen && menuOpen,
1044
+ anchorEl: inputRef.current,
1045
+ placement: dropup ? "top-start" : "bottom-start",
1046
+ className: "wm-search-popper",
1047
+ style: { width: (_a2 = searchRef.current) == null ? void 0 : _a2.clientWidth },
1048
+ children: /* @__PURE__ */ jsx(Paper, { elevation: 3, className: "search-dropdown-paper", children: /* @__PURE__ */ jsx(
1049
+ Box,
1050
+ {
1051
+ component: "div",
1052
+ ref: dropdownRef,
1053
+ onScroll: handleScroll,
1054
+ className: "search-dropdown-container wm-search-dropdown-scroll",
1055
+ children: /* @__PURE__ */ jsxs(MenuList, { className: "search-menu-list app-search dropdown-menu", ref: listRef, children: [
1056
+ renderItems(),
1057
+ renderNoResultsMessage(),
1058
+ renderLoadingIndicator(),
1059
+ renderCompletionMessage()
1060
+ ] })
1061
+ }
1062
+ ) })
1165
1063
  }
1166
- }, __jsx(_Paper["default"], {
1167
- elevation: 3,
1168
- className: "search-dropdown-paper"
1169
- }, __jsx(_material.Box, {
1170
- component: "div",
1171
- ref: dropdownRef,
1172
- onScroll: handleScroll,
1173
- className: "search-dropdown-container wm-search-dropdown-scroll"
1174
- }, __jsx(_MenuList["default"], {
1175
- className: "search-menu-list app-search dropdown-menu",
1176
- ref: listRef
1177
- }, renderItems(), renderNoResultsMessage(), renderLoadingIndicator(), renderCompletionMessage()))));
1064
+ );
1178
1065
  };
1179
-
1180
- // Only include safe props in restProps to avoid React warnings
1181
- var safeRestProps = Object.entries(restProps).reduce(function (acc, _ref5) {
1182
- var _ref6 = (0, _slicedToArray2["default"])(_ref5, 2),
1183
- key = _ref6[0],
1184
- value = _ref6[1];
1185
- // Filter out any props that might cause DOM warnings
1186
- var invalidProps = ["validation", "datasetItems", "selectedItems", "displayValue", "onchange", "onblur", "groupedData", "handleHeaderClick", "toggleAllHeaders", "isDestroyed"];
1187
- if (!invalidProps.includes(key)) {
1188
- acc[key] = value;
1189
- }
1190
- return acc;
1191
- }, {});
1192
- return __jsx(_ClickAwayListener["default"], {
1193
- onClickAway: handleClickAway
1194
- }, __jsx(_material.Box, (0, _extends2["default"])({
1195
- component: "div",
1196
- ref: searchRef,
1197
- style: searchStyle
1198
- // Don't pass tabIndex to div when it contains focusable elements
1199
- }, safeRestProps, {
1200
- className: (0, _clsx["default"])(DEFAULT_CLASS, className),
1201
- "data-search-type": type,
1202
- type: type,
1203
- "aria-readonly": readonly
1204
- }), renderBackButton(), __jsx(_material.Box, {
1205
- component: "span",
1206
- className: "sr-only"
1207
- }, "Back button"), __jsx(_material.Box, {
1208
- component: "input",
1209
- name: name,
1210
- className: (0, _clsx["default"])("app-textbox form-control list-of-objs app-search-input"),
1211
- type: "text",
1212
- "focus-target": "true",
1213
- value: query,
1214
- onChange: !readonly ? handleInputChange : undefined,
1215
- disabled: disabled,
1216
- tabIndex: tabindex,
1217
- ref: inputRef,
1218
- "aria-label": arialabel,
1219
- autoComplete: "off",
1220
- title: query,
1221
- placeholder: placeholder,
1222
- readOnly: readonly,
1223
- onBlur: function onBlur(e) {
1224
- return handleBlur(e);
1225
- },
1226
- onFocus: function onFocus(e) {
1227
- return handleFocus(e);
1066
+ const safeRestProps = Object.entries(restProps).reduce(
1067
+ (acc, [key, value2]) => {
1068
+ const invalidProps = [
1069
+ "validation",
1070
+ "datasetItems",
1071
+ "selectedItems",
1072
+ "displayValue",
1073
+ "onchange",
1074
+ "onblur",
1075
+ "groupedData",
1076
+ "handleHeaderClick",
1077
+ "toggleAllHeaders",
1078
+ "isDestroyed"
1079
+ ];
1080
+ if (!invalidProps.includes(key)) {
1081
+ acc[key] = value2;
1082
+ }
1083
+ return acc;
1228
1084
  },
1229
- onKeyDown: function onKeyDown(e) {
1230
- return handleKeyDown(e);
1231
- }
1232
- }), type === "autocomplete" ? null : __jsx(_material.Box, {
1233
- component: "span",
1234
- className: "input-group-addon"
1235
- }, __jsx(_material.Box, {
1236
- component: "form",
1237
- noValidate: true,
1238
- autoComplete: "off"
1239
- }, renderSearchIcon())), __jsx(_material.Box, {
1240
- component: "span",
1241
- className: "sr-only"
1242
- }, "Clear button"), showclear && showclear !== "false" ? renderClearButton() : null, renderDropdown()));
1085
+ {}
1086
+ );
1087
+ return /* @__PURE__ */ jsx(ClickAwayListener, { onClickAway: handleClickAway, children: /* @__PURE__ */ jsxs(
1088
+ Box,
1089
+ __spreadProps(__spreadValues({
1090
+ component: "div",
1091
+ ref: searchRef,
1092
+ style: searchStyle
1093
+ }, safeRestProps), {
1094
+ className: clsx(DEFAULT_CLASS, className),
1095
+ "data-search-type": type,
1096
+ type,
1097
+ "aria-readonly": readonly,
1098
+ children: [
1099
+ renderBackButton(),
1100
+ /* @__PURE__ */ jsx(Box, { component: "span", className: "sr-only", children: "Back button" }),
1101
+ /* @__PURE__ */ jsx(
1102
+ Box,
1103
+ {
1104
+ component: "input",
1105
+ name,
1106
+ className: clsx("app-textbox form-control list-of-objs app-search-input"),
1107
+ type: "text",
1108
+ "focus-target": "true",
1109
+ value: query,
1110
+ onChange: !readonly ? handleInputChange : void 0,
1111
+ disabled,
1112
+ tabIndex: tabindex,
1113
+ ref: inputRef,
1114
+ "aria-label": arialabel,
1115
+ autoComplete: "off",
1116
+ title: query,
1117
+ placeholder,
1118
+ readOnly: readonly,
1119
+ onBlur: (e) => handleBlur(e),
1120
+ onFocus: (e) => handleFocus(e),
1121
+ onKeyDown: (e) => handleKeyDown(e)
1122
+ }
1123
+ ),
1124
+ type === "autocomplete" ? null : /* @__PURE__ */ jsx(Box, { component: "span", className: "input-group-addon", children: /* @__PURE__ */ jsx(Box, { component: "form", noValidate: true, autoComplete: "off", children: renderSearchIcon() }) }),
1125
+ /* @__PURE__ */ jsx(Box, { component: "span", className: "sr-only", children: "Clear button" }),
1126
+ renderClearButton(),
1127
+ renderDropdown()
1128
+ ]
1129
+ })
1130
+ ) });
1243
1131
  });
1244
- var WmSearchStandalone = exports.WmSearch = (0, _withStandalone["default"])((0, _withFormController["default"])(Search));
1132
+ const WmSearchStandalone = withStandalone(withFormController(Search));
1245
1133
  Search.displayName = "WmSearch";
1246
-
1247
- /**
1248
- * The WmSearch component provides a search input with support for autocomplete,
1249
- * local and remote data filtering.
1250
- *
1251
- * - [Playground](https://react-components.wavemaker.ai/?path=/story/basic-search--showcase)
1252
- *
1253
- * - [Docs](https://react-components.wavemaker.ai/?path=/story/basic-search--docs)
1254
- *
1255
- * @param props - {@link WmSearchProps}
1256
- */
1257
- var _default = exports["default"] = (0, _withFormController["default"])((0, _withBaseWrapper["default"])(Search));
1134
+ var search_default = withFormController(withBaseWrapper(Search));
1135
+ export {
1136
+ WmSearchStandalone as WmSearch,
1137
+ search_default as default
1138
+ };