@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,322 +1,364 @@
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.WmDate = void 0;
9
- var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
10
- var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
11
- var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
12
- var _react = _interopRequireWildcard(require("react"));
13
- var _momentTimezone = _interopRequireDefault(require("moment-timezone"));
14
- var _material = require("@mui/material");
15
- var _BaseDateTime = _interopRequireDefault(require("@wavemaker-ai/react-runtime/higherOrder/BaseDateTime"));
16
- var _utils = require("./utils");
17
- var _DatePickerPopover = _interopRequireDefault(require("./components/DatePickerPopover"));
18
- var _withFormController = _interopRequireDefault(require("@wavemaker-ai/react-runtime/components/data/form/form-controller/withFormController"));
19
- var _button = require("@wavemaker-ai/react-runtime/components/form/button");
20
- var _withStandalone = _interopRequireDefault(require("@wavemaker-ai/react-runtime/higherOrder/withStandalone"));
21
- var _withBaseWrapper = _interopRequireDefault(require("@wavemaker-ai/react-runtime/higherOrder/withBaseWrapper"));
22
- var _excluded = ["name", "hint", "shortcutkey", "datavalue", "width", "arialabel", "invokeOnChange", "handleKeyDown", "getDateObj", "updatePrevDatavalue", "updateBoundVariable", "onChange", "onClick", "onFocus", "onBlur", "onMouseEnter", "onMouseLeave", "onBeforeload", "placeholder", "tabindex", "datepattern", "outputformat", "defaultDateFormat", "selectedLocale", "required", "excludedays", "excludedates", "showweeks", "showbuttonbar", "autofocus", "readonly", "disabled", "showdropdownon", "adaptiveposition", "selectfromothermonth", "todaybutton", "clearbutton", "todaybuttonlabel", "clearbuttonlabel", "showcustompicker", "showdateformatasplaceholder", "viewmode", "dataentrymode", "listener", "className", "styles", "validators", "validationmessage"];
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
- // Types
28
-
29
- // Main Component
30
- var WmDate = /*#__PURE__*/(0, _react.forwardRef)(function (props, ref) {
31
- var _listener$localeForma2;
32
- // Merge props with defaults
33
- var name = props.name,
34
- hint = props.hint,
35
- shortcutkey = props.shortcutkey,
36
- datavalue = props.datavalue,
37
- width = props.width,
38
- arialabel = props.arialabel,
39
- invokeOnChange = props.invokeOnChange,
40
- handleKeyDown = props.handleKeyDown,
41
- _props$getDateObj = props.getDateObj,
42
- _getDateObj = _props$getDateObj === void 0 ? _utils.defaultGetDateObj : _props$getDateObj,
43
- updatePrevDatavalue = props.updatePrevDatavalue,
44
- updateBoundVariable = props.updateBoundVariable,
45
- onChange = props.onChange,
46
- onClick = props.onClick,
47
- _onFocus = props.onFocus,
48
- _onBlur = props.onBlur,
49
- _onMouseEnter = props.onMouseEnter,
50
- _onMouseLeave = props.onMouseLeave,
51
- onBeforeload = props.onBeforeload,
52
- _props$placeholder = props.placeholder,
53
- placeholder = _props$placeholder === void 0 ? "Select Date" : _props$placeholder,
54
- _props$tabindex = props.tabindex,
55
- tabindex = _props$tabindex === void 0 ? 0 : _props$tabindex,
56
- datepatternProp = props.datepattern,
57
- _props$outputformat = props.outputformat,
58
- outputformat = _props$outputformat === void 0 ? "yyyy-MM-dd" : _props$outputformat,
59
- defaultDateFormat = props.defaultDateFormat,
60
- selectedLocale = props.selectedLocale,
61
- _props$required = props.required,
62
- required = _props$required === void 0 ? false : _props$required,
63
- _props$excludedays = props.excludedays,
64
- excludedays = _props$excludedays === void 0 ? "" : _props$excludedays,
65
- _props$excludedates = props.excludedates,
66
- excludedates = _props$excludedates === void 0 ? "" : _props$excludedates,
67
- _props$showweeks = props.showweeks,
68
- showweeks = _props$showweeks === void 0 ? false : _props$showweeks,
69
- _props$showbuttonbar = props.showbuttonbar,
70
- showbuttonbar = _props$showbuttonbar === void 0 ? true : _props$showbuttonbar,
71
- _props$autofocus = props.autofocus,
72
- autofocus = _props$autofocus === void 0 ? false : _props$autofocus,
73
- _props$readonly = props.readonly,
74
- readonly = _props$readonly === void 0 ? false : _props$readonly,
75
- _props$disabled = props.disabled,
76
- disabled = _props$disabled === void 0 ? false : _props$disabled,
77
- _props$showdropdownon = props.showdropdownon,
78
- showdropdownon = _props$showdropdownon === void 0 ? "default" : _props$showdropdownon,
79
- _props$adaptivepositi = props.adaptiveposition,
80
- adaptiveposition = _props$adaptivepositi === void 0 ? true : _props$adaptivepositi,
81
- _props$selectfromothe = props.selectfromothermonth,
82
- selectfromothermonth = _props$selectfromothe === void 0 ? true : _props$selectfromothe,
83
- _props$todaybutton = props.todaybutton,
84
- todaybutton = _props$todaybutton === void 0 ? true : _props$todaybutton,
85
- _props$clearbutton = props.clearbutton,
86
- clearbutton = _props$clearbutton === void 0 ? true : _props$clearbutton,
87
- _props$todaybuttonlab = props.todaybuttonlabel,
88
- todaybuttonlabel = _props$todaybuttonlab === void 0 ? "Today" : _props$todaybuttonlab,
89
- _props$clearbuttonlab = props.clearbuttonlabel,
90
- clearbuttonlabel = _props$clearbuttonlab === void 0 ? "Clear" : _props$clearbuttonlab,
91
- _props$showcustompick = props.showcustompicker,
92
- showcustompicker = _props$showcustompick === void 0 ? false : _props$showcustompick,
93
- _props$showdateformat = props.showdateformatasplaceholder,
94
- showdateformatasplaceholder = _props$showdateformat === void 0 ? false : _props$showdateformat,
95
- _props$viewmode = props.viewmode,
96
- viewmode = _props$viewmode === void 0 ? "day" : _props$viewmode,
97
- _props$dataentrymode = props.dataentrymode,
98
- dataentrymode = _props$dataentrymode === void 0 ? "default" : _props$dataentrymode,
99
- listener = props.listener,
100
- className = props.className,
101
- styles = props.styles,
102
- _props$validators = props.validators,
103
- validators = _props$validators === void 0 ? [] : _props$validators,
104
- validationmessage = props.validationmessage,
105
- restProps = (0, _objectWithoutProperties2["default"])(props, _excluded);
106
- var _useMemo = (0, _react.useMemo)(function () {
107
- var _listener$localeForma;
108
- return [defaultDateFormat || (listener === null || listener === void 0 || (_listener$localeForma = listener.localeFormats) === null || _listener$localeForma === void 0 ? void 0 : _listener$localeForma.date) || "MMM d, y", selectedLocale || (listener === null || listener === void 0 ? void 0 : listener.selectedLocale) || "en"];
109
- }, [defaultDateFormat, selectedLocale, listener === null || listener === void 0 || (_listener$localeForma2 = listener.localeFormats) === null || _listener$localeForma2 === void 0 ? void 0 : _listener$localeForma2.date, listener === null || listener === void 0 ? void 0 : listener.selectedLocale]),
110
- resolvedDateFormat = _useMemo[0],
111
- currentLocale = _useMemo[1];
112
- var datepattern = (0, _react.useMemo)(function () {
113
- return datepatternProp !== null && datepatternProp !== void 0 ? datepatternProp : resolvedDateFormat;
114
- }, [datepatternProp, resolvedDateFormat]);
115
-
116
- // State
117
- var _useState = (0, _react.useState)(false),
118
- showPicker = _useState[0],
119
- setShowPicker = _useState[1];
120
- var _useState2 = (0, _react.useState)(""),
121
- inputValue = _useState2[0],
122
- setInputValue = _useState2[1];
123
- var _useState3 = (0, _react.useState)(null),
124
- anchorEl = _useState3[0],
125
- setAnchorEl = _useState3[1];
126
- var _useState4 = (0, _react.useState)(false),
127
- invalidDateTimeFormat = _useState4[0],
128
- setInvalidDateTimeFormat = _useState4[1];
129
- var _useState5 = (0, _react.useState)(false),
130
- dateNotInRange = _useState5[0],
131
- setDateNotInRange = _useState5[1];
132
- var _useState6 = (0, _react.useState)(""),
133
- validationFailureMessage = _useState6[0],
134
- setValidationFailureMessage = _useState6[1];
135
- var _useState7 = (0, _react.useState)(viewmode),
136
- calendarViewMode = _useState7[0],
137
- setCalendarViewMode = _useState7[1];
138
- var _useState8 = (0, _react.useState)((0, _momentTimezone["default"])()),
139
- calendarDate = _useState8[0],
140
- setCalendarDate = _useState8[1];
141
- var _useState9 = (0, _react.useState)(null),
142
- selectedDate = _useState9[0],
143
- setSelectedDate = _useState9[1];
144
- var _useState0 = (0, _react.useState)(false),
145
- isCurrentDate = _useState0[0],
146
- setIsCurrentDate = _useState0[1];
147
-
148
- // Refs
149
- var datepickerRef = (0, _react.useRef)(null);
150
- var inputRef = (0, _react.useRef)(null);
151
- var onBeforeloadExecutedRef = (0, _react.useRef)(false);
152
-
153
- // Memoized values
154
- var excludedDaysToDisable = (0, _react.useMemo)(function () {
155
- return (0, _utils.parseExcludedDays)(excludedays);
156
- }, [excludedays]);
157
- var excludedDatesToDisable = (0, _react.useMemo)(function () {
158
- return (0, _utils.parseExcludedDates)(excludedates, _getDateObj);
159
- }, [excludedates, _getDateObj]);
160
- var dateValue = (0, _react.useMemo)(function () {
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 { useState, useRef, useEffect, useCallback, useMemo, forwardRef } from "react";
34
+ import moment from "moment-timezone";
35
+ import { TextField, Box } from "@mui/material";
36
+ import withBaseDateTime from "../../../../higherOrder/BaseDateTime";
37
+ import {
38
+ convertToMomentFormat,
39
+ formatDate,
40
+ parseExcludedDays,
41
+ parseExcludedDates,
42
+ defaultGetDateObj,
43
+ getWidthStyle,
44
+ validateDate
45
+ } from "./utils";
46
+ import DatePickerPopover from "./components/DatePickerPopover";
47
+ import withFormController from "../../../data/form/form-controller/withFormController";
48
+ import { WmButton } from "../../../form/button";
49
+ import withStandalone from "../../../../higherOrder/withStandalone";
50
+ import withBaseWrapper from "../../../../higherOrder/withBaseWrapper";
51
+ const WmDate = forwardRef((props, ref) => {
52
+ var _b;
53
+ const _a = props, {
54
+ name,
55
+ hint,
56
+ shortcutkey,
57
+ datavalue,
58
+ width,
59
+ arialabel,
60
+ invokeOnChange,
61
+ handleKeyDown,
62
+ getDateObj = defaultGetDateObj,
63
+ updatePrevDatavalue,
64
+ updateBoundVariable,
65
+ onChange,
66
+ onClick,
67
+ onFocus,
68
+ onBlur,
69
+ onMouseEnter,
70
+ onMouseLeave,
71
+ onBeforeload,
72
+ placeholder = "Select Date",
73
+ tabindex = 0,
74
+ datepattern: datepatternProp,
75
+ outputformat = "yyyy-MM-dd",
76
+ defaultDateFormat,
77
+ selectedLocale,
78
+ required = false,
79
+ excludedays = "",
80
+ excludedates = "",
81
+ showweeks = false,
82
+ showbuttonbar = true,
83
+ autofocus = false,
84
+ readonly = false,
85
+ disabled = false,
86
+ showdropdownon = "default",
87
+ adaptiveposition = true,
88
+ selectfromothermonth = true,
89
+ todaybutton = true,
90
+ clearbutton = true,
91
+ todaybuttonlabel = "Today",
92
+ clearbuttonlabel = "Clear",
93
+ showcustompicker = false,
94
+ showdateformatasplaceholder = false,
95
+ viewmode = "day",
96
+ dataentrymode = "default",
97
+ listener,
98
+ className,
99
+ styles,
100
+ validators = [],
101
+ validationmessage
102
+ } = _a, restProps = __objRest(_a, [
103
+ "name",
104
+ "hint",
105
+ "shortcutkey",
106
+ "datavalue",
107
+ "width",
108
+ "arialabel",
109
+ "invokeOnChange",
110
+ "handleKeyDown",
111
+ "getDateObj",
112
+ "updatePrevDatavalue",
113
+ "updateBoundVariable",
114
+ "onChange",
115
+ "onClick",
116
+ "onFocus",
117
+ "onBlur",
118
+ "onMouseEnter",
119
+ "onMouseLeave",
120
+ "onBeforeload",
121
+ "placeholder",
122
+ "tabindex",
123
+ "datepattern",
124
+ "outputformat",
125
+ "defaultDateFormat",
126
+ "selectedLocale",
127
+ "required",
128
+ "excludedays",
129
+ "excludedates",
130
+ "showweeks",
131
+ "showbuttonbar",
132
+ "autofocus",
133
+ "readonly",
134
+ "disabled",
135
+ "showdropdownon",
136
+ "adaptiveposition",
137
+ "selectfromothermonth",
138
+ "todaybutton",
139
+ "clearbutton",
140
+ "todaybuttonlabel",
141
+ "clearbuttonlabel",
142
+ "showcustompicker",
143
+ "showdateformatasplaceholder",
144
+ "viewmode",
145
+ "dataentrymode",
146
+ "listener",
147
+ "className",
148
+ "styles",
149
+ "validators",
150
+ "validationmessage"
151
+ ]);
152
+ const [resolvedDateFormat, currentLocale] = useMemo(
153
+ () => {
154
+ var _a2;
155
+ return [
156
+ defaultDateFormat || ((_a2 = listener == null ? void 0 : listener.localeFormats) == null ? void 0 : _a2.date) || "MMM d, y",
157
+ selectedLocale || (listener == null ? void 0 : listener.selectedLocale) || "en"
158
+ ];
159
+ },
160
+ [defaultDateFormat, selectedLocale, (_b = listener == null ? void 0 : listener.localeFormats) == null ? void 0 : _b.date, listener == null ? void 0 : listener.selectedLocale]
161
+ );
162
+ const datepattern = useMemo(
163
+ () => datepatternProp != null ? datepatternProp : resolvedDateFormat,
164
+ [datepatternProp, resolvedDateFormat]
165
+ );
166
+ const [showPicker, setShowPicker] = useState(false);
167
+ const [inputValue, setInputValue] = useState("");
168
+ const [anchorEl, setAnchorEl] = useState(null);
169
+ const [invalidDateTimeFormat, setInvalidDateTimeFormat] = useState(false);
170
+ const [dateNotInRange, setDateNotInRange] = useState(false);
171
+ const [validationFailureMessage, setValidationFailureMessage] = useState("");
172
+ const [calendarViewMode, setCalendarViewMode] = useState(
173
+ viewmode
174
+ );
175
+ const [calendarDate, setCalendarDate] = useState(moment());
176
+ const [selectedDate, setSelectedDate] = useState(null);
177
+ const [isCurrentDate, setIsCurrentDate] = useState(false);
178
+ const datepickerRef = useRef(null);
179
+ const inputRef = useRef(null);
180
+ const onBeforeloadExecutedRef = useRef(false);
181
+ const excludedDaysToDisable = useMemo(() => parseExcludedDays(excludedays), [excludedays]);
182
+ const excludedDatesToDisable = useMemo(
183
+ () => parseExcludedDates(excludedates, getDateObj),
184
+ [excludedates, getDateObj]
185
+ );
186
+ const dateValue = useMemo(() => {
161
187
  if (datavalue === "CURRENT_DATE") {
162
188
  setIsCurrentDate(true);
163
189
  }
164
- return _getDateObj(datavalue);
165
- }, [datavalue, _getDateObj]);
166
-
167
- // Parse min/max dates
168
- var minDateObj = (0, _react.useMemo)(function () {
169
- return restProps.mindate ? _getDateObj(restProps.mindate) : null;
170
- }, [restProps.mindate, _getDateObj]);
171
- var maxDateObj = (0, _react.useMemo)(function () {
172
- return restProps.maxdate ? _getDateObj(restProps.maxdate) : null;
173
- }, [restProps.maxdate, _getDateObj]);
174
-
175
- // Unified validation function - handles both validation messages and UI disabling
176
- var validateDateWithProps = (0, _react.useCallback)(function (date) {
177
- if (!date) return true;
178
- var validation = (0, _utils.validateDate)(date, minDateObj, maxDateObj, excludedDaysToDisable, excludedDatesToDisable, validators, validationmessage);
179
- setDateNotInRange(validation.isOutOfRange);
180
- setValidationFailureMessage(validation.validationMessage || "");
181
- setInvalidDateTimeFormat(false);
182
- return validation.isValid;
183
- }, [minDateObj, maxDateObj, excludedDaysToDisable, excludedDatesToDisable, validators, validationmessage]);
184
-
185
- // Function for calendar UI - returns boolean for disabling dates
186
- var isDateDisabled = (0, _react.useCallback)(function (date) {
187
- if (!(date !== null && date !== void 0 && date.isValid())) return false;
188
- var validation = (0, _utils.validateDate)(date, minDateObj, maxDateObj, excludedDaysToDisable, excludedDatesToDisable, validators, validationmessage);
189
- return validation.isDisabled || false;
190
- }, [minDateObj, maxDateObj, excludedDaysToDisable, excludedDatesToDisable, validators, validationmessage]);
191
- var isNavigationDisabled = (0, _react.useMemo)(function () {
190
+ return getDateObj(datavalue);
191
+ }, [datavalue, getDateObj]);
192
+ const minDateObj = useMemo(() => {
193
+ return restProps.mindate ? getDateObj(restProps.mindate) : null;
194
+ }, [restProps.mindate, getDateObj]);
195
+ const maxDateObj = useMemo(() => {
196
+ return restProps.maxdate ? getDateObj(restProps.maxdate) : null;
197
+ }, [restProps.maxdate, getDateObj]);
198
+ const validateDateWithProps = useCallback(
199
+ (date) => {
200
+ if (!date) return true;
201
+ const validation = validateDate(
202
+ date,
203
+ minDateObj,
204
+ maxDateObj,
205
+ excludedDaysToDisable,
206
+ excludedDatesToDisable,
207
+ validators,
208
+ validationmessage
209
+ );
210
+ setDateNotInRange(validation.isOutOfRange);
211
+ setValidationFailureMessage(validation.validationMessage || "");
212
+ setInvalidDateTimeFormat(false);
213
+ return validation.isValid;
214
+ },
215
+ [
216
+ minDateObj,
217
+ maxDateObj,
218
+ excludedDaysToDisable,
219
+ excludedDatesToDisable,
220
+ validators,
221
+ validationmessage
222
+ ]
223
+ );
224
+ const isDateDisabled = useCallback(
225
+ (date) => {
226
+ if (!(date == null ? void 0 : date.isValid())) return false;
227
+ const validation = validateDate(
228
+ date,
229
+ minDateObj,
230
+ maxDateObj,
231
+ excludedDaysToDisable,
232
+ excludedDatesToDisable,
233
+ validators,
234
+ validationmessage
235
+ );
236
+ return validation.isDisabled || false;
237
+ },
238
+ [
239
+ minDateObj,
240
+ maxDateObj,
241
+ excludedDaysToDisable,
242
+ excludedDatesToDisable,
243
+ validators,
244
+ validationmessage
245
+ ]
246
+ );
247
+ const isNavigationDisabled = useMemo(() => {
192
248
  if (!restProps.mindate || !restProps.maxdate) return false;
193
- var minMoment = (0, _momentTimezone["default"])(_getDateObj(restProps.mindate));
194
- var maxMoment = (0, _momentTimezone["default"])(_getDateObj(restProps.maxdate));
249
+ const minMoment = moment(getDateObj(restProps.mindate));
250
+ const maxMoment = moment(getDateObj(restProps.maxdate));
195
251
  return minMoment.isValid() && maxMoment.isValid() && minMoment.isSame(maxMoment, "day");
196
- }, [restProps.mindate, restProps.maxdate, _getDateObj]);
197
- var shouldOpenOnInput = showdropdownon === "default" || dataentrymode === "picker" && showdropdownon !== "button";
198
-
199
- // Computed values
200
- var getDisplayValue = (0, _react.useCallback)(function () {
252
+ }, [restProps.mindate, restProps.maxdate, getDateObj]);
253
+ const shouldOpenOnInput = showdropdownon === "default" || dataentrymode === "picker" && showdropdownon !== "button";
254
+ const getDisplayValue = useCallback(() => {
201
255
  if (!dateValue) return "";
202
256
  try {
203
- // Use moment with current locale for proper localization
204
- var momentDate = (0, _momentTimezone["default"])(dateValue).locale(currentLocale);
205
- var momentPattern = (0, _utils.convertToMomentFormat)(datepattern);
257
+ const momentDate = moment(dateValue).locale(currentLocale);
258
+ const momentPattern = convertToMomentFormat(datepattern);
206
259
  return momentDate.format(momentPattern);
207
- } catch (_unused) {
260
+ } catch (e) {
208
261
  return "";
209
262
  }
210
263
  }, [dateValue, datepattern, currentLocale]);
211
- var getPlaceholderText = (0, _react.useCallback)(function () {
264
+ const getPlaceholderText = useCallback(() => {
212
265
  return showdateformatasplaceholder ? datepattern.toUpperCase() : placeholder;
213
266
  }, [showdateformatasplaceholder, datepattern, placeholder]);
214
-
215
- // Effects
216
- (0, _react.useEffect)(function () {
267
+ useEffect(() => {
217
268
  if (invalidDateTimeFormat) return;
218
- var displayValue = getDisplayValue();
269
+ const displayValue = getDisplayValue();
219
270
  setInputValue(displayValue);
220
271
  if (dateValue) {
221
- var momentDateValue = (0, _momentTimezone["default"])(dateValue);
272
+ const momentDateValue = moment(dateValue);
222
273
  setSelectedDate(momentDateValue);
223
274
  setCalendarDate(momentDateValue);
224
- if (listener !== null && listener !== void 0 && listener.onChange) {
275
+ if (listener == null ? void 0 : listener.onChange) {
225
276
  listener.onChange(name || props.fieldName, {
226
- displayValue: displayValue,
227
- datavalue: (0, _utils.formatDate)(momentDateValue.toDate(), outputformat),
228
- timestamp: (0, _utils.formatDate)(momentDateValue.toDate(), "timestamp")
277
+ displayValue,
278
+ datavalue: formatDate(momentDateValue.toDate(), outputformat),
279
+ timestamp: formatDate(momentDateValue.toDate(), "timestamp")
229
280
  });
230
281
  }
231
282
  } else if (props.maxdate) {
232
- var maxDate = (0, _momentTimezone["default"])(props.maxdate);
233
-
234
- // Get the current date
235
- var currentDate = (0, _momentTimezone["default"])();
236
- // If maxDate is valid and less than current date, set to maxDate
283
+ const maxDate = moment(props.maxdate);
284
+ const currentDate = moment();
237
285
  if (maxDate.isValid() && maxDate.isBefore(currentDate)) {
238
286
  setSelectedDate(maxDate);
239
287
  setCalendarDate(maxDate);
240
288
  }
241
289
  } else {
242
290
  setSelectedDate(null);
243
- setCalendarDate((0, _momentTimezone["default"])());
291
+ setCalendarDate(moment());
244
292
  }
245
293
  }, [dateValue, getDisplayValue, datavalue, props.maxdate]);
246
- (0, _react.useEffect)(function () {
294
+ useEffect(() => {
247
295
  if (autofocus && inputRef.current) {
248
- var timer = setTimeout(function () {
249
- var _inputRef$current;
250
- return (_inputRef$current = inputRef.current) === null || _inputRef$current === void 0 ? void 0 : _inputRef$current.focus();
296
+ const timer = setTimeout(() => {
297
+ var _a2;
298
+ return (_a2 = inputRef.current) == null ? void 0 : _a2.focus();
251
299
  }, 0);
252
- return function () {
253
- return clearTimeout(timer);
254
- };
300
+ return () => clearTimeout(timer);
255
301
  }
256
302
  }, [autofocus]);
257
- (0, _react.useEffect)(function () {
303
+ useEffect(() => {
258
304
  setCalendarViewMode(viewmode);
259
305
  }, [viewmode]);
260
-
261
- // Update input value when locale changes
262
- (0, _react.useEffect)(function () {
306
+ useEffect(() => {
263
307
  if (dateValue && !invalidDateTimeFormat) {
264
- var newDisplayValue = getDisplayValue();
308
+ const newDisplayValue = getDisplayValue();
265
309
  setInputValue(newDisplayValue);
266
-
267
- // Update listener widget display value if it exists
268
- if (name && listener !== null && listener !== void 0 && listener.Widgets[name]) {
310
+ if (name && (listener == null ? void 0 : listener.Widgets[name])) {
269
311
  listener.Widgets[name].displayValue = newDisplayValue;
270
312
  }
271
313
  }
272
314
  }, [currentLocale, getDisplayValue, dateValue, name, invalidDateTimeFormat]);
273
-
274
- // Call onBeforeload callback on component mount
275
- (0, _react.useEffect)(function () {
276
- var _props$listener;
277
- if (onBeforeload && name && (_props$listener = props.listener) !== null && _props$listener !== void 0 && (_props$listener = _props$listener.Widgets) !== null && _props$listener !== void 0 && _props$listener[name] && !onBeforeloadExecutedRef.current) {
278
- var _props$listener2;
279
- var syntheticEvent = {};
280
- onBeforeload(syntheticEvent, (_props$listener2 = props.listener) === null || _props$listener2 === void 0 || (_props$listener2 = _props$listener2.Widgets) === null || _props$listener2 === void 0 ? void 0 : _props$listener2[name]);
315
+ useEffect(() => {
316
+ var _a2, _b2, _c, _d;
317
+ if (onBeforeload && name && ((_b2 = (_a2 = props.listener) == null ? void 0 : _a2.Widgets) == null ? void 0 : _b2[name]) && !onBeforeloadExecutedRef.current) {
318
+ const syntheticEvent = {};
319
+ onBeforeload(syntheticEvent, (_d = (_c = props.listener) == null ? void 0 : _c.Widgets) == null ? void 0 : _d[name]);
281
320
  onBeforeloadExecutedRef.current = true;
282
321
  }
283
322
  }, [onBeforeload, name]);
284
-
285
- // Event Handlers
286
- var handleOpen = (0, _react.useCallback)(function (event) {
287
- if (disabled || readonly) return;
288
- setAnchorEl(event.currentTarget);
289
- setShowPicker(true);
290
- var targetDate = selectedDate !== null && selectedDate !== void 0 && selectedDate.isValid() ? selectedDate : dateValue ? (0, _momentTimezone["default"])(dateValue) : (0, _momentTimezone["default"])();
291
- setCalendarDate(targetDate);
292
- if (dateValue && !selectedDate) {
293
- setSelectedDate((0, _momentTimezone["default"])(dateValue));
294
- }
295
- setCalendarViewMode(viewmode === "month" ? "month" : viewmode);
296
- }, [disabled, readonly, selectedDate, dateValue, viewmode]);
297
- var clearDateValue = (0, _react.useCallback)(function (invokeOnChange, updatePrevDatavalue, updateBoundVariable, setInputValue, setSelectedDate, setInvalidDateTimeFormat, setDateNotInRange) {
298
- var oldValue = inputValue;
299
- invokeOnChange === null || invokeOnChange === void 0 || invokeOnChange("");
300
- updatePrevDatavalue === null || updatePrevDatavalue === void 0 || updatePrevDatavalue("");
301
- updateBoundVariable === null || updateBoundVariable === void 0 || updateBoundVariable("");
302
- setInputValue === null || setInputValue === void 0 || setInputValue("");
303
- setSelectedDate === null || setSelectedDate === void 0 || setSelectedDate(null);
304
- setInvalidDateTimeFormat === null || setInvalidDateTimeFormat === void 0 || setInvalidDateTimeFormat(false);
305
- setDateNotInRange === null || setDateNotInRange === void 0 || setDateNotInRange(false);
306
- setValidationFailureMessage === null || setValidationFailureMessage === void 0 || setValidationFailureMessage("");
307
- if (listener !== null && listener !== void 0 && listener.onChange) {
308
- listener.onChange(props.fieldName || name, _objectSpread(_objectSpread({}, props), {}, {
309
- datavalue: "",
310
- timestamp: null
311
- }));
312
- }
313
- if (onChange && name && (listener !== null && listener !== void 0 && listener.Widgets[name] || props.standalone)) {
314
- onChange({}, listener === null || listener === void 0 ? void 0 : listener.Widgets[name], "", oldValue);
315
- }
316
- }, [name, onChange, props, inputValue]);
317
- var handleDateSelection = function handleDateSelection(date) {
318
- var shouldClose = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
319
- var dateObj = date.toDate();
323
+ const handleOpen = useCallback(
324
+ (event) => {
325
+ if (disabled || readonly) return;
326
+ setAnchorEl(event.currentTarget);
327
+ setShowPicker(true);
328
+ const targetDate = (selectedDate == null ? void 0 : selectedDate.isValid()) ? selectedDate : dateValue ? moment(dateValue) : moment();
329
+ setCalendarDate(targetDate);
330
+ if (dateValue && !selectedDate) {
331
+ setSelectedDate(moment(dateValue));
332
+ }
333
+ setCalendarViewMode(viewmode === "month" ? "month" : viewmode);
334
+ },
335
+ [disabled, readonly, selectedDate, dateValue, viewmode]
336
+ );
337
+ const clearDateValue = useCallback(
338
+ (invokeOnChange2, updatePrevDatavalue2, updateBoundVariable2, setInputValue2, setSelectedDate2, setInvalidDateTimeFormat2, setDateNotInRange2) => {
339
+ const oldValue = inputValue;
340
+ invokeOnChange2 == null ? void 0 : invokeOnChange2("");
341
+ updatePrevDatavalue2 == null ? void 0 : updatePrevDatavalue2("");
342
+ updateBoundVariable2 == null ? void 0 : updateBoundVariable2("");
343
+ setInputValue2 == null ? void 0 : setInputValue2("");
344
+ setSelectedDate2 == null ? void 0 : setSelectedDate2(null);
345
+ setInvalidDateTimeFormat2 == null ? void 0 : setInvalidDateTimeFormat2(false);
346
+ setDateNotInRange2 == null ? void 0 : setDateNotInRange2(false);
347
+ setValidationFailureMessage == null ? void 0 : setValidationFailureMessage("");
348
+ if (listener == null ? void 0 : listener.onChange) {
349
+ listener.onChange(props.fieldName || name, __spreadProps(__spreadValues({}, props), {
350
+ datavalue: "",
351
+ timestamp: null
352
+ }));
353
+ }
354
+ if (onChange && name && ((listener == null ? void 0 : listener.Widgets[name]) || props.standalone)) {
355
+ onChange({}, listener == null ? void 0 : listener.Widgets[name], "", oldValue);
356
+ }
357
+ },
358
+ [name, onChange, props, inputValue]
359
+ );
360
+ const handleDateSelection = (date, shouldClose = false) => {
361
+ const dateObj = date.toDate();
320
362
  if (!validateDateWithProps(dateObj)) {
321
363
  return;
322
364
  }
@@ -330,8 +372,7 @@ var WmDate = /*#__PURE__*/(0, _react.forwardRef)(function (props, ref) {
330
372
  handleClose();
331
373
  }
332
374
  };
333
- var handleValidationError = function handleValidationError(errorType) {
334
- var isRequired = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
375
+ const handleValidationError = (errorType, isRequired = false) => {
335
376
  if (errorType === "dateNotInRange") {
336
377
  setDateNotInRange(true);
337
378
  setValidationFailureMessage(validationmessage || "Date not in range");
@@ -340,267 +381,346 @@ var WmDate = /*#__PURE__*/(0, _react.forwardRef)(function (props, ref) {
340
381
  setValidationFailureMessage(validationmessage || "Invalid date format");
341
382
  }
342
383
  };
343
- var handleClose = (0, _react.useCallback)(function () {
384
+ const handleClose = useCallback(() => {
344
385
  setAnchorEl(null);
345
386
  setShowPicker(false);
346
- setTimeout(function () {
387
+ setTimeout(() => {
347
388
  if (inputRef.current && !disabled && !readonly) {
348
389
  inputRef.current.focus();
349
390
  }
350
391
  }, 0);
351
392
  }, [disabled, readonly]);
352
- var updateDateValue = (0, _react.useCallback)(function (date) {
353
- var outputValue = (0, _utils.formatDate)(date.toDate(), outputformat);
354
- // Use locale-aware formatting for display value
355
- var displayValue = (0, _momentTimezone["default"])(date.toDate()).locale(currentLocale).format((0, _utils.convertToMomentFormat)(datepattern));
356
- invokeOnChange === null || invokeOnChange === void 0 || invokeOnChange(outputValue);
357
- updatePrevDatavalue === null || updatePrevDatavalue === void 0 || updatePrevDatavalue(outputValue);
358
- updateBoundVariable === null || updateBoundVariable === void 0 || updateBoundVariable(outputValue);
359
- setInputValue(displayValue);
360
- var oldValue = inputValue;
361
- if (name && listener !== null && listener !== void 0 && listener.Widgets[name]) {
362
- listener.Widgets[name].displayValue = displayValue;
363
- }
364
- if (listener !== null && listener !== void 0 && listener.onChange) {
365
- listener.onChange(props.fieldName || name, _objectSpread(_objectSpread({}, props), {}, {
366
- datavalue: outputValue,
367
- timestamp: (0, _utils.formatDate)(date.toDate(), "timestamp")
368
- }));
369
- }
370
- if (onChange && name && (listener !== null && listener !== void 0 && listener.Widgets[name] || props.standalone)) {
371
- onChange({}, name && (listener === null || listener === void 0 ? void 0 : listener.Widgets[name]), outputValue, oldValue);
372
- }
373
- }, [outputformat, datepattern, currentLocale, invokeOnChange, updatePrevDatavalue, updateBoundVariable, inputValue, props.formfield, name, onChange, listener]);
374
- var handleCalendarChange = (0, _react.useCallback)(function (date) {
375
- if (!(date !== null && date !== void 0 && date.isValid())) return;
376
- setCalendarDate(date);
377
- var isMonthOrYearView = viewmode === "month" || viewmode === "year";
378
- if (!isMonthOrYearView) {
379
- var dateObj = date.toDate();
380
- if (!validateDateWithProps(dateObj)) {
381
- return;
393
+ const updateDateValue = useCallback(
394
+ (date) => {
395
+ const outputValue = formatDate(date.toDate(), outputformat);
396
+ const displayValue = moment(date.toDate()).locale(currentLocale).format(convertToMomentFormat(datepattern));
397
+ invokeOnChange == null ? void 0 : invokeOnChange(outputValue);
398
+ updatePrevDatavalue == null ? void 0 : updatePrevDatavalue(outputValue);
399
+ updateBoundVariable == null ? void 0 : updateBoundVariable(outputValue);
400
+ setInputValue(displayValue);
401
+ const oldValue = inputValue;
402
+ if (name && (listener == null ? void 0 : listener.Widgets[name])) {
403
+ listener.Widgets[name].displayValue = displayValue;
382
404
  }
383
- }
384
- handleDateSelection(date, true);
385
- }, [viewmode, validateDateWithProps, handleDateSelection]);
386
- var handleMonthChange = (0, _react.useCallback)(function (value) {
387
- if (!(value !== null && value !== void 0 && value.isValid())) return;
388
- if (viewmode === "month") {
389
- handleCalendarChange(value);
390
- } else {
391
- var newDate = calendarDate.clone().month(value.month()).year(value.year());
392
- setCalendarDate(newDate);
393
- setCalendarViewMode("day");
394
- }
395
- }, [viewmode, calendarDate, handleCalendarChange]);
396
- var handleYearChange = (0, _react.useCallback)(function (value) {
397
- if (!(value !== null && value !== void 0 && value.isValid())) return;
398
- if (viewmode === "year") {
399
- handleCalendarChange(value);
400
- } else if (viewmode === "month") {
401
- var newDate = calendarDate.clone().year(value.year());
402
- setCalendarDate(newDate);
403
- setCalendarViewMode("month");
404
- } else {
405
- var _newDate = calendarDate.clone().year(value.year());
406
- setCalendarDate(_newDate);
407
- setCalendarViewMode("month");
408
- }
409
- }, [viewmode, calendarDate, handleCalendarChange]);
410
- var handleInputChange = (0, _react.useCallback)(function (event) {
411
- if (dataentrymode === "picker") return;
412
- var value = event.target.value;
413
- setInputValue(value);
414
- if (!value) {
415
- clearDateValue(invokeOnChange, updatePrevDatavalue, updateBoundVariable, undefined, setSelectedDate, setInvalidDateTimeFormat, setDateNotInRange);
416
- return;
417
- }
418
- var parsedDate = datepattern === "timestamp" ? (0, _momentTimezone["default"])(parseInt(value, 10)) : (0, _momentTimezone["default"])(value, (0, _utils.convertToMomentFormat)(datepattern), true);
419
- if (!parsedDate.isValid()) {
420
- handleValidationError("invalidFormat", props.required);
421
- if (onChange && name && (listener !== null && listener !== void 0 && listener.Widgets[name] || props.standalone) && props.formfield) {
422
- onChange({}, listener === null || listener === void 0 ? void 0 : listener.Widgets[name], value, inputValue);
405
+ if (listener == null ? void 0 : listener.onChange) {
406
+ listener.onChange(props.fieldName || name, __spreadProps(__spreadValues({}, props), {
407
+ datavalue: outputValue,
408
+ timestamp: formatDate(date.toDate(), "timestamp")
409
+ }));
423
410
  }
424
- return;
425
- }
426
- setInvalidDateTimeFormat(false);
427
- var dateObj = parsedDate.toDate();
428
- if (!validateDateWithProps(dateObj)) {
429
- if (onChange && name && (listener !== null && listener !== void 0 && listener.Widgets[name] || props.standalone) && props.formfield) {
430
- onChange({}, listener === null || listener === void 0 ? void 0 : listener.Widgets[name], value, inputValue);
411
+ if (onChange && name && ((listener == null ? void 0 : listener.Widgets[name]) || props.standalone)) {
412
+ onChange(
413
+ {},
414
+ name && (listener == null ? void 0 : listener.Widgets[name]),
415
+ outputValue,
416
+ oldValue
417
+ );
431
418
  }
432
- return;
433
- }
434
- handleDateSelection(parsedDate, false);
435
- }, [dataentrymode, datepattern, validateDateWithProps, invokeOnChange, updatePrevDatavalue, updateBoundVariable, inputValue]);
436
- var handleInputKeyDown = (0, _react.useCallback)(function (event) {
437
- var allowedKeys = ["Tab", "Escape", "Enter", "ArrowUp", "ArrowDown", "ArrowLeft", "ArrowRight"];
438
- if (dataentrymode === "picker" && !allowedKeys.includes(event.key)) {
439
- event.preventDefault();
440
- return;
441
- }
442
- handleKeyDown === null || handleKeyDown === void 0 || handleKeyDown(event);
443
- switch (event.key) {
444
- case "Enter":
445
- event.preventDefault();
446
- if (!inputValue) {
447
- clearDateValue(invokeOnChange, updatePrevDatavalue, updateBoundVariable, undefined, setSelectedDate, undefined, undefined);
419
+ },
420
+ [
421
+ outputformat,
422
+ datepattern,
423
+ currentLocale,
424
+ invokeOnChange,
425
+ updatePrevDatavalue,
426
+ updateBoundVariable,
427
+ inputValue,
428
+ props.formfield,
429
+ name,
430
+ onChange,
431
+ listener
432
+ ]
433
+ );
434
+ const handleCalendarChange = useCallback(
435
+ (date) => {
436
+ if (!(date == null ? void 0 : date.isValid())) return;
437
+ setCalendarDate(date);
438
+ const isMonthOrYearView = viewmode === "month" || viewmode === "year";
439
+ if (!isMonthOrYearView) {
440
+ const dateObj = date.toDate();
441
+ if (!validateDateWithProps(dateObj)) {
448
442
  return;
449
443
  }
450
- var parsedDate = (0, _momentTimezone["default"])(inputValue, datepattern, true);
451
- if (parsedDate.isValid()) {
452
- var dateObj = parsedDate.toDate();
453
- if (!validateDateWithProps(dateObj)) {
444
+ }
445
+ handleDateSelection(date, true);
446
+ },
447
+ [viewmode, validateDateWithProps, handleDateSelection]
448
+ );
449
+ const handleMonthChange = useCallback(
450
+ (value) => {
451
+ if (!(value == null ? void 0 : value.isValid())) return;
452
+ if (viewmode === "month") {
453
+ handleCalendarChange(value);
454
+ } else {
455
+ const newDate = calendarDate.clone().month(value.month()).year(value.year());
456
+ setCalendarDate(newDate);
457
+ setCalendarViewMode("day");
458
+ }
459
+ },
460
+ [viewmode, calendarDate, handleCalendarChange]
461
+ );
462
+ const handleYearChange = useCallback(
463
+ (value) => {
464
+ if (!(value == null ? void 0 : value.isValid())) return;
465
+ if (viewmode === "year") {
466
+ handleCalendarChange(value);
467
+ } else if (viewmode === "month") {
468
+ const newDate = calendarDate.clone().year(value.year());
469
+ setCalendarDate(newDate);
470
+ setCalendarViewMode("month");
471
+ } else {
472
+ const newDate = calendarDate.clone().year(value.year());
473
+ setCalendarDate(newDate);
474
+ setCalendarViewMode("month");
475
+ }
476
+ },
477
+ [viewmode, calendarDate, handleCalendarChange]
478
+ );
479
+ const handleInputChange = useCallback(
480
+ (event) => {
481
+ if (dataentrymode === "picker") return;
482
+ const value = event.target.value;
483
+ setInputValue(value);
484
+ if (!value) {
485
+ clearDateValue(
486
+ invokeOnChange,
487
+ updatePrevDatavalue,
488
+ updateBoundVariable,
489
+ void 0,
490
+ setSelectedDate,
491
+ setInvalidDateTimeFormat,
492
+ setDateNotInRange
493
+ );
494
+ return;
495
+ }
496
+ const parsedDate = datepattern === "timestamp" ? moment(parseInt(value, 10)) : moment(value, convertToMomentFormat(datepattern), true);
497
+ if (!parsedDate.isValid()) {
498
+ handleValidationError("invalidFormat", props.required);
499
+ if (onChange && name && ((listener == null ? void 0 : listener.Widgets[name]) || props.standalone) && props.formfield) {
500
+ onChange({}, listener == null ? void 0 : listener.Widgets[name], value, inputValue);
501
+ }
502
+ return;
503
+ }
504
+ setInvalidDateTimeFormat(false);
505
+ const dateObj = parsedDate.toDate();
506
+ if (!validateDateWithProps(dateObj)) {
507
+ if (onChange && name && ((listener == null ? void 0 : listener.Widgets[name]) || props.standalone) && props.formfield) {
508
+ onChange({}, listener == null ? void 0 : listener.Widgets[name], value, inputValue);
509
+ }
510
+ return;
511
+ }
512
+ handleDateSelection(parsedDate, false);
513
+ },
514
+ [
515
+ dataentrymode,
516
+ datepattern,
517
+ validateDateWithProps,
518
+ invokeOnChange,
519
+ updatePrevDatavalue,
520
+ updateBoundVariable,
521
+ inputValue
522
+ ]
523
+ );
524
+ const handleInputKeyDown = useCallback(
525
+ (event) => {
526
+ const allowedKeys = [
527
+ "Tab",
528
+ "Escape",
529
+ "Enter",
530
+ "ArrowUp",
531
+ "ArrowDown",
532
+ "ArrowLeft",
533
+ "ArrowRight"
534
+ ];
535
+ if (dataentrymode === "picker" && !allowedKeys.includes(event.key)) {
536
+ event.preventDefault();
537
+ return;
538
+ }
539
+ handleKeyDown == null ? void 0 : handleKeyDown(event);
540
+ switch (event.key) {
541
+ case "Enter":
542
+ event.preventDefault();
543
+ if (!inputValue) {
544
+ clearDateValue(
545
+ invokeOnChange,
546
+ updatePrevDatavalue,
547
+ updateBoundVariable,
548
+ void 0,
549
+ setSelectedDate,
550
+ void 0,
551
+ void 0
552
+ );
454
553
  return;
455
554
  }
456
- handleCalendarChange(parsedDate);
457
- } else {
458
- handleValidationError("invalidFormat", props.required);
459
- }
460
- break;
461
- case "Escape":
462
- handleClose();
463
- break;
464
- case "Tab":
465
- if (showPicker) handleClose();
466
- break;
467
- }
468
- }, [dataentrymode, datepattern, inputValue, showPicker, handleKeyDown, handleCalendarChange, handleClose, validateDateWithProps, invokeOnChange, updatePrevDatavalue, updateBoundVariable]);
469
- var handleTodayClick = (0, _react.useCallback)(function () {
470
- handleCalendarChange((0, _momentTimezone["default"])());
555
+ const parsedDate = moment(inputValue, datepattern, true);
556
+ if (parsedDate.isValid()) {
557
+ const dateObj = parsedDate.toDate();
558
+ if (!validateDateWithProps(dateObj)) {
559
+ return;
560
+ }
561
+ handleCalendarChange(parsedDate);
562
+ } else {
563
+ handleValidationError("invalidFormat", props.required);
564
+ }
565
+ break;
566
+ case "Escape":
567
+ handleClose();
568
+ break;
569
+ case "Tab":
570
+ if (showPicker) handleClose();
571
+ break;
572
+ }
573
+ },
574
+ [
575
+ dataentrymode,
576
+ datepattern,
577
+ inputValue,
578
+ showPicker,
579
+ handleKeyDown,
580
+ handleCalendarChange,
581
+ handleClose,
582
+ validateDateWithProps,
583
+ invokeOnChange,
584
+ updatePrevDatavalue,
585
+ updateBoundVariable
586
+ ]
587
+ );
588
+ const handleTodayClick = useCallback(() => {
589
+ handleCalendarChange(moment());
471
590
  }, [handleCalendarChange]);
472
- var handleClearClick = (0, _react.useCallback)(function () {
473
- clearDateValue(invokeOnChange, updatePrevDatavalue, updateBoundVariable, setInputValue, setSelectedDate, undefined, undefined);
591
+ const handleClearClick = useCallback(() => {
592
+ clearDateValue(
593
+ invokeOnChange,
594
+ updatePrevDatavalue,
595
+ updateBoundVariable,
596
+ setInputValue,
597
+ setSelectedDate,
598
+ void 0,
599
+ void 0
600
+ );
474
601
  handleClose();
475
602
  }, [invokeOnChange, updatePrevDatavalue, updateBoundVariable, handleClose]);
476
- var handleIconButtonClick = (0, _react.useCallback)(function (event) {
477
- if (!disabled && !readonly && event) {
478
- handleOpen(event);
479
- }
480
- }, [disabled, readonly, handleOpen]);
481
- var handleInputClick = (0, _react.useCallback)(function (event) {
482
- if (onClick && name) {
483
- onClick(event, listener === null || listener === void 0 ? void 0 : listener.Widgets[name]);
484
- }
485
- if (shouldOpenOnInput && !readonly && !disabled) {
486
- handleIconButtonClick(event);
487
- }
488
- }, [shouldOpenOnInput, readonly, disabled, handleIconButtonClick]);
489
-
490
- // Render
491
- return __jsx(_material.Box, (0, _extends2["default"])({
492
- className: "ng-pristine ng-valid app-date input-group ng-touched ".concat(className),
493
- ref: datepickerRef,
494
- style: _objectSpread(_objectSpread({}, (0, _utils.getWidthStyle)(width)), styles),
495
- title: hint,
496
- hidden: props.hidden
497
- }, readonly && {
498
- readOnly: true
499
- }, disabled && {
500
- disabled: true
501
- }), __jsx(_material.TextField, {
502
- inputRef: inputRef,
503
- fullWidth: true,
504
- placeholder: getPlaceholderText(),
505
- disabled: disabled || readonly,
506
- "aria-readonly": readonly,
507
- error: Boolean(validationFailureMessage || invalidDateTimeFormat || dateNotInRange),
508
- helperText: validationFailureMessage || (invalidDateTimeFormat ? "Invalid date format" : dateNotInRange ? "Date not in valid range" : ""),
509
- slotProps: {
510
- htmlInput: {
511
- "aria-label": arialabel || "Date input ".concat(getPlaceholderText()),
512
- tabIndex: tabindex,
513
- accessKey: shortcutkey,
514
- "aria-invalid": validationFailureMessage || invalidDateTimeFormat || dateNotInRange,
515
- readOnly: readonly || dataentrymode === "picker",
516
- required: required,
517
- autoFocus: autofocus,
518
- name: name,
519
- className: "form-control app-textbox app-dateinput display-input",
520
- style: _objectSpread({}, (0, _utils.getWidthStyle)(width)),
521
- onMouseEnter: function onMouseEnter(event) {
522
- return _onMouseEnter && name && _onMouseEnter(event, listener === null || listener === void 0 ? void 0 : listener.Widgets[name]);
523
- },
524
- onMouseLeave: function onMouseLeave(event) {
525
- return _onMouseLeave && name && _onMouseLeave(event, listener === null || listener === void 0 ? void 0 : listener.Widgets[name]);
526
- }
603
+ const handleIconButtonClick = useCallback(
604
+ (event) => {
605
+ if (!disabled && !readonly && event) {
606
+ handleOpen(event);
527
607
  }
528
608
  },
529
- InputProps: {
530
- endAdornment: __jsx(_material.Box, {
531
- component: "span",
532
- className: "input-group-btn"
533
- }, __jsx(_button.WmButton, {
534
- type: "button",
535
- className: "btn btn-default btn-time",
536
- tabindex: tabindex,
537
- disabled: disabled || readonly,
538
- "aria-label": inputValue ? "Change Date ".concat(inputValue) : "Choose date by pressing enter",
539
- "aria-haspopup": "true",
540
- "aria-expanded": showPicker,
541
- onClick: handleIconButtonClick
542
- }, __jsx(_material.Box, {
543
- component: "i",
544
- "aria-hidden": "true",
545
- className: "app-icon wm-sl-l sl-calendar"
546
- })))
547
- },
548
- value: inputValue,
549
- onChange: handleInputChange,
550
- onKeyDown: handleInputKeyDown,
551
- onClick: handleInputClick,
552
- onFocus: function onFocus(event) {
553
- return _onFocus && name && _onFocus(event, listener === null || listener === void 0 ? void 0 : listener.Widgets[name]);
554
- },
555
- onBlur: function onBlur(event) {
556
- return _onBlur && name && _onBlur(event, listener === null || listener === void 0 ? void 0 : listener.Widgets[name]);
557
- },
558
- style: (0, _utils.getWidthStyle)(width)
559
- }), showPicker && __jsx(_DatePickerPopover["default"], {
560
- open: showPicker,
561
- anchorEl: anchorEl,
562
- onClose: handleClose,
563
- adaptiveposition: adaptiveposition,
564
- showbuttonbar: showbuttonbar,
565
- todaybutton: todaybutton,
566
- clearbutton: clearbutton,
567
- todaybuttonlabel: todaybuttonlabel,
568
- clearbuttonlabel: clearbuttonlabel,
569
- isNavigationDisabled: isNavigationDisabled,
570
- restProps: restProps,
571
- getDateObj: function getDateObj(date) {
572
- return _getDateObj(date !== null && date !== void 0 ? date : null);
609
+ [disabled, readonly, handleOpen]
610
+ );
611
+ const handleInputClick = useCallback(
612
+ (event) => {
613
+ if (onClick && name) {
614
+ onClick(event, listener == null ? void 0 : listener.Widgets[name]);
615
+ }
616
+ if (shouldOpenOnInput && !readonly && !disabled) {
617
+ handleIconButtonClick(event);
618
+ }
573
619
  },
574
- viewmode: viewmode,
575
- calendarViewMode: calendarViewMode,
576
- calendarDate: calendarDate,
577
- selectedDate: selectedDate,
578
- selectfromothermonth: selectfromothermonth,
579
- showweeks: showweeks,
580
- isDateDisabled: isDateDisabled,
581
- handleYearChange: handleYearChange,
582
- handleMonthChange: handleMonthChange,
583
- handleCalendarChange: handleCalendarChange,
584
- setCalendarViewMode: setCalendarViewMode,
585
- setCalendarDate: setCalendarDate,
586
- handleTodayClick: handleTodayClick,
587
- handleClearClick: handleClearClick,
588
- selectedLocale: currentLocale
589
- }));
620
+ [shouldOpenOnInput, readonly, disabled, handleIconButtonClick]
621
+ );
622
+ return /* @__PURE__ */ jsxs(
623
+ Box,
624
+ __spreadProps(__spreadValues(__spreadValues({
625
+ className: `ng-pristine ng-valid app-date input-group ng-touched ${className}`,
626
+ ref: datepickerRef,
627
+ style: __spreadValues(__spreadValues({}, getWidthStyle(width)), styles),
628
+ title: hint,
629
+ hidden: props.hidden
630
+ }, readonly && { readOnly: true }), disabled && { disabled: true }), {
631
+ children: [
632
+ /* @__PURE__ */ jsx(
633
+ TextField,
634
+ {
635
+ inputRef,
636
+ fullWidth: true,
637
+ placeholder: getPlaceholderText(),
638
+ disabled: disabled || readonly,
639
+ "aria-readonly": readonly,
640
+ error: Boolean(validationFailureMessage || invalidDateTimeFormat || dateNotInRange),
641
+ helperText: validationFailureMessage || (invalidDateTimeFormat ? "Invalid date format" : dateNotInRange ? "Date not in valid range" : ""),
642
+ slotProps: {
643
+ htmlInput: {
644
+ "aria-label": arialabel || `Date input ${getPlaceholderText()}`,
645
+ tabIndex: tabindex,
646
+ accessKey: shortcutkey,
647
+ "aria-invalid": validationFailureMessage || invalidDateTimeFormat || dateNotInRange,
648
+ readOnly: readonly || dataentrymode === "picker",
649
+ required,
650
+ autoFocus: autofocus,
651
+ name,
652
+ className: `form-control app-textbox app-dateinput display-input`,
653
+ style: __spreadValues({}, getWidthStyle(width)),
654
+ onMouseEnter: (event) => onMouseEnter && name && onMouseEnter(event, listener == null ? void 0 : listener.Widgets[name]),
655
+ onMouseLeave: (event) => onMouseLeave && name && onMouseLeave(event, listener == null ? void 0 : listener.Widgets[name])
656
+ }
657
+ },
658
+ InputProps: {
659
+ endAdornment: /* @__PURE__ */ jsx(Box, { component: "span", className: "input-group-btn", children: /* @__PURE__ */ jsx(
660
+ WmButton,
661
+ {
662
+ type: "button",
663
+ className: `btn btn-default btn-time`,
664
+ tabindex,
665
+ disabled: disabled || readonly,
666
+ "aria-label": inputValue ? `Change Date ${inputValue}` : "Choose date by pressing enter",
667
+ "aria-haspopup": "true",
668
+ "aria-expanded": showPicker,
669
+ onClick: handleIconButtonClick,
670
+ children: /* @__PURE__ */ jsx(Box, { component: "i", "aria-hidden": "true", className: "app-icon wm-sl-l sl-calendar" })
671
+ }
672
+ ) })
673
+ },
674
+ value: inputValue,
675
+ onChange: handleInputChange,
676
+ onKeyDown: handleInputKeyDown,
677
+ onClick: handleInputClick,
678
+ onFocus: (event) => onFocus && name && onFocus(event, listener == null ? void 0 : listener.Widgets[name]),
679
+ onBlur: (event) => onBlur && name && onBlur(event, listener == null ? void 0 : listener.Widgets[name]),
680
+ style: getWidthStyle(width)
681
+ }
682
+ ),
683
+ showPicker && /* @__PURE__ */ jsx(
684
+ DatePickerPopover,
685
+ {
686
+ open: showPicker,
687
+ anchorEl,
688
+ onClose: handleClose,
689
+ adaptiveposition,
690
+ showbuttonbar,
691
+ todaybutton,
692
+ clearbutton,
693
+ todaybuttonlabel,
694
+ clearbuttonlabel,
695
+ isNavigationDisabled,
696
+ restProps,
697
+ getDateObj: (date) => getDateObj(date != null ? date : null),
698
+ viewmode,
699
+ calendarViewMode,
700
+ calendarDate,
701
+ selectedDate,
702
+ selectfromothermonth,
703
+ showweeks,
704
+ isDateDisabled,
705
+ handleYearChange,
706
+ handleMonthChange,
707
+ handleCalendarChange,
708
+ setCalendarViewMode,
709
+ setCalendarDate,
710
+ handleTodayClick,
711
+ handleClearClick,
712
+ selectedLocale: currentLocale
713
+ }
714
+ )
715
+ ]
716
+ })
717
+ );
590
718
  });
591
719
  WmDate.displayName = "WmDate";
592
- var WithFormController = (0, _withFormController["default"])(WmDate);
593
-
594
- // @ts-expect-error baseDatetime is valid schenaio
595
- var WmDateStandalone = exports.WmDate = (0, _withStandalone["default"])((0, _BaseDateTime["default"])(WithFormController));
596
- /**
597
- * The WmDate component provides a date picker input with calendar popup and formatting.
598
- *
599
- * - [Playground](https://react-components.wavemaker.ai/?path=/story/input-date--showcase)
600
- *
601
- * - [Docs](https://react-components.wavemaker.ai/?path=/story/input-date--docs)
602
- *
603
- * @param props - {@link WmDateProps}
604
- */
605
- // @ts-expect-error baseDatetime is valid schenaio
606
- var _default = exports["default"] = (0, _withBaseWrapper["default"])((0, _BaseDateTime["default"])(WithFormController));
720
+ const WithFormController = withFormController(WmDate);
721
+ const WmDateStandalone = withStandalone(withBaseDateTime(WithFormController));
722
+ var date_default = withBaseWrapper(withBaseDateTime(WithFormController));
723
+ export {
724
+ WmDateStandalone as WmDate,
725
+ date_default as default
726
+ };