@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,499 +1,462 @@
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.WmText = void 0;
9
- var _react = _interopRequireWildcard(require("react"));
10
- var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
11
- var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
12
- var _TextField = _interopRequireDefault(require("@mui/material/TextField"));
13
- var _InputAdornment = _interopRequireDefault(require("@mui/material/InputAdornment"));
14
- var _clsx = _interopRequireDefault(require("clsx"));
15
- var _toNumber = _interopRequireDefault(require("lodash-es/toNumber"));
16
- var _debounce = _interopRequireDefault(require("lodash-es/debounce"));
17
- var _withBaseWrapper = require("@wavemaker-ai/react-runtime/higherOrder/withBaseWrapper");
18
- var _withFormController = _interopRequireDefault(require("@wavemaker-ai/react-runtime/components/data/form/form-controller/withFormController"));
19
- var _util = require("./util");
20
- var _delay = _interopRequireDefault(require("lodash-es/delay"));
21
- var _util2 = require("../util");
22
- var _withStandalone = _interopRequireDefault(require("@wavemaker-ai/react-runtime/higherOrder/withStandalone"));
23
- 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); }
24
- var __jsx = _react["default"].createElement;
25
- 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; }
26
- 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; }
27
- var DEFAULT_CLASS = "form-control app-textbox";
28
- var WmText = /*#__PURE__*/(0, _react.memo)(function (props) {
29
- var _props$autocomplete = props.autocomplete,
30
- autocomplete = _props$autocomplete === void 0 ? "true" : _props$autocomplete,
31
- autofocus = props.autofocus,
32
- disabled = props.disabled,
33
- readonly = props.readonly,
34
- placeholder = props.placeholder,
35
- type = props.type,
36
- maxchars = props.maxchars,
37
- _props$styles = props.styles,
38
- styles = _props$styles === void 0 ? {} : _props$styles,
39
- className = props.className,
40
- shortcutkey = props.shortcutkey,
41
- _props$required = props.required,
42
- required = _props$required === void 0 ? false : _props$required,
43
- name = props.name,
44
- arialabel = props.arialabel,
45
- _props$datavalue = props.datavalue,
46
- datavalue = _props$datavalue === void 0 ? "" : _props$datavalue,
47
- hint = props.hint,
48
- listener = props.listener,
49
- displayformat = props.displayformat,
50
- _props$showdisplayfor = props.showdisplayformaton,
51
- showdisplayformaton = _props$showdisplayfor === void 0 ? "keypress" : _props$showdisplayfor,
52
- _props$updatedelay = props.updatedelay,
53
- updatedelay = _props$updatedelay === void 0 ? "0" : _props$updatedelay,
54
- tabindex = props.tabindex,
55
- regexp = props.regexp,
56
- _props$updateon = props.updateon,
57
- updateon = _props$updateon === void 0 ? "blur" : _props$updateon,
58
- _props$autocapitalize = props.autocapitalize,
59
- autocapitalize = _props$autocapitalize === void 0 ? "none" : _props$autocapitalize,
60
- autotrim = props.autotrim,
61
- onChange = props.onChange,
62
- onBlur = props.onBlur,
63
- onFocus = props.onFocus,
64
- onKeydown = props.onKeydown,
65
- onKeypress = props.onKeypress,
66
- onKeyup = props.onKeyup,
67
- onMouseEnter = props.onMouseEnter,
68
- id = props.id,
69
- error = props.error,
70
- leadingiconclass = props.leadingiconclass,
71
- trailingiconclass = props.trailingiconclass,
72
- supportingtext = props.supportingtext,
73
- onLeadingiconclick = props.onLeadingiconclick,
74
- onTrailingiconclick = props.onTrailingiconclick;
75
-
76
- // Use a single state for the raw input value
77
- var _useState = (0, _react.useState)(datavalue),
78
- rawValue = _useState[0],
79
- setRawValue = _useState[1];
80
-
81
- // Compute formatted display value based on raw value
82
- var displayValue = displayformat ? (0, _util.formatInput)(rawValue, displayformat) : rawValue;
83
- var _useState2 = (0, _react.useState)(false),
84
- showError = _useState2[0],
85
- setShowError = _useState2[1];
86
- var _useState3 = (0, _react.useState)(false),
87
- isDirty = _useState3[0],
88
- setIsDirty = _useState3[1];
89
- var _useState4 = (0, _react.useState)(false),
90
- isTouched = _useState4[0],
91
- setIsTouched = _useState4[1];
92
- var _useState5 = (0, _react.useState)(false),
93
- isAutofilled = _useState5[0],
94
- setIsAutofilled = _useState5[1];
95
- var ref = (0, _react.useRef)(null);
96
- var cursorPositionRef = (0, _react.useRef)(0);
97
- var displayError = error || isDirty && showError;
98
-
99
- // Track if changes are coming from internal user input
100
- var isInternalChange = (0, _react.useRef)(false);
101
- // Store previous value for onChange callbacks
102
- var prevValueRef = (0, _react.useRef)(datavalue);
103
-
104
- // Sync state with prop changes
105
- (0, _react.useEffect)(function () {
106
- // Only update state from props if it's not from an internal change
107
- if (!isInternalChange.current && datavalue !== rawValue) {
108
- setRawValue(datavalue);
109
- prevValueRef.current = datavalue;
110
- } else if (datavalue !== rawValue) {
111
- setRawValue(datavalue);
1
+ var __defProp = Object.defineProperty;
2
+ var __defProps = Object.defineProperties;
3
+ var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
4
+ var __getOwnPropSymbols = Object.getOwnPropertySymbols;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __propIsEnum = Object.prototype.propertyIsEnumerable;
7
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
8
+ var __spreadValues = (a, b) => {
9
+ for (var prop in b || (b = {}))
10
+ if (__hasOwnProp.call(b, prop))
11
+ __defNormalProp(a, prop, b[prop]);
12
+ if (__getOwnPropSymbols)
13
+ for (var prop of __getOwnPropSymbols(b)) {
14
+ if (__propIsEnum.call(b, prop))
15
+ __defNormalProp(a, prop, b[prop]);
112
16
  }
113
- // Reset the flag
114
- isInternalChange.current = false;
115
-
116
- // Reset autofill state when value is reset externally
117
- if (datavalue === "" || datavalue === null || datavalue === undefined) {
118
- setIsAutofilled(false);
119
- }
120
- }, [datavalue]);
121
- var validateInput = (0, _react.useCallback)(function (value) {
122
- if (displayformat) {
123
- value = (0, _util.removeDisplayFormat)(value, displayformat);
124
- }
125
- if (!value.trim() && required) {
126
- return {
127
- isValid: false,
128
- type: "required",
129
- message: "This field is required"
130
- };
131
- }
132
- if (type === "email" && value && value.trim()) {
133
- var emailRegex = /^[^\s@]+@[^\s@]+\.[^\s@]+$/;
134
- if (!emailRegex.test(value.trim())) {
135
- return {
136
- isValid: false,
137
- type: "email",
138
- message: "Please enter a valid email address"
139
- };
140
- }
141
- }
142
- if (regexp && value && !new RegExp(regexp || ".*", "g").test(value)) {
143
- return {
144
- isValid: false,
145
- type: "regexp",
146
- message: "Invalid format"
147
- };
148
- }
149
- if (maxchars && value.length > maxchars) {
150
- return {
151
- isValid: false,
152
- type: "maxchars",
153
- message: "Maximum ".concat(maxchars, " characters allowed")
154
- };
155
- }
156
- if (props.type === "number") {
157
- if (props.minvalue && (0, _toNumber["default"])(value) < props.minvalue) {
158
- return {
159
- isValid: false,
160
- type: "minvalue",
161
- message: "Minimum ".concat(props.minvalue, " characters allowed")
162
- };
163
- }
164
- if (props.maxvalue && (0, _toNumber["default"])(value) > props.maxvalue) {
165
- return {
166
- isValid: false,
167
- type: "maxvalue",
168
- message: "Maximum ".concat(props.maxvalue, " characters allowed")
169
- };
17
+ return a;
18
+ };
19
+ var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
20
+ import { jsx } from "react/jsx-runtime";
21
+ import { memo, useRef, useEffect, useState, useCallback, useMemo } from "react";
22
+ import TextField from "@mui/material/TextField";
23
+ import InputAdornment from "@mui/material/InputAdornment";
24
+ import clsx from "clsx";
25
+ import toNumber from "lodash-es/toNumber";
26
+ import debounce from "lodash-es/debounce";
27
+ import { withBaseWrapper } from "../../../higherOrder/withBaseWrapper";
28
+ import withFormController from "../../data/form/form-controller/withFormController";
29
+ import { formatInput, removeDisplayFormat, applyAutoCapitalize, getFormatMaxLength } from "./util";
30
+ import delay from "lodash-es/delay";
31
+ import { sanitizeInputValue } from "../util";
32
+ import withStandalone from "../../../higherOrder/withStandalone";
33
+ const DEFAULT_CLASS = "form-control app-textbox";
34
+ const WmText = memo(
35
+ (props) => {
36
+ const {
37
+ autocomplete = "true",
38
+ autofocus,
39
+ disabled,
40
+ readonly,
41
+ placeholder,
42
+ type,
43
+ maxchars,
44
+ styles = {},
45
+ className,
46
+ shortcutkey,
47
+ required = false,
48
+ name,
49
+ arialabel,
50
+ datavalue = "",
51
+ hint,
52
+ listener,
53
+ displayformat,
54
+ showdisplayformaton = "keypress",
55
+ updatedelay = "0",
56
+ tabindex,
57
+ regexp,
58
+ updateon: updateonProp = "blur",
59
+ autocapitalize = "none",
60
+ autotrim,
61
+ onChange,
62
+ onBlur,
63
+ onFocus,
64
+ onKeydown,
65
+ onKeypress,
66
+ onKeyup,
67
+ onMouseEnter,
68
+ id,
69
+ error,
70
+ leadingiconclass,
71
+ trailingiconclass,
72
+ supportingtext,
73
+ onLeadingiconclick,
74
+ onTrailingiconclick
75
+ } = props;
76
+ const updateon = updateonProp === "default" ? "blur" : updateonProp;
77
+ const [rawValue, setRawValue] = useState(() => sanitizeInputValue(datavalue));
78
+ const displayValue = displayformat ? formatInput(rawValue, displayformat) : rawValue;
79
+ const [showError, setShowError] = useState(false);
80
+ const [isDirty, setIsDirty] = useState(false);
81
+ const [isTouched, setIsTouched] = useState(false);
82
+ const [isAutofilled, setIsAutofilled] = useState(false);
83
+ const ref = useRef(null);
84
+ const cursorPositionRef = useRef(0);
85
+ const displayError = error || isDirty && showError;
86
+ const isInternalChange = useRef(false);
87
+ const prevValueRef = useRef(datavalue);
88
+ useEffect(() => {
89
+ const normalizedValue = sanitizeInputValue(datavalue);
90
+ if (!isInternalChange.current && normalizedValue !== rawValue) {
91
+ setRawValue(normalizedValue);
92
+ prevValueRef.current = datavalue;
93
+ } else if (normalizedValue !== rawValue) {
94
+ setRawValue(normalizedValue);
170
95
  }
171
- }
172
- return {
173
- isValid: true,
174
- message: "",
175
- type: ""
176
- };
177
- }, [required, regexp, maxchars]);
178
-
179
- // Debounced update function for delayed updates
180
- var debouncedUpdateValue = (0, _react.useMemo)(function () {
181
- return (0, _debounce["default"])(function (value) {
182
- if (autotrim) {
183
- value = value.trim();
96
+ isInternalChange.current = false;
97
+ if (datavalue === "" || datavalue === null || datavalue === void 0) {
98
+ setIsAutofilled(false);
184
99
  }
185
- var validation = validateInput(value);
186
- setShowError(!validation.isValid);
187
- if (onChange || listener !== null && listener !== void 0 && listener.onChange) {
188
- isInternalChange.current = true;
189
-
190
- // Remove display format before processing the value
191
- var unformattedValue = displayformat ? (0, _util.removeDisplayFormat)(value, displayformat) : value;
192
- var _datavalue = props.type === "number" ? (0, _toNumber["default"])(unformattedValue) : unformattedValue;
193
- if (listener !== null && listener !== void 0 && listener.onChange) {
194
- listener.onChange(props.fieldName || name, {
195
- datavalue: _datavalue,
196
- value: value,
197
- charlength: value.length
198
- });
100
+ }, [datavalue]);
101
+ const validateInput = useCallback(
102
+ (value) => {
103
+ let stringValue = sanitizeInputValue(value);
104
+ if (displayformat) {
105
+ stringValue = removeDisplayFormat(stringValue, displayformat);
106
+ }
107
+ if (!stringValue.trim() && required) {
108
+ return { isValid: false, type: "required", message: "This field is required" };
109
+ }
110
+ if (type === "email" && stringValue && stringValue.trim()) {
111
+ const emailRegex = /^[^\s@]+@[^\s@]+\.[^\s@]+$/;
112
+ if (!emailRegex.test(stringValue.trim())) {
113
+ return { isValid: false, type: "email", message: "Please enter a valid email address" };
114
+ }
199
115
  }
200
- if (onChange) {
201
- var syntheticEvent = {
202
- target: {
203
- value: _datavalue,
204
- name: name
205
- },
206
- currentTarget: ref.current
116
+ if (regexp && stringValue && !new RegExp(regexp || ".*", "g").test(stringValue)) {
117
+ return { isValid: false, type: "regexp", message: "Invalid format" };
118
+ }
119
+ if (maxchars && stringValue.length > maxchars) {
120
+ return {
121
+ isValid: false,
122
+ type: "maxchars",
123
+ message: `Maximum ${maxchars} characters allowed`
207
124
  };
208
- // onChange expects string | null, so convert number to string if needed
209
- var onChangeValue = typeof _datavalue === "number" ? String(_datavalue) : _datavalue;
210
- var prevValue = typeof prevValueRef.current === "number" ? String(prevValueRef.current) : prevValueRef.current;
211
- onChange(syntheticEvent, props, onChangeValue, prevValue);
212
125
  }
213
- prevValueRef.current = _datavalue;
214
- }
215
- }, parseInt(updatedelay) || 0, {
216
- leading: parseInt(updatedelay) === 0
217
- });
218
- }, [onChange, listener, name, validateInput, autotrim, displayformat]);
219
-
220
- // Shortcut key handler
221
- (0, _react.useEffect)(function () {
222
- if (!shortcutkey) return;
223
- var handleGlobalKeyDown = function handleGlobalKeyDown(e) {
224
- if (e.altKey && e.key.toLowerCase() === shortcutkey.toLowerCase()) {
225
- var _ref$current;
226
- e.preventDefault();
227
- (_ref$current = ref.current) === null || _ref$current === void 0 || _ref$current.focus();
228
- }
229
- };
230
- window.addEventListener("keydown", handleGlobalKeyDown);
231
- return function () {
232
- return window.removeEventListener("keydown", handleGlobalKeyDown);
233
- };
234
- }, [shortcutkey]);
235
-
236
- // Autofill detection using mui-auto-fill animation event
237
- (0, _react.useEffect)(function () {
238
- var input = ref.current;
239
- function handleAnimationStart(e) {
240
- if (e.animationName === "mui-auto-fill") {
241
- setIsAutofilled(true);
126
+ if (props.type === "number") {
127
+ if (props.minvalue && toNumber(stringValue) < props.minvalue) {
128
+ return {
129
+ isValid: false,
130
+ type: "minvalue",
131
+ message: `Minimum ${props.minvalue} characters allowed`
132
+ };
133
+ }
134
+ if (props.maxvalue && toNumber(stringValue) > props.maxvalue) {
135
+ return {
136
+ isValid: false,
137
+ type: "maxvalue",
138
+ message: `Maximum ${props.maxvalue} characters allowed`
139
+ };
140
+ }
141
+ }
142
+ return { isValid: true, message: "", type: "" };
143
+ },
144
+ [required, regexp, maxchars, displayformat, type, props.type, props.minvalue, props.maxvalue]
145
+ );
146
+ const debouncedUpdateValue = useMemo(
147
+ () => debounce(
148
+ (value) => {
149
+ if (autotrim) {
150
+ value = value.trim();
151
+ }
152
+ const validation = validateInput(value);
153
+ setShowError(!validation.isValid);
154
+ if (onChange || (listener == null ? void 0 : listener.onChange)) {
155
+ isInternalChange.current = true;
156
+ const unformattedValue = displayformat ? removeDisplayFormat(value, displayformat) : value;
157
+ const datavalue2 = props.type === "number" ? toNumber(unformattedValue) : unformattedValue;
158
+ if (listener == null ? void 0 : listener.onChange) {
159
+ listener.onChange(props.fieldName || name, {
160
+ datavalue: datavalue2,
161
+ value,
162
+ charlength: value.length
163
+ });
164
+ }
165
+ if (onChange) {
166
+ const syntheticEvent = {
167
+ target: {
168
+ value: datavalue2,
169
+ name
170
+ },
171
+ currentTarget: ref.current
172
+ };
173
+ const onChangeValue = typeof datavalue2 === "number" ? String(datavalue2) : datavalue2;
174
+ const prevValue = typeof prevValueRef.current === "number" ? String(prevValueRef.current) : prevValueRef.current;
175
+ onChange(syntheticEvent, props, onChangeValue, prevValue);
176
+ }
177
+ prevValueRef.current = datavalue2;
178
+ }
179
+ },
180
+ parseInt(updatedelay) || 0,
181
+ { leading: parseInt(updatedelay) === 0 }
182
+ ),
183
+ [onChange, listener, name, validateInput, autotrim, displayformat]
184
+ );
185
+ useEffect(() => {
186
+ if (!shortcutkey) return;
187
+ const handleGlobalKeyDown = (e) => {
188
+ var _a;
189
+ if (e.altKey && e.key.toLowerCase() === shortcutkey.toLowerCase()) {
190
+ e.preventDefault();
191
+ (_a = ref.current) == null ? void 0 : _a.focus();
192
+ }
193
+ };
194
+ window.addEventListener("keydown", handleGlobalKeyDown);
195
+ return () => window.removeEventListener("keydown", handleGlobalKeyDown);
196
+ }, [shortcutkey]);
197
+ useEffect(() => {
198
+ const input = ref.current;
199
+ function handleAnimationStart(e) {
200
+ if (e.animationName === "mui-auto-fill") {
201
+ setIsAutofilled(true);
202
+ }
242
203
  }
243
- }
244
- if (input) {
245
- input.addEventListener("animationstart", handleAnimationStart);
246
- }
247
- return function () {
248
204
  if (input) {
249
- input.removeEventListener("animationstart", handleAnimationStart);
205
+ input.addEventListener("animationstart", handleAnimationStart);
250
206
  }
251
- };
252
- }, []);
253
- var handleInputChange = function handleInputChange(e) {
254
- isInternalChange.current = true;
255
- var inputEl = e.target;
256
- var newValue = inputEl.value;
257
- var previousValue = rawValue;
258
- cursorPositionRef.current = inputEl.selectionStart || 0;
259
-
260
- // Manual autocapitalize implementation
261
- var capitalizeResult = (0, _util.applyAutoCapitalize)(newValue, previousValue, cursorPositionRef.current, autocapitalize);
262
- newValue = capitalizeResult.value;
263
-
264
- // Extract meaningful characters for validation if displayformat is present
265
- var cleanValue = displayformat ? (0, _util.removeDisplayFormat)(newValue, displayformat) : newValue;
266
-
267
- // Enforce maxchars constraint BEFORE setting state
268
- if (maxchars && cleanValue.length > maxchars) {
269
- // Prevent input that exceeds maxchars
270
- return;
271
- }
272
-
273
- // Enforce displayformat character limit using the generic format parser
274
- if (displayformat) {
275
- var maxFormatLength = (0, _util.getFormatMaxLength)(displayformat);
276
- if (cleanValue.length > maxFormatLength) {
277
- // Prevent input that exceeds format character limit
278
- return;
279
- }
280
- }
281
-
282
- // Enforce min/max value constraints for number type
283
- if (props.type === "number") {
284
- var numValue = (0, _toNumber["default"])(cleanValue);
285
- if (props.maxvalue !== undefined && numValue > props.maxvalue) {
286
- // Prevent input that exceeds maxvalue
207
+ return () => {
208
+ if (input) {
209
+ input.removeEventListener("animationstart", handleAnimationStart);
210
+ }
211
+ };
212
+ }, []);
213
+ const handleInputChange = (e) => {
214
+ isInternalChange.current = true;
215
+ const inputEl = e.target;
216
+ let newValue = inputEl.value;
217
+ const previousValue = rawValue;
218
+ cursorPositionRef.current = inputEl.selectionStart || 0;
219
+ const capitalizeResult = applyAutoCapitalize(
220
+ newValue,
221
+ previousValue,
222
+ cursorPositionRef.current,
223
+ autocapitalize
224
+ );
225
+ newValue = capitalizeResult.value;
226
+ const cleanValue = displayformat ? removeDisplayFormat(newValue, displayformat) : newValue;
227
+ if (maxchars && cleanValue.length > maxchars) {
287
228
  return;
288
229
  }
289
- if (props.minvalue !== undefined && numValue < props.minvalue && cleanValue.length >= String(props.minvalue).length) {
290
- // Only prevent if the number length is complete and still below minvalue
291
- // This allows typing "1" when minvalue is 10
292
- var minLength = String(props.minvalue).length;
293
- if (cleanValue.length >= minLength) {
230
+ if (displayformat) {
231
+ const maxFormatLength = getFormatMaxLength(displayformat);
232
+ if (cleanValue.length > maxFormatLength) {
294
233
  return;
295
234
  }
296
235
  }
297
- }
298
- setRawValue(newValue);
299
-
300
- // Restore cursor position after capitalization
301
- if (capitalizeResult.wasCapitalized) {
302
- setTimeout(function () {
303
- if (ref.current && cursorPositionRef.current !== null) {
304
- ref.current.setSelectionRange(cursorPositionRef.current, cursorPositionRef.current);
236
+ if (props.type === "number") {
237
+ const numValue = toNumber(cleanValue);
238
+ if (props.maxvalue !== void 0 && numValue > props.maxvalue) {
239
+ return;
305
240
  }
306
- }, 0);
307
- }
308
-
309
- // Handle cursor position for formatted input
310
- if (displayformat && showdisplayformaton === "keypress") {
311
- setTimeout(function () {
312
- if (ref.current) {
313
- var formatted = (0, _util.formatInput)(newValue, displayformat);
314
- // Count meaningful characters (not separators) before cursor
315
- var charsBefore = (0, _util.removeDisplayFormat)(newValue.substring(0, cursorPositionRef.current), displayformat).length;
316
-
317
- // Find position in formatted string where we have the same number of meaningful chars
318
- var newPos = formatted.split("").reduce(function (pos, _char, index) {
319
- if (pos !== -1) return pos;
320
- var charsSoFar = (0, _util.removeDisplayFormat)(formatted.substring(0, index + 1), displayformat).length;
321
- return charsSoFar >= charsBefore ? index + 1 : -1;
322
- }, -1);
323
- if (newPos !== -1) {
324
- ref.current.setSelectionRange(newPos, newPos);
241
+ if (props.minvalue !== void 0 && numValue < props.minvalue && cleanValue.length >= String(props.minvalue).length) {
242
+ const minLength = String(props.minvalue).length;
243
+ if (cleanValue.length >= minLength) {
244
+ return;
325
245
  }
326
246
  }
327
- }, 0);
328
- }
329
- var validation = validateInput(newValue);
330
- setShowError(!validation.isValid);
331
-
332
- // Set isDirty based on validation and whether user has typed
333
- if (updateon === "keypress") {
334
- if (!validation.isValid && (newValue.trim() || required)) {
247
+ }
248
+ setRawValue(newValue);
249
+ if (capitalizeResult.wasCapitalized) {
250
+ setTimeout(() => {
251
+ if (ref.current && cursorPositionRef.current !== null) {
252
+ ref.current.setSelectionRange(cursorPositionRef.current, cursorPositionRef.current);
253
+ }
254
+ }, 0);
255
+ }
256
+ if (displayformat && showdisplayformaton === "keypress") {
257
+ setTimeout(() => {
258
+ if (ref.current) {
259
+ const formatted = formatInput(newValue, displayformat);
260
+ const charsBefore = removeDisplayFormat(
261
+ newValue.substring(0, cursorPositionRef.current),
262
+ displayformat
263
+ ).length;
264
+ const newPos = formatted.split("").reduce((pos, char, index) => {
265
+ if (pos !== -1) return pos;
266
+ const charsSoFar = removeDisplayFormat(
267
+ formatted.substring(0, index + 1),
268
+ displayformat
269
+ ).length;
270
+ return charsSoFar >= charsBefore ? index + 1 : -1;
271
+ }, -1);
272
+ if (newPos !== -1) {
273
+ ref.current.setSelectionRange(newPos, newPos);
274
+ }
275
+ }
276
+ }, 0);
277
+ }
278
+ const validation = validateInput(newValue);
279
+ setShowError(!validation.isValid);
280
+ if (updateon === "keypress") {
281
+ if (!validation.isValid && (newValue.trim() || required)) {
282
+ setIsDirty(true);
283
+ } else if (validation.isValid && !required) {
284
+ setIsDirty(false);
285
+ }
286
+ }
287
+ if (updateon === "keypress" || isAutofilled) {
288
+ debouncedUpdateValue(newValue);
289
+ }
290
+ };
291
+ const handleBlur = (e) => {
292
+ if (readonly || disabled) {
293
+ return;
294
+ }
295
+ const validation = validateInput(rawValue);
296
+ if (!validation.isValid && (required || validation.type === "regexp")) {
335
297
  setIsDirty(true);
336
- } else if (validation.isValid && !required) {
337
- // Reset isDirty when field becomes valid (except for required fields which need blur)
298
+ } else {
338
299
  setIsDirty(false);
339
300
  }
340
- }
341
- if (updateon === "keypress" || isAutofilled) {
342
- debouncedUpdateValue(newValue);
343
- }
344
- };
345
- var handleBlur = function handleBlur(e) {
346
- if (readonly || disabled) {
347
- return;
348
- }
349
- var validation = validateInput(rawValue);
350
- if (!validation.isValid && (required || validation.type === "regexp")) {
351
- setIsDirty(true);
352
- } else {
353
- setIsDirty(false);
354
- }
355
- setShowError(!validation.isValid);
356
- if (updateon === "blur") {
357
- debouncedUpdateValue(rawValue);
358
- }
359
- if (!validation.isValid && regexp != ".*") {
360
- setIsTouched(true);
361
- setIsDirty(true);
362
- }
363
- onBlur === null || onBlur === void 0 || onBlur(e, listener === null || listener === void 0 ? void 0 : listener.Widgets[name]);
364
- };
365
- var handleFocus = function handleFocus(e) {
366
- onFocus === null || onFocus === void 0 || onFocus(e, listener === null || listener === void 0 ? void 0 : listener.Widgets[name]);
367
- };
368
- var handleKeyDown = function handleKeyDown(e) {
369
- (0, _delay["default"])(function () {
370
- onKeydown === null || onKeydown === void 0 || onKeydown(e, listener === null || listener === void 0 ? void 0 : listener.Widgets[name]);
371
- if (e.key === "Enter") {
301
+ setShowError(!validation.isValid);
302
+ if (updateon === "blur") {
372
303
  debouncedUpdateValue(rawValue);
373
304
  }
374
- }, 0);
375
- };
376
- var handleKeyPress = function handleKeyPress(e) {
377
- (0, _delay["default"])(function () {
378
- onKeypress === null || onKeypress === void 0 || onKeypress(e, listener === null || listener === void 0 ? void 0 : listener.Widgets[name]);
379
- }, 0);
380
- };
381
- var handleKeyUp = function handleKeyUp(e) {
382
- (0, _delay["default"])(function () {
383
- onKeyup === null || onKeyup === void 0 || onKeyup(e, listener === null || listener === void 0 ? void 0 : listener.Widgets[name]);
384
- }, 0);
385
- };
386
- var handleLeadingIconClick = function handleLeadingIconClick(e) {
387
- e.preventDefault();
388
- onLeadingiconclick === null || onLeadingiconclick === void 0 || onLeadingiconclick(e, listener === null || listener === void 0 ? void 0 : listener.Widgets[name]);
389
- };
390
- var handleTrailingIconClick = function handleTrailingIconClick(e) {
391
- e.preventDefault();
392
- onTrailingiconclick === null || onTrailingiconclick === void 0 || onTrailingiconclick(e, listener === null || listener === void 0 ? void 0 : listener.Widgets[name]);
393
- };
394
- var handleMouseEnter = function handleMouseEnter(e) {
395
- onMouseEnter === null || onMouseEnter === void 0 || onMouseEnter(e, listener === null || listener === void 0 ? void 0 : listener.Widgets[name]);
396
- setIsTouched(true);
397
- };
398
- var events = _objectSpread(_objectSpread(_objectSpread(_objectSpread(_objectSpread(_objectSpread({
399
- onChange: handleInputChange,
400
- onBlur: handleBlur,
401
- onKeyDown: handleKeyDown
402
- }, onFocus ? {
403
- onFocus: handleFocus
404
- } : {}), onKeyup ? {
405
- onKeyUp: handleKeyUp
406
- } : {}), onKeypress ? {
407
- onKeyPress: handleKeyPress
408
- } : {}), props.onClick ? {
409
- onClick: props.onClick
410
- } : {}), props.onMouseEnter ? {
411
- onMouseEnter: handleMouseEnter
412
- } : {}), props.onMouseLeave ? {
413
- onMouseLeave: props.onMouseLeave
414
- } : {});
415
- return __jsx(_TextField["default"], (0, _extends2["default"])({}, events, {
416
- hidden: props.hidden,
417
- title: hint || "Text Input",
418
- name: name,
419
- id: id || name,
420
- variant: "standard",
421
- autoComplete: (autocomplete === null || autocomplete === void 0 ? void 0 : autocomplete.toString()) === "true" ? "on" : "off",
422
- autoFocus: autofocus,
423
- disabled: disabled,
424
- required: required,
425
- placeholder: placeholder !== null && placeholder !== void 0 ? placeholder : "Enter text",
426
- value: (0, _util2.sanitizeInputValue)(displayValue),
427
- type: type,
428
- inputRef: ref,
429
- error: displayError,
430
- "aria-readonly": readonly,
431
- helperText: supportingtext || undefined,
432
- className: (0, _clsx["default"])("app-input-wrapper", isTouched ? "ng-touched" : "ng-untouched", displayError && "ng-invalid"),
433
- slotProps: {
434
- formHelperText: {
435
- className: (0, _clsx["default"])("app-label help-block supporting-text", "wm-text-helper-text", displayError && "wm-text-helper-text-error"),
436
- name: "supportingText"
437
- },
438
- input: {
439
- startAdornment: leadingiconclass ? __jsx(_InputAdornment["default"], {
440
- position: "start"
441
- }, __jsx("button", {
442
- type: "button",
443
- name: "leadingIcon",
444
- className: "btn-leading-icon",
445
- onClick: handleLeadingIconClick,
446
- "aria-hidden": "true",
447
- tabIndex: -1
448
- }, __jsx("i", {
449
- "aria-hidden": "true",
450
- className: leadingiconclass
451
- }))) : undefined,
452
- endAdornment: trailingiconclass ? __jsx(_InputAdornment["default"], {
453
- position: "end"
454
- }, __jsx("button", {
455
- type: "button",
456
- name: "trailingIcon",
457
- className: "btn-trailing-icon",
458
- onClick: handleTrailingIconClick,
459
- "aria-hidden": "true",
460
- tabIndex: -1
461
- }, __jsx("i", {
462
- "aria-hidden": "true",
463
- className: trailingiconclass
464
- }))) : undefined
465
- },
466
- htmlInput: {
467
- tabIndex: tabindex,
468
- readOnly: readonly,
469
- autoCapitalize: autocapitalize,
470
- className: (0, _clsx["default"])(DEFAULT_CLASS, className, "wm-text-input", leadingiconclass && "with-leading-icon", trailingiconclass && "with-trailing-icon", isTouched ? "ng-touched" : "ng-untouched", displayError && "ng-invalid"),
471
- style: styles,
472
- "aria-label": arialabel,
473
- maxLength: maxchars,
474
- pattern: regexp,
475
- min: props.minvalue,
476
- max: props.maxvalue,
477
- step: props.step
305
+ if (!validation.isValid && regexp != ".*") {
306
+ setIsTouched(true);
307
+ setIsDirty(true);
478
308
  }
479
- }
480
- }));
481
- }, function (prev, current) {
482
- var keys = ["datavalue", "disabled", "required", "readonly", "placeholder", "maxchars", "tabindex", "shortcutkey", "autofocus", "arialabel", "error", "className", "hidden", "leadingiconclass", "trailingiconclass", "supportingtext"];
483
- return keys.every(function (key) {
484
- return prev[key] === current[key];
485
- });
486
- });
309
+ onBlur == null ? void 0 : onBlur(e, listener == null ? void 0 : listener.Widgets[name]);
310
+ };
311
+ const handleFocus = (e) => {
312
+ onFocus == null ? void 0 : onFocus(e, listener == null ? void 0 : listener.Widgets[name]);
313
+ };
314
+ const handleKeyDown = (e) => {
315
+ delay(() => {
316
+ onKeydown == null ? void 0 : onKeydown(e, listener == null ? void 0 : listener.Widgets[name]);
317
+ if (e.key === "Enter") {
318
+ debouncedUpdateValue(rawValue);
319
+ }
320
+ }, 0);
321
+ };
322
+ const handleKeyPress = (e) => {
323
+ delay(() => {
324
+ onKeypress == null ? void 0 : onKeypress(e, listener == null ? void 0 : listener.Widgets[name]);
325
+ }, 0);
326
+ };
327
+ const handleKeyUp = (e) => {
328
+ delay(() => {
329
+ onKeyup == null ? void 0 : onKeyup(e, listener == null ? void 0 : listener.Widgets[name]);
330
+ }, 0);
331
+ };
332
+ const handleLeadingIconClick = (e) => {
333
+ e.preventDefault();
334
+ onLeadingiconclick == null ? void 0 : onLeadingiconclick(e, listener == null ? void 0 : listener.Widgets[name]);
335
+ };
336
+ const handleTrailingIconClick = (e) => {
337
+ e.preventDefault();
338
+ onTrailingiconclick == null ? void 0 : onTrailingiconclick(e, listener == null ? void 0 : listener.Widgets[name]);
339
+ };
340
+ const handleMouseEnter = (e) => {
341
+ onMouseEnter == null ? void 0 : onMouseEnter(e, listener == null ? void 0 : listener.Widgets[name]);
342
+ setIsTouched(true);
343
+ };
344
+ const events = __spreadValues(__spreadValues(__spreadValues(__spreadValues(__spreadValues(__spreadValues({
345
+ onChange: handleInputChange,
346
+ onBlur: handleBlur,
347
+ onKeyDown: handleKeyDown
348
+ }, onFocus ? { onFocus: handleFocus } : {}), onKeyup ? { onKeyUp: handleKeyUp } : {}), onKeypress ? { onKeyPress: handleKeyPress } : {}), props.onClick ? { onClick: props.onClick } : {}), props.onMouseEnter ? { onMouseEnter: handleMouseEnter } : {}), props.onMouseLeave ? { onMouseLeave: props.onMouseLeave } : {});
349
+ return /* @__PURE__ */ jsx(
350
+ TextField,
351
+ __spreadProps(__spreadValues({}, events), {
352
+ hidden: props.hidden,
353
+ title: hint || "Text Input",
354
+ name,
355
+ id: id || name,
356
+ variant: "standard",
357
+ autoComplete: (autocomplete == null ? void 0 : autocomplete.toString()) === "true" ? "on" : "off",
358
+ autoFocus: autofocus,
359
+ disabled,
360
+ required,
361
+ placeholder: placeholder != null ? placeholder : "Enter text",
362
+ value: sanitizeInputValue(displayValue),
363
+ type,
364
+ inputRef: ref,
365
+ error: displayError,
366
+ "aria-readonly": readonly,
367
+ helperText: supportingtext || void 0,
368
+ className: clsx(
369
+ "app-input-wrapper",
370
+ isTouched ? "ng-touched" : "ng-untouched",
371
+ displayError && "ng-invalid"
372
+ ),
373
+ slotProps: {
374
+ formHelperText: {
375
+ className: clsx(
376
+ "app-label help-block supporting-text",
377
+ "wm-text-helper-text",
378
+ displayError && "wm-text-helper-text-error"
379
+ ),
380
+ name: "supportingText"
381
+ },
382
+ input: {
383
+ startAdornment: leadingiconclass ? /* @__PURE__ */ jsx(InputAdornment, { position: "start", children: /* @__PURE__ */ jsx(
384
+ "button",
385
+ {
386
+ type: "button",
387
+ name: "leadingIcon",
388
+ className: "btn-leading-icon",
389
+ onClick: handleLeadingIconClick,
390
+ "aria-hidden": "true",
391
+ tabIndex: -1,
392
+ children: /* @__PURE__ */ jsx("i", { "aria-hidden": "true", className: leadingiconclass })
393
+ }
394
+ ) }) : void 0,
395
+ endAdornment: trailingiconclass ? /* @__PURE__ */ jsx(InputAdornment, { position: "end", children: /* @__PURE__ */ jsx(
396
+ "button",
397
+ {
398
+ type: "button",
399
+ name: "trailingIcon",
400
+ className: "btn-trailing-icon",
401
+ onClick: handleTrailingIconClick,
402
+ "aria-hidden": "true",
403
+ tabIndex: -1,
404
+ children: /* @__PURE__ */ jsx("i", { "aria-hidden": "true", className: trailingiconclass })
405
+ }
406
+ ) }) : void 0
407
+ },
408
+ htmlInput: {
409
+ tabIndex: tabindex,
410
+ readOnly: readonly,
411
+ autoCapitalize: autocapitalize,
412
+ className: clsx(
413
+ DEFAULT_CLASS,
414
+ className,
415
+ "wm-text-input",
416
+ leadingiconclass && "with-leading-icon",
417
+ trailingiconclass && "with-trailing-icon",
418
+ isTouched ? "ng-touched" : "ng-untouched",
419
+ displayError && "ng-invalid"
420
+ ),
421
+ style: styles,
422
+ "aria-label": arialabel,
423
+ maxLength: maxchars,
424
+ pattern: regexp,
425
+ min: props.minvalue,
426
+ max: props.maxvalue,
427
+ step: props.step
428
+ }
429
+ }
430
+ })
431
+ );
432
+ },
433
+ (prev, current) => {
434
+ const keys = [
435
+ "datavalue",
436
+ "disabled",
437
+ "required",
438
+ "readonly",
439
+ "placeholder",
440
+ "maxchars",
441
+ "tabindex",
442
+ "shortcutkey",
443
+ "autofocus",
444
+ "arialabel",
445
+ "error",
446
+ "className",
447
+ "hidden",
448
+ "leadingiconclass",
449
+ "trailingiconclass",
450
+ "supportingtext"
451
+ ];
452
+ return keys.every((key) => prev[key] === current[key]);
453
+ }
454
+ );
487
455
  WmText.displayName = "WmText";
488
- var WithForm = (0, _withFormController["default"])(WmText);
489
- var WmTextStandalone = exports.WmText = (0, _withStandalone["default"])(WithForm);
490
- /**
491
- * The WmText component provides a single-line text input with formatting, validation, and event support.
492
- *
493
- * - [Playground](https://react-components.wavemaker.ai/?path=/story/input-text--showcase)
494
- *
495
- * - [Docs](https://react-components.wavemaker.ai/?path=/story/input-text--docs)
496
- *
497
- * @param props - {@link WmTextProps}
498
- */
499
- var _default = exports["default"] = (0, _withBaseWrapper.withBaseWrapper)(WithForm);
456
+ const WithForm = withFormController(WmText);
457
+ const WmTextStandalone = withStandalone(WithForm);
458
+ var text_default = withBaseWrapper(WithForm);
459
+ export {
460
+ WmTextStandalone as WmText,
461
+ text_default as default
462
+ };