funda-ui 4.7.624 → 4.7.625

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 (560) hide show
  1. package/README.md +2 -116
  2. package/package.json +1 -591
  3. package/.gitattributes +0 -2
  4. package/README_PUBLISH.md +0 -328
  5. package/logo.png +0 -0
  6. package/preview.png +0 -0
  7. package/publish/LICENSE +0 -21
  8. package/publish/README.md +0 -328
  9. package/publish/lib/cjs/Accordion/index.d.ts +0 -2
  10. package/publish/lib/cjs/Accordion/index.js +0 -667
  11. package/publish/lib/cjs/BackToTop/index.d.ts +0 -17
  12. package/publish/lib/cjs/BackToTop/index.js +0 -904
  13. package/publish/lib/cjs/CascadingSelect/index.d.ts +0 -80
  14. package/publish/lib/cjs/CascadingSelect/index.js +0 -3383
  15. package/publish/lib/cjs/CascadingSelectE2E/index.d.ts +0 -91
  16. package/publish/lib/cjs/CascadingSelectE2E/index.js +0 -3988
  17. package/publish/lib/cjs/Chatbox/index.d.ts +0 -101
  18. package/publish/lib/cjs/Chatbox/index.js +0 -7037
  19. package/publish/lib/cjs/Checkbox/index.d.ts +0 -28
  20. package/publish/lib/cjs/Checkbox/index.js +0 -673
  21. package/publish/lib/cjs/ColorPicker/index.d.ts +0 -27
  22. package/publish/lib/cjs/ColorPicker/index.js +0 -662
  23. package/publish/lib/cjs/Date/index.d.ts +0 -70
  24. package/publish/lib/cjs/Date/index.js +0 -6368
  25. package/publish/lib/cjs/DigitalClock/index.d.ts +0 -7
  26. package/publish/lib/cjs/DigitalClock/index.js +0 -402
  27. package/publish/lib/cjs/DragDropList/index.d.ts +0 -45
  28. package/publish/lib/cjs/DragDropList/index.js +0 -1586
  29. package/publish/lib/cjs/DropdownMenu/index.d.ts +0 -38
  30. package/publish/lib/cjs/DropdownMenu/index.js +0 -1507
  31. package/publish/lib/cjs/DynamicFields/index.d.ts +0 -40
  32. package/publish/lib/cjs/DynamicFields/index.js +0 -818
  33. package/publish/lib/cjs/EventCalendar/index.d.ts +0 -61
  34. package/publish/lib/cjs/EventCalendar/index.js +0 -3789
  35. package/publish/lib/cjs/EventCalendarTimeline/index.d.ts +0 -100
  36. package/publish/lib/cjs/EventCalendarTimeline/index.js +0 -6141
  37. package/publish/lib/cjs/File/index.d.ts +0 -40
  38. package/publish/lib/cjs/File/index.js +0 -1751
  39. package/publish/lib/cjs/HorizontalScrollContent/index.d.ts +0 -14
  40. package/publish/lib/cjs/HorizontalScrollContent/index.js +0 -426
  41. package/publish/lib/cjs/Input/index.d.ts +0 -59
  42. package/publish/lib/cjs/Input/index.js +0 -1486
  43. package/publish/lib/cjs/LiveSearch/index.d.ts +0 -70
  44. package/publish/lib/cjs/LiveSearch/index.js +0 -4180
  45. package/publish/lib/cjs/MasonryLayout/index.d.ts +0 -14
  46. package/publish/lib/cjs/MasonryLayout/index.js +0 -689
  47. package/publish/lib/cjs/ModalDialog/index.d.ts +0 -83
  48. package/publish/lib/cjs/ModalDialog/index.js +0 -1719
  49. package/publish/lib/cjs/ModeSwitch/index.d.ts +0 -17
  50. package/publish/lib/cjs/ModeSwitch/index.js +0 -202
  51. package/publish/lib/cjs/MultilevelDropdownMenu/index.d.ts +0 -20
  52. package/publish/lib/cjs/MultilevelDropdownMenu/index.js +0 -930
  53. package/publish/lib/cjs/MultipleCheckboxes/index.d.ts +0 -66
  54. package/publish/lib/cjs/MultipleCheckboxes/index.js +0 -2337
  55. package/publish/lib/cjs/MultipleSelect/index.d.ts +0 -65
  56. package/publish/lib/cjs/MultipleSelect/index.js +0 -4197
  57. package/publish/lib/cjs/NativeSelect/index.d.ts +0 -37
  58. package/publish/lib/cjs/NativeSelect/index.js +0 -2052
  59. package/publish/lib/cjs/NumberInput/index.d.ts +0 -40
  60. package/publish/lib/cjs/NumberInput/index.js +0 -1191
  61. package/publish/lib/cjs/Pagination/index.d.ts +0 -51
  62. package/publish/lib/cjs/Pagination/index.js +0 -612
  63. package/publish/lib/cjs/Radio/index.d.ts +0 -45
  64. package/publish/lib/cjs/Radio/index.js +0 -1838
  65. package/publish/lib/cjs/RangeSlider/index.d.ts +0 -22
  66. package/publish/lib/cjs/RangeSlider/index.js +0 -2696
  67. package/publish/lib/cjs/Refresher/index.d.ts +0 -22
  68. package/publish/lib/cjs/Refresher/index.js +0 -564
  69. package/publish/lib/cjs/RootPortal/index.d.ts +0 -9
  70. package/publish/lib/cjs/RootPortal/index.js +0 -148
  71. package/publish/lib/cjs/ScrollReveal/index.d.ts +0 -21
  72. package/publish/lib/cjs/ScrollReveal/index.js +0 -401
  73. package/publish/lib/cjs/Scrollbar/index.d.ts +0 -17
  74. package/publish/lib/cjs/Scrollbar/index.js +0 -1107
  75. package/publish/lib/cjs/SearchBar/index.d.ts +0 -41
  76. package/publish/lib/cjs/SearchBar/index.js +0 -701
  77. package/publish/lib/cjs/Select/index.d.ts +0 -107
  78. package/publish/lib/cjs/Select/index.js +0 -6540
  79. package/publish/lib/cjs/ShowMoreLess/index.d.ts +0 -36
  80. package/publish/lib/cjs/ShowMoreLess/index.js +0 -387
  81. package/publish/lib/cjs/SplitterPanel/index.d.ts +0 -20
  82. package/publish/lib/cjs/SplitterPanel/index.js +0 -800
  83. package/publish/lib/cjs/Stepper/index.d.ts +0 -26
  84. package/publish/lib/cjs/Stepper/index.js +0 -568
  85. package/publish/lib/cjs/Switch/index.d.ts +0 -25
  86. package/publish/lib/cjs/Switch/index.js +0 -630
  87. package/publish/lib/cjs/Table/index.d.ts +0 -12
  88. package/publish/lib/cjs/Table/index.js +0 -2311
  89. package/publish/lib/cjs/Tabs/index.d.ts +0 -3
  90. package/publish/lib/cjs/Tabs/index.js +0 -771
  91. package/publish/lib/cjs/TagInput/index.d.ts +0 -37
  92. package/publish/lib/cjs/TagInput/index.js +0 -1227
  93. package/publish/lib/cjs/Textarea/index.d.ts +0 -50
  94. package/publish/lib/cjs/Textarea/index.js +0 -1795
  95. package/publish/lib/cjs/Toast/index.d.ts +0 -3
  96. package/publish/lib/cjs/Toast/index.js +0 -1345
  97. package/publish/lib/cjs/Tooltip/index.d.ts +0 -38
  98. package/publish/lib/cjs/Tooltip/index.js +0 -1778
  99. package/publish/lib/cjs/Tree/index.d.ts +0 -78
  100. package/publish/lib/cjs/Tree/index.js +0 -2330
  101. package/publish/lib/cjs/Utils/anim.d.ts +0 -11
  102. package/publish/lib/cjs/Utils/anim.js +0 -846
  103. package/publish/lib/cjs/Utils/bodyScrollLock.d.ts +0 -8
  104. package/publish/lib/cjs/Utils/bodyScrollLock.js +0 -311
  105. package/publish/lib/cjs/Utils/buffer.d.ts +0 -67
  106. package/publish/lib/cjs/Utils/buffer.js +0 -343
  107. package/publish/lib/cjs/Utils/cls.d.ts +0 -15
  108. package/publish/lib/cjs/Utils/cls.js +0 -124
  109. package/publish/lib/cjs/Utils/convert.d.ts +0 -25
  110. package/publish/lib/cjs/Utils/convert.js +0 -109
  111. package/publish/lib/cjs/Utils/date.d.ts +0 -227
  112. package/publish/lib/cjs/Utils/date.js +0 -587
  113. package/publish/lib/cjs/Utils/dom.d.ts +0 -13
  114. package/publish/lib/cjs/Utils/dom.js +0 -215
  115. package/publish/lib/cjs/Utils/easing.d.ts +0 -29
  116. package/publish/lib/cjs/Utils/easing.js +0 -221
  117. package/publish/lib/cjs/Utils/extract.d.ts +0 -66
  118. package/publish/lib/cjs/Utils/extract.js +0 -195
  119. package/publish/lib/cjs/Utils/format-string.d.ts +0 -65
  120. package/publish/lib/cjs/Utils/format-string.js +0 -167
  121. package/publish/lib/cjs/Utils/formdata.d.ts +0 -13
  122. package/publish/lib/cjs/Utils/formdata.js +0 -131
  123. package/publish/lib/cjs/Utils/getElementProperty.d.ts +0 -52
  124. package/publish/lib/cjs/Utils/getElementProperty.js +0 -189
  125. package/publish/lib/cjs/Utils/guid.d.ts +0 -7
  126. package/publish/lib/cjs/Utils/guid.js +0 -67
  127. package/publish/lib/cjs/Utils/initDefaultOptions.d.ts +0 -10
  128. package/publish/lib/cjs/Utils/initDefaultOptions.js +0 -607
  129. package/publish/lib/cjs/Utils/inputsCalculation.d.ts +0 -28
  130. package/publish/lib/cjs/Utils/inputsCalculation.js +0 -188
  131. package/publish/lib/cjs/Utils/math.d.ts +0 -77
  132. package/publish/lib/cjs/Utils/math.js +0 -305
  133. package/publish/lib/cjs/Utils/object.d.ts +0 -18
  134. package/publish/lib/cjs/Utils/object.js +0 -120
  135. package/publish/lib/cjs/Utils/os.d.ts +0 -2
  136. package/publish/lib/cjs/Utils/os.js +0 -104
  137. package/publish/lib/cjs/Utils/performance.d.ts +0 -3
  138. package/publish/lib/cjs/Utils/performance.js +0 -94
  139. package/publish/lib/cjs/Utils/sanitize.d.ts +0 -14
  140. package/publish/lib/cjs/Utils/sanitize.js +0 -87
  141. package/publish/lib/cjs/Utils/time.d.ts +0 -40
  142. package/publish/lib/cjs/Utils/time.js +0 -177
  143. package/publish/lib/cjs/Utils/tree.d.ts +0 -40
  144. package/publish/lib/cjs/Utils/tree.js +0 -195
  145. package/publish/lib/cjs/Utils/useAutosizeTextArea.d.ts +0 -10
  146. package/publish/lib/cjs/Utils/useAutosizeTextArea.js +0 -231
  147. package/publish/lib/cjs/Utils/useBoundedDrag.d.ts +0 -125
  148. package/publish/lib/cjs/Utils/useBoundedDrag.js +0 -380
  149. package/publish/lib/cjs/Utils/useClickOutside.d.ts +0 -33
  150. package/publish/lib/cjs/Utils/useClickOutside.js +0 -166
  151. package/publish/lib/cjs/Utils/useComId.d.ts +0 -6
  152. package/publish/lib/cjs/Utils/useComId.js +0 -114
  153. package/publish/lib/cjs/Utils/useDebounce.d.ts +0 -20
  154. package/publish/lib/cjs/Utils/useDebounce.js +0 -138
  155. package/publish/lib/cjs/Utils/useDragDropPosition.d.ts +0 -166
  156. package/publish/lib/cjs/Utils/useDragDropPosition.js +0 -453
  157. package/publish/lib/cjs/Utils/useDraggable.d.ts +0 -62
  158. package/publish/lib/cjs/Utils/useDraggable.js +0 -348
  159. package/publish/lib/cjs/Utils/useHistoryTracker.d.ts +0 -166
  160. package/publish/lib/cjs/Utils/useHistoryTracker.js +0 -649
  161. package/publish/lib/cjs/Utils/useInterval.d.ts +0 -5
  162. package/publish/lib/cjs/Utils/useInterval.js +0 -168
  163. package/publish/lib/cjs/Utils/useIsMobile.d.ts +0 -2
  164. package/publish/lib/cjs/Utils/useIsMobile.js +0 -232
  165. package/publish/lib/cjs/Utils/useKeyPress.d.ts +0 -44
  166. package/publish/lib/cjs/Utils/useKeyPress.js +0 -200
  167. package/publish/lib/cjs/Utils/useSessionStorageListener.d.ts +0 -2
  168. package/publish/lib/cjs/Utils/useSessionStorageListener.js +0 -157
  169. package/publish/lib/cjs/Utils/useStreamController.d.ts +0 -71
  170. package/publish/lib/cjs/Utils/useStreamController.js +0 -494
  171. package/publish/lib/cjs/Utils/useThrottle.d.ts +0 -2
  172. package/publish/lib/cjs/Utils/useThrottle.js +0 -136
  173. package/publish/lib/cjs/Utils/useWindowScroll.d.ts +0 -12
  174. package/publish/lib/cjs/Utils/useWindowScroll.js +0 -217
  175. package/publish/lib/cjs/Utils/validate.d.ts +0 -53
  176. package/publish/lib/cjs/Utils/validate.js +0 -536
  177. package/publish/lib/cjs/Utils/viewport.d.ts +0 -7
  178. package/publish/lib/cjs/Utils/viewport.js +0 -64
  179. package/publish/lib/cjs/index.d.ts +0 -49
  180. package/publish/lib/cjs/index.js +0 -50
  181. package/publish/lib/css/BackToTop/index.css +0 -34
  182. package/publish/lib/css/CascadingSelect/index.css +0 -245
  183. package/publish/lib/css/CascadingSelectE2E/index.css +0 -245
  184. package/publish/lib/css/Chatbox/index.css +0 -774
  185. package/publish/lib/css/ColorPicker/index.css +0 -58
  186. package/publish/lib/css/Date/index.css +0 -434
  187. package/publish/lib/css/DragDropList/index.css +0 -188
  188. package/publish/lib/css/DropdownMenu/index.css +0 -151
  189. package/publish/lib/css/EventCalendar/index.css +0 -300
  190. package/publish/lib/css/EventCalendarTimeline/index.css +0 -694
  191. package/publish/lib/css/HorizontalScrollContent/index.css +0 -70
  192. package/publish/lib/css/LiveSearch/index.css +0 -88
  193. package/publish/lib/css/MultilevelDropdownMenu/index.css +0 -38
  194. package/publish/lib/css/MultipleSelect/index.css +0 -313
  195. package/publish/lib/css/RangeSlider/index.css +0 -150
  196. package/publish/lib/css/Scrollbar/index.css +0 -176
  197. package/publish/lib/css/Select/index.css +0 -434
  198. package/publish/lib/css/ShowMoreLess/index.css +0 -23
  199. package/publish/lib/css/SplitterPanel/index.css +0 -63
  200. package/publish/lib/css/Stepper/index.css +0 -250
  201. package/publish/lib/css/Table/index.css +0 -584
  202. package/publish/lib/css/TagInput/index.css +0 -91
  203. package/publish/lib/css/Toast/index.css +0 -149
  204. package/publish/lib/css/Tooltip/index.css +0 -198
  205. package/publish/lib/css/Tree/index.css +0 -237
  206. package/publish/lib/esm/Accordion/Accordion.tsx +0 -185
  207. package/publish/lib/esm/Accordion/AccordionItem.tsx +0 -248
  208. package/publish/lib/esm/Accordion/index.tsx +0 -2
  209. package/publish/lib/esm/BackToTop/index.scss +0 -47
  210. package/publish/lib/esm/BackToTop/index.tsx +0 -177
  211. package/publish/lib/esm/CascadingSelect/Group.tsx +0 -83
  212. package/publish/lib/esm/CascadingSelect/index.scss +0 -330
  213. package/publish/lib/esm/CascadingSelect/index.tsx +0 -1397
  214. package/publish/lib/esm/CascadingSelectE2E/Group.tsx +0 -87
  215. package/publish/lib/esm/CascadingSelectE2E/index.scss +0 -333
  216. package/publish/lib/esm/CascadingSelectE2E/index.tsx +0 -1684
  217. package/publish/lib/esm/Chatbox/PureLoader.tsx +0 -47
  218. package/publish/lib/esm/Chatbox/TypingEffect.tsx +0 -56
  219. package/publish/lib/esm/Chatbox/index.scss +0 -966
  220. package/publish/lib/esm/Chatbox/index.tsx +0 -1742
  221. package/publish/lib/esm/Chatbox/utils/func.ts +0 -180
  222. package/publish/lib/esm/Checkbox/index.tsx +0 -206
  223. package/publish/lib/esm/ColorPicker/index.scss +0 -91
  224. package/publish/lib/esm/ColorPicker/index.tsx +0 -204
  225. package/publish/lib/esm/Date/Calendar.tsx +0 -723
  226. package/publish/lib/esm/Date/index.scss +0 -567
  227. package/publish/lib/esm/Date/index.tsx +0 -1797
  228. package/publish/lib/esm/Date/localization/en_US.js +0 -13
  229. package/publish/lib/esm/Date/localization/zh_CN.js +0 -12
  230. package/publish/lib/esm/DigitalClock/index.tsx +0 -74
  231. package/publish/lib/esm/DragDropList/index.scss +0 -245
  232. package/publish/lib/esm/DragDropList/index.tsx +0 -504
  233. package/publish/lib/esm/DropdownMenu/Option.tsx +0 -55
  234. package/publish/lib/esm/DropdownMenu/index.scss +0 -205
  235. package/publish/lib/esm/DropdownMenu/index.tsx +0 -378
  236. package/publish/lib/esm/DynamicFields/index.tsx +0 -409
  237. package/publish/lib/esm/EventCalendar/index.scss +0 -407
  238. package/publish/lib/esm/EventCalendar/index.tsx +0 -1005
  239. package/publish/lib/esm/EventCalendarTimeline/index.scss +0 -926
  240. package/publish/lib/esm/EventCalendarTimeline/index.tsx +0 -2686
  241. package/publish/lib/esm/File/index.tsx +0 -477
  242. package/publish/lib/esm/HorizontalScrollContent/index.scss +0 -87
  243. package/publish/lib/esm/HorizontalScrollContent/index.tsx +0 -171
  244. package/publish/lib/esm/Input/index.tsx +0 -641
  245. package/publish/lib/esm/LiveSearch/index.scss +0 -129
  246. package/publish/lib/esm/LiveSearch/index.tsx +0 -1058
  247. package/publish/lib/esm/MasonryLayout/index.tsx +0 -326
  248. package/publish/lib/esm/ModalDialog/index.tsx +0 -572
  249. package/publish/lib/esm/ModeSwitch/index.tsx +0 -82
  250. package/publish/lib/esm/MultilevelDropdownMenu/ItemList.tsx +0 -265
  251. package/publish/lib/esm/MultilevelDropdownMenu/index.scss +0 -79
  252. package/publish/lib/esm/MultilevelDropdownMenu/index.tsx +0 -77
  253. package/publish/lib/esm/MultipleCheckboxes/index.tsx +0 -849
  254. package/publish/lib/esm/MultipleSelect/index.scss +0 -398
  255. package/publish/lib/esm/MultipleSelect/index.tsx +0 -769
  256. package/publish/lib/esm/MultipleSelect/utils/func.ts +0 -63
  257. package/publish/lib/esm/NativeSelect/index.tsx +0 -396
  258. package/publish/lib/esm/NativeSelect/utils/func.ts +0 -51
  259. package/publish/lib/esm/NumberInput/index.tsx +0 -425
  260. package/publish/lib/esm/Pagination/index.tsx +0 -286
  261. package/publish/lib/esm/Pagination/pagination-navigators.tsx +0 -60
  262. package/publish/lib/esm/Radio/index.tsx +0 -694
  263. package/publish/lib/esm/RangeSlider/index.scss +0 -186
  264. package/publish/lib/esm/RangeSlider/index.tsx +0 -241
  265. package/publish/lib/esm/Refresher/index.tsx +0 -121
  266. package/publish/lib/esm/RootPortal/index.tsx +0 -59
  267. package/publish/lib/esm/ScrollReveal/index.tsx +0 -148
  268. package/publish/lib/esm/Scrollbar/index.scss +0 -221
  269. package/publish/lib/esm/Scrollbar/index.tsx +0 -561
  270. package/publish/lib/esm/SearchBar/index.tsx +0 -252
  271. package/publish/lib/esm/Select/index.scss +0 -639
  272. package/publish/lib/esm/Select/index.tsx +0 -3104
  273. package/publish/lib/esm/Select/utils/func.ts +0 -98
  274. package/publish/lib/esm/ShowMoreLess/index.scss +0 -27
  275. package/publish/lib/esm/ShowMoreLess/index.tsx +0 -145
  276. package/publish/lib/esm/SplitterPanel/index.scss +0 -82
  277. package/publish/lib/esm/SplitterPanel/index.tsx +0 -174
  278. package/publish/lib/esm/Stepper/index.scss +0 -315
  279. package/publish/lib/esm/Stepper/index.tsx +0 -325
  280. package/publish/lib/esm/Switch/index.tsx +0 -149
  281. package/publish/lib/esm/Table/Table.tsx +0 -351
  282. package/publish/lib/esm/Table/TableBody.tsx +0 -41
  283. package/publish/lib/esm/Table/TableCaption.tsx +0 -34
  284. package/publish/lib/esm/Table/TableCell.tsx +0 -126
  285. package/publish/lib/esm/Table/TableColgroup.tsx +0 -38
  286. package/publish/lib/esm/Table/TableContext.tsx +0 -26
  287. package/publish/lib/esm/Table/TableFoot.tsx +0 -28
  288. package/publish/lib/esm/Table/TableHead.tsx +0 -28
  289. package/publish/lib/esm/Table/TableRow.tsx +0 -76
  290. package/publish/lib/esm/Table/index.scss +0 -418
  291. package/publish/lib/esm/Table/index.tsx +0 -14
  292. package/publish/lib/esm/Table/utils/DragHandleSprite.tsx +0 -46
  293. package/publish/lib/esm/Table/utils/SortSprite.tsx +0 -63
  294. package/publish/lib/esm/Table/utils/TableFilter.tsx +0 -56
  295. package/publish/lib/esm/Table/utils/ToggleSelection.tsx +0 -255
  296. package/publish/lib/esm/Table/utils/func.ts +0 -182
  297. package/publish/lib/esm/Table/utils/hooks/useTableDraggable.tsx +0 -342
  298. package/publish/lib/esm/Table/utils/hooks/useTableKeyPress.tsx +0 -255
  299. package/publish/lib/esm/Table/utils/hooks/useTableResponsive.tsx +0 -92
  300. package/publish/lib/esm/Table/utils/hooks/useTableSort.tsx +0 -187
  301. package/publish/lib/esm/Tabs/TabList.tsx +0 -50
  302. package/publish/lib/esm/Tabs/TabPanel.tsx +0 -44
  303. package/publish/lib/esm/Tabs/Tabs.tsx +0 -282
  304. package/publish/lib/esm/Tabs/index.tsx +0 -3
  305. package/publish/lib/esm/TagInput/index.scss +0 -126
  306. package/publish/lib/esm/TagInput/index.tsx +0 -379
  307. package/publish/lib/esm/Textarea/index.tsx +0 -621
  308. package/publish/lib/esm/Toast/Item.tsx +0 -165
  309. package/publish/lib/esm/Toast/Toast.tsx +0 -391
  310. package/publish/lib/esm/Toast/ToastContext.tsx +0 -104
  311. package/publish/lib/esm/Toast/__toast.vanilla.js +0 -422
  312. package/publish/lib/esm/Toast/index.scss +0 -197
  313. package/publish/lib/esm/Toast/index.tsx +0 -3
  314. package/publish/lib/esm/Toast/types.ts +0 -60
  315. package/publish/lib/esm/Toast/useToast.tsx +0 -72
  316. package/publish/lib/esm/Tooltip/index.scss +0 -272
  317. package/publish/lib/esm/Tooltip/index.tsx +0 -416
  318. package/publish/lib/esm/Tree/TreeList.tsx +0 -600
  319. package/publish/lib/esm/Tree/index.scss +0 -384
  320. package/publish/lib/esm/Tree/index.tsx +0 -661
  321. package/publish/lib/esm/Tree/init-height.tsx +0 -40
  322. package/publish/lib/esm/Tree/utils/func.ts +0 -15
  323. package/publish/lib/esm/Utils/hooks/useAutosizeTextArea.tsx +0 -131
  324. package/publish/lib/esm/Utils/hooks/useBoundedDrag.tsx +0 -301
  325. package/publish/lib/esm/Utils/hooks/useClickOutside.tsx +0 -69
  326. package/publish/lib/esm/Utils/hooks/useComId.tsx +0 -13
  327. package/publish/lib/esm/Utils/hooks/useDebounce.tsx +0 -40
  328. package/publish/lib/esm/Utils/hooks/useDragDropPosition.tsx +0 -417
  329. package/publish/lib/esm/Utils/hooks/useDraggable.tsx +0 -265
  330. package/publish/lib/esm/Utils/hooks/useHistoryTracker.tsx +0 -554
  331. package/publish/lib/esm/Utils/hooks/useInterval.tsx +0 -74
  332. package/publish/lib/esm/Utils/hooks/useIsMobile.tsx +0 -139
  333. package/publish/lib/esm/Utils/hooks/useKeyPress.tsx +0 -104
  334. package/publish/lib/esm/Utils/hooks/useSessionStorageListener.tsx +0 -45
  335. package/publish/lib/esm/Utils/hooks/useStreamController.tsx +0 -277
  336. package/publish/lib/esm/Utils/hooks/useThrottle.tsx +0 -39
  337. package/publish/lib/esm/Utils/hooks/useWindowScroll.tsx +0 -83
  338. package/publish/lib/esm/Utils/libs/anim.ts +0 -96
  339. package/publish/lib/esm/Utils/libs/buffer.ts +0 -262
  340. package/publish/lib/esm/Utils/libs/cls.ts +0 -64
  341. package/publish/lib/esm/Utils/libs/convert.ts +0 -59
  342. package/publish/lib/esm/Utils/libs/date.ts +0 -598
  343. package/publish/lib/esm/Utils/libs/dom.ts +0 -150
  344. package/publish/lib/esm/Utils/libs/easing.ts +0 -201
  345. package/publish/lib/esm/Utils/libs/extract.ts +0 -160
  346. package/publish/lib/esm/Utils/libs/format-string.ts +0 -116
  347. package/publish/lib/esm/Utils/libs/formdata.ts +0 -93
  348. package/publish/lib/esm/Utils/libs/getElementProperty.ts +0 -150
  349. package/publish/lib/esm/Utils/libs/guid.ts +0 -16
  350. package/publish/lib/esm/Utils/libs/initDefaultOptions.ts +0 -43
  351. package/publish/lib/esm/Utils/libs/inputsCalculation.ts +0 -160
  352. package/publish/lib/esm/Utils/libs/math.ts +0 -276
  353. package/publish/lib/esm/Utils/libs/object.ts +0 -68
  354. package/publish/lib/esm/Utils/libs/os.ts +0 -63
  355. package/publish/lib/esm/Utils/libs/performance.ts +0 -47
  356. package/publish/lib/esm/Utils/libs/sanitize.ts +0 -55
  357. package/publish/lib/esm/Utils/libs/time.ts +0 -139
  358. package/publish/lib/esm/Utils/libs/tree.ts +0 -119
  359. package/publish/lib/esm/Utils/libs/validate.ts +0 -434
  360. package/publish/lib/esm/Utils/libs/viewport.ts +0 -20
  361. package/publish/lib/esm/Utils/plugins/bodyScrollLock.ts +0 -286
  362. package/publish/lib/esm/index.js +0 -47
  363. package/publish/package.json +0 -1
  364. /package/{publish/Accordion → Accordion}/index.d.ts +0 -0
  365. /package/{publish/Accordion → Accordion}/index.js +0 -0
  366. /package/{publish/BackToTop → BackToTop}/index.css +0 -0
  367. /package/{publish/BackToTop → BackToTop}/index.d.ts +0 -0
  368. /package/{publish/BackToTop → BackToTop}/index.js +0 -0
  369. /package/{publish/CascadingSelect → CascadingSelect}/index.css +0 -0
  370. /package/{publish/CascadingSelect → CascadingSelect}/index.d.ts +0 -0
  371. /package/{publish/CascadingSelect → CascadingSelect}/index.js +0 -0
  372. /package/{publish/CascadingSelectE2E → CascadingSelectE2E}/index.css +0 -0
  373. /package/{publish/CascadingSelectE2E → CascadingSelectE2E}/index.d.ts +0 -0
  374. /package/{publish/CascadingSelectE2E → CascadingSelectE2E}/index.js +0 -0
  375. /package/{publish/Chatbox → Chatbox}/index.css +0 -0
  376. /package/{publish/Chatbox → Chatbox}/index.d.ts +0 -0
  377. /package/{publish/Chatbox → Chatbox}/index.js +0 -0
  378. /package/{publish/Checkbox → Checkbox}/index.d.ts +0 -0
  379. /package/{publish/Checkbox → Checkbox}/index.js +0 -0
  380. /package/{publish/ColorPicker → ColorPicker}/index.css +0 -0
  381. /package/{publish/ColorPicker → ColorPicker}/index.d.ts +0 -0
  382. /package/{publish/ColorPicker → ColorPicker}/index.js +0 -0
  383. /package/{publish/Date → Date}/index.css +0 -0
  384. /package/{publish/Date → Date}/index.d.ts +0 -0
  385. /package/{publish/Date → Date}/index.js +0 -0
  386. /package/{publish/DigitalClock → DigitalClock}/index.d.ts +0 -0
  387. /package/{publish/DigitalClock → DigitalClock}/index.js +0 -0
  388. /package/{publish/DragDropList → DragDropList}/index.css +0 -0
  389. /package/{publish/DragDropList → DragDropList}/index.d.ts +0 -0
  390. /package/{publish/DragDropList → DragDropList}/index.js +0 -0
  391. /package/{publish/DropdownMenu → DropdownMenu}/index.css +0 -0
  392. /package/{publish/DropdownMenu → DropdownMenu}/index.d.ts +0 -0
  393. /package/{publish/DropdownMenu → DropdownMenu}/index.js +0 -0
  394. /package/{publish/DynamicFields → DynamicFields}/index.d.ts +0 -0
  395. /package/{publish/DynamicFields → DynamicFields}/index.js +0 -0
  396. /package/{publish/EventCalendar → EventCalendar}/index.css +0 -0
  397. /package/{publish/EventCalendar → EventCalendar}/index.d.ts +0 -0
  398. /package/{publish/EventCalendar → EventCalendar}/index.js +0 -0
  399. /package/{publish/EventCalendarTimeline → EventCalendarTimeline}/index.css +0 -0
  400. /package/{publish/EventCalendarTimeline → EventCalendarTimeline}/index.d.ts +0 -0
  401. /package/{publish/EventCalendarTimeline → EventCalendarTimeline}/index.js +0 -0
  402. /package/{publish/File → File}/index.d.ts +0 -0
  403. /package/{publish/File → File}/index.js +0 -0
  404. /package/{publish/HorizontalScrollContent → HorizontalScrollContent}/index.css +0 -0
  405. /package/{publish/HorizontalScrollContent → HorizontalScrollContent}/index.d.ts +0 -0
  406. /package/{publish/HorizontalScrollContent → HorizontalScrollContent}/index.js +0 -0
  407. /package/{publish/Input → Input}/index.d.ts +0 -0
  408. /package/{publish/Input → Input}/index.js +0 -0
  409. /package/{publish/LiveSearch → LiveSearch}/index.css +0 -0
  410. /package/{publish/LiveSearch → LiveSearch}/index.d.ts +0 -0
  411. /package/{publish/LiveSearch → LiveSearch}/index.js +0 -0
  412. /package/{publish/MasonryLayout → MasonryLayout}/index.d.ts +0 -0
  413. /package/{publish/MasonryLayout → MasonryLayout}/index.js +0 -0
  414. /package/{publish/ModalDialog → ModalDialog}/index.d.ts +0 -0
  415. /package/{publish/ModalDialog → ModalDialog}/index.js +0 -0
  416. /package/{publish/ModeSwitch → ModeSwitch}/index.d.ts +0 -0
  417. /package/{publish/ModeSwitch → ModeSwitch}/index.js +0 -0
  418. /package/{publish/MultilevelDropdownMenu → MultilevelDropdownMenu}/index.css +0 -0
  419. /package/{publish/MultilevelDropdownMenu → MultilevelDropdownMenu}/index.d.ts +0 -0
  420. /package/{publish/MultilevelDropdownMenu → MultilevelDropdownMenu}/index.js +0 -0
  421. /package/{publish/MultipleCheckboxes → MultipleCheckboxes}/index.d.ts +0 -0
  422. /package/{publish/MultipleCheckboxes → MultipleCheckboxes}/index.js +0 -0
  423. /package/{publish/MultipleSelect → MultipleSelect}/index.css +0 -0
  424. /package/{publish/MultipleSelect → MultipleSelect}/index.d.ts +0 -0
  425. /package/{publish/MultipleSelect → MultipleSelect}/index.js +0 -0
  426. /package/{publish/NativeSelect → NativeSelect}/index.d.ts +0 -0
  427. /package/{publish/NativeSelect → NativeSelect}/index.js +0 -0
  428. /package/{publish/NumberInput → NumberInput}/index.d.ts +0 -0
  429. /package/{publish/NumberInput → NumberInput}/index.js +0 -0
  430. /package/{publish/Pagination → Pagination}/index.d.ts +0 -0
  431. /package/{publish/Pagination → Pagination}/index.js +0 -0
  432. /package/{publish/Radio → Radio}/index.d.ts +0 -0
  433. /package/{publish/Radio → Radio}/index.js +0 -0
  434. /package/{publish/RangeSlider → RangeSlider}/index.css +0 -0
  435. /package/{publish/RangeSlider → RangeSlider}/index.d.ts +0 -0
  436. /package/{publish/RangeSlider → RangeSlider}/index.js +0 -0
  437. /package/{publish/Refresher → Refresher}/index.d.ts +0 -0
  438. /package/{publish/Refresher → Refresher}/index.js +0 -0
  439. /package/{publish/RootPortal → RootPortal}/index.d.ts +0 -0
  440. /package/{publish/RootPortal → RootPortal}/index.js +0 -0
  441. /package/{publish/ScrollReveal → ScrollReveal}/index.d.ts +0 -0
  442. /package/{publish/ScrollReveal → ScrollReveal}/index.js +0 -0
  443. /package/{publish/Scrollbar → Scrollbar}/index.css +0 -0
  444. /package/{publish/Scrollbar → Scrollbar}/index.d.ts +0 -0
  445. /package/{publish/Scrollbar → Scrollbar}/index.js +0 -0
  446. /package/{publish/SearchBar → SearchBar}/index.d.ts +0 -0
  447. /package/{publish/SearchBar → SearchBar}/index.js +0 -0
  448. /package/{publish/Select → Select}/index.css +0 -0
  449. /package/{publish/Select → Select}/index.d.ts +0 -0
  450. /package/{publish/Select → Select}/index.js +0 -0
  451. /package/{publish/ShowMoreLess → ShowMoreLess}/index.css +0 -0
  452. /package/{publish/ShowMoreLess → ShowMoreLess}/index.d.ts +0 -0
  453. /package/{publish/ShowMoreLess → ShowMoreLess}/index.js +0 -0
  454. /package/{publish/SplitterPanel → SplitterPanel}/index.css +0 -0
  455. /package/{publish/SplitterPanel → SplitterPanel}/index.d.ts +0 -0
  456. /package/{publish/SplitterPanel → SplitterPanel}/index.js +0 -0
  457. /package/{publish/Stepper → Stepper}/index.css +0 -0
  458. /package/{publish/Stepper → Stepper}/index.d.ts +0 -0
  459. /package/{publish/Stepper → Stepper}/index.js +0 -0
  460. /package/{publish/Switch → Switch}/index.d.ts +0 -0
  461. /package/{publish/Switch → Switch}/index.js +0 -0
  462. /package/{publish/Table → Table}/index.css +0 -0
  463. /package/{publish/Table → Table}/index.d.ts +0 -0
  464. /package/{publish/Table → Table}/index.js +0 -0
  465. /package/{publish/Tabs → Tabs}/index.d.ts +0 -0
  466. /package/{publish/Tabs → Tabs}/index.js +0 -0
  467. /package/{publish/TagInput → TagInput}/index.css +0 -0
  468. /package/{publish/TagInput → TagInput}/index.d.ts +0 -0
  469. /package/{publish/TagInput → TagInput}/index.js +0 -0
  470. /package/{publish/Textarea → Textarea}/index.d.ts +0 -0
  471. /package/{publish/Textarea → Textarea}/index.js +0 -0
  472. /package/{publish/Toast → Toast}/index.css +0 -0
  473. /package/{publish/Toast → Toast}/index.d.ts +0 -0
  474. /package/{publish/Toast → Toast}/index.js +0 -0
  475. /package/{publish/Tooltip → Tooltip}/index.css +0 -0
  476. /package/{publish/Tooltip → Tooltip}/index.d.ts +0 -0
  477. /package/{publish/Tooltip → Tooltip}/index.js +0 -0
  478. /package/{publish/Tree → Tree}/index.css +0 -0
  479. /package/{publish/Tree → Tree}/index.d.ts +0 -0
  480. /package/{publish/Tree → Tree}/index.js +0 -0
  481. /package/{publish/Utils → Utils}/anim.d.ts +0 -0
  482. /package/{publish/Utils → Utils}/anim.js +0 -0
  483. /package/{publish/Utils → Utils}/bodyScrollLock.d.ts +0 -0
  484. /package/{publish/Utils → Utils}/bodyScrollLock.js +0 -0
  485. /package/{publish/Utils → Utils}/buffer.d.ts +0 -0
  486. /package/{publish/Utils → Utils}/buffer.js +0 -0
  487. /package/{publish/Utils → Utils}/cls.d.ts +0 -0
  488. /package/{publish/Utils → Utils}/cls.js +0 -0
  489. /package/{publish/Utils → Utils}/convert.d.ts +0 -0
  490. /package/{publish/Utils → Utils}/convert.js +0 -0
  491. /package/{publish/Utils → Utils}/date.d.ts +0 -0
  492. /package/{publish/Utils → Utils}/date.js +0 -0
  493. /package/{publish/Utils → Utils}/dom.d.ts +0 -0
  494. /package/{publish/Utils → Utils}/dom.js +0 -0
  495. /package/{publish/Utils → Utils}/easing.d.ts +0 -0
  496. /package/{publish/Utils → Utils}/easing.js +0 -0
  497. /package/{publish/Utils → Utils}/extract.d.ts +0 -0
  498. /package/{publish/Utils → Utils}/extract.js +0 -0
  499. /package/{publish/Utils → Utils}/format-string.d.ts +0 -0
  500. /package/{publish/Utils → Utils}/format-string.js +0 -0
  501. /package/{publish/Utils → Utils}/formdata.d.ts +0 -0
  502. /package/{publish/Utils → Utils}/formdata.js +0 -0
  503. /package/{publish/Utils → Utils}/getElementProperty.d.ts +0 -0
  504. /package/{publish/Utils → Utils}/getElementProperty.js +0 -0
  505. /package/{publish/Utils → Utils}/guid.d.ts +0 -0
  506. /package/{publish/Utils → Utils}/guid.js +0 -0
  507. /package/{publish/Utils → Utils}/initDefaultOptions.d.ts +0 -0
  508. /package/{publish/Utils → Utils}/initDefaultOptions.js +0 -0
  509. /package/{publish/Utils → Utils}/inputsCalculation.d.ts +0 -0
  510. /package/{publish/Utils → Utils}/inputsCalculation.js +0 -0
  511. /package/{publish/Utils → Utils}/math.d.ts +0 -0
  512. /package/{publish/Utils → Utils}/math.js +0 -0
  513. /package/{publish/Utils → Utils}/object.d.ts +0 -0
  514. /package/{publish/Utils → Utils}/object.js +0 -0
  515. /package/{publish/Utils → Utils}/os.d.ts +0 -0
  516. /package/{publish/Utils → Utils}/os.js +0 -0
  517. /package/{publish/Utils → Utils}/performance.d.ts +0 -0
  518. /package/{publish/Utils → Utils}/performance.js +0 -0
  519. /package/{publish/Utils → Utils}/sanitize.d.ts +0 -0
  520. /package/{publish/Utils → Utils}/sanitize.js +0 -0
  521. /package/{publish/Utils → Utils}/time.d.ts +0 -0
  522. /package/{publish/Utils → Utils}/time.js +0 -0
  523. /package/{publish/Utils → Utils}/tree.d.ts +0 -0
  524. /package/{publish/Utils → Utils}/tree.js +0 -0
  525. /package/{publish/Utils → Utils}/useAutosizeTextArea.d.ts +0 -0
  526. /package/{publish/Utils → Utils}/useAutosizeTextArea.js +0 -0
  527. /package/{publish/Utils → Utils}/useBoundedDrag.d.ts +0 -0
  528. /package/{publish/Utils → Utils}/useBoundedDrag.js +0 -0
  529. /package/{publish/Utils → Utils}/useClickOutside.d.ts +0 -0
  530. /package/{publish/Utils → Utils}/useClickOutside.js +0 -0
  531. /package/{publish/Utils → Utils}/useComId.d.ts +0 -0
  532. /package/{publish/Utils → Utils}/useComId.js +0 -0
  533. /package/{publish/Utils → Utils}/useDebounce.d.ts +0 -0
  534. /package/{publish/Utils → Utils}/useDebounce.js +0 -0
  535. /package/{publish/Utils → Utils}/useDragDropPosition.d.ts +0 -0
  536. /package/{publish/Utils → Utils}/useDragDropPosition.js +0 -0
  537. /package/{publish/Utils → Utils}/useDraggable.d.ts +0 -0
  538. /package/{publish/Utils → Utils}/useDraggable.js +0 -0
  539. /package/{publish/Utils → Utils}/useHistoryTracker.d.ts +0 -0
  540. /package/{publish/Utils → Utils}/useHistoryTracker.js +0 -0
  541. /package/{publish/Utils → Utils}/useInterval.d.ts +0 -0
  542. /package/{publish/Utils → Utils}/useInterval.js +0 -0
  543. /package/{publish/Utils → Utils}/useIsMobile.d.ts +0 -0
  544. /package/{publish/Utils → Utils}/useIsMobile.js +0 -0
  545. /package/{publish/Utils → Utils}/useKeyPress.d.ts +0 -0
  546. /package/{publish/Utils → Utils}/useKeyPress.js +0 -0
  547. /package/{publish/Utils → Utils}/useSessionStorageListener.d.ts +0 -0
  548. /package/{publish/Utils → Utils}/useSessionStorageListener.js +0 -0
  549. /package/{publish/Utils → Utils}/useStreamController.d.ts +0 -0
  550. /package/{publish/Utils → Utils}/useStreamController.js +0 -0
  551. /package/{publish/Utils → Utils}/useThrottle.d.ts +0 -0
  552. /package/{publish/Utils → Utils}/useThrottle.js +0 -0
  553. /package/{publish/Utils → Utils}/useWindowScroll.d.ts +0 -0
  554. /package/{publish/Utils → Utils}/useWindowScroll.js +0 -0
  555. /package/{publish/Utils → Utils}/validate.d.ts +0 -0
  556. /package/{publish/Utils → Utils}/validate.js +0 -0
  557. /package/{publish/Utils → Utils}/viewport.d.ts +0 -0
  558. /package/{publish/Utils → Utils}/viewport.js +0 -0
  559. /package/{publish/all.d.ts → all.d.ts} +0 -0
  560. /package/{publish/all.js → all.js} +0 -0
@@ -1,425 +0,0 @@
1
- import React, { useState, useEffect, useRef, forwardRef, ChangeEvent, FocusEvent, useImperativeHandle } from 'react';
2
-
3
-
4
- import useComId from 'funda-utils/dist/cjs/useComId';
5
- import { clsWrite, combinedCls } from 'funda-utils/dist/cjs/cls';
6
- import {
7
- calcAdd,
8
- calcSub,
9
- isNumeric,
10
- truncateDecimals,
11
- exceedDecimalPlaces,
12
- formatNumber
13
- } from 'funda-utils/dist/cjs/math';
14
-
15
- export type NumberInputProps = {
16
- contentRef?: React.ForwardedRef<any>;
17
- wrapperClassName?: string;
18
- controlClassName?: string;
19
- controlGroupWrapperClassName?: string;
20
- controlGroupTextClassName?: string;
21
- arrowBtnClassName?: string[];
22
- arrowBtnContainerClassName?: string;
23
- increaseIcon?: React.ReactNode | string;
24
- decreaseIcon?: React.ReactNode | string;
25
- hideArrowButton?: boolean;
26
- defaultValue?: string;
27
- value?: string;
28
- requiredLabel?: React.ReactNode | string;
29
- label?: React.ReactNode | string;
30
- units?: React.ReactNode | string;
31
- name?: string;
32
- step?: any;
33
- min?: any;
34
- max?: any;
35
- decimalPlaces?: number;
36
- alt?: any;
37
- disabled?: any;
38
- required?: any;
39
- readOnly?: any;
40
- placeholder?: string;
41
- iconLeft?: React.ReactNode | string;
42
- iconRight?: React.ReactNode | string;
43
- /** -- */
44
- id?: string;
45
- style?: React.CSSProperties;
46
- tabIndex?: number;
47
- [key: `data-${string}`]: string | undefined;
48
- onChange?: (
49
- e: ChangeEvent<HTMLInputElement> | React.MouseEvent<HTMLButtonElement> | null,
50
- el: HTMLInputElement | null,
51
- val: number
52
- ) => void;
53
- onBlur?: (e: FocusEvent<HTMLInputElement>, el: HTMLInputElement | null) => void;
54
- onFocus?: (e: FocusEvent<HTMLInputElement>, el: HTMLInputElement | null) => void;
55
-
56
- };
57
-
58
-
59
- const NumberInput = forwardRef((props: NumberInputProps, externalRef: any) => {
60
- const {
61
- contentRef,
62
- wrapperClassName,
63
- controlClassName,
64
- controlGroupWrapperClassName,
65
- controlGroupTextClassName,
66
- arrowBtnClassName,
67
- arrowBtnContainerClassName,
68
- increaseIcon,
69
- decreaseIcon,
70
- hideArrowButton = false,
71
- requiredLabel,
72
- disabled,
73
- required,
74
- placeholder,
75
- readOnly,
76
- defaultValue,
77
- value,
78
- label,
79
- units,
80
- name,
81
- step = 1,
82
- min = Number.MIN_SAFE_INTEGER,
83
- max = Number.MAX_SAFE_INTEGER,
84
- decimalPlaces = 0,
85
- alt,
86
- id,
87
- iconLeft,
88
- iconRight,
89
- style,
90
- tabIndex,
91
- onChange,
92
- onBlur,
93
- onFocus,
94
- ...attributes
95
- } = props;
96
-
97
-
98
- const uniqueID = useComId();
99
- const idRes = id || uniqueID;
100
- const rootRef = useRef<any>(null);
101
- const valRef = useRef<any>(null);
102
- const [changedVal, setChangedVal] = useState<string>(value || '');
103
-
104
- // exposes the following methods
105
- useImperativeHandle(
106
- contentRef,
107
- () => ({
108
- control: () => {
109
- return valRef.current;
110
- },
111
- getLatestVal: () => {
112
- return changedVal || '';
113
- },
114
- clear: (cb?: any) => {
115
- setChangedVal('');
116
- cb?.();
117
-
118
- onChange?.(null, valRef.current, Number(''));
119
- },
120
- set: (value: string, cb?: any) => {
121
- setChangedVal(`${value}`);
122
- cb?.();
123
-
124
- onChange?.(null, valRef.current, Number(formatValue(`${value}`)));
125
- },
126
- increment: (cb?: any) => {
127
- handleIncrement(null);
128
- cb?.();
129
- },
130
- decrement: (cb?: any) => {
131
- handleDecrement(null);
132
- cb?.();
133
- }
134
-
135
- }),
136
- [contentRef, changedVal],
137
- );
138
-
139
- const propExist = (p: any) => {
140
- return typeof p !== 'undefined' && p !== null && p !== '';
141
- };
142
-
143
- // Formalized digits, supporting decimal places
144
- const formatValue = (inputValue: any) => {
145
- return formatNumber(inputValue, decimalPlaces, min, max);
146
- };
147
-
148
- const checkResValue = (inputValue: number | string) => {
149
- // Check whether the number of decimal places exceeds the specified value
150
- if (exceedDecimalPlaces(inputValue, decimalPlaces)) {
151
- inputValue = truncateDecimals(Number(inputValue), decimalPlaces);
152
- }
153
-
154
- // check min or max value
155
- if ( Number(inputValue) > max ) inputValue = max;
156
- if ( Number(inputValue) < min ) inputValue = min;
157
-
158
- return inputValue;
159
- };
160
-
161
- const handleIncrement = (e: React.MouseEvent<HTMLButtonElement> | null) => {
162
- if (e) e.preventDefault();
163
-
164
- setChangedVal((prevValue: string) => {
165
- const newValue = calcAdd(parseFloat(prevValue), step);
166
- onChange?.(e, valRef.current, Number(formatValue(newValue)));
167
- return formatValue(newValue);
168
- });
169
-
170
- };
171
-
172
- const handleDecrement = (e: React.MouseEvent<HTMLButtonElement> | null) => {
173
- if (e) e.preventDefault();
174
-
175
- setChangedVal((prevValue: string) => {
176
- const newValue = calcSub(parseFloat(prevValue), step);
177
- onChange?.(e, valRef.current, Number(formatValue(newValue)));
178
- return formatValue(newValue);
179
- });
180
-
181
- };
182
-
183
-
184
-
185
- function handleFocus(event: FocusEvent<HTMLInputElement>) {
186
- rootRef.current?.classList.add('focus');
187
-
188
- //
189
- onFocus?.(event, valRef.current);
190
- }
191
-
192
- function handleChange(event: ChangeEvent<HTMLInputElement>) {
193
- const val = event.target.value;
194
- let newVal: number | string = parseFloat(event.target.value);
195
-
196
- if (!isNumeric(newVal)) newVal = val;
197
-
198
- // Determine whether it is a null or negative symbol
199
- if (val === '-') {
200
- newVal = '-';
201
-
202
- // Determine whether to enter a decimal
203
- } else if (val.startsWith('-0') && decimalPlaces > 0) {
204
- newVal = val;
205
-
206
- //
207
- } else if (val.includes('.') && decimalPlaces > 0) {
208
- newVal = val;
209
-
210
- }else {
211
- newVal = formatValue(newVal);
212
- }
213
-
214
- // Check result
215
- newVal = checkResValue(newVal);
216
-
217
-
218
- //
219
- const resToInput = String(newVal) === 'NaN' ? '0' : String(newVal);
220
- setChangedVal(resToInput);
221
-
222
-
223
- //----
224
- //remove focus style
225
- if (val === '') {
226
- rootRef.current?.classList.remove('focus');
227
- }
228
-
229
- //
230
- onChange?.(event, valRef.current, Number(!isNumeric(newVal) ? '0' : resToInput));
231
-
232
-
233
- }
234
-
235
- function handleBlur(event: FocusEvent<HTMLInputElement>) {
236
- const el = event.target;
237
- const val = event.target.value;
238
-
239
-
240
- // Determine whether to enter a decimal
241
- if (val.includes('.') && decimalPlaces > 0) {
242
- setChangedVal(formatValue(val));
243
- }
244
-
245
- // Determine whether it is a null or negative symbol
246
- if (val === '' || val === '-') {
247
- setChangedVal('0');
248
- }
249
-
250
-
251
- //----
252
- //remove focus style
253
- if (val === '') {
254
- rootRef.current?.classList.remove('focus');
255
- }
256
-
257
- //
258
- onBlur?.(event, valRef.current);
259
-
260
- }
261
-
262
-
263
- useEffect(() => {
264
-
265
- // update default value
266
- //--------------
267
- if (typeof value !== 'undefined') {
268
- setChangedVal(`${formatValue(value)}`); // Avoid displaying the number 0
269
- }
270
-
271
-
272
- }, [value]);
273
-
274
-
275
- useEffect(() => {
276
-
277
- // update default value (It does not re-render the component because the incoming value changes.)
278
- //--------------
279
- if (typeof defaultValue !== 'undefined') { //REQUIRED
280
- setChangedVal(`${formatValue(defaultValue)}`); // Avoid displaying the number 0
281
- }
282
-
283
- }, []);
284
-
285
-
286
- return (
287
- <>
288
-
289
- <div className={clsWrite(wrapperClassName, 'mb-3 position-relative')} ref={rootRef}>
290
- {label ? <>{typeof label === 'string' ? <label htmlFor={idRes} className="form-label" dangerouslySetInnerHTML={{__html: `${label}`}}></label> : <label htmlFor={idRes} className="form-label">{label}</label>}</> : null}
291
-
292
- <div className="position-relative">
293
-
294
- {/* FLEX INPUT GROUP: Use flexbox to align input, units, iconRight, and arrow buttons */}
295
- <div
296
- className={combinedCls(
297
- clsWrite(controlGroupWrapperClassName, 'input-group position-relative z-1 d-flex align-items-stretch'),
298
- {
299
- 'has-left-content': propExist(iconLeft),
300
- 'has-right-content': propExist(iconRight) || propExist(units)
301
- }
302
- )}
303
- >
304
- {/* Left icon, if present */}
305
- {propExist(iconLeft) ? (
306
- <span className={clsWrite(controlGroupTextClassName, 'input-group-text d-flex align-items-center')}>{iconLeft}</span>
307
- ) : null}
308
-
309
- {/* Main input field */}
310
- <input
311
- ref={(node) => {
312
- valRef.current = node;
313
- if (typeof externalRef === 'function') {
314
- externalRef(node);
315
- } else if (externalRef) {
316
- externalRef.current = node;
317
- }
318
- }}
319
- tabIndex={tabIndex || 0}
320
- type="text"
321
- inputMode={decimalPlaces > 0 ? 'decimal' : 'numeric'} // numeric | decimal
322
- className={combinedCls(
323
- clsWrite(controlClassName, 'form-control')
324
- )}
325
- id={idRes}
326
- name={name}
327
- min={min || null}
328
- max={max || null}
329
- alt={alt || null}
330
- placeholder={placeholder || ''}
331
- value={changedVal}
332
- autoComplete={'off'}
333
- spellCheck={false}
334
- onFocus={handleFocus}
335
- onBlur={handleBlur}
336
- onChange={handleChange}
337
- disabled={disabled || null}
338
- required={required || null}
339
- readOnly={readOnly || null}
340
- style={style}
341
- {...attributes}
342
- />
343
-
344
- {/* Units, if present */}
345
- {propExist(units) ? (
346
- <span className={clsWrite(controlGroupTextClassName, 'input-group-text d-flex align-items-center')}>{units}</span>
347
- ) : null}
348
-
349
- {/* Right icon, if present */}
350
- {propExist(iconRight) ? (
351
- <span className={clsWrite(controlGroupTextClassName, 'input-group-text d-flex align-items-center')}>{iconRight}</span>
352
- ) : null}
353
-
354
-
355
- {/* ARROW GROUP*/}
356
- {hideArrowButton ? null : <>
357
- <span
358
- className={clsWrite(
359
- arrowBtnContainerClassName,
360
- 'btn-group-vertical d-flex flex-column justify-content-center align-items-center border border-start-0 rounded-end',
361
- )}
362
- role="group"
363
- >
364
- <button
365
- type="button"
366
- className={combinedCls(
367
- clsWrite(Array(arrowBtnClassName) && arrowBtnClassName ? arrowBtnClassName[0] : undefined, 'btn btn-sm border-0 border-bottom py-0 lh-1 flex-fill')
368
- )}
369
- tabIndex={-1}
370
- onClick={handleIncrement}
371
- disabled={disabled || null}
372
- >
373
- <span>{increaseIcon || <svg width={13} fill="#000000" viewBox="0 0 24 24">
374
- <path d="M18.5,15.5l-6-7l-6,7H18.5z" />
375
- <rect fill="none" width="24" height="24" />
376
- <rect fill="none" width="24" height="24" />
377
- </svg>}</span>
378
- </button>
379
-
380
- <button
381
- type="button"
382
- className={combinedCls(
383
- clsWrite(Array(arrowBtnClassName) && arrowBtnClassName ? arrowBtnClassName[1] : undefined, 'btn btn-sm border-0 py-0 lh-1 flex-fill')
384
- )}
385
- tabIndex={-1}
386
- onClick={handleDecrement}
387
- disabled={disabled || null}
388
- >
389
- <span>{decreaseIcon || <svg width={13} fill="#000000" viewBox="0 0 24 24">
390
- <path d="M6.5,8.5l6,7l6-7H6.5z"/>
391
- <rect fill="none" width="24" height="24" />
392
- <rect fill="none" width="24" height="24" />
393
- </svg>}</span>
394
- </button>
395
- </span>
396
- </>}
397
- {/* /ARROW GROUP*/}
398
-
399
- </div>
400
- {/* /FLEX INPUT GROUP*/}
401
-
402
-
403
- {/* Required label, if present */}
404
- {required ? (
405
- <>
406
- {requiredLabel || requiredLabel === '' ? requiredLabel : (
407
- <span className="position-absolute end-0 top-0 my-2 mx-2 me-3 pe-3 z-1">
408
- <span className="text-danger">*</span>
409
- </span>
410
- )}
411
- </>
412
- ) : ''}
413
-
414
-
415
- </div>
416
-
417
-
418
- </div>
419
-
420
-
421
- </>
422
- )
423
- });
424
-
425
- export default NumberInput;