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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (574) hide show
  1. package/.npmignore +4 -0
  2. package/actions/base-action.js +12 -29
  3. package/actions/login-action.js +35 -52
  4. package/actions/logout-action.js +21 -38
  5. package/actions/navigation-action.js +251 -346
  6. package/actions/notification-action.js +121 -149
  7. package/actions/timer-action.js +95 -151
  8. package/actions/toast-provider.js +62 -76
  9. package/actions/toast.js +95 -91
  10. package/actions/toast.service.js +59 -79
  11. package/actions/types/index.js +6 -9
  12. package/components/advanced/carousel/index.js +358 -366
  13. package/components/advanced/carousel/props.js +0 -5
  14. package/components/advanced/carousel/template.js +102 -80
  15. package/components/advanced/login/index.js +227 -285
  16. package/components/advanced/login/props.js +0 -5
  17. package/components/advanced/marquee/index.js +169 -163
  18. package/components/advanced/marquee/props.js +0 -5
  19. package/components/basic/anchor/index.js +207 -187
  20. package/components/basic/anchor/props.js +0 -5
  21. package/components/basic/audio/index.js +110 -72
  22. package/components/basic/audio/props.js +0 -5
  23. package/components/basic/html/index.js +163 -203
  24. package/components/basic/html/props.js +0 -5
  25. package/components/basic/html/utils.js +30 -28
  26. package/components/basic/icon/index.js +98 -84
  27. package/components/basic/icon/props.js +0 -5
  28. package/components/basic/iframe/iframe.utils.js +7 -16
  29. package/components/basic/iframe/index.js +97 -103
  30. package/components/basic/iframe/props.js +0 -5
  31. package/components/basic/label/index.js +156 -134
  32. package/components/basic/label/props.js +0 -5
  33. package/components/basic/message/index.js +129 -113
  34. package/components/basic/message/props.js +0 -5
  35. package/components/basic/picture/index.js +156 -127
  36. package/components/basic/picture/props.js +0 -5
  37. package/components/basic/progress-bar/index.js +240 -176
  38. package/components/basic/progress-bar/props.js +5 -31
  39. package/components/basic/progress-circle/index.js +166 -183
  40. package/components/basic/progress-circle/props.js +14 -34
  41. package/components/basic/richtexteditor/index.js +430 -396
  42. package/components/basic/richtexteditor/props.js +0 -5
  43. package/components/basic/search/index.js +812 -931
  44. package/components/basic/search/props.js +0 -5
  45. package/components/basic/search/providers.js +233 -380
  46. package/components/basic/spinner/index.js +210 -200
  47. package/components/basic/spinner/props.js +4 -22
  48. package/components/basic/tile/index.js +73 -81
  49. package/components/basic/tile/props.js +0 -5
  50. package/components/basic/tree/Components/TreeNodeComponent.js +238 -170
  51. package/components/basic/tree/hooks/useTreePartialNodeApi.js +143 -135
  52. package/components/basic/tree/index.js +378 -454
  53. package/components/basic/tree/props.js +0 -5
  54. package/components/basic/tree/utils.js +129 -185
  55. package/components/basic/video/index.js +161 -107
  56. package/components/basic/video/props.js +0 -5
  57. package/components/chart/index.js +42 -50
  58. package/components/chart/props.js +31 -37
  59. package/components/chart/src/ChartRenderer.js +172 -154
  60. package/components/chart/src/chart.js +391 -213
  61. package/components/chart/src/chartStyles.generated.js +6 -14
  62. package/components/chart/src/chartUtils.js +228 -272
  63. package/components/chart/src/constants.d.ts +13 -0
  64. package/components/chart/src/constants.js +316 -90
  65. package/components/chart/src/d3Setup.js +11 -30
  66. package/components/chart/src/dataUtils.js +362 -446
  67. package/components/chart/src/formatUtils.js +47 -38
  68. package/components/chart/src/index.js +11 -19
  69. package/components/chart/src/nvd3Source.generated.js +5 -13
  70. package/components/chart/src/pieDonutResponsiveLayout.d.ts +5 -0
  71. package/components/chart/src/pieDonutResponsiveLayout.js +76 -96
  72. package/components/chart/src/types.js +0 -5
  73. package/components/common/AppSpinner.js +17 -33
  74. package/components/common/app-spinner.js +11 -22
  75. package/components/common/customTemplate/index.d.ts +3 -0
  76. package/components/common/customTemplate/index.js +6 -0
  77. package/components/common/customTemplate/props.d.ts +20 -0
  78. package/components/common/customTemplate/props.js +0 -0
  79. package/components/common/customTemplate/template.d.ts +3 -0
  80. package/components/common/customTemplate/template.js +27 -0
  81. package/components/common/customTemplate/useCustomTemplate.d.ts +8 -0
  82. package/components/common/customTemplate/useCustomTemplate.js +17 -0
  83. package/components/common/customTemplate/utils.d.ts +6 -0
  84. package/components/common/customTemplate/utils.js +12 -0
  85. package/components/common/index.js +4 -12
  86. package/components/constants.js +81 -77
  87. package/components/container/accordion/accordion-pane/index.js +105 -118
  88. package/components/container/accordion/accordion-pane/props.js +5 -21
  89. package/components/container/accordion/index.js +225 -243
  90. package/components/container/accordion/props.js +5 -16
  91. package/components/container/index.js +214 -150
  92. package/components/container/layout-grid/grid-column/index.js +68 -43
  93. package/components/container/layout-grid/grid-column/props.js +0 -5
  94. package/components/container/layout-grid/grid-row/index.js +12 -29
  95. package/components/container/layout-grid/grid-row/props.js +0 -5
  96. package/components/container/layout-grid/index.js +53 -38
  97. package/components/container/layout-grid/props.js +0 -5
  98. package/components/container/linear-layout/index.js +56 -60
  99. package/components/container/linear-layout/linear-layout-item/index.js +43 -47
  100. package/components/container/linear-layout/linear-layout-item/props.js +0 -5
  101. package/components/container/linear-layout/props.js +0 -5
  102. package/components/container/panel/components/panel-content/index.js +7 -16
  103. package/components/container/panel/components/panel-header/index.js +166 -146
  104. package/components/container/panel/components/panel-header/props.js +0 -5
  105. package/components/container/panel/hooks.js +76 -102
  106. package/components/container/panel/index.js +289 -252
  107. package/components/container/panel/props.js +0 -5
  108. package/components/container/props.js +0 -5
  109. package/components/container/repeat-template/index.js +65 -44
  110. package/components/container/repeat-template/props.js +0 -5
  111. package/components/container/tabs/index.js +517 -526
  112. package/components/container/tabs/props.js +5 -28
  113. package/components/container/tabs/tab-pane/index.js +105 -100
  114. package/components/container/tabs/tab-pane/props.js +0 -5
  115. package/components/container/tabs/utils.js +30 -35
  116. package/components/container/wizard/WizardContext.js +9 -11
  117. package/components/container/wizard/components/StepComponents.js +76 -99
  118. package/components/container/wizard/components/WizardStep.js +107 -85
  119. package/components/container/wizard/index.js +791 -921
  120. package/components/container/wizard/props.js +0 -5
  121. package/components/container/wizard/utils.js +97 -131
  122. package/components/container/wizard/wizard-action/index.js +41 -81
  123. package/components/container/wizard/wizard-step/index.js +140 -120
  124. package/components/data/card/card-actions/index.js +13 -31
  125. package/components/data/card/card-content/index.js +27 -36
  126. package/components/data/card/card-footer/index.js +13 -31
  127. package/components/data/card/index.js +192 -199
  128. package/components/data/card/props.js +0 -5
  129. package/components/data/form/base-form/constant.js +5 -8
  130. package/components/data/form/base-form/hooks/index.js +26 -77
  131. package/components/data/form/base-form/hooks/useFormDataSync.js +106 -212
  132. package/components/data/form/base-form/hooks/useFormOperations.js +109 -161
  133. package/components/data/form/base-form/hooks/useFormSubmission.js +220 -280
  134. package/components/data/form/base-form/hooks/useFormValidation.js +119 -168
  135. package/components/data/form/base-form/hooks/useParentFormRelationship.js +67 -103
  136. package/components/data/form/base-form/index.js +531 -646
  137. package/components/data/form/base-form/props.js +74 -151
  138. package/components/data/form/base-form/utils.js +210 -323
  139. package/components/data/form/dynamic-fields/constant.js +43 -53
  140. package/components/data/form/dynamic-fields/index.js +135 -144
  141. package/components/data/form/dynamic-fields/props.js +0 -5
  142. package/components/data/form/dynamic-fields/utils.js +99 -158
  143. package/components/data/form/form-action/index.js +107 -85
  144. package/components/data/form/form-body/index.js +52 -26
  145. package/components/data/form/form-context.js +43 -59
  146. package/components/data/form/form-controller/hooks/index.js +43 -57
  147. package/components/data/form/form-controller/props.js +5 -8
  148. package/components/data/form/form-controller/utils.js +54 -49
  149. package/components/data/form/form-controller/validation-contrustor.js +203 -426
  150. package/components/data/form/form-controller/withFormController.js +319 -269
  151. package/components/data/form/form-dynamic-section/index.js +47 -41
  152. package/components/data/form/form-dynamic-section/props.js +0 -5
  153. package/components/data/form/form-field/base-field.js +97 -109
  154. package/components/data/form/form-field/index.js +91 -82
  155. package/components/data/form/form-field/props.js +0 -5
  156. package/components/data/form/form-footer/index.js +52 -25
  157. package/components/data/form/form-header/index.js +61 -58
  158. package/components/data/form/index.js +95 -74
  159. package/components/data/form/props.js +0 -5
  160. package/components/data/list/components/GroupHeader.js +34 -33
  161. package/components/data/list/components/GroupedListItems.js +108 -104
  162. package/components/data/list/components/ListContainer.js +22 -27
  163. package/components/data/list/components/ListDND.js +193 -185
  164. package/components/data/list/components/ListHeader.js +32 -49
  165. package/components/data/list/components/ListItem.js +153 -146
  166. package/components/data/list/components/ListItemWithTemplate.js +87 -105
  167. package/components/data/list/components/ListItems.js +180 -194
  168. package/components/data/list/components/ListPagination.js +127 -153
  169. package/components/data/list/components/LoadMoreButton.js +25 -33
  170. package/components/data/list/components/NoDataMessage.js +9 -22
  171. package/components/data/list/components/StandardListItems.js +79 -85
  172. package/components/data/list/components/index.js +31 -119
  173. package/components/data/list/components/props.js +0 -5
  174. package/components/data/list/hooks/index.js +22 -75
  175. package/components/data/list/hooks/props.js +0 -5
  176. package/components/data/list/hooks/useCurrentPageItems.js +20 -38
  177. package/components/data/list/hooks/useGroupedData.js +19 -33
  178. package/components/data/list/hooks/useListData.js +17 -47
  179. package/components/data/list/hooks/useListEffects.js +168 -237
  180. package/components/data/list/hooks/useListEventHandlers.js +301 -285
  181. package/components/data/list/hooks/useListPagination.js +90 -136
  182. package/components/data/list/hooks/useListState.js +49 -91
  183. package/components/data/list/hooks/useListStateManager.js +104 -159
  184. package/components/data/list/hooks/usePaginatedGroupedData.js +74 -110
  185. package/components/data/list/index.d.ts +1 -0
  186. package/components/data/list/index.js +579 -621
  187. package/components/data/list/props.d.ts +4 -0
  188. package/components/data/list/props.js +0 -5
  189. package/components/data/list/templates/media-template.js +29 -50
  190. package/components/data/list/utils/constants.js +20 -32
  191. package/components/data/list/utils/list-helpers.d.ts +2 -1
  192. package/components/data/list/utils/list-helpers.js +71 -115
  193. package/components/data/list/utils/list-widget-methods.js +56 -76
  194. package/components/data/list/utils/widget-instance-utils.js +20 -57
  195. package/components/data/live-filter/index.js +219 -271
  196. package/components/data/live-filter/props.js +5 -12
  197. package/components/data/live-form/index.js +68 -91
  198. package/components/data/live-form/props.js +5 -12
  199. package/components/data/pagination/components/BasicPagination.js +124 -104
  200. package/components/data/pagination/components/ClassicPagination.js +167 -190
  201. package/components/data/pagination/components/InlinePagination.js +97 -98
  202. package/components/data/pagination/components/LoadingComponent.js +17 -30
  203. package/components/data/pagination/components/PageSizeSelector.js +176 -169
  204. package/components/data/pagination/components/PagerNavigation.js +84 -105
  205. package/components/data/pagination/components/TotalRecords.js +48 -47
  206. package/components/data/pagination/components/index.js +14 -47
  207. package/components/data/pagination/components/props.js +0 -5
  208. package/components/data/pagination/hooks/index.js +6 -19
  209. package/components/data/pagination/hooks/props.js +0 -5
  210. package/components/data/pagination/hooks/useNavigationSize.js +12 -21
  211. package/components/data/pagination/hooks/usePagination.js +702 -905
  212. package/components/data/pagination/index.js +336 -389
  213. package/components/data/table/components/AddNewRow.js +122 -154
  214. package/components/data/table/components/EditableCell.js +68 -75
  215. package/components/data/table/components/FieldValidationError.js +19 -20
  216. package/components/data/table/components/RowCells.js +97 -80
  217. package/components/data/table/components/RowExpansionButton.js +43 -39
  218. package/components/data/table/components/SummaryCell.js +54 -88
  219. package/components/data/table/components/SummaryRow.js +45 -52
  220. package/components/data/table/components/SummaryRowFooter.js +35 -42
  221. package/components/data/table/components/TableBody.js +222 -218
  222. package/components/data/table/components/TableDataRow.js +113 -106
  223. package/components/data/table/components/TableFilters.js +391 -390
  224. package/components/data/table/components/TableFooterActions.js +25 -32
  225. package/components/data/table/components/TableHeader.js +460 -435
  226. package/components/data/table/components/TablePanelHeading.js +157 -181
  227. package/components/data/table/components/index.js +27 -95
  228. package/components/data/table/hooks/index.js +21 -230
  229. package/components/data/table/hooks/use-edited-rows.js +59 -94
  230. package/components/data/table/hooks/useCellState.js +58 -83
  231. package/components/data/table/hooks/useCustomExpressionColumns.js +65 -86
  232. package/components/data/table/hooks/useDynamicColumns.js +59 -92
  233. package/components/data/table/hooks/useEditingState.js +30 -41
  234. package/components/data/table/hooks/useFormWidget.js +163 -172
  235. package/components/data/table/hooks/usePaginationState.js +67 -77
  236. package/components/data/table/hooks/usePanelStructure.js +47 -41
  237. package/components/data/table/hooks/useResponsiveColumns.js +14 -20
  238. package/components/data/table/hooks/useRowExpansion.js +131 -127
  239. package/components/data/table/hooks/useRowHandlers.js +56 -69
  240. package/components/data/table/hooks/useRowSelection.js +249 -329
  241. package/components/data/table/hooks/useServerSideSorting.js +109 -175
  242. package/components/data/table/hooks/useTableColumns.js +322 -331
  243. package/components/data/table/hooks/useTableData.js +111 -166
  244. package/components/data/table/hooks/useTableEdit.js +526 -564
  245. package/components/data/table/hooks/useTableEffects.js +60 -107
  246. package/components/data/table/hooks/useTableFilter.js +244 -237
  247. package/components/data/table/hooks/useTableInitialization.js +44 -76
  248. package/components/data/table/hooks/useTableState.js +39 -61
  249. package/components/data/table/hooks/useTableStateManager.js +295 -468
  250. package/components/data/table/index.js +1553 -1713
  251. package/components/data/table/live-table/index.js +157 -219
  252. package/components/data/table/props.js +0 -5
  253. package/components/data/table/table-action/index.js +97 -75
  254. package/components/data/table/table-column/index.js +48 -42
  255. package/components/data/table/table-group/index.js +7 -25
  256. package/components/data/table/table-row/index.js +63 -55
  257. package/components/data/table/table-row-action/index.js +102 -77
  258. package/components/data/table/utils/buildSelectionColumns.js +86 -137
  259. package/components/data/table/utils/columnBuilder.js +116 -158
  260. package/components/data/table/utils/columnProxy.js +48 -66
  261. package/components/data/table/utils/columnWidthDistribution.js +40 -64
  262. package/components/data/table/utils/constants.js +92 -40
  263. package/components/data/table/utils/crud-handlers.js +292 -473
  264. package/components/data/table/utils/dynamic-columns.js +99 -144
  265. package/components/data/table/utils/groupHeaderUtils.js +36 -61
  266. package/components/data/table/utils/index.d.ts +8 -5
  267. package/components/data/table/utils/index.js +419 -639
  268. package/components/data/table/utils/renderDisplayCell.js +127 -169
  269. package/components/data/table/utils/script-page-size-broadcast.js +17 -29
  270. package/components/data/table/utils/selectionUtils.js +59 -113
  271. package/components/data/table/utils/table-helpers.js +38 -74
  272. package/components/data/table/utils/validation.js +35 -78
  273. package/components/data/table/utils/widgetMapping.d.ts +5 -0
  274. package/components/data/table/utils/widgetMapping.js +41 -0
  275. package/components/data/types.js +112 -112
  276. package/components/data/utils/field-data-utils.js +38 -42
  277. package/components/data/utils/filter-field-util.js +42 -44
  278. package/components/data/utils/index.js +112 -111
  279. package/components/dialogs/alert-dialog/index.js +83 -78
  280. package/components/dialogs/alert-dialog/props.js +0 -5
  281. package/components/dialogs/confirm-dialog/index.js +102 -92
  282. package/components/dialogs/confirm-dialog/props.js +0 -5
  283. package/components/dialogs/dialog/index.js +93 -69
  284. package/components/dialogs/dialog/props.js +0 -5
  285. package/components/dialogs/dialog-actions/index.js +12 -26
  286. package/components/dialogs/dialog-actions/props.js +0 -5
  287. package/components/dialogs/dialog-body/index.js +13 -30
  288. package/components/dialogs/dialog-body/props.js +0 -5
  289. package/components/dialogs/dialog-content/index.js +48 -41
  290. package/components/dialogs/dialog-content/props.js +0 -5
  291. package/components/dialogs/dialog-header/index.js +88 -101
  292. package/components/dialogs/dialog-header/props.js +0 -5
  293. package/components/dialogs/iframe-dialog/index.js +136 -128
  294. package/components/dialogs/iframe-dialog/props.js +0 -5
  295. package/components/dialogs/index.js +104 -101
  296. package/components/dialogs/login-dialog/index.js +285 -347
  297. package/components/dialogs/login-dialog/props.js +0 -5
  298. package/components/dialogs/page-dialog/index.js +95 -86
  299. package/components/dialogs/page-dialog/props.js +0 -5
  300. package/components/dialogs/props.js +0 -5
  301. package/components/dialogs/withDialogWrapper.js +110 -83
  302. package/components/form/button/index.js +296 -245
  303. package/components/form/button/props.js +0 -5
  304. package/components/form/button-group/index.js +80 -69
  305. package/components/form/button-group/props.js +0 -5
  306. package/components/input/calendar/index.js +409 -362
  307. package/components/input/calendar/props.js +0 -5
  308. package/components/input/calendar/utils.js +164 -172
  309. package/components/input/chips/SortableChip/index.js +109 -100
  310. package/components/input/chips/SortableChip/props.js +0 -5
  311. package/components/input/chips/index.js +663 -570
  312. package/components/input/chips/props.js +0 -5
  313. package/components/input/chips/utils.js +131 -122
  314. package/components/input/color-picker/index.js +536 -594
  315. package/components/input/color-picker/props.js +0 -5
  316. package/components/input/composite/index.js +71 -110
  317. package/components/input/composite/props.js +0 -5
  318. package/components/input/currency/index.js +277 -224
  319. package/components/input/currency/props.js +0 -5
  320. package/components/input/default/checkbox/index.js +329 -250
  321. package/components/input/default/checkbox/props.js +0 -5
  322. package/components/input/default/checkboxset/index.d.ts +2 -0
  323. package/components/input/default/checkboxset/index.js +529 -446
  324. package/components/input/default/checkboxset/props.d.ts +4 -0
  325. package/components/input/default/checkboxset/props.js +0 -5
  326. package/components/input/default/checkboxset/utils.js +15 -25
  327. package/components/input/default/radioset/index.d.ts +2 -0
  328. package/components/input/default/radioset/index.js +409 -350
  329. package/components/input/default/radioset/props.d.ts +6 -0
  330. package/components/input/default/radioset/props.js +0 -5
  331. package/components/input/default/switch/index.js +494 -458
  332. package/components/input/default/switch/prop.js +0 -5
  333. package/components/input/epoch/date/components/DatePickerPopover.js +242 -193
  334. package/components/input/epoch/date/index.js +638 -518
  335. package/components/input/epoch/date/props.js +0 -5
  336. package/components/input/epoch/date/styled.js +61 -70
  337. package/components/input/epoch/date/utils.js +67 -115
  338. package/components/input/epoch/datetime/index.js +758 -695
  339. package/components/input/epoch/datetime/props.js +0 -5
  340. package/components/input/epoch/datetime/utils.js +121 -186
  341. package/components/input/epoch/time/index.js +441 -415
  342. package/components/input/epoch/time/props.js +0 -5
  343. package/components/input/epoch/time/utils.js +101 -112
  344. package/components/input/fileupload/Utils.js +70 -97
  345. package/components/input/fileupload/components/ListItems.js +132 -130
  346. package/components/input/fileupload/components/MultiUpload.js +80 -77
  347. package/components/input/fileupload/components/SingleUpload.js +57 -57
  348. package/components/input/fileupload/index.js +253 -178
  349. package/components/input/fileupload/props.js +0 -5
  350. package/components/input/fileupload/useFileUpload.js +209 -258
  351. package/components/input/number/index.js +434 -393
  352. package/components/input/number/props.js +0 -5
  353. package/components/input/rating/index.js +401 -394
  354. package/components/input/rating/props.js +0 -5
  355. package/components/input/select/index.js +408 -463
  356. package/components/input/select/props.js +0 -5
  357. package/components/input/slider/index.js +339 -332
  358. package/components/input/slider/props.js +0 -5
  359. package/components/input/text/index.d.ts +3 -3
  360. package/components/input/text/index.js +438 -475
  361. package/components/input/text/props.d.ts +1 -1
  362. package/components/input/text/props.js +0 -5
  363. package/components/input/text/util.js +82 -222
  364. package/components/input/textarea/index.js +322 -358
  365. package/components/input/textarea/props.js +0 -5
  366. package/components/input/upload/index.js +135 -131
  367. package/components/input/upload/props.js +0 -5
  368. package/components/input/util/index.js +9 -11
  369. package/components/layout/footer/index.js +12 -35
  370. package/components/layout/footer/props.js +0 -5
  371. package/components/layout/header/index.js +12 -38
  372. package/components/layout/header/props.js +0 -5
  373. package/components/layout/leftnav/index.js +38 -44
  374. package/components/layout/leftnav/props.js +0 -5
  375. package/components/layout/rightnav/index.js +12 -36
  376. package/components/layout/rightnav/props.js +0 -5
  377. package/components/layout/topnav/index.js +24 -38
  378. package/components/layout/topnav/props.js +0 -5
  379. package/components/navbar/index.js +119 -98
  380. package/components/navbar/nav/index.js +236 -232
  381. package/components/navbar/nav/props.js +0 -5
  382. package/components/navbar/nav-item/index.js +74 -65
  383. package/components/navbar/nav-item/props.js +0 -5
  384. package/components/navigation/breadcrumb/index.js +38 -61
  385. package/components/navigation/breadcrumb/props.js +0 -5
  386. package/components/navigation/menu/components/ListItems.js +76 -67
  387. package/components/navigation/menu/constants.js +27 -42
  388. package/components/navigation/menu/hooks/useHoverState.hook.js +20 -47
  389. package/components/navigation/menu/hooks/useKeyboardMovements.hook.js +34 -28
  390. package/components/navigation/menu/hooks/useTransformedDataset.hook.js +21 -14
  391. package/components/navigation/menu/index.js +911 -846
  392. package/components/navigation/menu/props.js +0 -5
  393. package/components/navigation/menu/utils/action-task.js +6 -9
  394. package/components/navigation/menu/utils/role-filter.js +41 -56
  395. package/components/navigation/popover/index.js +191 -205
  396. package/components/navigation/popover/props.js +5 -8
  397. package/components/page/content/index.js +9 -31
  398. package/components/page/content/props.js +0 -5
  399. package/components/page/error-boundary/index.js +115 -105
  400. package/components/page/error-boundary/props.js +0 -5
  401. package/components/page/index.js +84 -102
  402. package/components/page/page-content/index.js +21 -30
  403. package/components/page/page-content/props.js +0 -5
  404. package/components/page/partial/index.js +50 -45
  405. package/components/page/partial/props.js +0 -5
  406. package/components/page/partial-container/index.js +81 -107
  407. package/components/page/partial-container/props.d.ts +1 -1
  408. package/components/page/partial-container/props.js +0 -5
  409. package/components/page/props.js +0 -5
  410. package/components/page/toast-container/index.js +20 -41
  411. package/components/page/toast-container/props.js +0 -5
  412. package/components/prefab/container/index.js +60 -53
  413. package/components/prefab/container/props.js +0 -5
  414. package/components/prefab/index.js +76 -61
  415. package/components/prefab/props.js +0 -5
  416. package/context/AppContext.d.ts +1 -1
  417. package/context/AppContext.js +17 -18
  418. package/context/AppSpinnerProvider.js +19 -34
  419. package/context/LayoutProvider.js +54 -57
  420. package/context/LocalizationProvider.js +34 -49
  421. package/context/PrefabContext.js +68 -119
  422. package/context/WidgetProvider.js +160 -166
  423. package/core/app-config.js +0 -1
  424. package/core/app.service.js +200 -327
  425. package/core/appVariablesStore.js +10 -15
  426. package/core/appstore.js +37 -53
  427. package/core/constants/currency-constant.js +81 -83
  428. package/core/constants/events.js +34 -44
  429. package/core/constants/index.js +21 -31
  430. package/core/dialog.service.js +52 -72
  431. package/core/event-notifier.js +94 -131
  432. package/core/formatter/array-formatters.js +18 -32
  433. package/core/formatter/date-formatters.js +140 -204
  434. package/core/formatter/index.js +64 -117
  435. package/core/formatter/number-formatters.js +115 -159
  436. package/core/formatter/security-formatters.js +233 -283
  437. package/core/formatter/string-formatters.js +23 -45
  438. package/core/formatter/types.js +12 -18
  439. package/core/formatters.js +6 -24
  440. package/core/proxy-service.js +242 -306
  441. package/core/script-registry.js +87 -134
  442. package/core/security.service.js +8 -11
  443. package/core/util/compare.js +13 -25
  444. package/core/util/dom.js +32 -63
  445. package/core/util/index.d.ts +5 -0
  446. package/core/util/index.js +95 -95
  447. package/core/util/safe-is-equal.js +42 -94
  448. package/core/util/security.js +114 -153
  449. package/core/util/utils.d.ts +8 -1
  450. package/core/util/utils.js +124 -132
  451. package/core/widget-observer.js +34 -61
  452. package/higherOrder/BaseApp.js +327 -500
  453. package/higherOrder/BaseAppProps.js +0 -5
  454. package/higherOrder/BaseDateTime.js +277 -231
  455. package/higherOrder/BasePage.js +479 -735
  456. package/higherOrder/BasePartial.js +87 -114
  457. package/higherOrder/BasePrefab.js +190 -206
  458. package/higherOrder/DataNav.js +287 -302
  459. package/higherOrder/helper.js +62 -48
  460. package/higherOrder/props.js +0 -5
  461. package/higherOrder/withBaseWrapper.js +123 -168
  462. package/higherOrder/withStandalone.js +28 -26
  463. package/hooks/useAccess.js +113 -289
  464. package/hooks/useAppConfig.js +15 -40
  465. package/hooks/useAuth.js +256 -495
  466. package/hooks/useDataSourceSubscription.d.ts +3 -3
  467. package/hooks/useDataSourceSubscription.js +99 -109
  468. package/hooks/useDebounce.js +28 -56
  469. package/hooks/useDeviceVisibility.js +14 -23
  470. package/hooks/useHttp.d.ts +1 -0
  471. package/hooks/useHttp.js +318 -493
  472. package/libs/index.js +4 -13
  473. package/libs/prefab/index.js +6 -20
  474. package/mui-config/theme-provider.js +9 -17
  475. package/mui-config/theme.js +6 -9
  476. package/package-lock.json +808 -3177
  477. package/package.json +3 -19
  478. package/providers/AppProviders.js +21 -24
  479. package/runtime-dynamic/App.js +65 -93
  480. package/runtime-dynamic/app-initializer.js +207 -400
  481. package/runtime-dynamic/components/ErrorBoundary.js +59 -76
  482. package/runtime-dynamic/components/PageWrapper.js +23 -35
  483. package/runtime-dynamic/components/PrefabPreview.js +40 -69
  484. package/runtime-dynamic/components/partial-content.d.ts +2 -3
  485. package/runtime-dynamic/components/partial-content.js +66 -48
  486. package/runtime-dynamic/components/prefab-content.js +37 -30
  487. package/runtime-dynamic/components/use-dynamic-component.js +62 -150
  488. package/runtime-dynamic/factories/build-base-page-like-component.js +44 -58
  489. package/runtime-dynamic/factories/dynamic-component.d.ts +9 -0
  490. package/runtime-dynamic/factories/dynamic-component.js +83 -0
  491. package/runtime-dynamic/factories/prefab-factory.js +60 -81
  492. package/runtime-dynamic/factories/startup-info.js +12 -25
  493. package/runtime-dynamic/factories/utils.d.ts +1 -9
  494. package/runtime-dynamic/factories/utils.js +47 -130
  495. package/runtime-dynamic/index.js +56 -191
  496. package/runtime-dynamic/main.js +42 -70
  497. package/runtime-dynamic/preview-mode.js +14 -29
  498. package/runtime-dynamic/preview-navigation.js +21 -30
  499. package/runtime-dynamic/preview-path.d.ts +5 -0
  500. package/runtime-dynamic/preview-path.js +13 -0
  501. package/runtime-dynamic/preview-resource-base.js +15 -31
  502. package/runtime-dynamic/registry/component-registry.js +269 -334
  503. package/runtime-dynamic/registry/custom-widget-registry.js +11 -15
  504. package/runtime-dynamic/registry/index.js +24 -63
  505. package/runtime-dynamic/registry/store.d.ts +1 -0
  506. package/runtime-dynamic/registry/store.js +18 -23
  507. package/runtime-dynamic/routes.js +53 -81
  508. package/runtime-dynamic/services/app-extension-provider.js +17 -44
  509. package/runtime-dynamic/services/autolayout-inject.d.ts +4 -0
  510. package/runtime-dynamic/services/autolayout-inject.js +27 -0
  511. package/runtime-dynamic/services/cache.js +27 -33
  512. package/runtime-dynamic/services/compile-render.d.ts +9 -0
  513. package/runtime-dynamic/services/compile-render.js +142 -0
  514. package/runtime-dynamic/services/component-ref-provider.js +70 -124
  515. package/runtime-dynamic/services/css-scoping.js +27 -28
  516. package/runtime-dynamic/services/fragment-url.js +37 -50
  517. package/runtime-dynamic/services/index.js +48 -152
  518. package/runtime-dynamic/services/markup-transpiler.d.ts +2 -2
  519. package/runtime-dynamic/services/markup-transpiler.js +39 -231
  520. package/runtime-dynamic/services/prefab-resources.js +42 -130
  521. package/runtime-dynamic/services/resource-manager.d.ts +2 -1
  522. package/runtime-dynamic/services/resource-manager.js +32 -63
  523. package/runtime-dynamic/services/script-executor.js +50 -61
  524. package/runtime-dynamic/services/variable-factory.js +141 -184
  525. package/runtime-dynamic/services/variable-registry.js +69 -115
  526. package/runtime-dynamic/services/variable-transpiler.js +73 -103
  527. package/runtime-dynamic/shims/next-image.js +79 -50
  528. package/runtime-dynamic/shims/next-link.js +58 -32
  529. package/runtime-dynamic/shims/next-navigation.js +17 -34
  530. package/runtime-dynamic/utils/index.d.ts +2 -0
  531. package/runtime-dynamic/utils/index.js +22 -24
  532. package/store/bindActions/i18nActions.js +16 -18
  533. package/store/index.js +29 -35
  534. package/store/middleware/navigationMiddleware.js +25 -45
  535. package/store/middleware/pendingTabNavigationIntentMiddleware.js +20 -25
  536. package/store/slices/appConfigSlice.js +65 -94
  537. package/store/slices/authSlice.js +317 -471
  538. package/store/slices/i18nSlice.js +169 -168
  539. package/store/slices/navigationSlice.js +22 -20
  540. package/store/util/resolve-path.d.ts +1 -0
  541. package/store/util/resolve-path.js +7 -0
  542. package/store/viewport.service.js +150 -194
  543. package/types/index.js +10 -15
  544. package/utils/attr.js +198 -41
  545. package/utils/custom-expression/index.js +55 -151
  546. package/utils/custom-expression/parser.js +106 -182
  547. package/utils/dataset-util.js +113 -154
  548. package/utils/eval-expression.js +10 -19
  549. package/utils/form-state.util.js +60 -118
  550. package/utils/form-utils.js +49 -190
  551. package/utils/format-util.js +113 -184
  552. package/utils/layoutsize-util.js +11 -17
  553. package/utils/lib-error-skipper.js +54 -52
  554. package/utils/page-params-util.js +50 -40
  555. package/utils/pending-tab-navigation-intent.js +7 -17
  556. package/utils/resource-url.js +8 -19
  557. package/utils/state-persistance.js +136 -253
  558. package/utils/style-utils.d.ts +2 -0
  559. package/utils/style-utils.js +25 -74
  560. package/utils/transformedDataset-utils.js +353 -381
  561. package/utils/widget-cleanup-util.js +42 -74
  562. package/utils/widgets.js +19 -31
  563. package/variables/base-variable.js +117 -166
  564. package/variables/constants.js +5 -8
  565. package/variables/crud-variable.js +150 -181
  566. package/variables/live-variable.d.ts +1 -1
  567. package/variables/live-variable.js +140 -174
  568. package/variables/metadata.service.js +74 -116
  569. package/variables/model-variable.js +68 -78
  570. package/variables/service-variable.js +171 -285
  571. package/wm-namespace.js +11 -14
  572. package/components/chart/src/css.d.js +0 -1
  573. package/tsconfig.declaration.tsbuildinfo +0 -1
  574. package/types/global.d.js +0 -3
@@ -1,73 +1,78 @@
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.WmColorPicker = void 0;
9
- var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
10
- var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
11
- var _react = _interopRequireWildcard(require("react"));
12
- var _reactColor = require("react-color");
13
- var _clsx = _interopRequireDefault(require("clsx"));
14
- var _Box = _interopRequireDefault(require("@mui/material/Box"));
15
- var _styles = require("@mui/material/styles");
16
- var _input = require("@base-ui-components/react/input");
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 _reactDom = require("react-dom");
20
- var _withStandalone = _interopRequireDefault(require("@wavemaker-ai/react-runtime/higherOrder/withStandalone"));
21
- var _excluded = ["datavalue", "placeholder", "readonly", "disabled", "required", "name", "shortcutkey", "tabindex", "className", "autoclose", "arialabel", "onDoubleClick", "onMouseEnter", "onMouseLeave", "onFocus", "onBlur", "onClick", "onKeydown", "onKeyup", "onChange", "listener"];
22
- 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); }
23
- var __jsx = _react["default"].createElement;
24
- 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; }
25
- 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; }
26
- // Constants
27
- var AUTOCLOSE_TYPE = {
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 { memo, useRef, useCallback, useState, useEffect } from "react";
34
+ import { ChromePicker } from "react-color";
35
+ import clsx from "clsx";
36
+ import Box from "@mui/material/Box";
37
+ import { useTheme } from "@mui/material/styles";
38
+ import { Input } from "@base-ui-components/react/input";
39
+ import { withBaseWrapper } from "../../../higherOrder/withBaseWrapper";
40
+ import withFormController from "../../data/form/form-controller/withFormController";
41
+ import { createPortal } from "react-dom";
42
+ import withStandalone from "../../../higherOrder/withStandalone";
43
+ const AUTOCLOSE_TYPE = {
28
44
  ALWAYS: "always",
29
45
  OUTSIDECLICK: "outsideClick",
30
46
  NEVER: "disabled"
31
47
  };
32
- var DEFAULT_CLASS = "input-group app-colorpicker";
33
- var PICKER_HEIGHT = 320;
34
- var POSITION_DELAY = 100;
35
-
36
- // Utility Functions
37
- var isValidHexColor = function isValidHexColor(hex) {
48
+ const DEFAULT_CLASS = "input-group app-colorpicker";
49
+ const PICKER_HEIGHT = 320;
50
+ const POSITION_DELAY = 100;
51
+ const isValidHexColor = (hex) => {
38
52
  return /^#([0-9A-F]{3}){1,2}$/i.test(hex);
39
53
  };
40
- var isValidRgbaColor = function isValidRgbaColor(rgba) {
54
+ const isValidRgbaColor = (rgba) => {
41
55
  return /^rgba\(\s*\d+\s*,\s*\d+\s*,\s*\d+\s*,\s*[\d.]+\s*\)$/.test(rgba);
42
56
  };
43
- var isValidRgbColor = function isValidRgbColor(rgb) {
57
+ const isValidRgbColor = (rgb) => {
44
58
  return /^rgb\(\s*\d+\s*,\s*\d+\s*,\s*\d+\s*\)$/.test(rgb);
45
59
  };
46
- var isValidNamedColor = function isValidNamedColor(color) {
47
- var tempElem = document.createElement("div");
60
+ const isValidNamedColor = (color) => {
61
+ const tempElem = document.createElement("div");
48
62
  tempElem.style.color = "";
49
63
  document.body.appendChild(tempElem);
50
- var defaultColor = getComputedStyle(tempElem).color;
64
+ const defaultColor = getComputedStyle(tempElem).color;
51
65
  tempElem.style.color = color;
52
- var computedColor = getComputedStyle(tempElem).color;
66
+ const computedColor = getComputedStyle(tempElem).color;
53
67
  document.body.removeChild(tempElem);
54
-
55
- // If color didn’t change, it's invalid
56
68
  return computedColor !== defaultColor;
57
69
  };
58
- var hexToRgba = function hexToRgba(colorString) {
59
- var defaultColor = {
60
- r: 0,
61
- g: 0,
62
- b: 0,
63
- a: 0
64
- };
70
+ const hexToRgba = (colorString) => {
71
+ const defaultColor = { r: 0, g: 0, b: 0, a: 0 };
65
72
  if (!colorString || colorString === "") {
66
73
  return defaultColor;
67
74
  }
68
-
69
- //Handle RGB format
70
- var rgbMatch = colorString.match(/rgb\((\d+),\s*(\d+),\s*(\d+)\)/);
75
+ const rgbMatch = colorString.match(/rgb\((\d+),\s*(\d+),\s*(\d+)\)/);
71
76
  if (rgbMatch) {
72
77
  return {
73
78
  r: parseInt(rgbMatch[1], 10),
@@ -75,9 +80,7 @@ var hexToRgba = function hexToRgba(colorString) {
75
80
  b: parseInt(rgbMatch[3], 10)
76
81
  };
77
82
  }
78
-
79
- // Handle RGBA format
80
- var rgbaMatch = colorString.match(/rgba\((\d+),\s*(\d+),\s*(\d+),\s*([\d.]+)\)/);
83
+ const rgbaMatch = colorString.match(/rgba\((\d+),\s*(\d+),\s*(\d+),\s*([\d.]+)\)/);
81
84
  if (rgbaMatch) {
82
85
  return {
83
86
  r: parseInt(rgbaMatch[1], 10),
@@ -89,13 +92,8 @@ var hexToRgba = function hexToRgba(colorString) {
89
92
  if (isValidNamedColor(colorString)) {
90
93
  return getNamedColorRgba(colorString) || defaultColor;
91
94
  }
92
-
93
- // Handle HEX format
94
- var hex = colorString.replace("#", "");
95
- var r = 0,
96
- g = 0,
97
- b = 0,
98
- a = 1;
95
+ let hex = colorString.replace("#", "");
96
+ let r = 0, g = 0, b = 0, a = 1;
99
97
  if (hex.length === 3) {
100
98
  r = parseInt(hex.charAt(0).repeat(2), 16);
101
99
  g = parseInt(hex.charAt(1).repeat(2), 16);
@@ -108,582 +106,526 @@ var hexToRgba = function hexToRgba(colorString) {
108
106
  a = parseInt(hex.substring(6, 8), 16) / 255;
109
107
  }
110
108
  }
111
- return {
112
- r: r,
113
- g: g,
114
- b: b,
115
- a: a
116
- };
109
+ return { r, g, b, a };
117
110
  };
118
- var rgbaToHex = function rgbaToHex(color) {
119
- var toHex = function toHex(value) {
120
- return Math.round(value).toString(16).padStart(2, "0");
121
- };
122
- var r = toHex(color.r);
123
- var g = toHex(color.g);
124
- var b = toHex(color.b);
111
+ const rgbaToHex = (color) => {
112
+ const toHex = (value) => Math.round(value).toString(16).padStart(2, "0");
113
+ const r = toHex(color.r);
114
+ const g = toHex(color.g);
115
+ const b = toHex(color.b);
125
116
  if (color.a === 1) {
126
- return "#".concat(r).concat(g).concat(b);
117
+ return `#${r}${g}${b}`;
127
118
  }
128
- var a = toHex(color.a ? color.a * 255 : 255);
129
- return "#".concat(r).concat(g).concat(b).concat(a);
119
+ const a = toHex(color.a ? color.a * 255 : 255);
120
+ return `#${r}${g}${b}${a}`;
130
121
  };
131
- var rgbaToString = function rgbaToString(color) {
132
- if (color.a === undefined) {
133
- return "rgba(".concat(color.r, ",").concat(color.g, ",").concat(color.b, ",1)");
122
+ const rgbaToString = (color) => {
123
+ if (color.a === void 0) {
124
+ return `rgba(${color.r},${color.g},${color.b},1)`;
134
125
  }
135
- return "rgba(".concat(color.r, ",").concat(color.g, ",").concat(color.b, ",").concat(color.a, ")");
126
+ return `rgba(${color.r},${color.g},${color.b},${color.a})`;
136
127
  };
137
- var rgbToString = function rgbToString(color) {
138
- return "rgb(".concat(color.r, ",").concat(color.g, ",").concat(color.b, ")");
128
+ const rgbToString = (color) => {
129
+ return `rgb(${color.r},${color.g},${color.b})`;
139
130
  };
140
-
141
- // get RGBA value from named color
142
- var getNamedColorRgba = function getNamedColorRgba(colorName) {
143
- var tempElem = document.createElement("div");
144
- tempElem.style.display = "none"; // hide element
131
+ const getNamedColorRgba = (colorName) => {
132
+ const tempElem = document.createElement("div");
133
+ tempElem.style.display = "none";
145
134
  document.body.appendChild(tempElem);
146
-
147
- // Get default computed color before setting the name
148
- var defaultColor = getComputedStyle(tempElem).color;
135
+ const defaultColor = getComputedStyle(tempElem).color;
149
136
  tempElem.style.color = colorName;
150
- var computedColor = getComputedStyle(tempElem).color;
137
+ const computedColor = getComputedStyle(tempElem).color;
151
138
  document.body.removeChild(tempElem);
152
-
153
- // If color didn’t change, it's invalid
154
139
  if (computedColor === defaultColor) {
155
140
  return null;
156
141
  }
157
-
158
- // Parse the valid computed color
159
- var rgbaMatch = computedColor.match(/rgba?\((\d+),\s*(\d+),\s*(\d+)(?:,\s*([\d.]+))?\)/);
142
+ const rgbaMatch = computedColor.match(/rgba?\((\d+),\s*(\d+),\s*(\d+)(?:,\s*([\d.]+))?\)/);
160
143
  if (rgbaMatch) {
161
144
  return {
162
145
  r: parseInt(rgbaMatch[1], 10),
163
146
  g: parseInt(rgbaMatch[2], 10),
164
147
  b: parseInt(rgbaMatch[3], 10),
165
- a: rgbaMatch[4] !== undefined ? parseFloat(rgbaMatch[4]) : 1
148
+ a: rgbaMatch[4] !== void 0 ? parseFloat(rgbaMatch[4]) : 1
166
149
  };
167
150
  }
168
- return {
169
- r: 255,
170
- g: 255,
171
- b: 255,
172
- a: 1
173
- };
151
+ return { r: 255, g: 255, b: 255, a: 1 };
174
152
  };
175
-
176
- // Custom Hooks
177
- var useColorValue = function useColorValue(initialValue) {
178
- var _useState = (0, _react.useState)(function () {
179
- return initialValue ? hexToRgba(initialValue) : {
180
- r: 255,
181
- g: 255,
182
- b: 255,
183
- a: 1
184
- };
185
- }),
186
- colorValue = _useState[0],
187
- setColorValue = _useState[1];
188
- var _useState2 = (0, _react.useState)(initialValue || ""),
189
- inputValue = _useState2[0],
190
- setInputValue = _useState2[1];
153
+ const useColorValue = (initialValue) => {
154
+ const [colorValue, setColorValue] = useState(
155
+ () => initialValue ? hexToRgba(initialValue) : { r: 255, g: 255, b: 255, a: 1 }
156
+ );
157
+ const [inputValue, setInputValue] = useState(initialValue || "");
191
158
  return {
192
- colorValue: colorValue,
193
- setColorValue: setColorValue,
194
- inputValue: inputValue,
195
- setInputValue: setInputValue
159
+ colorValue,
160
+ setColorValue,
161
+ inputValue,
162
+ setInputValue
196
163
  };
197
164
  };
198
- var usePickerPosition = function usePickerPosition() {
199
- var _useState3 = (0, _react.useState)({
200
- top: 0,
201
- left: 0,
202
- direction: "down"
203
- }),
204
- position = _useState3[0],
205
- setPosition = _useState3[1];
206
- var calculatePosition = (0, _react.useCallback)(function (containerElement) {
165
+ const usePickerPosition = () => {
166
+ const [position, setPosition] = useState({ top: 0, left: 0, direction: "down" });
167
+ const calculatePosition = useCallback((containerElement) => {
207
168
  if (!containerElement) {
208
- return {
209
- top: 0,
210
- left: 0,
211
- direction: "down"
212
- };
169
+ return { top: 0, left: 0, direction: "down" };
213
170
  }
214
- var rect = containerElement.getBoundingClientRect();
215
- var viewportHeight = window.innerHeight;
216
- var spaceBelow = viewportHeight - rect.bottom;
217
-
218
- // Calculate absolute position using fixed positioning (for portal)
219
- var openUpward = spaceBelow < PICKER_HEIGHT;
220
- var top = openUpward ? rect.top - PICKER_HEIGHT + 50 // Position above if not enough space below
221
- : rect.bottom + 8; // Position below with 8px gap
222
-
171
+ const rect = containerElement.getBoundingClientRect();
172
+ const viewportHeight = window.innerHeight;
173
+ const spaceBelow = viewportHeight - rect.bottom;
174
+ const openUpward = spaceBelow < PICKER_HEIGHT;
175
+ const top = openUpward ? rect.top - PICKER_HEIGHT + 50 : rect.bottom + 8;
223
176
  return {
224
- top: top,
177
+ top,
225
178
  left: rect.left,
226
179
  direction: openUpward ? "up" : "down"
227
180
  };
228
181
  }, []);
229
- return {
230
- position: position,
231
- setPosition: setPosition,
232
- calculatePosition: calculatePosition
233
- };
182
+ return { position, setPosition, calculatePosition };
234
183
  };
235
-
236
- // Main Component
237
- var WmColorPicker = /*#__PURE__*/(0, _react.memo)(function (props) {
238
- var theme = (0, _styles.useTheme)();
239
- var datavalue = props.datavalue,
240
- _props$placeholder = props.placeholder,
241
- placeholder = _props$placeholder === void 0 ? "Select Color" : _props$placeholder,
242
- _props$readonly = props.readonly,
243
- readonly = _props$readonly === void 0 ? false : _props$readonly,
244
- _props$disabled = props.disabled,
245
- disabled = _props$disabled === void 0 ? false : _props$disabled,
246
- _props$required = props.required,
247
- required = _props$required === void 0 ? false : _props$required,
248
- name = props.name,
249
- shortcutkey = props.shortcutkey,
250
- _props$tabindex = props.tabindex,
251
- tabindex = _props$tabindex === void 0 ? 0 : _props$tabindex,
252
- className = props.className,
253
- _props$autoclose = props.autoclose,
254
- autoclose = _props$autoclose === void 0 ? AUTOCLOSE_TYPE.OUTSIDECLICK : _props$autoclose,
255
- arialabel = props.arialabel,
256
- onDoubleClick = props.onDoubleClick,
257
- _onMouseEnter = props.onMouseEnter,
258
- _onMouseLeave = props.onMouseLeave,
259
- onFocus = props.onFocus,
260
- onBlur = props.onBlur,
261
- onClick = props.onClick,
262
- onKeydown = props.onKeydown,
263
- onKeyup = props.onKeyup,
264
- onChange = props.onChange,
265
- listener = props.listener,
266
- restProps = (0, _objectWithoutProperties2["default"])(props, _excluded);
267
-
268
- // Refs
269
- var inputRef = (0, _react.useRef)(null);
270
- var pickerRef = (0, _react.useRef)(null);
271
- var containerRef = (0, _react.useRef)(null);
272
-
273
- // State
274
- var _useState4 = (0, _react.useState)(false),
275
- isOpen = _useState4[0],
276
- setIsOpen = _useState4[1];
277
- var _useState5 = (0, _react.useState)(false),
278
- isInteractingWithPicker = _useState5[0],
279
- setIsInteractingWithPicker = _useState5[1];
280
- var _useState6 = (0, _react.useState)(""),
281
- prevValue = _useState6[0],
282
- setPrevValue = _useState6[1];
283
- var _useState7 = (0, _react.useState)(placeholder),
284
- getPlaceholder = _useState7[0],
285
- setPlaceholder = _useState7[1];
286
-
287
- // Custom hooks
288
- var _useColorValue = useColorValue(datavalue),
289
- colorValue = _useColorValue.colorValue,
290
- setColorValue = _useColorValue.setColorValue,
291
- inputValue = _useColorValue.inputValue,
292
- setInputValue = _useColorValue.setInputValue;
293
- var _usePickerPosition = usePickerPosition(),
294
- pickerPosition = _usePickerPosition.position,
295
- setPickerPosition = _usePickerPosition.setPosition,
296
- calculatePosition = _usePickerPosition.calculatePosition;
297
-
298
- // Computed values
299
- var shouldCloseOnOutsideClick = autoclose === AUTOCLOSE_TYPE.OUTSIDECLICK || autoclose === AUTOCLOSE_TYPE.ALWAYS;
300
- var isReadonlyOrDisabled = readonly || disabled;
301
- var openPicker = (0, _react.useCallback)(function () {
302
- if (!isReadonlyOrDisabled && !isOpen) {
303
- setPickerPosition(calculatePosition(containerRef.current));
304
- setIsOpen(true);
305
- }
306
- }, [isReadonlyOrDisabled, isOpen, calculatePosition, setPickerPosition]);
307
- var closePicker = (0, _react.useCallback)(function () {
308
- if (isOpen && !isInteractingWithPicker) {
309
- setIsOpen(false);
310
- }
311
- }, [isOpen, isInteractingWithPicker]);
312
-
313
- // Register widget methods (open/close) with listener
314
- (0, _react.useEffect)(function () {
315
- if (listener !== null && listener !== void 0 && listener.onChange) {
316
- listener.onChange(props.fieldName || name, {
317
- open: openPicker,
318
- close: closePicker
319
- });
320
- }
321
- }, [openPicker, closePicker]);
322
- var validateAndSetColor = (0, _react.useCallback)(function (value) {
323
- if (!value.trim()) {
324
- setColorValue({
325
- r: 255,
326
- g: 255,
327
- b: 255,
328
- a: 1
329
- });
330
- return "";
331
- }
332
- if (isValidRgbaColor(value)) {
333
- var color = hexToRgba(value);
334
- setColorValue(color);
335
- return rgbaToString(color);
336
- }
337
- if (isValidHexColor(value)) {
338
- var _color = hexToRgba(value);
339
- setColorValue(_color);
340
- return value;
341
- }
342
- if (isValidRgbColor(value)) {
343
- var _color2 = hexToRgba(value);
344
- setColorValue(_color2);
345
- return rgbToString(_color2);
346
- }
347
- var namedColor = isValidNamedColor(value);
348
- if (namedColor) {
349
- var namedColorValue = getNamedColorRgba(value);
350
- setColorValue(namedColorValue);
351
- return rgbaToString(namedColorValue);
352
- }
353
-
354
- // Invalid format
355
- setColorValue({
356
- r: 255,
357
- g: 255,
358
- b: 255,
359
- a: 1
360
- });
361
- return "";
362
- }, [setColorValue]);
363
- var handleInputChange = (0, _react.useCallback)(function (event) {
364
- var newValue = event.target.value;
365
- setInputValue(newValue);
366
- if (newValue === "") {
367
- setPlaceholder(placeholder);
368
- }
369
- // Update color value for valid inputs
370
- if (newValue && (isValidHexColor(newValue) || isValidRgbaColor(newValue) || isValidRgbColor(newValue) || isValidNamedColor(newValue))) {
371
- setColorValue(hexToRgba(newValue));
372
- } else if (!newValue) {
373
- setColorValue({
374
- r: 255,
375
- g: 255,
376
- b: 255,
377
- a: 1
378
- });
379
- }
380
- if (onChange && name) {
381
- onChange(event, listener === null || listener === void 0 ? void 0 : listener.Widgets[name], newValue, colorValue);
382
- }
383
- }, [setInputValue, setColorValue]);
384
- var handleInputBlur = (0, _react.useCallback)(function (event) {
385
- // Close picker logic
386
- if (autoclose !== AUTOCLOSE_TYPE.NEVER && !isInteractingWithPicker && pickerRef.current && !pickerRef.current.contains(event.relatedTarget)) {
387
- setIsOpen(false);
388
- handleFloatingLabel("close");
389
- }
390
-
391
- // Validate and correct input value
392
- if (inputValue) {
393
- var validatedValue = validateAndSetColor(inputValue);
394
- // Check for named color equivalence
395
- var namedColor = getNamedColorRgba(inputValue);
396
- if (validatedValue !== inputValue && !(namedColor && validatedValue === rgbaToString(namedColor))) {
397
- setInputValue(validatedValue);
398
- }
399
- }
400
-
401
- // Call blur handlers
402
- if (onBlur) {
403
- onBlur(event, listener === null || listener === void 0 ? void 0 : listener.Widgets[name]);
404
- }
405
- }, [autoclose, isInteractingWithPicker, inputValue, validateAndSetColor, setInputValue, onBlur]);
406
- var handleInputFocus = (0, _react.useCallback)(function (event) {
407
- if (onFocus) {
408
- onFocus(event, listener === null || listener === void 0 ? void 0 : listener.Widgets[name]);
409
- }
410
- openPicker();
411
- handleFloatingLabel("open");
412
- }, [onFocus, openPicker]);
413
- var handleInputClick = (0, _react.useCallback)(function (event) {
414
- event.stopPropagation();
415
- if (!isReadonlyOrDisabled) {
416
- if (onClick && name) {
417
- onClick(event, listener === null || listener === void 0 ? void 0 : listener.Widgets[name]);
184
+ const WmColorPicker = memo(
185
+ (props) => {
186
+ const theme = useTheme();
187
+ const _a = props, {
188
+ datavalue,
189
+ placeholder = "Select Color",
190
+ readonly = false,
191
+ disabled = false,
192
+ required = false,
193
+ name,
194
+ shortcutkey,
195
+ tabindex = 0,
196
+ className,
197
+ autoclose = AUTOCLOSE_TYPE.OUTSIDECLICK,
198
+ arialabel,
199
+ onDoubleClick: onDoubleClick,
200
+ onMouseEnter,
201
+ onMouseLeave,
202
+ onFocus,
203
+ onBlur,
204
+ onClick,
205
+ onKeydown,
206
+ onKeyup,
207
+ onChange,
208
+ listener
209
+ } = _a, restProps = __objRest(_a, [
210
+ "datavalue",
211
+ "placeholder",
212
+ "readonly",
213
+ "disabled",
214
+ "required",
215
+ "name",
216
+ "shortcutkey",
217
+ "tabindex",
218
+ "className",
219
+ "autoclose",
220
+ "arialabel",
221
+ // Event handlers
222
+ "onDoubleClick",
223
+ "onMouseEnter",
224
+ "onMouseLeave",
225
+ "onFocus",
226
+ "onBlur",
227
+ "onClick",
228
+ "onKeydown",
229
+ "onKeyup",
230
+ "onChange",
231
+ "listener"
232
+ ]);
233
+ const inputRef = useRef(null);
234
+ const pickerRef = useRef(null);
235
+ const containerRef = useRef(null);
236
+ const [isOpen, setIsOpen] = useState(false);
237
+ const [isInteractingWithPicker, setIsInteractingWithPicker] = useState(false);
238
+ const [prevValue, setPrevValue] = useState("");
239
+ const [getPlaceholder, setPlaceholder] = useState(placeholder);
240
+ const { colorValue, setColorValue, inputValue, setInputValue } = useColorValue(datavalue);
241
+ const {
242
+ position: pickerPosition,
243
+ setPosition: setPickerPosition,
244
+ calculatePosition
245
+ } = usePickerPosition();
246
+ const shouldCloseOnOutsideClick = autoclose === AUTOCLOSE_TYPE.OUTSIDECLICK || autoclose === AUTOCLOSE_TYPE.ALWAYS;
247
+ const isReadonlyOrDisabled = readonly || disabled;
248
+ const openPicker = useCallback(() => {
249
+ if (!isReadonlyOrDisabled && !isOpen) {
250
+ setPickerPosition(calculatePosition(containerRef.current));
251
+ setIsOpen(true);
418
252
  }
419
- openPicker();
420
- handleFloatingLabel("open");
421
- }
422
- }, [isReadonlyOrDisabled, onClick, openPicker]);
423
- var handleColorBoxClick = (0, _react.useCallback)(function (event) {
424
- event.stopPropagation();
425
- if (!isReadonlyOrDisabled) {
426
- isOpen ? closePicker() : openPicker();
427
- }
428
- }, [isReadonlyOrDisabled, isOpen, closePicker, openPicker]);
429
- var handleColorChange = (0, _react.useCallback)(function (color, event) {
430
- var _color$rgb = color.rgb,
431
- r = _color$rgb.r,
432
- g = _color$rgb.g,
433
- b = _color$rgb.b,
434
- a = _color$rgb.a;
435
- var rgbaColor = {
436
- r: r,
437
- g: g,
438
- b: b,
439
- a: a
440
- };
441
- setColorValue(rgbaColor);
442
- var newValue = a !== 1 ? rgbaToString(rgbaColor) : rgbaToHex(rgbaColor);
443
- if (inputRef.current) {
444
- inputRef.current.value = newValue;
445
- }
446
- if (listener !== null && listener !== void 0 && listener.Widgets[(props === null || props === void 0 ? void 0 : props.fieldName) || name]) {
447
- listener.Widgets[name].datavalue = newValue;
448
- listener.Widgets[name].displayValue = newValue;
449
- }
450
- setInputValue(newValue);
451
- if (listener !== null && listener !== void 0 && listener.onChange) {
452
- listener.onChange((props === null || props === void 0 ? void 0 : props.fieldName) || name, {
453
- datavalue: newValue
454
- });
455
- }
456
- var customEvent = _objectSpread(_objectSpread({}, event), {}, {
457
- type: "change"
458
- });
459
- if (onChange) {
460
- onChange(customEvent, listener === null || listener === void 0 ? void 0 : listener.Widgets[name], newValue, inputValue);
461
- }
462
- if (autoclose === AUTOCLOSE_TYPE.ALWAYS && !isInteractingWithPicker) {
463
- setTimeout(function () {
464
- return setIsOpen(false);
465
- }, POSITION_DELAY);
466
- }
467
- }, [setColorValue, setInputValue, autoclose, isInteractingWithPicker]);
468
- var handleKeyDown = (0, _react.useCallback)(function (event) {
469
- if (event.key === "Enter") {
470
- setIsOpen(false);
471
- var newValue = event.target.value;
472
- setInputValue(newValue);
473
- if (newValue === "") {
474
- setPlaceholder(placeholder);
253
+ }, [isReadonlyOrDisabled, isOpen, calculatePosition, setPickerPosition]);
254
+ const closePicker = useCallback(() => {
255
+ if (isOpen && !isInteractingWithPicker) {
256
+ setIsOpen(false);
475
257
  }
476
- // Update color value for valid inputs
477
- if (newValue && (isValidHexColor(newValue) || isValidRgbaColor(newValue) || isValidRgbColor(newValue) || isValidNamedColor(newValue))) {
478
- setColorValue(hexToRgba(newValue));
479
- } else if (!newValue) {
480
- setColorValue({
481
- r: 255,
482
- g: 255,
483
- b: 255,
484
- a: 1
258
+ }, [isOpen, isInteractingWithPicker]);
259
+ useEffect(() => {
260
+ if (listener == null ? void 0 : listener.onChange) {
261
+ listener.onChange(props.fieldName || name, {
262
+ open: openPicker,
263
+ close: closePicker
485
264
  });
486
265
  }
487
- }
488
- if (onKeydown) {
489
- onKeydown(event);
490
- }
491
- }, [onKeydown]);
492
-
493
- // Picker interaction handlers
494
- var handlePickerMouseDown = (0, _react.useCallback)(function () {
495
- setIsInteractingWithPicker(true);
496
- }, []);
497
- var handlePickerMouseUp = (0, _react.useCallback)(function () {
498
- setTimeout(function () {
499
- return setIsInteractingWithPicker(false);
500
- }, POSITION_DELAY);
501
- }, []);
502
- var handleFloatingLabel = (0, _react.useCallback)(function (action, currentValue) {
503
- var _containerRef$current;
504
- var captionEl = (_containerRef$current = containerRef.current) === null || _containerRef$current === void 0 ? void 0 : _containerRef$current.closest(".app-composite-widget.caption-floating");
505
- if (!captionEl) return;
506
- if (action === "open") {
507
- // On click/focus - show placeholder and activate floating
508
- captionEl.classList.add("float-active");
509
- setPlaceholder(placeholder);
510
- } else if (action === "close" && (!inputValue || currentValue === "")) {
511
- // On blur - hide placeholder if no value
512
- captionEl.classList.remove("float-active");
513
- setPlaceholder("");
514
- }
515
- }, [inputValue]);
516
-
517
- // Effects
518
- (0, _react.useEffect)(function () {
519
- if (datavalue !== prevValue) {
520
- setPrevValue(datavalue);
521
- if (datavalue) {
522
- try {
523
- handleFloatingLabel("open");
524
- var color = hexToRgba(datavalue);
266
+ }, [openPicker, closePicker]);
267
+ const validateAndSetColor = useCallback(
268
+ (value) => {
269
+ if (!value.trim()) {
270
+ setColorValue({ r: 255, g: 255, b: 255, a: 1 });
271
+ return "";
272
+ }
273
+ if (isValidRgbaColor(value)) {
274
+ const color = hexToRgba(value);
525
275
  setColorValue(color);
526
- var formattedValue = datavalue.startsWith("rgba(") ? datavalue : datavalue.startsWith("#") ? datavalue : "#".concat(datavalue);
527
- setInputValue(formattedValue);
528
- } catch (error) {
529
- console.error("Invalid color format:", error);
530
- setColorValue({
531
- r: 255,
532
- g: 255,
533
- b: 255,
534
- a: 1
276
+ return rgbaToString(color);
277
+ }
278
+ if (isValidHexColor(value)) {
279
+ const color = hexToRgba(value);
280
+ setColorValue(color);
281
+ return value;
282
+ }
283
+ if (isValidRgbColor(value)) {
284
+ const color = hexToRgba(value);
285
+ setColorValue(color);
286
+ return rgbToString(color);
287
+ }
288
+ const namedColor = isValidNamedColor(value);
289
+ if (namedColor) {
290
+ const namedColorValue = getNamedColorRgba(value);
291
+ setColorValue(namedColorValue);
292
+ return rgbaToString(namedColorValue);
293
+ }
294
+ setColorValue({ r: 255, g: 255, b: 255, a: 1 });
295
+ return "";
296
+ },
297
+ [setColorValue]
298
+ );
299
+ const handleInputChange = useCallback(
300
+ (event) => {
301
+ const newValue = event.target.value;
302
+ setInputValue(newValue);
303
+ if (newValue === "") {
304
+ setPlaceholder(placeholder);
305
+ }
306
+ if (newValue && (isValidHexColor(newValue) || isValidRgbaColor(newValue) || isValidRgbColor(newValue) || isValidNamedColor(newValue))) {
307
+ setColorValue(hexToRgba(newValue));
308
+ } else if (!newValue) {
309
+ setColorValue({ r: 255, g: 255, b: 255, a: 1 });
310
+ }
311
+ if (onChange && name) {
312
+ onChange(
313
+ event,
314
+ listener == null ? void 0 : listener.Widgets[name],
315
+ newValue,
316
+ colorValue
317
+ );
318
+ }
319
+ },
320
+ [setInputValue, setColorValue]
321
+ );
322
+ const handleInputBlur = useCallback(
323
+ (event) => {
324
+ if (autoclose !== AUTOCLOSE_TYPE.NEVER && !isInteractingWithPicker && pickerRef.current && !pickerRef.current.contains(event.relatedTarget)) {
325
+ setIsOpen(false);
326
+ handleFloatingLabel("close");
327
+ }
328
+ if (inputValue) {
329
+ const validatedValue = validateAndSetColor(inputValue);
330
+ const namedColor = getNamedColorRgba(inputValue);
331
+ if (validatedValue !== inputValue && !(namedColor && validatedValue === rgbaToString(namedColor))) {
332
+ setInputValue(validatedValue);
333
+ }
334
+ }
335
+ if (onBlur) {
336
+ onBlur(event, listener == null ? void 0 : listener.Widgets[name]);
337
+ }
338
+ },
339
+ [autoclose, isInteractingWithPicker, inputValue, validateAndSetColor, setInputValue, onBlur]
340
+ );
341
+ const handleInputFocus = useCallback(
342
+ (event) => {
343
+ if (onFocus) {
344
+ onFocus(event, listener == null ? void 0 : listener.Widgets[name]);
345
+ }
346
+ openPicker();
347
+ handleFloatingLabel("open");
348
+ },
349
+ [onFocus, openPicker]
350
+ );
351
+ const handleInputClick = useCallback(
352
+ (event) => {
353
+ event.stopPropagation();
354
+ if (!isReadonlyOrDisabled) {
355
+ if (onClick && name) {
356
+ onClick(event, listener == null ? void 0 : listener.Widgets[name]);
357
+ }
358
+ openPicker();
359
+ handleFloatingLabel("open");
360
+ }
361
+ },
362
+ [isReadonlyOrDisabled, onClick, openPicker]
363
+ );
364
+ const handleColorBoxClick = useCallback(
365
+ (event) => {
366
+ event.stopPropagation();
367
+ if (!isReadonlyOrDisabled) {
368
+ isOpen ? closePicker() : openPicker();
369
+ }
370
+ },
371
+ [isReadonlyOrDisabled, isOpen, closePicker, openPicker]
372
+ );
373
+ const handleColorChange = useCallback(
374
+ (color, event) => {
375
+ const { r, g, b, a } = color.rgb;
376
+ const rgbaColor = { r, g, b, a };
377
+ setColorValue(rgbaColor);
378
+ const newValue = a !== 1 ? rgbaToString(rgbaColor) : rgbaToHex(rgbaColor);
379
+ if (inputRef.current) {
380
+ inputRef.current.value = newValue;
381
+ }
382
+ if (listener == null ? void 0 : listener.Widgets[(props == null ? void 0 : props.fieldName) || name]) {
383
+ listener.Widgets[name].datavalue = newValue;
384
+ listener.Widgets[name].displayValue = newValue;
385
+ }
386
+ setInputValue(newValue);
387
+ if (listener == null ? void 0 : listener.onChange) {
388
+ listener.onChange((props == null ? void 0 : props.fieldName) || name, {
389
+ datavalue: newValue
535
390
  });
536
- setInputValue("");
537
391
  }
538
- } else {
539
- setColorValue({
540
- r: 255,
541
- g: 255,
542
- b: 255,
543
- a: 1
392
+ const customEvent = __spreadProps(__spreadValues({}, event), {
393
+ type: "change"
544
394
  });
545
- setInputValue("");
546
- }
547
- }
548
- }, [datavalue, prevValue, setColorValue, setInputValue]);
549
-
550
- // Outside click handler
551
- (0, _react.useEffect)(function () {
552
- if (!isOpen || !shouldCloseOnOutsideClick) return;
553
- var handleClickOutside = function handleClickOutside(event) {
554
- var target = event.target;
555
- if (!isInteractingWithPicker && pickerRef.current && !pickerRef.current.contains(target) && containerRef.current && !containerRef.current.contains(target)) {
556
- var _inputRef$current;
557
- setIsOpen(false);
558
- var currentValue = ((_inputRef$current = inputRef.current) === null || _inputRef$current === void 0 ? void 0 : _inputRef$current.value) || "";
559
- if (currentValue === "") {
395
+ if (onChange) {
396
+ onChange(
397
+ customEvent,
398
+ listener == null ? void 0 : listener.Widgets[name],
399
+ newValue,
400
+ inputValue
401
+ );
402
+ }
403
+ if (autoclose === AUTOCLOSE_TYPE.ALWAYS && !isInteractingWithPicker) {
404
+ setTimeout(() => setIsOpen(false), POSITION_DELAY);
405
+ }
406
+ },
407
+ [setColorValue, setInputValue, autoclose, isInteractingWithPicker]
408
+ );
409
+ const handleKeyDown = useCallback(
410
+ (event) => {
411
+ if (event.key === "Enter") {
412
+ setIsOpen(false);
413
+ const newValue = event.target.value;
414
+ setInputValue(newValue);
415
+ if (newValue === "") {
416
+ setPlaceholder(placeholder);
417
+ }
418
+ if (newValue && (isValidHexColor(newValue) || isValidRgbaColor(newValue) || isValidRgbColor(newValue) || isValidNamedColor(newValue))) {
419
+ setColorValue(hexToRgba(newValue));
420
+ } else if (!newValue) {
421
+ setColorValue({ r: 255, g: 255, b: 255, a: 1 });
422
+ }
423
+ }
424
+ if (onKeydown) {
425
+ onKeydown(event);
426
+ }
427
+ },
428
+ [onKeydown]
429
+ );
430
+ const handlePickerMouseDown = useCallback(() => {
431
+ setIsInteractingWithPicker(true);
432
+ }, []);
433
+ const handlePickerMouseUp = useCallback(() => {
434
+ setTimeout(() => setIsInteractingWithPicker(false), POSITION_DELAY);
435
+ }, []);
436
+ const handleFloatingLabel = useCallback(
437
+ (action, currentValue) => {
438
+ var _a2;
439
+ const captionEl = (_a2 = containerRef.current) == null ? void 0 : _a2.closest(".app-composite-widget.caption-floating");
440
+ if (!captionEl) return;
441
+ if (action === "open") {
442
+ captionEl.classList.add("float-active");
443
+ setPlaceholder(placeholder);
444
+ } else if (action === "close" && (!inputValue || currentValue === "")) {
445
+ captionEl.classList.remove("float-active");
446
+ setPlaceholder("");
447
+ }
448
+ },
449
+ [inputValue]
450
+ );
451
+ useEffect(() => {
452
+ if (datavalue !== prevValue) {
453
+ setPrevValue(datavalue);
454
+ if (datavalue) {
455
+ try {
456
+ handleFloatingLabel("open");
457
+ const color = hexToRgba(datavalue);
458
+ setColorValue(color);
459
+ const formattedValue = datavalue.startsWith("rgba(") ? datavalue : datavalue.startsWith("#") ? datavalue : `#${datavalue}`;
460
+ setInputValue(formattedValue);
461
+ } catch (error) {
462
+ console.error("Invalid color format:", error);
463
+ setColorValue({ r: 255, g: 255, b: 255, a: 1 });
464
+ setInputValue("");
465
+ }
466
+ } else {
467
+ setColorValue({ r: 255, g: 255, b: 255, a: 1 });
560
468
  setInputValue("");
561
- handleFloatingLabel("close", currentValue);
562
469
  }
563
470
  }
471
+ }, [datavalue, prevValue, setColorValue, setInputValue]);
472
+ useEffect(() => {
473
+ if (!isOpen || !shouldCloseOnOutsideClick) return;
474
+ const handleClickOutside = (event) => {
475
+ var _a2;
476
+ const target = event.target;
477
+ if (!isInteractingWithPicker && pickerRef.current && !pickerRef.current.contains(target) && containerRef.current && !containerRef.current.contains(target)) {
478
+ setIsOpen(false);
479
+ const currentValue = ((_a2 = inputRef.current) == null ? void 0 : _a2.value) || "";
480
+ if (currentValue === "") {
481
+ setInputValue("");
482
+ handleFloatingLabel("close", currentValue);
483
+ }
484
+ }
485
+ };
486
+ document.addEventListener("mousedown", handleClickOutside, true);
487
+ return () => document.removeEventListener("mousedown", handleClickOutside, true);
488
+ }, [isOpen, shouldCloseOnOutsideClick, isInteractingWithPicker]);
489
+ useEffect(() => {
490
+ if (!isOpen) return;
491
+ const handleEscape = (event) => {
492
+ if (event.key === "Escape" || event.key === "Esc") {
493
+ setIsOpen(false);
494
+ }
495
+ };
496
+ window.addEventListener("keydown", handleEscape);
497
+ return () => window.removeEventListener("keydown", handleEscape);
498
+ }, [isOpen]);
499
+ useEffect(() => {
500
+ if (!isOpen) return;
501
+ const updatePosition = () => {
502
+ setPickerPosition(calculatePosition(containerRef.current));
503
+ };
504
+ window.addEventListener("scroll", updatePosition, true);
505
+ window.addEventListener("resize", updatePosition);
506
+ return () => {
507
+ window.removeEventListener("scroll", updatePosition, true);
508
+ window.removeEventListener("resize", updatePosition);
509
+ };
510
+ }, [isOpen, calculatePosition, setPickerPosition]);
511
+ const checkPlaceholder = () => {
512
+ setTimeout(() => {
513
+ var _a2;
514
+ const captionEl = (_a2 = containerRef.current) == null ? void 0 : _a2.closest(".app-composite-widget.caption-floating");
515
+ if (captionEl && !captionEl.classList.contains("float-active")) {
516
+ setPlaceholder("");
517
+ } else {
518
+ setPlaceholder(placeholder);
519
+ }
520
+ }, 100);
564
521
  };
565
- document.addEventListener("mousedown", handleClickOutside, true);
566
- return function () {
567
- return document.removeEventListener("mousedown", handleClickOutside, true);
568
- };
569
- }, [isOpen, shouldCloseOnOutsideClick, isInteractingWithPicker]);
570
-
571
- // Escape key handler
572
- (0, _react.useEffect)(function () {
573
- if (!isOpen) return;
574
- var handleEscape = function handleEscape(event) {
575
- if (event.key === "Escape" || event.key === "Esc") {
576
- setIsOpen(false);
577
- }
578
- };
579
- window.addEventListener("keydown", handleEscape);
580
- return function () {
581
- return window.removeEventListener("keydown", handleEscape);
582
- };
583
- }, [isOpen]);
584
-
585
- // Update picker position on scroll or resize
586
- (0, _react.useEffect)(function () {
587
- if (!isOpen) return;
588
- var updatePosition = function updatePosition() {
589
- setPickerPosition(calculatePosition(containerRef.current));
590
- };
591
- window.addEventListener("scroll", updatePosition, true);
592
- window.addEventListener("resize", updatePosition);
593
- return function () {
594
- window.removeEventListener("scroll", updatePosition, true);
595
- window.removeEventListener("resize", updatePosition);
596
- };
597
- }, [isOpen, calculatePosition, setPickerPosition]);
598
- var checkPlaceholder = function checkPlaceholder() {
599
- setTimeout(function () {
600
- var _containerRef$current2;
601
- var captionEl = (_containerRef$current2 = containerRef.current) === null || _containerRef$current2 === void 0 ? void 0 : _containerRef$current2.closest(".app-composite-widget.caption-floating");
602
- // For floating labels: show placeholder only when user has interacted and no value
603
- if (captionEl && !captionEl.classList.contains("float-active")) {
604
- setPlaceholder("");
605
- } else {
606
- setPlaceholder(placeholder);
522
+ useEffect(() => {
523
+ checkPlaceholder();
524
+ }, [inputValue, isInteractingWithPicker]);
525
+ return /* @__PURE__ */ jsxs(
526
+ Box,
527
+ {
528
+ className: clsx(DEFAULT_CLASS, "wm-colorpicker-root", className),
529
+ tabIndex: tabindex,
530
+ onKeyDown: handleKeyDown,
531
+ ref: containerRef,
532
+ name,
533
+ children: [
534
+ /* @__PURE__ */ jsx(
535
+ Input,
536
+ {
537
+ ref: inputRef,
538
+ type: "text",
539
+ className: "form-control app-textbox",
540
+ name,
541
+ value: inputValue,
542
+ placeholder: getPlaceholder,
543
+ disabled: disabled || readonly,
544
+ required,
545
+ tabIndex: tabindex,
546
+ accessKey: shortcutkey,
547
+ onChange: handleInputChange,
548
+ onBlur: handleInputBlur,
549
+ onFocus: handleInputFocus,
550
+ onClick: handleInputClick,
551
+ onMouseEnter: (event) => onMouseEnter && onMouseEnter(event, listener == null ? void 0 : listener.Widgets[name]),
552
+ onMouseLeave: (event) => onMouseLeave && onMouseLeave(event, listener == null ? void 0 : listener.Widgets[name]),
553
+ "aria-label": arialabel,
554
+ "aria-readonly": readonly
555
+ }
556
+ ),
557
+ /* @__PURE__ */ jsx(
558
+ Box,
559
+ {
560
+ component: "span",
561
+ className: clsx(
562
+ "input-group-addon colorpicker-container",
563
+ isReadonlyOrDisabled ? "wm-colorpicker-addon-disabled" : "wm-colorpicker-addon-enabled"
564
+ ),
565
+ onClick: handleColorBoxClick,
566
+ children: /* @__PURE__ */ jsx(
567
+ Box,
568
+ {
569
+ component: "i",
570
+ className: "colored-box wm-colorpicker-swatch",
571
+ style: {
572
+ "--colorpicker-swatch-bg": inputValue ? rgbaToString(colorValue) : "transparent"
573
+ }
574
+ }
575
+ )
576
+ }
577
+ ),
578
+ isOpen && createPortal(
579
+ /* @__PURE__ */ jsx(
580
+ Box,
581
+ {
582
+ className: clsx(
583
+ "color-picker",
584
+ "wm-colorpicker-popup",
585
+ pickerPosition.direction === "down" ? "wm-colorpicker-popup-direction-down" : "wm-colorpicker-popup-direction-up"
586
+ ),
587
+ ref: pickerRef,
588
+ style: {
589
+ "--colorpicker-popup-top": `${pickerPosition.top}px`,
590
+ "--colorpicker-popup-left": `${pickerPosition.left}px`,
591
+ "--colorpicker-popup-margin-top": theme.spacing(1)
592
+ },
593
+ onClick: (e) => e.stopPropagation(),
594
+ onMouseDown: handlePickerMouseDown,
595
+ onMouseUp: handlePickerMouseUp,
596
+ children: /* @__PURE__ */ jsx(ChromePicker, { color: colorValue, onChange: handleColorChange })
597
+ }
598
+ ),
599
+ document.body
600
+ )
601
+ ]
607
602
  }
608
- }, 100);
609
- };
610
- (0, _react.useEffect)(function () {
611
- checkPlaceholder();
612
- }, [inputValue, isInteractingWithPicker]);
613
-
614
- // Render
615
- return __jsx(_Box["default"], {
616
- className: (0, _clsx["default"])(DEFAULT_CLASS, "wm-colorpicker-root", className),
617
- tabIndex: tabindex,
618
- onKeyDown: handleKeyDown,
619
- ref: containerRef,
620
- name: name
621
- }, __jsx(_input.Input, {
622
- ref: inputRef,
623
- type: "text",
624
- className: "form-control app-textbox",
625
- name: name,
626
- value: inputValue,
627
- placeholder: getPlaceholder,
628
- disabled: disabled || readonly,
629
- required: required,
630
- tabIndex: tabindex,
631
- accessKey: shortcutkey,
632
- onChange: handleInputChange,
633
- onBlur: handleInputBlur,
634
- onFocus: handleInputFocus,
635
- onClick: handleInputClick,
636
- onMouseEnter: function onMouseEnter(event) {
637
- return _onMouseEnter && _onMouseEnter(event, listener === null || listener === void 0 ? void 0 : listener.Widgets[name]);
638
- },
639
- onMouseLeave: function onMouseLeave(event) {
640
- return _onMouseLeave && _onMouseLeave(event, listener === null || listener === void 0 ? void 0 : listener.Widgets[name]);
641
- },
642
- "aria-label": arialabel,
643
- "aria-readonly": readonly
644
- }), __jsx(_Box["default"], {
645
- component: "span",
646
- className: (0, _clsx["default"])("input-group-addon colorpicker-container", isReadonlyOrDisabled ? "wm-colorpicker-addon-disabled" : "wm-colorpicker-addon-enabled"),
647
- onClick: handleColorBoxClick
648
- }, __jsx(_Box["default"], {
649
- component: "i",
650
- className: "colored-box wm-colorpicker-swatch",
651
- style: {
652
- "--colorpicker-swatch-bg": inputValue ? rgbaToString(colorValue) : "transparent"
653
- }
654
- })), isOpen && /*#__PURE__*/(0, _reactDom.createPortal)(__jsx(_Box["default"], {
655
- className: (0, _clsx["default"])("color-picker", "wm-colorpicker-popup", pickerPosition.direction === "down" ? "wm-colorpicker-popup-direction-down" : "wm-colorpicker-popup-direction-up"),
656
- ref: pickerRef,
657
- style: {
658
- "--colorpicker-popup-top": "".concat(pickerPosition.top, "px"),
659
- "--colorpicker-popup-left": "".concat(pickerPosition.left, "px"),
660
- "--colorpicker-popup-margin-top": theme.spacing(1)
661
- },
662
- onClick: function onClick(e) {
663
- return e.stopPropagation();
664
- },
665
- onMouseDown: handlePickerMouseDown,
666
- onMouseUp: handlePickerMouseUp
667
- }, __jsx(_reactColor.ChromePicker, {
668
- color: colorValue,
669
- onChange: handleColorChange
670
- })), document.body));
671
- }, function (prevProps, nextProps) {
672
- var keysToCompare = ["datavalue", "placeholder", "readonly", "disabled", "required", "name", "shortcutkey", "show", "tabindex", "autoclose", "arialabel", "hidden", "show"];
673
- return keysToCompare.every(function (key) {
674
- return prevProps[key] === nextProps[key];
675
- });
676
- });
603
+ );
604
+ },
605
+ (prevProps, nextProps) => {
606
+ const keysToCompare = [
607
+ "datavalue",
608
+ "placeholder",
609
+ "readonly",
610
+ "disabled",
611
+ "required",
612
+ "name",
613
+ "shortcutkey",
614
+ "show",
615
+ "tabindex",
616
+ "autoclose",
617
+ "arialabel",
618
+ "hidden",
619
+ "show"
620
+ ];
621
+ return keysToCompare.every((key) => prevProps[key] === nextProps[key]);
622
+ }
623
+ );
677
624
  WmColorPicker.displayName = "WmColorPicker";
678
- var WithFormController = (0, _withFormController["default"])(WmColorPicker);
679
- var WmColorPickerStandalone = exports.WmColorPicker = (0, _withStandalone["default"])(WithFormController);
680
- /**
681
- * The WmColorPicker component provides a color picker input with a popover palette.
682
- *
683
- * - [Playground](https://react-components.wavemaker.ai/?path=/story/input-colorpicker--showcase)
684
- *
685
- * - [Docs](https://react-components.wavemaker.ai/?path=/story/input-colorpicker--docs)
686
- *
687
- * @param props - {@link WmColorPickerProps}
688
- */
689
- var _default = exports["default"] = (0, _withBaseWrapper.withBaseWrapper)(WithFormController);
625
+ const WithFormController = withFormController(WmColorPicker);
626
+ const WmColorPickerStandalone = withStandalone(WithFormController);
627
+ var color_picker_default = withBaseWrapper(WithFormController);
628
+ export {
629
+ WmColorPickerStandalone as WmColorPicker,
630
+ color_picker_default as default
631
+ };