@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,29 +1,54 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
- var _typeof = require("@babel/runtime/helpers/typeof");
5
- Object.defineProperty(exports, "__esModule", {
6
- value: true
7
- });
8
- exports["default"] = exports.WmSwitch = void 0;
9
- var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
10
- var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
11
- var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
12
- var _react = _interopRequireWildcard(require("react"));
13
- var _lodashEs = require("lodash-es");
14
- var _withBaseWrapper = require("@wavemaker-ai/react-runtime/higherOrder/withBaseWrapper");
15
- var _Box = _interopRequireDefault(require("@mui/material/Box"));
16
- var _material = require("@mui/material");
17
- var _transformedDatasetUtils = require("@wavemaker-ai/react-runtime/utils/transformedDataset-utils");
18
- var _withFormController = _interopRequireDefault(require("@wavemaker-ai/react-runtime/components/data/form/form-controller/withFormController"));
19
- var _withStandalone = _interopRequireDefault(require("@wavemaker-ai/react-runtime/higherOrder/withStandalone"));
20
- var _excluded = ["dataset", "datasetItems", "multiple", "disabled", "required", "name", "hint", "iconclass", "checkediconclass", "displayfield", "datafield", "value", "onChange", "onClick", "onMouseEnter", "onMouseLeave", "onBlur", "compareby", "toBeProcessedValue", "show", "tabindex", "arialabel", "className", "datavalue", "displayExpression", "orderby", "displayValue", "listener", "styles", "dataPath", "hidden", "fieldName"];
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" != _typeof(e) && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (var _t2 in e) "default" !== _t2 && {}.hasOwnProperty.call(e, _t2) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, _t2)) && (i.get || i.set) ? o(f, _t2, i) : f[_t2] = e[_t2]); return f; })(e, t); }
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_CLS = "app-switch";
26
- var defaultProps = {
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 { jsx, jsxs } from "react/jsx-runtime";
33
+ import {
34
+ useEffect,
35
+ useRef,
36
+ useState,
37
+ useCallback,
38
+ memo,
39
+ useMemo
40
+ } from "react";
41
+ import { find, findIndex, forEach, toString } from "lodash-es";
42
+ import {
43
+ withBaseWrapper
44
+ } from "../../../../higherOrder/withBaseWrapper";
45
+ import Box from "@mui/material/Box";
46
+ import { InputBase } from "@mui/material";
47
+ import { transformDataset } from "../../../../utils/transformedDataset-utils";
48
+ import withFormController from "../../../data/form/form-controller/withFormController";
49
+ import withStandalone from "../../../../higherOrder/withStandalone";
50
+ const DEFAULT_CLS = "app-switch";
51
+ const defaultProps = {
27
52
  show: true,
28
53
  tabindex: 0,
29
54
  checkediconclass: "",
@@ -35,485 +60,496 @@ var defaultProps = {
35
60
  acceptsArray: false,
36
61
  dataset: "yes, no, maybe"
37
62
  };
38
- var useSwitch = function useSwitch(props) {
39
- var _props$dataset = props.dataset,
40
- dataset = _props$dataset === void 0 ? defaultProps.dataset : _props$dataset,
41
- propDatasetItems = props.datasetItems,
42
- _props$multiple = props.multiple,
43
- multiple = _props$multiple === void 0 ? defaultProps.multiple : _props$multiple,
44
- value = props.value,
45
- toBeProcessedValue = props.toBeProcessedValue,
46
- onChange = props.onChange,
47
- onClick = props.onClick,
48
- onMouseEnter = props.onMouseEnter,
49
- onMouseLeave = props.onMouseLeave,
50
- onBlur = props.onBlur,
51
- _props$disabled = props.disabled,
52
- disabled = _props$disabled === void 0 ? defaultProps.disabled : _props$disabled,
53
- compareby = props.compareby,
54
- datafield = props.datafield,
55
- _props$allowempty = props.allowempty,
56
- allowempty = _props$allowempty === void 0 ? defaultProps.allowempty : _props$allowempty,
57
- _props$acceptsArray = props.acceptsArray,
58
- acceptsArray = _props$acceptsArray === void 0 ? defaultProps.acceptsArray : _props$acceptsArray,
59
- datavalue = props.datavalue,
60
- listener = props.listener,
61
- displayfield = props.displayfield,
62
- orderby = props.orderby,
63
- displayExpression = props.displayExpression,
64
- name = props.name,
65
- dataPath = props.dataPath;
66
-
67
- // Consolidated dataset transformation - handles both initial value and updates
68
- var transformedDataset = (0, _react.useMemo)(function () {
69
- if (propDatasetItems !== null && propDatasetItems !== void 0 && propDatasetItems.length) return propDatasetItems;
70
- // Check if dataset is a function and call it to get the actual dataset value
71
- var resolvedDataset = typeof dataset === "function" ? dataset() : dataset;
72
- return (0, _transformedDatasetUtils.transformDataset)(resolvedDataset, datafield, displayfield, undefined, displayExpression, orderby, null, dataPath);
63
+ const useSwitch = (props) => {
64
+ const {
65
+ dataset = defaultProps.dataset,
66
+ datasetItems: propDatasetItems,
67
+ multiple = defaultProps.multiple,
68
+ value,
69
+ toBeProcessedValue,
70
+ onChange,
71
+ onClick,
72
+ onMouseEnter,
73
+ onMouseLeave,
74
+ onBlur,
75
+ disabled = defaultProps.disabled,
76
+ compareby,
77
+ datafield,
78
+ allowempty = defaultProps.allowempty,
79
+ acceptsArray = defaultProps.acceptsArray,
80
+ datavalue,
81
+ listener,
82
+ displayfield,
83
+ orderby,
84
+ displayExpression,
85
+ name,
86
+ dataPath
87
+ } = props;
88
+ const transformedDataset = useMemo(() => {
89
+ if (propDatasetItems == null ? void 0 : propDatasetItems.length) return propDatasetItems;
90
+ const resolvedDataset = typeof dataset === "function" ? dataset() : dataset;
91
+ return transformDataset(
92
+ resolvedDataset,
93
+ datafield,
94
+ displayfield,
95
+ void 0,
96
+ displayExpression,
97
+ orderby,
98
+ null,
99
+ dataPath
100
+ );
73
101
  }, [dataset, datafield, displayfield, displayExpression, orderby, propDatasetItems]);
74
- var _useState = (0, _react.useState)(transformedDataset),
75
- datasetItems = _useState[0],
76
- setDatasetItems = _useState[1];
77
- var _useState2 = (0, _react.useState)(null),
78
- selectedItem = _useState2[0],
79
- setSelectedItem = _useState2[1];
80
- var _useState3 = (0, _react.useState)(null),
81
- modelByValue = _useState3[0],
82
- setModelByValue = _useState3[1];
83
- var _useState4 = (0, _react.useState)(null),
84
- modelByKey = _useState4[0],
85
- setModelByKey = _useState4[1];
86
- var _useState5 = (0, _react.useState)(""),
87
- CHDisplayValue = _useState5[0],
88
- setDisplayValue = _useState5[1];
89
- var switchRef = (0, _react.useRef)(null);
90
- var overlayRef = (0, _react.useRef)(null);
91
-
92
- // This flag helps us distinguish between programmatic updates and user clicks
93
- var _useState6 = (0, _react.useState)(false),
94
- isUserInteraction = _useState6[0],
95
- setIsUserInteraction = _useState6[1];
96
- var btnWidth = (0, _react.useMemo)(function () {
97
- return datasetItems !== null && datasetItems !== void 0 && datasetItems.length && !multiple ? 100 / datasetItems.length : 0;
98
- }, [datasetItems === null || datasetItems === void 0 ? void 0 : datasetItems.length, multiple]);
99
- var updateHighlighter = (0, _react.useCallback)(function () {
100
- var skipAnimation = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;
101
- if (!overlayRef.current || !switchRef.current) return;
102
- var index = selectedItem ? (0, _lodashEs.findIndex)(datasetItems, {
103
- key: selectedItem.key
104
- }) : -1;
105
- if (index === -1) return;
106
- var left = index * btnWidth;
107
- if (skipAnimation) {
108
- overlayRef.current.style.left = "".concat(left, "%");
109
- } else {
110
- overlayRef.current.style.left = "".concat(left, "%");
111
- }
112
- }, [btnWidth, datasetItems, selectedItem]);
113
- (0, _react.useEffect)(function () {
102
+ const [datasetItems, setDatasetItems] = useState(
103
+ transformedDataset
104
+ );
105
+ const [selectedItem, setSelectedItem] = useState(null);
106
+ const [modelByValue, setModelByValue] = useState(null);
107
+ const [modelByKey, setModelByKey] = useState(null);
108
+ const [CHDisplayValue, setDisplayValue] = useState("");
109
+ const switchRef = useRef(null);
110
+ const overlayRef = useRef(null);
111
+ const [isUserInteraction, setIsUserInteraction] = useState(false);
112
+ const btnWidth = useMemo(() => {
113
+ return (datasetItems == null ? void 0 : datasetItems.length) && !multiple ? 100 / datasetItems.length : 0;
114
+ }, [datasetItems == null ? void 0 : datasetItems.length, multiple]);
115
+ const updateHighlighter = useCallback(
116
+ (skipAnimation = false) => {
117
+ if (!overlayRef.current || !switchRef.current) return;
118
+ const index = selectedItem ? findIndex(datasetItems, { key: selectedItem.key }) : -1;
119
+ if (index === -1) return;
120
+ const left = index * btnWidth;
121
+ if (skipAnimation) {
122
+ overlayRef.current.style.left = `${left}%`;
123
+ } else {
124
+ overlayRef.current.style.left = `${left}%`;
125
+ }
126
+ },
127
+ [btnWidth, datasetItems, selectedItem]
128
+ );
129
+ useEffect(() => {
114
130
  if (overlayRef.current && btnWidth > 0) {
115
- overlayRef.current.style.width = "".concat(btnWidth, "%");
131
+ overlayRef.current.style.width = `${btnWidth}%`;
116
132
  }
117
133
  }, [btnWidth]);
118
-
119
- // Update datasetItems when transformedDataset changes
120
- (0, _react.useEffect)(function () {
121
- setDatasetItems(function (prevItems) {
122
- // Only update if actually different
134
+ useEffect(() => {
135
+ setDatasetItems((prevItems) => {
123
136
  if (JSON.stringify(prevItems) !== JSON.stringify(transformedDataset)) {
124
137
  return transformedDataset;
125
138
  }
126
139
  return prevItems;
127
140
  });
128
141
  }, [transformedDataset]);
129
-
130
- // This is the key fix: we only run the value update logic when it's NOT a user interaction
131
- // This prevents the useEffect from overriding user clicks
132
- var onValueUpdateFn = (0, _react.useCallback)(function () {
142
+ const onValueUpdateFn = useCallback(() => {
133
143
  if (isUserInteraction) {
134
- return; // Don't override user interactions
144
+ return;
135
145
  }
136
- if (value !== undefined || toBeProcessedValue !== undefined || datavalue !== undefined) {
137
- var selected = (0, _lodashEs.find)(datasetItems, function (item) {
138
- return item.value === (value || toBeProcessedValue || datavalue) || (0, _lodashEs.toString)(item.key) === (0, _lodashEs.toString)(value || toBeProcessedValue || datavalue);
139
- });
146
+ if (value !== void 0 || toBeProcessedValue !== void 0 || datavalue !== void 0) {
147
+ const selected = find(
148
+ datasetItems,
149
+ (item) => item.value === (value || toBeProcessedValue || datavalue) || toString(item.key) === toString(value || toBeProcessedValue || datavalue)
150
+ );
140
151
  if (selected) {
141
- var updatedItems = datasetItems.map(function (item) {
142
- return _objectSpread(_objectSpread({}, item), {}, {
143
- selected: (0, _lodashEs.toString)(item.key) === (0, _lodashEs.toString)(selected.key)
144
- });
145
- });
152
+ const updatedItems = datasetItems.map((item) => __spreadProps(__spreadValues({}, item), {
153
+ selected: toString(item.key) === toString(selected.key)
154
+ }));
146
155
  setDatasetItems(updatedItems);
147
156
  setSelectedItem(selected);
148
157
  setModelByKey(selected.key);
149
158
  setModelByValue(selected.value);
150
159
  }
151
- } else if ((datasetItems === null || datasetItems === void 0 ? void 0 : datasetItems.length) > 0 && !selectedItem && datavalue) {
152
- var firstItem = datasetItems[0];
153
- var _updatedItems = datasetItems.map(function (item, idx) {
154
- return _objectSpread(_objectSpread({}, item), {}, {
155
- selected: idx === 0
156
- });
157
- });
158
- setDatasetItems(_updatedItems);
160
+ } else if ((datasetItems == null ? void 0 : datasetItems.length) > 0 && !selectedItem && datavalue) {
161
+ const firstItem = datasetItems[0];
162
+ const updatedItems = datasetItems.map((item, idx) => __spreadProps(__spreadValues({}, item), {
163
+ selected: idx === 0
164
+ }));
165
+ setDatasetItems(updatedItems);
159
166
  setSelectedItem(firstItem);
160
167
  setModelByKey(firstItem.key);
161
168
  setModelByValue(firstItem.value);
162
- } else if ((datasetItems === null || datasetItems === void 0 ? void 0 : datasetItems.length) > 0 && datavalue === undefined && selectedItem) {
163
- var _updatedItems2 = datasetItems.map(function (item) {
164
- return _objectSpread(_objectSpread({}, item), {}, {
165
- selected: false
166
- });
167
- });
168
- setDatasetItems(_updatedItems2);
169
+ } else if ((datasetItems == null ? void 0 : datasetItems.length) > 0 && datavalue === void 0 && selectedItem) {
170
+ const updatedItems = datasetItems.map((item) => __spreadProps(__spreadValues({}, item), {
171
+ selected: false
172
+ }));
173
+ setDatasetItems(updatedItems);
169
174
  setSelectedItem(null);
170
175
  setModelByKey(null);
171
176
  setModelByValue(null);
172
177
  }
173
178
  }, [datasetItems, value, toBeProcessedValue, datavalue, selectedItem, isUserInteraction]);
174
- (0, _react.useEffect)(function () {
179
+ useEffect(() => {
175
180
  onValueUpdateFn();
176
- }, [value, toBeProcessedValue, datavalue, datasetItems === null || datasetItems === void 0 ? void 0 : datasetItems.length]);
177
- (0, _react.useEffect)(function () {
181
+ }, [value, toBeProcessedValue, datavalue, datasetItems == null ? void 0 : datasetItems.length]);
182
+ useEffect(() => {
178
183
  if (selectedItem) {
179
184
  updateHighlighter(true);
180
185
  }
181
186
  }, [selectedItem, updateHighlighter]);
182
- var selectOpt = (0, _react.useCallback)(function (event, index, option) {
183
- event.preventDefault();
184
- if (disabled) return;
185
- var selectedValue = {
186
- datavalue: props.datavalue,
187
- displayValue: props.displayValue
188
- };
189
-
190
- // Mark this as a user interaction to prevent useEffect interference
191
- setIsUserInteraction(true);
192
- if (multiple) {
193
- var updatedItems = datasetItems.map(function (item, idx) {
194
- return _objectSpread(_objectSpread({}, item), {}, {
187
+ const selectOpt = useCallback(
188
+ (event, index, option) => {
189
+ event.preventDefault();
190
+ if (disabled) return;
191
+ const selectedValue = {
192
+ datavalue: props.datavalue,
193
+ displayValue: props.displayValue
194
+ };
195
+ setIsUserInteraction(true);
196
+ if (multiple) {
197
+ const updatedItems = datasetItems.map((item, idx) => __spreadProps(__spreadValues({}, item), {
195
198
  selected: idx === index ? !item.selected : item.selected
199
+ }));
200
+ const keys = [];
201
+ forEach(updatedItems, (item) => {
202
+ if (item.selected) {
203
+ keys.push(item.key);
204
+ }
196
205
  });
197
- });
198
- var keys = [];
199
- (0, _lodashEs.forEach)(updatedItems, function (item) {
200
- if (item.selected) {
201
- keys.push(item.key);
202
- }
203
- });
204
-
205
- // Use a single state update to avoid conflicts
206
- setDatasetItems(updatedItems);
207
- setModelByKey(keys);
208
- setModelByValue(keys.map(function (key) {
209
- var _find;
210
- return (_find = (0, _lodashEs.find)(updatedItems, {
211
- key: key
212
- })) === null || _find === void 0 ? void 0 : _find.value;
213
- }));
214
- setSelectedItem((0, _lodashEs.find)(updatedItems, {
215
- selected: true
216
- }) || null);
217
- var datavalueArray = keys.map(function (key) {
218
- var _find2;
219
- return (_find2 = (0, _lodashEs.find)(updatedItems, {
220
- key: key
221
- })) === null || _find2 === void 0 ? void 0 : _find2.value;
222
- });
223
- var displayValueArray = keys.map(function (key) {
224
- var _find3;
225
- return (_find3 = (0, _lodashEs.find)(updatedItems, {
226
- key: key
227
- })) === null || _find3 === void 0 ? void 0 : _find3.label;
228
- });
229
- selectedValue.datavalue = datavalueArray;
230
- selectedValue.displayValue = displayValueArray;
231
- if (listener !== null && listener !== void 0 && listener.onChange) {
232
- listener.onChange(name, _objectSpread(_objectSpread({}, props), {}, {
233
- datavalue: datavalueArray,
234
- displayValue: displayValueArray
206
+ setDatasetItems(updatedItems);
207
+ setModelByKey(keys);
208
+ setModelByValue(keys.map((key) => {
209
+ var _a;
210
+ return (_a = find(updatedItems, { key })) == null ? void 0 : _a.value;
235
211
  }));
236
- }
237
- if (onChange) {
238
- onChange(event, listener === null || listener === void 0 ? void 0 : listener.Widgets[name], keys.map(function (key) {
239
- var _find4;
240
- return (_find4 = (0, _lodashEs.find)(updatedItems, {
241
- key: key
242
- })) === null || _find4 === void 0 ? void 0 : _find4.value;
243
- }), keys);
244
- }
245
- } else {
246
- // Handle single selection logic - clicking already-selected option keeps it selected
247
- var targetIndex = index;
248
- if (!multiple && selectedItem && index === (0, _lodashEs.findIndex)(datasetItems, {
249
- key: selectedItem.key
250
- })) {
251
- // No change when user clicks the already-selected option
252
- setIsUserInteraction(false);
253
- return;
254
- }
255
- var _updatedItems3 = (0, _toConsumableArray2["default"])(datasetItems);
256
- _updatedItems3.forEach(function (item) {
257
- return item.selected = false;
258
- });
259
- _updatedItems3[targetIndex].selected = true;
260
- var selectedOption = _updatedItems3[targetIndex];
261
-
262
- // Batch all state updates together to ensure they happen atomically
263
- setDatasetItems(_updatedItems3);
264
- setSelectedItem(selectedOption);
265
- setModelByKey(selectedOption.key);
266
- setModelByValue(selectedOption.value);
267
-
268
- // Update overlay position immediately for immediate visual feedback
269
- if (overlayRef.current) {
270
- overlayRef.current.style.transition = "left 300ms";
271
- var left = targetIndex * btnWidth;
272
- overlayRef.current.style.left = "".concat(left, "%");
273
- }
274
- selectedValue.datavalue = selectedOption.value;
275
- selectedValue.displayValue = selectedOption.label;
276
- if (listener !== null && listener !== void 0 && listener.onChange) {
277
- listener.onChange((props === null || props === void 0 ? void 0 : props.fieldName) || name, {
278
- datavalue: selectedOption.value,
279
- displayValue: selectedOption.label
212
+ setSelectedItem(find(updatedItems, { selected: true }) || null);
213
+ const datavalueArray = keys.map((key) => {
214
+ var _a;
215
+ return (_a = find(updatedItems, { key })) == null ? void 0 : _a.value;
280
216
  });
217
+ const displayValueArray = keys.map((key) => {
218
+ var _a;
219
+ return (_a = find(updatedItems, { key })) == null ? void 0 : _a.label;
220
+ });
221
+ selectedValue.datavalue = datavalueArray;
222
+ selectedValue.displayValue = displayValueArray;
223
+ if (listener == null ? void 0 : listener.onChange) {
224
+ listener.onChange(name, __spreadProps(__spreadValues({}, props), {
225
+ datavalue: datavalueArray,
226
+ displayValue: displayValueArray
227
+ }));
228
+ }
229
+ if (onChange) {
230
+ onChange(
231
+ event,
232
+ listener == null ? void 0 : listener.Widgets[name],
233
+ keys.map((key) => {
234
+ var _a;
235
+ return (_a = find(updatedItems, { key })) == null ? void 0 : _a.value;
236
+ }),
237
+ keys
238
+ );
239
+ }
240
+ } else {
241
+ let targetIndex = index;
242
+ if (!multiple && selectedItem && index === findIndex(datasetItems, { key: selectedItem.key })) {
243
+ setIsUserInteraction(false);
244
+ return;
245
+ }
246
+ const updatedItems = [...datasetItems];
247
+ updatedItems.forEach((item) => item.selected = false);
248
+ updatedItems[targetIndex].selected = true;
249
+ const selectedOption = updatedItems[targetIndex];
250
+ setDatasetItems(updatedItems);
251
+ setSelectedItem(selectedOption);
252
+ setModelByKey(selectedOption.key);
253
+ setModelByValue(selectedOption.value);
254
+ if (overlayRef.current) {
255
+ overlayRef.current.style.transition = "left 300ms";
256
+ const left = targetIndex * btnWidth;
257
+ overlayRef.current.style.left = `${left}%`;
258
+ }
259
+ selectedValue.datavalue = selectedOption.value;
260
+ selectedValue.displayValue = selectedOption.label;
261
+ if (listener == null ? void 0 : listener.onChange) {
262
+ listener.onChange((props == null ? void 0 : props.fieldName) || name, {
263
+ datavalue: selectedOption.value,
264
+ displayValue: selectedOption.label
265
+ });
266
+ }
267
+ if (onChange) {
268
+ onChange(
269
+ event,
270
+ listener == null ? void 0 : listener.Widgets[name],
271
+ selectedOption.value,
272
+ selectedItem == null ? void 0 : selectedItem.label
273
+ );
274
+ }
281
275
  }
282
- if (onChange) {
283
- onChange(event, listener === null || listener === void 0 ? void 0 : listener.Widgets[name], selectedOption.value, selectedItem === null || selectedItem === void 0 ? void 0 : selectedItem.label);
276
+ setTimeout(() => {
277
+ setIsUserInteraction(false);
278
+ }, 100);
279
+ if (onBlur) {
280
+ onBlur();
284
281
  }
285
- }
286
-
287
- // Reset the user interaction flag after a short delay to allow for programmatic updates again
288
- setTimeout(function () {
289
- setIsUserInteraction(false);
290
- }, 100);
291
- if (onBlur) {
292
- onBlur();
293
- }
294
- return selectedValue;
295
- }, [datasetItems, disabled, multiple, onChange, onBlur, onClick, selectedItem, btnWidth, listener]);
296
- var handleOnMouseEnter = function handleOnMouseEnter(event, option) {
282
+ return selectedValue;
283
+ },
284
+ [datasetItems, disabled, multiple, onChange, onBlur, onClick, selectedItem, btnWidth, listener]
285
+ );
286
+ const handleOnMouseEnter = (event, option) => {
297
287
  if (disabled || !onMouseEnter) return;
298
- onMouseEnter(event, listener === null || listener === void 0 ? void 0 : listener.Widgets[name]);
288
+ onMouseEnter(event, listener == null ? void 0 : listener.Widgets[name]);
299
289
  };
300
- var handleOnMouseLeave = function handleOnMouseLeave(event, option) {
290
+ const handleOnMouseLeave = (event, option) => {
301
291
  if (disabled || !onMouseLeave) return;
302
- onMouseLeave(event, listener === null || listener === void 0 ? void 0 : listener.Widgets[name]);
292
+ onMouseLeave(event, listener == null ? void 0 : listener.Widgets[name]);
303
293
  };
304
- var handleOnClick = function handleOnClick(event, index, option) {
305
- var selectedValue = selectOpt(event, index, option);
294
+ const handleOnClick = (event, index, option) => {
295
+ const selectedValue = selectOpt(event, index, option);
306
296
  if (disabled || !onClick) return;
307
- onClick(event, Object.assign({}, listener === null || listener === void 0 ? void 0 : listener.Widgets[name], selectedValue));
297
+ onClick(event, Object.assign({}, listener == null ? void 0 : listener.Widgets[name], selectedValue));
308
298
  };
309
299
  return {
310
- datasetItems: datasetItems,
311
- selectedItem: selectedItem,
312
- btnWidth: btnWidth,
313
- switchRef: switchRef,
314
- overlayRef: overlayRef,
315
- selectOpt: selectOpt,
316
- updateHighlighter: updateHighlighter,
317
- modelByValue: modelByValue,
318
- modelByKey: modelByKey,
319
- CHDisplayValue: CHDisplayValue,
320
- handleOnMouseEnter: handleOnMouseEnter,
321
- handleOnMouseLeave: handleOnMouseLeave,
322
- handleOnClick: handleOnClick
300
+ datasetItems,
301
+ selectedItem,
302
+ btnWidth,
303
+ switchRef,
304
+ overlayRef,
305
+ selectOpt,
306
+ updateHighlighter,
307
+ modelByValue,
308
+ modelByKey,
309
+ CHDisplayValue,
310
+ handleOnMouseEnter,
311
+ handleOnMouseLeave,
312
+ handleOnClick
323
313
  };
324
314
  };
325
- var SwitchOption = /*#__PURE__*/(0, _react.memo)(function (_ref) {
326
- var _opt$dataObject, _opt$dataObject2;
327
- var opt = _ref.opt,
328
- index = _ref.index,
329
- getHint = _ref.getHint,
330
- selectOpt = _ref.selectOpt,
331
- handleOnMouseEnter = _ref.handleOnMouseEnter,
332
- handleOnMouseLeave = _ref.handleOnMouseLeave,
333
- handleOnClick = _ref.handleOnClick,
334
- _ref$disabled = _ref.disabled,
335
- disabled = _ref$disabled === void 0 ? false : _ref$disabled,
336
- iconclass = _ref.iconclass,
337
- checkediconclass = _ref.checkediconclass,
338
- displayfield = _ref.displayfield;
339
- return __jsx(_Box["default"], {
340
- component: "a",
341
- key: opt.key,
342
- href: "javascript:void(0);",
343
- className: "btn btn-default ".concat(opt.selected ? "selected" : "", " ").concat(disabled ? "disabled" : ""),
344
- title: getHint(opt, index),
345
- role: "button",
346
- "aria-pressed": opt.selected ? "true" : "false",
347
- onClick: function onClick(e) {
348
- return handleOnClick(e, index, opt);
349
- },
350
- onMouseEnter: function onMouseEnter(e) {
351
- return handleOnMouseEnter(e, opt);
352
- },
353
- onMouseLeave: function onMouseLeave(e) {
354
- return handleOnMouseLeave(e, opt);
355
- },
356
- name: "wm-switch-".concat(opt.key)
357
- }, iconclass && ((_opt$dataObject = opt.dataObject) === null || _opt$dataObject === void 0 ? void 0 : _opt$dataObject[iconclass]) && (!opt.selected || !checkediconclass) && __jsx(_Box["default"], {
358
- component: "i",
359
- "aria-hidden": "true",
360
- className: "app-icon ".concat(((_opt$dataObject2 = opt.dataObject) === null || _opt$dataObject2 === void 0 ? void 0 : _opt$dataObject2[iconclass]) || opt["icon"])
361
- }), opt.selected && checkediconclass && __jsx(_Box["default"], {
362
- component: "i",
363
- "aria-hidden": "true",
364
- className: checkediconclass
365
- }), __jsx(_Box["default"], {
366
- component: "span",
367
- className: "caption"
368
- }, displayfield && opt[displayfield] || opt.label));
369
- });
315
+ const SwitchOption = memo(
316
+ ({
317
+ opt,
318
+ index,
319
+ getHint,
320
+ selectOpt,
321
+ handleOnMouseEnter,
322
+ handleOnMouseLeave,
323
+ handleOnClick,
324
+ disabled = false,
325
+ iconclass,
326
+ checkediconclass,
327
+ displayfield
328
+ }) => {
329
+ var _a, _b;
330
+ return /* @__PURE__ */ jsxs(
331
+ Box,
332
+ __spreadProps(__spreadValues({
333
+ component: "a",
334
+ href: "javascript:void(0);",
335
+ className: `btn btn-default ${opt.selected ? "selected" : ""} ${disabled ? "disabled" : ""}`,
336
+ title: getHint(opt, index),
337
+ role: "button",
338
+ "aria-pressed": opt.selected ? "true" : "false",
339
+ onClick: (e) => handleOnClick(e, index, opt),
340
+ onMouseEnter: (e) => handleOnMouseEnter(e, opt),
341
+ onMouseLeave: (e) => handleOnMouseLeave(e, opt)
342
+ }, {
343
+ name: `wm-switch-${opt.key}`
344
+ }), {
345
+ children: [
346
+ iconclass && ((_a = opt.dataObject) == null ? void 0 : _a[iconclass]) && (!opt.selected || !checkediconclass) && /* @__PURE__ */ jsx(
347
+ Box,
348
+ {
349
+ component: "i",
350
+ "aria-hidden": "true",
351
+ className: `app-icon ${((_b = opt.dataObject) == null ? void 0 : _b[iconclass]) || opt["icon"]}`
352
+ }
353
+ ),
354
+ opt.selected && checkediconclass && /* @__PURE__ */ jsx(Box, { component: "i", "aria-hidden": "true", className: checkediconclass }),
355
+ /* @__PURE__ */ jsx(Box, { component: "span", className: "caption", children: displayfield && opt[displayfield] || opt.label })
356
+ ]
357
+ }),
358
+ opt.key
359
+ );
360
+ }
361
+ );
370
362
  SwitchOption.displayName = "SwitchOption";
371
- var WmSwitch = /*#__PURE__*/(0, _react.memo)(function (_ref2) {
372
- var dataset = _ref2.dataset,
373
- propDatasetItems = _ref2.datasetItems,
374
- _ref2$multiple = _ref2.multiple,
375
- multiple = _ref2$multiple === void 0 ? defaultProps.multiple : _ref2$multiple,
376
- _ref2$disabled = _ref2.disabled,
377
- disabled = _ref2$disabled === void 0 ? defaultProps.disabled : _ref2$disabled,
378
- _ref2$required = _ref2.required,
379
- required = _ref2$required === void 0 ? defaultProps.required : _ref2$required,
380
- name = _ref2.name,
381
- hint = _ref2.hint,
382
- iconclass = _ref2.iconclass,
383
- _ref2$checkediconclas = _ref2.checkediconclass,
384
- checkediconclass = _ref2$checkediconclas === void 0 ? defaultProps.checkediconclass : _ref2$checkediconclas,
385
- _ref2$displayfield = _ref2.displayfield,
386
- displayfield = _ref2$displayfield === void 0 ? defaultProps.displayfield : _ref2$displayfield,
387
- datafield = _ref2.datafield,
388
- value = _ref2.value,
389
- onChange = _ref2.onChange,
390
- onClick = _ref2.onClick,
391
- onMouseEnter = _ref2.onMouseEnter,
392
- onMouseLeave = _ref2.onMouseLeave,
393
- onBlur = _ref2.onBlur,
394
- compareby = _ref2.compareby,
395
- toBeProcessedValue = _ref2.toBeProcessedValue,
396
- _ref2$show = _ref2.show,
397
- show = _ref2$show === void 0 ? defaultProps.show : _ref2$show,
398
- _ref2$tabindex = _ref2.tabindex,
399
- tabindex = _ref2$tabindex === void 0 ? defaultProps.tabindex : _ref2$tabindex,
400
- _ref2$arialabel = _ref2.arialabel,
401
- arialabel = _ref2$arialabel === void 0 ? "Switch choose options" : _ref2$arialabel,
402
- className = _ref2.className,
403
- datavalue = _ref2.datavalue,
404
- displayExpression = _ref2.displayExpression,
405
- orderby = _ref2.orderby,
406
- displayValue = _ref2.displayValue,
407
- listener = _ref2.listener,
408
- styles = _ref2.styles,
409
- dataPath = _ref2.dataPath,
410
- hidden = _ref2.hidden,
411
- fieldName = _ref2.fieldName,
412
- rest = (0, _objectWithoutProperties2["default"])(_ref2, _excluded);
413
- var _useSwitch = useSwitch({
414
- dataset: dataset,
363
+ const WmSwitch = memo(
364
+ (_a) => {
365
+ var _b = _a, {
366
+ dataset,
415
367
  datasetItems: propDatasetItems,
416
- multiple: multiple,
417
- value: value,
418
- toBeProcessedValue: toBeProcessedValue,
419
- onChange: onChange,
420
- onClick: onClick,
421
- onMouseEnter: onMouseEnter,
422
- onMouseLeave: onMouseLeave,
423
- onBlur: onBlur,
424
- disabled: disabled,
425
- compareby: compareby,
426
- datafield: datafield,
427
- datavalue: datavalue,
428
- name: name,
429
- displayfield: displayfield,
430
- displayExpression: displayExpression,
431
- orderby: orderby,
432
- listener: listener,
433
- dataPath: dataPath,
434
- fieldName: fieldName
435
- }),
436
- datasetItems = _useSwitch.datasetItems,
437
- selectedItem = _useSwitch.selectedItem,
438
- switchRef = _useSwitch.switchRef,
439
- overlayRef = _useSwitch.overlayRef,
440
- selectOpt = _useSwitch.selectOpt,
441
- updateHighlighter = _useSwitch.updateHighlighter,
442
- handleOnMouseEnter = _useSwitch.handleOnMouseEnter,
443
- handleOnMouseLeave = _useSwitch.handleOnMouseLeave,
444
- handleOnClick = _useSwitch.handleOnClick,
445
- modelByValue = _useSwitch.modelByValue,
446
- modelByKey = _useSwitch.modelByKey,
447
- CHDisplayValue = _useSwitch.CHDisplayValue,
448
- btnWidth = _useSwitch.btnWidth;
449
- var getHint = (0, _react.useCallback)(function (opt, index) {
450
- if (!hint) return opt[displayfield] || opt.label;
451
- if (Array.isArray(hint)) {
452
- return hint[index - 1] || hint[0] || opt[displayfield] || opt.label;
453
- }
454
- return hint;
455
- }, [hint, displayfield]);
456
- return __jsx(_Box["default"], {
457
- hidden: hidden,
458
- className: "".concat(DEFAULT_CLS, " wm-switch-root"),
459
- name: name,
460
- "aria-label": arialabel,
461
- datavalue: datavalue,
462
- style: styles
463
- }, __jsx(_Box["default"], {
464
- ref: switchRef,
465
- role: "group",
466
- className: "btn-group btn-group-justified wm-switch-inner ".concat(multiple ? "multi-select" : "", " ").concat(className || ""),
467
- style: styles,
468
- tabIndex: tabindex,
469
- "aria-label": arialabel
470
- }, datasetItems && datasetItems.map(function (opt, index) {
471
- return __jsx(SwitchOption, {
472
- key: opt.key,
473
- opt: opt,
474
- index: index,
475
- getHint: getHint,
476
- selectOpt: selectOpt,
477
- disabled: disabled,
478
- iconclass: iconclass,
479
- checkediconclass: checkediconclass,
480
- displayfield: displayfield,
481
- handleOnMouseEnter: handleOnMouseEnter,
482
- handleOnMouseLeave: handleOnMouseLeave,
483
- handleOnClick: handleOnClick
368
+ multiple = defaultProps.multiple,
369
+ disabled = defaultProps.disabled,
370
+ required = defaultProps.required,
371
+ name,
372
+ hint,
373
+ iconclass,
374
+ checkediconclass = defaultProps.checkediconclass,
375
+ displayfield = defaultProps.displayfield,
376
+ datafield,
377
+ value,
378
+ onChange,
379
+ onClick,
380
+ onMouseEnter,
381
+ onMouseLeave,
382
+ onBlur,
383
+ compareby,
384
+ toBeProcessedValue,
385
+ show = defaultProps.show,
386
+ tabindex = defaultProps.tabindex,
387
+ arialabel = "Switch choose options",
388
+ className,
389
+ datavalue,
390
+ displayExpression,
391
+ orderby,
392
+ displayValue,
393
+ listener,
394
+ styles,
395
+ dataPath,
396
+ hidden,
397
+ fieldName
398
+ } = _b, rest = __objRest(_b, [
399
+ "dataset",
400
+ "datasetItems",
401
+ "multiple",
402
+ "disabled",
403
+ "required",
404
+ "name",
405
+ "hint",
406
+ "iconclass",
407
+ "checkediconclass",
408
+ "displayfield",
409
+ "datafield",
410
+ "value",
411
+ "onChange",
412
+ "onClick",
413
+ "onMouseEnter",
414
+ "onMouseLeave",
415
+ "onBlur",
416
+ "compareby",
417
+ "toBeProcessedValue",
418
+ "show",
419
+ "tabindex",
420
+ "arialabel",
421
+ "className",
422
+ "datavalue",
423
+ "displayExpression",
424
+ "orderby",
425
+ "displayValue",
426
+ "listener",
427
+ "styles",
428
+ "dataPath",
429
+ "hidden",
430
+ "fieldName"
431
+ ]);
432
+ const {
433
+ datasetItems,
434
+ selectedItem,
435
+ switchRef,
436
+ overlayRef,
437
+ selectOpt,
438
+ updateHighlighter,
439
+ handleOnMouseEnter,
440
+ handleOnMouseLeave,
441
+ handleOnClick,
442
+ modelByValue,
443
+ modelByKey,
444
+ CHDisplayValue,
445
+ btnWidth
446
+ } = useSwitch({
447
+ dataset,
448
+ datasetItems: propDatasetItems,
449
+ multiple,
450
+ value,
451
+ toBeProcessedValue,
452
+ onChange,
453
+ onClick,
454
+ onMouseEnter,
455
+ onMouseLeave,
456
+ onBlur,
457
+ disabled,
458
+ compareby,
459
+ datafield,
460
+ datavalue,
461
+ name,
462
+ displayfield,
463
+ displayExpression,
464
+ orderby,
465
+ listener,
466
+ dataPath,
467
+ fieldName
484
468
  });
485
- })), !multiple && __jsx(_Box["default"], {
486
- component: "span",
487
- ref: overlayRef,
488
- title: selectedItem ? selectedItem.label : modelByKey,
489
- "aria-hidden": "true",
490
- className: "btn btn-primary app-switch-overlay switch-handle"
491
- }, checkediconclass && __jsx(_Box["default"], {
492
- component: "i",
493
- className: checkediconclass
494
- }), __jsx(_Box["default"], {
495
- component: "span",
496
- className: "caption"
497
- }, selectedItem ? selectedItem.label : modelByKey)), __jsx(_material.InputBase, {
498
- name: name,
499
- className: "model-holder ng-hide",
500
- disabled: disabled,
501
- value: modelByKey || "",
502
- required: required,
503
- "aria-hidden": "true",
504
- readOnly: true
505
- }));
506
- });
469
+ const getHint = useCallback(
470
+ (opt, index) => {
471
+ if (!hint) return opt[displayfield] || opt.label;
472
+ if (Array.isArray(hint)) {
473
+ return hint[index - 1] || hint[0] || opt[displayfield] || opt.label;
474
+ }
475
+ return hint;
476
+ },
477
+ [hint, displayfield]
478
+ );
479
+ return /* @__PURE__ */ jsxs(
480
+ Box,
481
+ __spreadProps(__spreadValues(__spreadProps(__spreadValues({
482
+ hidden,
483
+ className: `${DEFAULT_CLS} wm-switch-root`
484
+ }, { name }), {
485
+ "aria-label": arialabel
486
+ }), { datavalue }), {
487
+ style: styles,
488
+ children: [
489
+ /* @__PURE__ */ jsx(
490
+ Box,
491
+ {
492
+ ref: switchRef,
493
+ role: "group",
494
+ className: `btn-group btn-group-justified wm-switch-inner ${multiple ? "multi-select" : ""} ${className || ""}`,
495
+ style: styles,
496
+ tabIndex: tabindex,
497
+ "aria-label": arialabel,
498
+ children: datasetItems && datasetItems.map((opt, index) => /* @__PURE__ */ jsx(
499
+ SwitchOption,
500
+ {
501
+ opt,
502
+ index,
503
+ getHint,
504
+ selectOpt,
505
+ disabled,
506
+ iconclass,
507
+ checkediconclass,
508
+ displayfield,
509
+ handleOnMouseEnter,
510
+ handleOnMouseLeave,
511
+ handleOnClick
512
+ },
513
+ opt.key
514
+ ))
515
+ }
516
+ ),
517
+ !multiple && /* @__PURE__ */ jsxs(
518
+ Box,
519
+ {
520
+ component: "span",
521
+ ref: overlayRef,
522
+ title: selectedItem ? selectedItem.label : modelByKey,
523
+ "aria-hidden": "true",
524
+ className: "btn btn-primary app-switch-overlay switch-handle",
525
+ children: [
526
+ checkediconclass && /* @__PURE__ */ jsx(Box, { component: "i", className: checkediconclass }),
527
+ /* @__PURE__ */ jsx(Box, { component: "span", className: "caption", children: selectedItem ? selectedItem.label : modelByKey })
528
+ ]
529
+ }
530
+ ),
531
+ /* @__PURE__ */ jsx(
532
+ InputBase,
533
+ {
534
+ name,
535
+ className: "model-holder ng-hide",
536
+ disabled,
537
+ value: modelByKey || "",
538
+ required,
539
+ "aria-hidden": "true",
540
+ readOnly: true
541
+ }
542
+ )
543
+ ]
544
+ })
545
+ );
546
+ }
547
+ );
507
548
  WmSwitch.displayName = "WmSwitch";
508
- var WithForm = (0, _withFormController["default"])(WmSwitch);
509
- var WmSwitchStandalone = exports.WmSwitch = (0, _withStandalone["default"])(WithForm);
510
- /**
511
- * The WmSwitch component provides a toggle switch input with multiple selection modes.
512
- *
513
- * - [Playground](https://react-components.wavemaker.ai/?path=/story/input-switch--showcase)
514
- *
515
- * - [Docs](https://react-components.wavemaker.ai/?path=/story/input-switch--docs)
516
- *
517
- * @param props - {@link WmSwitchProps}
518
- */
519
- var _default = exports["default"] = (0, _withBaseWrapper.withBaseWrapper)(WithForm);
549
+ const WithForm = withFormController(WmSwitch);
550
+ const WmSwitchStandalone = withStandalone(WithForm);
551
+ var switch_default = withBaseWrapper(WithForm);
552
+ export {
553
+ WmSwitchStandalone as WmSwitch,
554
+ switch_default as default
555
+ };