@wavemaker-ai/react-runtime 1.0.0-rc.647502 → 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,492 +1,437 @@
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.WmSelect = void 0;
9
- var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
10
- var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
11
- var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
12
- var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
13
- var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
14
- var _react = _interopRequireWildcard(require("react"));
15
- var _clsx = _interopRequireDefault(require("clsx"));
16
- var _NativeSelect = _interopRequireDefault(require("@mui/material/NativeSelect"));
17
- var _transformedDatasetUtils = require("@wavemaker-ai/react-runtime/utils/transformedDataset-utils");
18
- var _withBaseWrapper = require("@wavemaker-ai/react-runtime/higherOrder/withBaseWrapper");
19
- var _withFormController = _interopRequireDefault(require("@wavemaker-ai/react-runtime/components/data/form/form-controller/withFormController"));
20
- var _withStandalone = _interopRequireDefault(require("@wavemaker-ai/react-runtime/higherOrder/withStandalone"));
21
- 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); }
22
- var __jsx = _react["default"].createElement;
23
- 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; }
24
- 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; }
25
- var DEFAULT_CLASS = "app-select-wrapper ng-dirty";
26
- var WmSelect = /*#__PURE__*/_react["default"].memo(function (props) {
27
- var _ref2, _key;
28
- var autofocus = props.autofocus,
29
- className = props.className,
30
- _props$datafield = props.datafield,
31
- datafield = _props$datafield === void 0 ? "key" : _props$datafield,
32
- dataset = props.dataset,
33
- datavalue = props.datavalue,
34
- _props$disabled = props.disabled,
35
- disabled = _props$disabled === void 0 ? false : _props$disabled,
36
- displayExpression = props.displayExpression,
37
- displaylabel = props.displaylabel,
38
- _props$displayfield = props.displayfield,
39
- displayfield = _props$displayfield === void 0 ? "value" : _props$displayfield,
40
- groupby = props.groupby,
41
- hint = props.hint,
42
- dataPath = props.dataPath,
43
- arialabel = props.arialabel,
44
- _props$multiple = props.multiple,
45
- multiple = _props$multiple === void 0 ? false : _props$multiple,
46
- name = props.name,
47
- styles = props.styles,
48
- orderby = props.orderby,
49
- placeholder = props.placeholder,
50
- _props$readonly = props.readonly,
51
- readonly = _props$readonly === void 0 ? false : _props$readonly,
52
- _props$required = props.required,
53
- required = _props$required === void 0 ? false : _props$required,
54
- shortcutkey = props.shortcutkey,
55
- listener = props.listener,
56
- _props$tabindex = props.tabindex,
57
- tabindex = _props$tabindex === void 0 ? 0 : _props$tabindex,
58
- match = props.match,
59
- onClick = props.onClick,
60
- onChange = props.onChange,
61
- onBlur = props.onBlur,
62
- onFocus = props.onFocus,
63
- onKeyDown = props.onKeyDown,
64
- onEnter = props.onEnter,
65
- onMouseEnter = props.onMouseEnter,
66
- onMouseLeave = props.onMouseLeave,
67
- onKeyUp = props.onKeyUp;
68
- var selectRef = (0, _react.useRef)(null);
69
- var lastDatavalueRef = (0, _react.useRef)(datavalue);
70
- var externalDatavalueRef = (0, _react.useRef)(null);
71
- var _useState = (0, _react.useState)(""),
72
- displayValue = _useState[0],
73
- setDisplayValue = _useState[1];
74
- var _useState2 = (0, _react.useState)(multiple ? Array.isArray(datavalue) ? datavalue : datavalue ? [datavalue] : [] : datavalue),
75
- localDatavalue = _useState2[0],
76
- setLocalDatavalue = _useState2[1];
77
- var _useState3 = (0, _react.useState)(false),
78
- isTouched = _useState3[0],
79
- setIsTouched = _useState3[1];
80
- var _useState4 = (0, _react.useState)(false),
81
- showError = _useState4[0],
82
- setShowError = _useState4[1];
83
- var _useState5 = (0, _react.useState)(false),
84
- isDirty = _useState5[0],
85
- setIsDirty = _useState5[1];
86
- var _useState6 = (0, _react.useState)(datavalue),
87
- prevDatavalue = _useState6[0],
88
- setPrevDatavalue = _useState6[1];
89
- // Check if dataset is a function and call it to get the actual dataset value
90
- var resolvedDataset = typeof dataset === "function" ? dataset() : dataset;
91
- var transformedDataset = (0, _transformedDatasetUtils.transformDataset)(resolvedDataset, datafield, displayfield, displaylabel, displayExpression, orderby, groupby, dataPath, "", match);
92
- var validateInput = (0, _react.useCallback)(function (value) {
93
- // Handle special case value
94
- if (value === "") {
95
- return {
96
- isValid: !required,
97
- message: required ? "This field is required" : ""
98
- };
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]);
99
16
  }
100
- if (!value || !value.toString().trim()) {
101
- return {
102
- isValid: !required,
103
- message: required ? "This field is required" : ""
104
- };
105
- }
106
- return {
107
- isValid: true,
108
- message: ""
109
- };
110
- }, [required]);
111
-
112
- // Handle value change
113
- var handleValueChange = /*#__PURE__*/function () {
114
- var _ref = (0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee(event) {
115
- var _listener$Widgets, _transformedDataset;
116
- var newValue, filteredValues, selectedTexts, findItem, selectedValues, selectedDisplayValues, _event$target$options;
117
- return _regenerator["default"].wrap(function _callee$(_context) {
118
- while (1) switch (_context.prev = _context.next) {
119
- case 0:
120
- if (!(props.readonly || disabled)) {
121
- _context.next = 2;
122
- break;
123
- }
124
- return _context.abrupt("return");
125
- case 2:
126
- newValue = multiple ? Array.from(event.target.selectedOptions, function (option) {
127
- return option.value;
128
- }) : event.target.selectedIndex;
129
- if (!multiple) {
130
- _context.next = 20;
131
- break;
132
- }
133
- // Filter out placeholder value from multiple selection
134
- filteredValues = newValue.filter(function (val) {
135
- return val !== placeholder;
136
- });
137
- setLocalDatavalue(filteredValues);
138
- selectedTexts = Array.from(event.target.selectedOptions, function (option) {
139
- return option.text;
140
- }).filter(function (text) {
141
- return text !== placeholder;
142
- });
143
- setDisplayValue(selectedTexts.join(", "));
144
- if (!(listener !== null && listener !== void 0 && listener.onChange)) {
145
- _context.next = 18;
146
- break;
147
- }
148
- if (!(filteredValues.length === 0)) {
149
- _context.next = 14;
150
- break;
151
- }
152
- _context.next = 12;
153
- return listener.onChange(props.fieldName || name, {
17
+ return a;
18
+ };
19
+ var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
20
+ import { jsx, jsxs } from "react/jsx-runtime";
21
+ import React, { useCallback, useEffect, useMemo, useRef, useState } from "react";
22
+ import clsx from "clsx";
23
+ import NativeSelect from "@mui/material/NativeSelect";
24
+ import { transformDataset } from "../../../utils/transformedDataset-utils";
25
+ import { withBaseWrapper } from "../../../higherOrder/withBaseWrapper";
26
+ import withFormController from "../../data/form/form-controller/withFormController";
27
+ import withStandalone from "../../../higherOrder/withStandalone";
28
+ const DEFAULT_CLASS = "app-select-wrapper ng-dirty";
29
+ const WmSelect = React.memo(
30
+ (props) => {
31
+ var _a, _b;
32
+ const {
33
+ autofocus,
34
+ className,
35
+ datafield = "key",
36
+ dataset,
37
+ datavalue,
38
+ disabled = false,
39
+ displayExpression,
40
+ displaylabel,
41
+ displayfield = "value",
42
+ groupby,
43
+ hint,
44
+ dataPath,
45
+ arialabel,
46
+ multiple = false,
47
+ name,
48
+ styles,
49
+ orderby,
50
+ placeholder,
51
+ readonly = false,
52
+ required = false,
53
+ shortcutkey,
54
+ listener,
55
+ tabindex = 0,
56
+ match,
57
+ onClick,
58
+ onChange,
59
+ onBlur,
60
+ onFocus,
61
+ onKeyDown,
62
+ onEnter,
63
+ onMouseEnter,
64
+ onMouseLeave,
65
+ onKeyUp
66
+ } = props;
67
+ const selectRef = useRef(null);
68
+ const lastDatavalueRef = useRef(datavalue);
69
+ const externalDatavalueRef = useRef(null);
70
+ const [displayValue, setDisplayValue] = useState("");
71
+ const [localDatavalue, setLocalDatavalue] = useState(
72
+ multiple ? Array.isArray(datavalue) ? datavalue : datavalue ? [datavalue] : [] : datavalue
73
+ );
74
+ const [isTouched, setIsTouched] = useState(false);
75
+ const [showError, setShowError] = useState(false);
76
+ const [isDirty, setIsDirty] = useState(false);
77
+ const [prevDatavalue, setPrevDatavalue] = useState(datavalue);
78
+ const resolvedDataset = typeof dataset === "function" ? dataset() : dataset;
79
+ const transformedDataset = transformDataset(
80
+ resolvedDataset,
81
+ datafield,
82
+ displayfield,
83
+ displaylabel,
84
+ displayExpression,
85
+ orderby,
86
+ groupby,
87
+ dataPath,
88
+ "",
89
+ match
90
+ );
91
+ const validateInput = useCallback(
92
+ (value) => {
93
+ if (value === "") {
94
+ return { isValid: !required, message: required ? "This field is required" : "" };
95
+ }
96
+ if (!value || !value.toString().trim()) {
97
+ return { isValid: !required, message: required ? "This field is required" : "" };
98
+ }
99
+ return { isValid: true, message: "" };
100
+ },
101
+ [required]
102
+ );
103
+ const handleValueChange = async (event) => {
104
+ var _a2, _b2, _c;
105
+ if (props.readonly || disabled) {
106
+ return;
107
+ }
108
+ const newValue = multiple ? Array.from(event.target.selectedOptions, (option) => option.value) : event.target.selectedIndex;
109
+ if (multiple) {
110
+ const filteredValues = newValue.filter((val) => val !== placeholder);
111
+ setLocalDatavalue(filteredValues);
112
+ const selectedTexts = Array.from(
113
+ event.target.selectedOptions,
114
+ (option) => option.text
115
+ ).filter((text) => text !== placeholder);
116
+ setDisplayValue(selectedTexts.join(", "));
117
+ if (listener == null ? void 0 : listener.onChange) {
118
+ if (filteredValues.length === 0) {
119
+ await listener.onChange(props.fieldName || name, {
154
120
  datavalue: [],
155
121
  displayValue: []
156
122
  });
157
- case 12:
158
- _context.next = 18;
159
- break;
160
- case 14:
161
- findItem = function findItem(val) {
162
- return transformedDataset.find(function (item) {
163
- return (0, _typeof2["default"])(item.value) === "object" ? String(item.key) === String(val) : String(item.value) === String(val);
164
- });
165
- };
166
- selectedValues = filteredValues.map(function (val) {
167
- var item = findItem(val);
168
- return item ? item.value : val;
169
- });
170
- selectedDisplayValues = filteredValues.map(function (val) {
171
- var item = findItem(val);
172
- return item ? item.label : val;
173
- });
123
+ } else {
124
+ const findItem = (val) => transformedDataset.find(
125
+ (item) => typeof item.value === "object" ? String(item.key) === String(val) : String(item.value) === String(val)
126
+ );
127
+ const selectedValues = filteredValues.map(
128
+ (val) => {
129
+ const item = findItem(val);
130
+ return item ? item.value : val;
131
+ }
132
+ );
133
+ const selectedDisplayValues = filteredValues.map(
134
+ (val) => {
135
+ const item = findItem(val);
136
+ return item ? item.label : val;
137
+ }
138
+ );
174
139
  listener.onChange(props.fieldName || name, {
175
140
  datavalue: selectedValues,
176
141
  displayValue: selectedDisplayValues
177
142
  });
178
- case 18:
179
- _context.next = 30;
180
- break;
181
- case 20:
182
- setLocalDatavalue(event.target.value);
183
- setDisplayValue(((_event$target$options = event.target.options[event.target.selectedIndex]) === null || _event$target$options === void 0 ? void 0 : _event$target$options.text) || "");
184
- if (!(listener !== null && listener !== void 0 && listener.onChange)) {
185
- _context.next = 30;
186
- break;
187
- }
188
- if (!(newValue === 0 || event.target.value === placeholder)) {
189
- _context.next = 28;
190
- break;
191
- }
192
- _context.next = 26;
193
- return listener.onChange(props.fieldName || name, {
143
+ }
144
+ }
145
+ } else {
146
+ setLocalDatavalue(event.target.value);
147
+ setDisplayValue(((_a2 = event.target.options[event.target.selectedIndex]) == null ? void 0 : _a2.text) || "");
148
+ if (listener == null ? void 0 : listener.onChange) {
149
+ if (newValue === 0 || event.target.value === placeholder) {
150
+ await listener.onChange(props.fieldName || name, {
194
151
  datavalue: "",
195
152
  displayValue: ""
196
153
  });
197
- case 26:
198
- _context.next = 30;
199
- break;
200
- case 28:
201
- _context.next = 30;
202
- return listener.onChange(props.fieldName || name, {
154
+ } else {
155
+ await listener.onChange(props.fieldName || name, {
203
156
  datavalue: transformedDataset[newValue - 1].value,
204
157
  displayValue: transformedDataset[newValue - 1].label
205
158
  });
206
- case 30:
207
- if (onChange) onChange === null || onChange === void 0 || onChange(event, listener === null || listener === void 0 || (_listener$Widgets = listener.Widgets) === null || _listener$Widgets === void 0 ? void 0 : _listener$Widgets[name], (transformedDataset === null || transformedDataset === void 0 || (_transformedDataset = transformedDataset[newValue - 1]) === null || _transformedDataset === void 0 ? void 0 : _transformedDataset.value) || "en", prevDatavalue);
208
- setPrevDatavalue(newValue);
209
- case 32:
210
- case "end":
211
- return _context.stop();
159
+ }
212
160
  }
213
- }, _callee);
214
- }));
215
- return function handleValueChange(_x) {
216
- return _ref.apply(this, arguments);
161
+ }
162
+ if (onChange)
163
+ onChange == null ? void 0 : onChange(
164
+ event,
165
+ (_b2 = listener == null ? void 0 : listener.Widgets) == null ? void 0 : _b2[name],
166
+ ((_c = transformedDataset == null ? void 0 : transformedDataset[newValue - 1]) == null ? void 0 : _c.value) || "en",
167
+ prevDatavalue
168
+ );
169
+ setPrevDatavalue(newValue);
217
170
  };
218
- }();
219
- var handleBlur = function handleBlur(e) {
220
- var newValue = e.target.value;
221
- var selectedItem = transformedDataset.find(function (item) {
222
- return String(item.value) === newValue;
223
- });
224
- var validation = validateInput(selectedItem === null || selectedItem === void 0 ? void 0 : selectedItem.value);
225
- setIsTouched(true);
226
- if (!validation.isValid) {
227
- setIsDirty(true);
228
- } else {
229
- setIsDirty(false);
230
- }
231
- setShowError(!validation.isValid);
232
- onBlur === null || onBlur === void 0 || onBlur(e, props);
233
- };
234
-
235
- // Handle floating label behavior
236
- var handleFloatingLabel = (0, _react.useCallback)(function (event) {
237
- var _selectRef$current, _selectRef$current2, _selectRef$current3;
238
- var captionEl = (_selectRef$current = selectRef.current) === null || _selectRef$current === void 0 ? void 0 : _selectRef$current.closest(".app-composite-widget.caption-floating");
239
- if (!captionEl) return;
240
- var placeholderOption = (_selectRef$current2 = selectRef.current) === null || _selectRef$current2 === void 0 ? void 0 : _selectRef$current2.querySelector("#placeholderOption");
241
- if (!placeholderOption) return;
242
- if (event.type === "mousedown" && (!datavalue || datavalue && ((_selectRef$current3 = selectRef.current) === null || _selectRef$current3 === void 0 || (_selectRef$current3 = _selectRef$current3.querySelector("option:checked")) === null || _selectRef$current3 === void 0 ? void 0 : _selectRef$current3.textContent) === "")) {
243
- if (placeholder) {
244
- placeholderOption.textContent = placeholder;
171
+ const handleBlur = (e) => {
172
+ const newValue = e.target.value;
173
+ const selectedItem = transformedDataset.find((item) => String(item.value) === newValue);
174
+ const validation = validateInput(selectedItem == null ? void 0 : selectedItem.value);
175
+ setIsTouched(true);
176
+ if (!validation.isValid) {
177
+ setIsDirty(true);
178
+ } else {
179
+ setIsDirty(false);
180
+ }
181
+ setShowError(!validation.isValid);
182
+ onBlur == null ? void 0 : onBlur(e, props);
183
+ };
184
+ const handleFloatingLabel = useCallback(
185
+ (event) => {
186
+ var _a2, _b2, _c, _d;
187
+ const captionEl = (_a2 = selectRef.current) == null ? void 0 : _a2.closest(".app-composite-widget.caption-floating");
188
+ if (!captionEl) return;
189
+ const placeholderOption = (_b2 = selectRef.current) == null ? void 0 : _b2.querySelector("#placeholderOption");
190
+ if (!placeholderOption) return;
191
+ if (event.type === "mousedown" && (!datavalue || datavalue && ((_d = (_c = selectRef.current) == null ? void 0 : _c.querySelector("option:checked")) == null ? void 0 : _d.textContent) === "")) {
192
+ if (placeholder) {
193
+ placeholderOption.textContent = placeholder;
194
+ }
195
+ } else if (!datavalue) {
196
+ if (placeholder) {
197
+ placeholderOption.textContent = "";
198
+ }
199
+ captionEl.classList.remove("float-active");
200
+ }
201
+ },
202
+ [datavalue, placeholder]
203
+ );
204
+ const handleKeyDown = useCallback(
205
+ (event) => {
206
+ if (event.key === "Enter") {
207
+ onEnter == null ? void 0 : onEnter(event);
208
+ }
209
+ onKeyDown == null ? void 0 : onKeyDown(event);
210
+ },
211
+ [onEnter, onKeyDown]
212
+ );
213
+ useEffect(() => {
214
+ if (datavalue !== void 0) {
215
+ if (multiple) {
216
+ const normalizedValue = Array.isArray(datavalue) ? datavalue : datavalue ? [datavalue] : [];
217
+ const selectedOptions = normalizedValue.map(
218
+ (val) => transformedDataset.find((item) => String(item.value) === String(val))
219
+ );
220
+ const displayText = selectedOptions.map((option) => option == null ? void 0 : option.label).join(", ");
221
+ setDisplayValue(displayText);
222
+ } else {
223
+ const selectedOption = transformedDataset.find((item) => item.selected);
224
+ if (selectedOption) {
225
+ setDisplayValue(selectedOption.label);
226
+ }
227
+ }
245
228
  }
246
- } else if (!datavalue) {
247
- if (placeholder) {
248
- placeholderOption.textContent = "";
229
+ }, [transformedDataset, datavalue, multiple]);
230
+ useEffect(() => {
231
+ var _a2;
232
+ if (lastDatavalueRef.current !== datavalue) {
233
+ lastDatavalueRef.current = datavalue;
234
+ } else {
235
+ return;
249
236
  }
250
- captionEl.classList.remove("float-active");
251
- }
252
- }, [datavalue, placeholder]);
253
- var handleKeyDown = (0, _react.useCallback)(function (event) {
254
- if (event.key === "Enter") {
255
- onEnter === null || onEnter === void 0 || onEnter(event);
256
- }
257
- onKeyDown === null || onKeyDown === void 0 || onKeyDown(event);
258
- }, [onEnter, onKeyDown]);
259
- (0, _react.useEffect)(function () {
260
- if (datavalue !== undefined) {
261
237
  if (multiple) {
262
- var normalizedValue = Array.isArray(datavalue) ? datavalue : datavalue ? [datavalue] : [];
263
- var selectedOptions = normalizedValue.map(function (val) {
264
- return transformedDataset.find(function (item) {
265
- return String(item.value) === String(val);
266
- });
267
- });
268
- var displayText = selectedOptions.map(function (option) {
269
- return option === null || option === void 0 ? void 0 : option.label;
270
- }).join(", ");
271
- setDisplayValue(displayText);
238
+ const normalizedValue = Array.isArray(datavalue) ? datavalue : datavalue ? [datavalue] : [];
239
+ if (JSON.stringify(normalizedValue) !== JSON.stringify(localDatavalue)) {
240
+ setLocalDatavalue(normalizedValue);
241
+ }
272
242
  } else {
273
- var selectedOption = transformedDataset.find(function (item) {
274
- return item.selected;
275
- });
276
- if (selectedOption) {
277
- setDisplayValue(selectedOption.label);
243
+ if (datavalue !== localDatavalue) {
244
+ let computedDisplayValue = "";
245
+ if (typeof datavalue === "object" && datavalue !== null) {
246
+ const matchingItem = transformedDataset.find(
247
+ (item) => item.value === datavalue || JSON.stringify(item.value) === JSON.stringify(datavalue)
248
+ );
249
+ computedDisplayValue = (matchingItem == null ? void 0 : matchingItem.label) || "";
250
+ } else {
251
+ const matchingItem = transformedDataset.find((item) => item.value == datavalue);
252
+ computedDisplayValue = (matchingItem == null ? void 0 : matchingItem.label) || "";
253
+ }
254
+ externalDatavalueRef.current = datavalue;
255
+ setLocalDatavalue(datavalue);
256
+ (_a2 = listener == null ? void 0 : listener.onChange) == null ? void 0 : _a2.call(listener, props.fieldName || name, {
257
+ datavalue,
258
+ displayValue: computedDisplayValue
259
+ });
278
260
  }
279
261
  }
280
- }
281
- }, [transformedDataset, datavalue, multiple]);
282
- // Sync localDatavalue with incoming datavalue prop
283
- (0, _react.useEffect)(function () {
284
- if (lastDatavalueRef.current !== datavalue) {
285
- lastDatavalueRef.current = datavalue;
286
- } else {
287
- return;
288
- }
289
- if (multiple) {
290
- var normalizedValue = Array.isArray(datavalue) ? datavalue : datavalue ? [datavalue] : [];
291
- if (JSON.stringify(normalizedValue) !== JSON.stringify(localDatavalue)) {
292
- setLocalDatavalue(normalizedValue);
262
+ }, [datavalue, multiple, transformedDataset]);
263
+ const handleClick = useCallback(
264
+ (event) => {
265
+ onClick == null ? void 0 : onClick(event);
266
+ },
267
+ [onClick]
268
+ );
269
+ const handleFocus = useCallback(
270
+ (event) => {
271
+ onFocus == null ? void 0 : onFocus(event);
272
+ },
273
+ [onFocus]
274
+ );
275
+ const handleMouseEnter = useCallback(
276
+ (event) => {
277
+ onMouseEnter == null ? void 0 : onMouseEnter(event);
278
+ },
279
+ [onMouseEnter]
280
+ );
281
+ const handleMouseLeave = useCallback(
282
+ (event) => {
283
+ onMouseLeave == null ? void 0 : onMouseLeave(event);
284
+ },
285
+ [onMouseLeave]
286
+ );
287
+ const handleKeyUp = useCallback(
288
+ (event) => {
289
+ onKeyUp == null ? void 0 : onKeyUp(event);
290
+ },
291
+ [onKeyUp]
292
+ );
293
+ const events = __spreadValues(__spreadValues(__spreadValues(__spreadValues(__spreadValues(__spreadValues({
294
+ onChange: handleValueChange,
295
+ onBlur: (e) => {
296
+ handleFloatingLabel(e);
297
+ handleBlur(e);
293
298
  }
294
- } else {
295
- if (datavalue !== localDatavalue) {
296
- var _listener$onChange;
297
- // Compute displayValue for the external value
298
- var computedDisplayValue = "";
299
- if ((0, _typeof2["default"])(datavalue) === "object" && datavalue !== null) {
300
- var matchingItem = transformedDataset.find(function (item) {
301
- return item.value === datavalue || JSON.stringify(item.value) === JSON.stringify(datavalue);
302
- });
303
- computedDisplayValue = (matchingItem === null || matchingItem === void 0 ? void 0 : matchingItem.label) || "";
304
- } else {
305
- var _matchingItem = transformedDataset.find(function (item) {
306
- return item.value == datavalue;
307
- });
308
- computedDisplayValue = (_matchingItem === null || _matchingItem === void 0 ? void 0 : _matchingItem.label) || "";
299
+ }, onFocus ? { onFocus: handleFocus } : {}), onKeyDown ? { onKeyDown: handleKeyDown } : {}), onKeyUp ? { onKeyUp: handleKeyUp } : {}), onClick ? { onClick: handleClick } : {}), onMouseEnter ? { onMouseEnter: handleMouseEnter } : {}), onMouseLeave ? { onMouseLeave: handleMouseLeave } : {});
300
+ const computedSelectValue = useMemo(() => {
301
+ if (multiple) {
302
+ return Array.isArray(localDatavalue) ? localDatavalue : [];
303
+ }
304
+ if (typeof localDatavalue === "object" && localDatavalue !== null) {
305
+ const matchingItem2 = transformedDataset.find(
306
+ (item) => item.value === localDatavalue || JSON.stringify(item.value) === JSON.stringify(localDatavalue)
307
+ );
308
+ if (matchingItem2) {
309
+ return { key: matchingItem2.key, displayValue: matchingItem2.label };
309
310
  }
310
-
311
- // Store the DATAVALUE so listener useEffect can skip until localDatavalue matches
312
- externalDatavalueRef.current = datavalue;
313
- setLocalDatavalue(datavalue);
314
-
315
- // Call listener.onChange with BOTH datavalue and displayValue in a single call
316
- listener === null || listener === void 0 || (_listener$onChange = listener.onChange) === null || _listener$onChange === void 0 || _listener$onChange.call(listener, props.fieldName || name, {
317
- datavalue: datavalue,
318
- displayValue: computedDisplayValue
319
- });
320
311
  }
321
- }
322
- }, [datavalue, multiple, transformedDataset]);
323
- var handleClick = (0, _react.useCallback)(function (event) {
324
- onClick === null || onClick === void 0 || onClick(event);
325
- }, [onClick]);
326
- var handleFocus = (0, _react.useCallback)(function (event) {
327
- onFocus === null || onFocus === void 0 || onFocus(event);
328
- }, [onFocus]);
329
- var handleMouseEnter = (0, _react.useCallback)(function (event) {
330
- onMouseEnter === null || onMouseEnter === void 0 || onMouseEnter(event);
331
- }, [onMouseEnter]);
332
- var handleMouseLeave = (0, _react.useCallback)(function (event) {
333
- onMouseLeave === null || onMouseLeave === void 0 || onMouseLeave(event);
334
- }, [onMouseLeave]);
335
- var handleKeyUp = (0, _react.useCallback)(function (event) {
336
- onKeyUp === null || onKeyUp === void 0 || onKeyUp(event);
337
- }, [onKeyUp]);
338
- var events = _objectSpread(_objectSpread(_objectSpread(_objectSpread(_objectSpread(_objectSpread({
339
- onChange: handleValueChange,
340
- onBlur: function onBlur(e) {
341
- handleFloatingLabel(e);
342
- handleBlur(e);
343
- }
344
- }, onFocus ? {
345
- onFocus: handleFocus
346
- } : {}), onKeyDown ? {
347
- onKeyDown: handleKeyDown
348
- } : {}), onKeyUp ? {
349
- onKeyUp: handleKeyUp
350
- } : {}), onClick ? {
351
- onClick: handleClick
352
- } : {}), onMouseEnter ? {
353
- onMouseEnter: handleMouseEnter
354
- } : {}), onMouseLeave ? {
355
- onMouseLeave: handleMouseLeave
356
- } : {});
357
-
358
- // Memoize the computed select value to prevent re-renders
359
- var computedSelectValue = (0, _react.useMemo)(function () {
360
- if (multiple) {
361
- return Array.isArray(localDatavalue) ? localDatavalue : [];
362
- }
363
- if ((0, _typeof2["default"])(localDatavalue) === "object" && localDatavalue !== null) {
364
- var _matchingItem2 = transformedDataset.find(function (item) {
365
- return item.value === localDatavalue || JSON.stringify(item.value) === JSON.stringify(localDatavalue);
366
- });
367
- if (_matchingItem2) {
368
- return {
369
- key: _matchingItem2.key,
370
- displayValue: _matchingItem2.label
371
- };
312
+ const matchingItem = transformedDataset.find((item) => item.value == localDatavalue);
313
+ const displayLabel = (matchingItem == null ? void 0 : matchingItem.label) || "";
314
+ return { key: localDatavalue, displayValue: displayLabel };
315
+ }, [localDatavalue, transformedDataset, multiple]);
316
+ const prevComputedValueRef = useRef(null);
317
+ useEffect(() => {
318
+ var _a2;
319
+ if (multiple) return;
320
+ const currentValue = computedSelectValue;
321
+ const isExternalChange = externalDatavalueRef.current !== null && (localDatavalue === externalDatavalueRef.current || typeof localDatavalue === "object" && typeof externalDatavalueRef.current === "object" && JSON.stringify(localDatavalue) === JSON.stringify(externalDatavalueRef.current));
322
+ if (externalDatavalueRef.current !== null) {
323
+ if (isExternalChange) {
324
+ externalDatavalueRef.current = null;
325
+ }
326
+ prevComputedValueRef.current = currentValue;
327
+ return;
372
328
  }
373
- }
374
- var matchingItem = transformedDataset.find(function (item) {
375
- return item.value == localDatavalue;
376
- });
377
- var displayLabel = (matchingItem === null || matchingItem === void 0 ? void 0 : matchingItem.label) || "";
378
- return {
379
- key: localDatavalue,
380
- displayValue: displayLabel
381
- };
382
- }, [localDatavalue, transformedDataset, multiple]);
383
-
384
- // Track previous computed value to avoid unnecessary listener calls
385
- var prevComputedValueRef = (0, _react.useRef)(null);
386
-
387
- // Handle side effect (listener.onChange) in useEffect, not during render
388
- // This effect ONLY handles displayValue updates for INTERNAL state changes
389
- // External prop changes are handled in sync useEffect above
390
- (0, _react.useEffect)(function () {
391
- if (multiple) return;
392
- var currentValue = computedSelectValue;
393
-
394
- // Check if localDatavalue matches the external datavalue (final state reached)
395
- var isExternalChange = externalDatavalueRef.current !== null && (localDatavalue === externalDatavalueRef.current || (0, _typeof2["default"])(localDatavalue) === "object" && (0, _typeof2["default"])(externalDatavalueRef.current) === "object" && JSON.stringify(localDatavalue) === JSON.stringify(externalDatavalueRef.current));
396
-
397
- // Skip if we have a pending external change (already handled in sync useEffect)
398
- if (externalDatavalueRef.current !== null) {
399
- // Only clear when localDatavalue has been updated to match the external value
400
- if (isExternalChange) {
401
- externalDatavalueRef.current = null;
329
+ const prevValue = prevComputedValueRef.current;
330
+ if (currentValue.displayValue && (!prevValue || prevValue.key !== currentValue.key || prevValue.displayValue !== currentValue.displayValue)) {
331
+ (_a2 = listener == null ? void 0 : listener.onChange) == null ? void 0 : _a2.call(listener, props.fieldName || name, {
332
+ displayValue: currentValue.displayValue
333
+ });
402
334
  }
403
335
  prevComputedValueRef.current = currentValue;
404
- return;
405
- }
406
- var prevValue = prevComputedValueRef.current;
407
-
408
- // Only call listener if the computed value actually changed
409
- if (currentValue.displayValue && (!prevValue || prevValue.key !== currentValue.key || prevValue.displayValue !== currentValue.displayValue)) {
410
- var _listener$onChange2;
411
- listener === null || listener === void 0 || (_listener$onChange2 = listener.onChange) === null || _listener$onChange2 === void 0 || _listener$onChange2.call(listener, props.fieldName || name, {
412
- displayValue: currentValue.displayValue
413
- });
414
- }
415
- prevComputedValueRef.current = currentValue;
416
- }, [computedSelectValue, multiple, listener, props.fieldName, name, localDatavalue]);
417
- return __jsx("div", {
418
- className: (0, _clsx["default"])(DEFAULT_CLASS, className)
419
- }, __jsx(_NativeSelect["default"], (0, _extends2["default"])({
420
- key: name,
421
- hidden: props.hidden,
422
- name: name,
423
- IconComponent: function IconComponent() {
424
- return null;
425
- },
426
- className: (0, _clsx["default"])(isTouched ? "ng-touched" : "ng-untouched", isDirty ? "ng-invalid" : "ng-valid", className, "wm-native-select-root"),
427
- value: multiple ? computedSelectValue : (_ref2 = (_key = computedSelectValue.key) !== null && _key !== void 0 ? _key : placeholder) !== null && _ref2 !== void 0 ? _ref2 : ""
428
- }, events, {
429
- sx: {
430
- "& .MuiNativeSelect-select": {
431
- WebkitAppearance: (styles === null || styles === void 0 ? void 0 : styles.WebkitAppearance) || "auto"
432
- },
433
- "& .MuiNativeSelect-icon": {
434
- display: "none"
435
- }
436
- },
437
- inputProps: {
438
- id: name,
439
- name: name,
440
- required: required,
441
- autoFocus: autofocus,
442
- tabIndex: tabindex,
443
- "aria-label": arialabel,
444
- multiple: multiple,
445
- disabled: disabled,
446
- "aria-readonly": readonly,
447
- className: "app-select ".concat(className, " ").concat(DEFAULT_CLASS, " form-control ng-valid ng-touched ng-dirty wm-app "),
448
- accessKey: shortcutkey,
449
- title: hint,
450
- style: styles
451
- },
452
- readOnly: readonly
453
- }), __jsx("option", {
454
- value: placeholder,
455
- id: "placeholderOption",
456
- key: "placeholder-text",
457
- hidden: !placeholder
458
- }, placeholder), groupby && transformedDataset ? transformedDataset.map(function (group) {
459
- return __jsx("optgroup", {
460
- key: group.key,
461
- label: group.key
462
- }, group.data.map(function (item) {
463
- return __jsx("option", {
464
- key: "".concat(group.key, "-").concat(item.key),
465
- value: (0, _typeof2["default"])(item.value) === "object" ? item.key : item.value
466
- }, item.label);
467
- }));
468
- }) : transformedDataset && transformedDataset.map(function (item) {
469
- return __jsx("option", {
470
- key: item.key,
471
- value: (0, _typeof2["default"])(item.value) === "object" ? item.key : item.value
472
- }, item.label);
473
- })));
474
- }, function (prevProps, nextProps) {
475
- var keys = ["dataset", "datafield", "displayfield", "displaylabel", "displayExpression", "orderby", "groupby", "dataPath", "arialabel", "multiple", "styles", "autofocus", "disabled", "readonly", "required", "datavalue", "hidden", "className"];
476
- return keys.every(function (key) {
477
- return prevProps[key] === nextProps[key];
478
- });
479
- });
336
+ }, [computedSelectValue, multiple, listener, props.fieldName, name, localDatavalue]);
337
+ return /* @__PURE__ */ jsx("div", { className: clsx(DEFAULT_CLASS, className), children: /* @__PURE__ */ jsxs(
338
+ NativeSelect,
339
+ __spreadProps(__spreadValues({
340
+ hidden: props.hidden,
341
+ name,
342
+ IconComponent: () => null,
343
+ className: clsx(
344
+ isTouched ? "ng-touched" : "ng-untouched",
345
+ isDirty ? "ng-invalid" : "ng-valid",
346
+ className,
347
+ "wm-native-select-root"
348
+ ),
349
+ value: multiple ? computedSelectValue : (_b = (_a = computedSelectValue.key) != null ? _a : placeholder) != null ? _b : ""
350
+ }, events), {
351
+ sx: {
352
+ "& .MuiNativeSelect-select": {
353
+ WebkitAppearance: (styles == null ? void 0 : styles.WebkitAppearance) || "auto"
354
+ },
355
+ "& .MuiNativeSelect-icon": {
356
+ display: "none"
357
+ }
358
+ },
359
+ inputProps: {
360
+ id: name,
361
+ name,
362
+ required,
363
+ autoFocus: autofocus,
364
+ tabIndex: tabindex,
365
+ "aria-label": arialabel,
366
+ multiple,
367
+ disabled,
368
+ "aria-readonly": readonly,
369
+ className: `app-select ${className} ${DEFAULT_CLASS} form-control ng-valid ng-touched ng-dirty wm-app `,
370
+ accessKey: shortcutkey,
371
+ title: hint,
372
+ style: styles
373
+ },
374
+ readOnly: readonly,
375
+ children: [
376
+ /* @__PURE__ */ jsx(
377
+ "option",
378
+ {
379
+ value: placeholder,
380
+ id: "placeholderOption",
381
+ hidden: !placeholder,
382
+ children: placeholder
383
+ },
384
+ "placeholder-text"
385
+ ),
386
+ groupby && transformedDataset ? transformedDataset.map((group) => /* @__PURE__ */ jsx("optgroup", { label: group.key, children: group.data.map((item) => /* @__PURE__ */ jsx(
387
+ "option",
388
+ {
389
+ value: typeof item.value === "object" ? item.key : item.value,
390
+ children: item.label
391
+ },
392
+ `${group.key}-${item.key}`
393
+ )) }, group.key)) : transformedDataset && transformedDataset.map((item) => /* @__PURE__ */ jsx(
394
+ "option",
395
+ {
396
+ value: typeof item.value === "object" ? item.key : item.value,
397
+ children: item.label
398
+ },
399
+ item.key
400
+ ))
401
+ ]
402
+ }),
403
+ name
404
+ ) });
405
+ },
406
+ (prevProps, nextProps) => {
407
+ const keys = [
408
+ "dataset",
409
+ "datafield",
410
+ "displayfield",
411
+ "displaylabel",
412
+ "displayExpression",
413
+ "orderby",
414
+ "groupby",
415
+ "dataPath",
416
+ "arialabel",
417
+ "multiple",
418
+ "styles",
419
+ "autofocus",
420
+ "disabled",
421
+ "readonly",
422
+ "required",
423
+ "datavalue",
424
+ "hidden",
425
+ "className"
426
+ ];
427
+ return keys.every((key) => prevProps[key] === nextProps[key]);
428
+ }
429
+ );
480
430
  WmSelect.displayName = "WmSelect";
481
- var WithForm = (0, _withFormController["default"])(WmSelect);
482
- var WmSelectStandalone = exports.WmSelect = (0, _withStandalone["default"])(WithForm);
483
- /**
484
- * The WmSelect component provides a dropdown select input with single and multi-select support.
485
- *
486
- * - [Playground](https://react-components.wavemaker.ai/?path=/story/input-select--showcase)
487
- *
488
- * - [Docs](https://react-components.wavemaker.ai/?path=/story/input-select--docs)
489
- *
490
- * @param props - {@link WmSelectProps}
491
- */
492
- var _default = exports["default"] = (0, _withBaseWrapper.withBaseWrapper)(WithForm);
431
+ const WithForm = withFormController(WmSelect);
432
+ const WmSelectStandalone = withStandalone(WithForm);
433
+ var select_default = withBaseWrapper(WithForm);
434
+ export {
435
+ WmSelectStandalone as WmSelect,
436
+ select_default as default
437
+ };