impact-ui 3.7.25 → 4.0.0-alpha.10

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 (465) hide show
  1. package/MIGRATION_GUIDE.md +328 -0
  2. package/README.md +154 -15
  3. package/bin/migrate-image-paths.cjs +127 -0
  4. package/bin/migrate.js +293 -0
  5. package/codemods/component-map.js +153 -0
  6. package/codemods/image-paths-transform.js +69 -0
  7. package/codemods/transform.js +136 -0
  8. package/dist/components/Accordion/index.js +2 -1
  9. package/dist/components/AccordionModern/index.js +2 -1
  10. package/dist/components/Alert/index.js +2 -1
  11. package/dist/components/Avatar/index.js +2 -1
  12. package/dist/components/Badge/filled/filledIconLabelBadges/index.js +2 -1
  13. package/dist/components/Badge/filled/filledOnlyIconBadges/index.js +2 -1
  14. package/dist/components/Badge/filled/filledOnlyLabelBadges/index.js +2 -1
  15. package/dist/components/Badge/index.js +3 -2
  16. package/dist/components/Badge/stroke/strokeIconLabelBadges/index.js +2 -1
  17. package/dist/components/Badge/stroke/strokeOnlyIconBadges/index.js +2 -1
  18. package/dist/components/Badge/stroke/strokeOnlyLabelBadges/index.js +2 -1
  19. package/dist/components/Badge/subtle/subtleIOnlyIconBadges/index.js +2 -1
  20. package/dist/components/Badge/subtle/subtleIconLabelBadges/index.js +2 -1
  21. package/dist/components/Badge/subtle/subtleOnlyLabelBadges/index.js +2 -1
  22. package/dist/components/BottomSheet/index.js +2 -1
  23. package/dist/components/Breadcrumbs/index.js +2 -1
  24. package/dist/components/Button/index.js +2 -1
  25. package/dist/components/ButtonGroup/index.js +2 -1
  26. package/dist/components/Card/index.js +2 -1
  27. package/dist/components/Chart/index.js +2 -1
  28. package/dist/components/Chatbot/index.js +2 -1
  29. package/dist/components/Checkbox/index.js +2 -1
  30. package/dist/components/Chips/index.js +2 -1
  31. package/dist/components/CreateItemFlow/index.js +2 -1
  32. package/dist/components/DatePicker/datePickerDropdown.js +2 -1
  33. package/dist/components/DatePicker/index.js +3 -2
  34. package/dist/components/DateRangePicker/dateRangePickerDropdown.js +2 -1
  35. package/dist/components/DateRangePicker/index.js +3 -2
  36. package/dist/components/DynamicLayout/index.js +2 -1
  37. package/dist/components/EmptyState/EmptyStateImage.d.ts.map +1 -1
  38. package/dist/components/EmptyState/EmptyStateImage.js +3 -2
  39. package/dist/components/EmptyState/index.js +2 -1
  40. package/dist/components/FileUpload/index.js +2 -1
  41. package/dist/components/FilterPanel/index.js +2 -1
  42. package/dist/components/FiltersStrip/index.js +2 -1
  43. package/dist/components/Header/index.js +2 -1
  44. package/dist/components/HomePage/index.js +2 -1
  45. package/dist/components/Input/index.js +2 -1
  46. package/dist/components/Loader/index.js +2 -1
  47. package/dist/components/Menu/IconMenuItem.js +2 -1
  48. package/dist/components/Menu/MenuHeaderInfo.js +2 -1
  49. package/dist/components/Menu/NestedMenuItem.js +2 -1
  50. package/dist/components/Menu/index.js +2 -1
  51. package/dist/components/Menu/nestedMenuItemsFromObject.js +2 -1
  52. package/dist/components/Modal/index.js +2 -1
  53. package/dist/components/Notification/NotificationBody/NotificationList/NotificationList.js +2 -1
  54. package/dist/components/Notification/index.js +2 -1
  55. package/dist/components/Panel/index.js +2 -1
  56. package/dist/components/Popover/index.js +2 -1
  57. package/dist/components/ProgressBar/index.js +2 -1
  58. package/dist/components/Prompt/index.js +2 -1
  59. package/dist/components/RadioButtonGroup/index.js +2 -1
  60. package/dist/components/Select/index.js +2 -1
  61. package/dist/components/Sidebar/index.js +2 -1
  62. package/dist/components/Slider/index.js +2 -1
  63. package/dist/components/Stepper/index.js +2 -1
  64. package/dist/components/Switch/index.js +2 -1
  65. package/dist/components/Table/TableImpl.js +4 -3
  66. package/dist/components/TableChat/EmptyContainer.js +2 -1
  67. package/dist/components/TableChat/TableChatSidePanel.js +2 -1
  68. package/dist/components/TableChat/components/ChatMessageSkeleton/ChatFooterSkeleton.js +2 -1
  69. package/dist/components/TableChat/components/ChatMessageSkeleton/ChatHeaderSkeleton.js +2 -1
  70. package/dist/components/TableChat/components/ChatMessageSkeleton/ChatMessageListSkeleton.js +2 -1
  71. package/dist/components/TableChat/components/ChatMessageSkeleton/ChatSkeleton.js +2 -1
  72. package/dist/components/TableChat/components/TableChatLeftSection/AddChatContainer/AddChatContainer.js +2 -1
  73. package/dist/components/TableChat/components/TableChatLeftSection/TableChatChannelHeader.js +2 -1
  74. package/dist/components/TableChat/components/TableChatRightSection/AvatarGroup/AvatarGroup.js +2 -1
  75. package/dist/components/TableChat/components/TableChatRightSection/ChatDefaultMessageType/ChatDefaultMessageType.js +2 -1
  76. package/dist/components/TableChat/components/TableChatRightSection/ChatDeleteMessageType/ChatDeletedMessageType.js +2 -1
  77. package/dist/components/TableChat/components/TableChatRightSection/ChatHeader/ChatHeader.js +2 -1
  78. package/dist/components/TableChat/components/TableChatRightSection/ChatInput/ChatInput.js +2 -1
  79. package/dist/components/TableChat/components/TableChatRightSection/ChatMessageAvatar/ChatMessageAvatar.js +2 -1
  80. package/dist/components/TableChat/components/TableChatRightSection/ChatMessages/ChatMessage.js +2 -1
  81. package/dist/components/TableChat/components/TableChatRightSection/ChatNotificationSettings/ChatNotificationSettings.js +2 -1
  82. package/dist/components/TableChat/components/TableChatRightSection/DateSeparator/DateSeparator.js +2 -1
  83. package/dist/components/TableChat/components/TableChatRightSection/PinedChatPanel/PinedChatPanel.js +2 -1
  84. package/dist/components/TableChat/components/TableChatRightSection/TableChatRightSection.js +2 -1
  85. package/dist/components/TableChat/components/TextEditor/EditorToolbar.js +2 -1
  86. package/dist/components/TableChat/components/TextEditor/Mention.js +2 -1
  87. package/dist/components/TableChat/components/TextEditor/MentionList.js +2 -1
  88. package/dist/components/Tabs/index.js +2 -1
  89. package/dist/components/Tag/index.js +2 -1
  90. package/dist/components/TagGroup/index.js +2 -1
  91. package/dist/components/TextArea/index.js +2 -1
  92. package/dist/components/Toast/index.js +2 -1
  93. package/dist/components/Tooltip/index.js +2 -1
  94. package/dist/components/common/HelperText/index.js +2 -1
  95. package/dist/components/index.d.ts +0 -1
  96. package/dist/components/index.d.ts.map +1 -1
  97. package/dist/components/index.js +0 -1
  98. package/dist/mcp-component-registry.json +1 -1
  99. package/dist/styles/entry.d.ts +2 -0
  100. package/dist/styles/entry.d.ts.map +1 -0
  101. package/dist/styles/entry.js +1 -0
  102. package/dist/styles/style.css +1 -1
  103. package/eslint-plugin/index.js +91 -0
  104. package/eslint-plugin/rules/no-barrel-import.js +224 -0
  105. package/package.json +153 -89
  106. package/dist/0db32db10ae1525f.svg +0 -9
  107. package/dist/2bc76319b1fa572e.svg +0 -9
  108. package/dist/39d49e4daed1a992.svg +0 -9
  109. package/dist/44beedf64dc29d19.svg +0 -9
  110. package/dist/49a4f914058314f1.svg +0 -9
  111. package/dist/6fc8a59d621a04a1.svg +0 -13
  112. package/dist/78f845dcfc981491.svg +0 -9
  113. package/dist/b31c0c2a19c1c19a.svg +0 -9
  114. package/dist/index.js +0 -308
  115. package/dist/index.js.map +0 -1
  116. package/src/components/Accordion/Accordion.styles.scss +0 -118
  117. package/src/components/Accordion/index.js +0 -104
  118. package/src/components/AccordionModern/AccordionModern.styles.scss +0 -121
  119. package/src/components/AccordionModern/SortableAccordionComp.js +0 -156
  120. package/src/components/AccordionModern/index.js +0 -103
  121. package/src/components/Alert/Alert.styles.scss +0 -131
  122. package/src/components/Alert/index.js +0 -71
  123. package/src/components/Avatar/Avatar.styles.scss +0 -25
  124. package/src/components/Avatar/index.js +0 -58
  125. package/src/components/Badge/Badges.style.scss +0 -55
  126. package/src/components/Badge/filled/filledIconLabelBadges/filledIconLabelBadges.styles.scss +0 -32
  127. package/src/components/Badge/filled/filledIconLabelBadges/index.js +0 -38
  128. package/src/components/Badge/filled/filledOnlyIconBadges/filledOnlyIconBadges.styles.scss +0 -26
  129. package/src/components/Badge/filled/filledOnlyIconBadges/index.js +0 -31
  130. package/src/components/Badge/filled/filledOnlyLabelBadges/filledOnlyLabelBadges.styles.scss +0 -66
  131. package/src/components/Badge/filled/filledOnlyLabelBadges/index.js +0 -31
  132. package/src/components/Badge/filled/index.js +0 -30
  133. package/src/components/Badge/index.js +0 -53
  134. package/src/components/Badge/stroke/index.js +0 -43
  135. package/src/components/Badge/stroke/strokeIconLabelBadges/index.js +0 -38
  136. package/src/components/Badge/stroke/strokeIconLabelBadges/strokeIconLabelBadges.styles.scss +0 -33
  137. package/src/components/Badge/stroke/strokeOnlyIconBadges/index.js +0 -31
  138. package/src/components/Badge/stroke/strokeOnlyIconBadges/strokeOnlyIconBadges.styles.scss +0 -27
  139. package/src/components/Badge/stroke/strokeOnlyLabelBadges/index.js +0 -31
  140. package/src/components/Badge/stroke/strokeOnlyLabelBadges/strokeOnlyLabelBadges.styles.scss +0 -89
  141. package/src/components/Badge/styles.css +0 -52
  142. package/src/components/Badge/subtle/index.js +0 -41
  143. package/src/components/Badge/subtle/subtleIOnlyIconBadges/index.js +0 -31
  144. package/src/components/Badge/subtle/subtleIOnlyIconBadges/subtleIOnlyIconBadges.scss +0 -26
  145. package/src/components/Badge/subtle/subtleIconLabelBadges/index.js +0 -38
  146. package/src/components/Badge/subtle/subtleIconLabelBadges/subtleIconLabelBadges.scss +0 -56
  147. package/src/components/Badge/subtle/subtleOnlyLabelBadges/index.js +0 -31
  148. package/src/components/Badge/subtle/subtleOnlyLabelBadges/subtleOnlyLabelBadges.scss +0 -70
  149. package/src/components/BottomSheet/BottomSheet.styles.scss +0 -46
  150. package/src/components/BottomSheet/index.js +0 -60
  151. package/src/components/Breadcrumbs/Breadcrumbs.styles.scss +0 -65
  152. package/src/components/Breadcrumbs/index.js +0 -121
  153. package/src/components/Button/Button.styles.scss +0 -345
  154. package/src/components/Button/index.js +0 -171
  155. package/src/components/ButtonGroup/ButtonGroup.styles.scss +0 -125
  156. package/src/components/ButtonGroup/index.js +0 -84
  157. package/src/components/Card/Card.styles.scss +0 -33
  158. package/src/components/Card/index.js +0 -21
  159. package/src/components/Chart/Chart.style.scss +0 -142
  160. package/src/components/Chart/index.js +0 -752
  161. package/src/components/ChatBot/bookMarkPanel.js +0 -74
  162. package/src/components/ChatBot/chatBot.style.scss +0 -1295
  163. package/src/components/ChatBot/chatBotFooter.js +0 -14
  164. package/src/components/ChatBot/chatBotLandingScreen.js +0 -26
  165. package/src/components/ChatBot/chatInput.js +0 -206
  166. package/src/components/ChatBot/chatbotModuleMenu.js +0 -278
  167. package/src/components/ChatBot/constant.js +0 -32
  168. package/src/components/ChatBot/conversationScreen.js +0 -281
  169. package/src/components/ChatBot/customScreen.js +0 -69
  170. package/src/components/ChatBot/historyPanel.js +0 -579
  171. package/src/components/ChatBot/index.js +0 -473
  172. package/src/components/ChatBot/newChatComponent.js +0 -105
  173. package/src/components/ChatBot/utils.js +0 -27
  174. package/src/components/Checkbox/Checkbox.styles.scss +0 -232
  175. package/src/components/Checkbox/dashed/index.js +0 -34
  176. package/src/components/Checkbox/default/index.js +0 -70
  177. package/src/components/Checkbox/index.js +0 -50
  178. package/src/components/Checkbox/withDropDown/index.js +0 -96
  179. package/src/components/Checkbox/withoutFormLabel/index.js +0 -46
  180. package/src/components/Chips/Chip.style.scss +0 -134
  181. package/src/components/Chips/index.js +0 -34
  182. package/src/components/CreateItemFlow/CreateItemFlow.styles.scss +0 -37
  183. package/src/components/CreateItemFlow/index.js +0 -145
  184. package/src/components/DatePicker/DatePicker.styles.scss +0 -519
  185. package/src/components/DatePicker/datePickerDropdown.js +0 -282
  186. package/src/components/DatePicker/datePickerFooter.js +0 -76
  187. package/src/components/DatePicker/datePickerInput.js +0 -333
  188. package/src/components/DatePicker/index.js +0 -288
  189. package/src/components/DatePicker/showMonthYearSelect.js +0 -119
  190. package/src/components/DateRangePicker/DateRangePicker.styles.scss +0 -635
  191. package/src/components/DateRangePicker/dateRangePickerCustom.js +0 -22
  192. package/src/components/DateRangePicker/dateRangePickerDropdown.js +0 -320
  193. package/src/components/DateRangePicker/dateRangePickerFooter.js +0 -50
  194. package/src/components/DateRangePicker/dateRangePickerInput.js +0 -544
  195. package/src/components/DateRangePicker/index.js +0 -393
  196. package/src/components/DateRangePicker/showMonthYearSelect.js +0 -103
  197. package/src/components/DateRangePicker/utils.js +0 -71
  198. package/src/components/DynamicLayout/DynamicLayout.styles.scss +0 -153
  199. package/src/components/DynamicLayout/index.js +0 -73
  200. package/src/components/EmptyState/EmptyState.styles.scss +0 -88
  201. package/src/components/EmptyState/EmptyStateImageComponent.jsx +0 -36
  202. package/src/components/EmptyState/index.js +0 -54
  203. package/src/components/FileUpload/FileUpload.styles.scss +0 -449
  204. package/src/components/FileUpload/index.js +0 -641
  205. package/src/components/FilterPanel/FilterPanel.styles.scss +0 -241
  206. package/src/components/FilterPanel/FilterPanelHeader.js +0 -15
  207. package/src/components/FilterPanel/PanelFooter.js +0 -65
  208. package/src/components/FilterPanel/PanelSidebar.js +0 -85
  209. package/src/components/FilterPanel/index.js +0 -147
  210. package/src/components/FiltersStrip/FiltersStrip.styles.scss +0 -343
  211. package/src/components/FiltersStrip/Slider/FilterSlider.styles.scss +0 -85
  212. package/src/components/FiltersStrip/Slider/Portal.js +0 -59
  213. package/src/components/FiltersStrip/Slider/index.js +0 -233
  214. package/src/components/FiltersStrip/appliedFilter.js +0 -180
  215. package/src/components/FiltersStrip/filterDropDown.js +0 -96
  216. package/src/components/FiltersStrip/index.js +0 -127
  217. package/src/components/FiltersStrip/mockData.js +0 -227
  218. package/src/components/Header/Header.styles.scss +0 -223
  219. package/src/components/Header/index.js +0 -156
  220. package/src/components/HomePage/HomePage.styles.scss +0 -1638
  221. package/src/components/HomePage/constant.js +0 -331
  222. package/src/components/HomePage/index.js +0 -675
  223. package/src/components/Input/Input.styles.scss +0 -318
  224. package/src/components/Input/helperText.js +0 -19
  225. package/src/components/Input/index.js +0 -60
  226. package/src/components/Input/inputWithIcon.js +0 -134
  227. package/src/components/Input/vanilaInput.js +0 -68
  228. package/src/components/Loader/Loader.styles.scss +0 -90
  229. package/src/components/Loader/index.js +0 -69
  230. package/src/components/Menu/IconMenuItem.js +0 -100
  231. package/src/components/Menu/Menu.styles.scss +0 -190
  232. package/src/components/Menu/MenuHeader.jsx +0 -84
  233. package/src/components/Menu/MenuHeaderInfo.jsx +0 -319
  234. package/src/components/Menu/MenuHeaderInfo.styles.scss +0 -123
  235. package/src/components/Menu/NestedMenuItem.js +0 -189
  236. package/src/components/Menu/index.js +0 -254
  237. package/src/components/Menu/nestedMenuItemsFromObject.js +0 -100
  238. package/src/components/Modal/Modal.styles.scss +0 -129
  239. package/src/components/Modal/index.js +0 -141
  240. package/src/components/MonthPicker/MonthPicker.styles.scss +0 -255
  241. package/src/components/MonthPicker/constant.js +0 -1
  242. package/src/components/MonthPicker/index.js +0 -373
  243. package/src/components/MonthRangePicker/MonthRangePicker.styles.scss +0 -383
  244. package/src/components/MonthRangePicker/constant.js +0 -1
  245. package/src/components/MonthRangePicker/index.js +0 -574
  246. package/src/components/Notification/Notification.styles.scss +0 -594
  247. package/src/components/Notification/NotificationBody/NotificationInfoList/chipsLists.js +0 -144
  248. package/src/components/Notification/NotificationBody/NotificationInfoList/index.js +0 -128
  249. package/src/components/Notification/NotificationBody/NotificationInfoList/notificationList.js +0 -165
  250. package/src/components/Notification/NotificationBody/NotificationPanels/chipsLists.js +0 -85
  251. package/src/components/Notification/NotificationBody/NotificationPanels/index.js +0 -259
  252. package/src/components/Notification/NotificationBody/NotificationPanels/notificationList.js +0 -637
  253. package/src/components/Notification/NotificationBody/index.js +0 -117
  254. package/src/components/Notification/index.js +0 -128
  255. package/src/components/Notification/mockData.js +0 -389
  256. package/src/components/Notification/notificationFooter.js +0 -31
  257. package/src/components/Notification/notificationHeader.js +0 -28
  258. package/src/components/Panel/Panel.styles.scss +0 -71
  259. package/src/components/Panel/index.js +0 -144
  260. package/src/components/Popover/Popover.styles.scss +0 -52
  261. package/src/components/Popover/index.js +0 -71
  262. package/src/components/Portal/index.js +0 -31
  263. package/src/components/ProgressBar/ProgressBar.styles.scss +0 -62
  264. package/src/components/ProgressBar/index.js +0 -40
  265. package/src/components/Prompt/Prompt.styles.scss +0 -107
  266. package/src/components/Prompt/index.js +0 -107
  267. package/src/components/RadioButtonGroup/RadioButtonGroup.styles.scss +0 -136
  268. package/src/components/RadioButtonGroup/index.js +0 -107
  269. package/src/components/Select/SearchFilter.js +0 -72
  270. package/src/components/Select/Select.styles.scss +0 -748
  271. package/src/components/Select/customGroupHeading.js +0 -24
  272. package/src/components/Select/dropdown.js +0 -65
  273. package/src/components/Select/hooks/index.js +0 -2
  274. package/src/components/Select/hooks/useClickOutside.js +0 -61
  275. package/src/components/Select/hooks/useMenuPosition.js +0 -288
  276. package/src/components/Select/index.js +0 -1307
  277. package/src/components/Select/menuList.js +0 -119
  278. package/src/components/Select/optionList.js +0 -215
  279. package/src/components/Select/selected-option-tags.js +0 -99
  280. package/src/components/Select/utils.js +0 -232
  281. package/src/components/Sidebar/Menus/childMenu.js +0 -88
  282. package/src/components/Sidebar/Menus/index.js +0 -130
  283. package/src/components/Sidebar/Menus/parentMenu.js +0 -173
  284. package/src/components/Sidebar/Sidebar.styles.scss +0 -411
  285. package/src/components/Sidebar/actions.js +0 -31
  286. package/src/components/Sidebar/index.js +0 -84
  287. package/src/components/Sidebar/mock.js +0 -202
  288. package/src/components/Slider/Sliders.styles.scss +0 -260
  289. package/src/components/Slider/index.js +0 -314
  290. package/src/components/Stepper/Stepper.styles.scss +0 -355
  291. package/src/components/Stepper/index.js +0 -101
  292. package/src/components/Switch/Switch.styles.scss +0 -96
  293. package/src/components/Switch/index.js +0 -59
  294. package/src/components/Table/AdvanceSearchModalItem.js +0 -392
  295. package/src/components/Table/AdvanceSortModal.js +0 -332
  296. package/src/components/Table/AgGridHeader.js +0 -1009
  297. package/src/components/Table/CommentsPortal.js +0 -428
  298. package/src/components/Table/NewAdvanceSearchModal/NewAdvanceSearchModal.js +0 -323
  299. package/src/components/Table/NewAdvanceSearchModal/NewAdvanceSearchModalItem.js +0 -476
  300. package/src/components/Table/NoComments.js +0 -295
  301. package/src/components/Table/Table.styles.scss +0 -3859
  302. package/src/components/Table/actionBar.js +0 -43
  303. package/src/components/Table/advanceSearchModal.js +0 -797
  304. package/src/components/Table/commentPanel.js +0 -421
  305. package/src/components/Table/filterUtils.js +0 -850
  306. package/src/components/Table/index.js +0 -2175
  307. package/src/components/Table/mockData.js +0 -1344
  308. package/src/components/Table/tableFunctions.js +0 -1676
  309. package/src/components/Table/tableHeader.js +0 -476
  310. package/src/components/Table/tableIcons.js +0 -61
  311. package/src/components/Table/tableMoreOptions.js +0 -293
  312. package/src/components/Table/tablePagination.js +0 -63
  313. package/src/components/Table/tableSettings.js +0 -287
  314. package/src/components/Table/withCommentIcon.js +0 -107
  315. package/src/components/TableChat/EmptyContainer.jsx +0 -13
  316. package/src/components/TableChat/README.md +0 -588
  317. package/src/components/TableChat/TableChatSidePanel.jsx +0 -832
  318. package/src/components/TableChat/TableChatSidePanel.styles.scss +0 -57
  319. package/src/components/TableChat/components/ChatMessageSkeleton/ChatFooterSkeleton.jsx +0 -43
  320. package/src/components/TableChat/components/ChatMessageSkeleton/ChatHeaderSkeleton.jsx +0 -55
  321. package/src/components/TableChat/components/ChatMessageSkeleton/ChatMessageListSkeleton.jsx +0 -94
  322. package/src/components/TableChat/components/ChatMessageSkeleton/ChatSkeleton.jsx +0 -22
  323. package/src/components/TableChat/components/ChatMessageSkeleton/ChatSkeleton.scss +0 -179
  324. package/src/components/TableChat/components/SkeletonList.jsx +0 -12
  325. package/src/components/TableChat/components/TableChatLeftSection/AddChatContainer/AddChatContainer.jsx +0 -171
  326. package/src/components/TableChat/components/TableChatLeftSection/AddChatContainer/AddChatContainer.styles.scss +0 -37
  327. package/src/components/TableChat/components/TableChatLeftSection/ChannelCheckbox/ChannelCheckbox.jsx +0 -28
  328. package/src/components/TableChat/components/TableChatLeftSection/ChatChannelItem.jsx +0 -116
  329. package/src/components/TableChat/components/TableChatLeftSection/ChatChannelList.jsx +0 -89
  330. package/src/components/TableChat/components/TableChatLeftSection/ChatHeaderButton/ChatHeaderButton.jsx +0 -27
  331. package/src/components/TableChat/components/TableChatLeftSection/ChatHeaderNavigation.jsx +0 -191
  332. package/src/components/TableChat/components/TableChatLeftSection/ChatIconButton/ChatIconButton.jsx +0 -23
  333. package/src/components/TableChat/components/TableChatLeftSection/TableChatChannelHeader.jsx +0 -117
  334. package/src/components/TableChat/components/TableChatLeftSection/TableChatChannelHeader.styles.scss +0 -469
  335. package/src/components/TableChat/components/TableChatLeftSection/UnreadBadge/UnreadBadge.jsx +0 -16
  336. package/src/components/TableChat/components/TableChatRightSection/AvatarGroup/AvatarGroup.jsx +0 -119
  337. package/src/components/TableChat/components/TableChatRightSection/AvatarGroup/AvatarGroup.styles.scss +0 -87
  338. package/src/components/TableChat/components/TableChatRightSection/ChatDefaultMessageType/ChatDefaultMessageType.jsx +0 -216
  339. package/src/components/TableChat/components/TableChatRightSection/ChatDefaultMessageType/ChatDefaultMessageType.styles.scss +0 -291
  340. package/src/components/TableChat/components/TableChatRightSection/ChatDeleteMessageType/ChatDeletedMessageType.jsx +0 -19
  341. package/src/components/TableChat/components/TableChatRightSection/ChatDeleteMessageType/DeletedMessage.styles.scss +0 -55
  342. package/src/components/TableChat/components/TableChatRightSection/ChatEditedMessageType/ChatEditedMessageType.jsx +0 -61
  343. package/src/components/TableChat/components/TableChatRightSection/ChatEditedMessageType/ChatEditedMessageType.styles.scss +0 -13
  344. package/src/components/TableChat/components/TableChatRightSection/ChatHeader/ChatHeader.jsx +0 -432
  345. package/src/components/TableChat/components/TableChatRightSection/ChatHeader/ChatHeaderAction.jsx +0 -365
  346. package/src/components/TableChat/components/TableChatRightSection/ChatHeader/ChatHeaderInfo.jsx +0 -42
  347. package/src/components/TableChat/components/TableChatRightSection/ChatHeader/chatHeader.styles.scss +0 -323
  348. package/src/components/TableChat/components/TableChatRightSection/ChatInput/ChatInput.jsx +0 -793
  349. package/src/components/TableChat/components/TableChatRightSection/ChatInput/ChatInput.styles.scss +0 -394
  350. package/src/components/TableChat/components/TableChatRightSection/ChatMessageActions/ChatMessageActions.jsx +0 -61
  351. package/src/components/TableChat/components/TableChatRightSection/ChatMessageActions/ChatMessageActions.styles.scss +0 -28
  352. package/src/components/TableChat/components/TableChatRightSection/ChatMessageAvatar/ChatMessageAvatar.jsx +0 -11
  353. package/src/components/TableChat/components/TableChatRightSection/ChatMessageAvatar/ChatMessageAvatar.styles.scss +0 -3
  354. package/src/components/TableChat/components/TableChatRightSection/ChatMessages/ChatMessage.jsx +0 -220
  355. package/src/components/TableChat/components/TableChatRightSection/ChatMessages/ChatMessage.styles.scss +0 -128
  356. package/src/components/TableChat/components/TableChatRightSection/ChatNotificationSettings/ChatNotificationSettings.jsx +0 -246
  357. package/src/components/TableChat/components/TableChatRightSection/ChatNotificationSettings/ChatNotificationSettings.styles.scss +0 -210
  358. package/src/components/TableChat/components/TableChatRightSection/DateSeparator/DateSeparator.jsx +0 -52
  359. package/src/components/TableChat/components/TableChatRightSection/DateSeparator/DateSeparator.styles.scss +0 -34
  360. package/src/components/TableChat/components/TableChatRightSection/EmojiPicker/EmojiPicker.jsx +0 -31
  361. package/src/components/TableChat/components/TableChatRightSection/FileUploader/FileUploader.jsx +0 -170
  362. package/src/components/TableChat/components/TableChatRightSection/ImageUploader/ImageUploader.jsx +0 -165
  363. package/src/components/TableChat/components/TableChatRightSection/PinedChatPanel/PinedChat.styles.scss +0 -587
  364. package/src/components/TableChat/components/TableChatRightSection/PinedChatPanel/PinedChatPanel.jsx +0 -244
  365. package/src/components/TableChat/components/TableChatRightSection/ReplyBadge/ReplyBadge.jsx +0 -29
  366. package/src/components/TableChat/components/TableChatRightSection/ReplyBadge/ReplyBadge.styles.scss +0 -47
  367. package/src/components/TableChat/components/TableChatRightSection/TableChatRightSection.jsx +0 -1340
  368. package/src/components/TableChat/components/TableChatRightSection/TableChatRightSection.styles.scss +0 -147
  369. package/src/components/TableChat/components/TextEditor/EditorToolbar.jsx +0 -209
  370. package/src/components/TableChat/components/TextEditor/EditorToolbar.styles.scss +0 -61
  371. package/src/components/TableChat/components/TextEditor/Mention.jsx +0 -234
  372. package/src/components/TableChat/components/TextEditor/MentionList.jsx +0 -118
  373. package/src/components/TableChat/components/TextEditor/MentionList.scss +0 -146
  374. package/src/components/TableChat/components/TextEditor/styles.scss +0 -278
  375. package/src/components/TableChat/components/TextEditor/suggestion.js +0 -124
  376. package/src/components/TableChat/components/chatConfig.js +0 -64
  377. package/src/components/TableChat/hooks/useInfiniteScroll.js +0 -256
  378. package/src/components/TableOld/AgGridHeader.js +0 -545
  379. package/src/components/TableOld/Table.styles.scss +0 -2192
  380. package/src/components/TableOld/actionBar.js +0 -43
  381. package/src/components/TableOld/index.js +0 -598
  382. package/src/components/TableOld/mockData.js +0 -1344
  383. package/src/components/TableOld/tableFunctions.js +0 -1734
  384. package/src/components/TableOld/tableHeader.js +0 -251
  385. package/src/components/TableOld/tableIcons.js +0 -61
  386. package/src/components/TableOld/tablePagination.js +0 -64
  387. package/src/components/TableOld/tableSettings.js +0 -166
  388. package/src/components/Tabs/Tabs.styles.scss +0 -120
  389. package/src/components/Tabs/index.js +0 -91
  390. package/src/components/Tabs/tabPanel.js +0 -38
  391. package/src/components/Tag/Tags.styles.scss +0 -71
  392. package/src/components/Tag/filled.js +0 -48
  393. package/src/components/Tag/index.js +0 -54
  394. package/src/components/Tag/solid.js +0 -47
  395. package/src/components/Tag/stroke.js +0 -47
  396. package/src/components/Tag/utils.js +0 -12
  397. package/src/components/TagGroup/TagGroup.styles.scss +0 -7
  398. package/src/components/TagGroup/index.js +0 -6
  399. package/src/components/TextArea/TextArea.styles.scss +0 -158
  400. package/src/components/TextArea/index.js +0 -121
  401. package/src/components/Toast/Toast.styles.scss +0 -66
  402. package/src/components/Toast/index.js +0 -35
  403. package/src/components/Tooltip/Tooltips.styles.scss +0 -111
  404. package/src/components/Tooltip/index.js +0 -68
  405. package/src/components/common/HelperText/HelperText.styles.scss +0 -18
  406. package/src/components/common/HelperText/index.js +0 -44
  407. package/src/components/common/MentionEditor/MentionEditor.styles.scss +0 -301
  408. package/src/components/common/MentionEditor/MentionList/MentionList.styles.scss +0 -146
  409. package/src/components/common/MentionEditor/MentionList/index.js +0 -130
  410. package/src/components/common/MentionEditor/index.js +0 -246
  411. package/src/components/common/MentionEditor/suggestion.js +0 -124
  412. package/src/components/index.js +0 -53
  413. package/src/stories/Accordion.stories.js +0 -151
  414. package/src/stories/AccordionModern.stories.js +0 -263
  415. package/src/stories/Alert.stories.js +0 -103
  416. package/src/stories/Avatar.stories.js +0 -79
  417. package/src/stories/Badge.stories.js +0 -112
  418. package/src/stories/BottomSheet.stories.js +0 -224
  419. package/src/stories/Breadcrumbs.stories.js +0 -143
  420. package/src/stories/Button.stories.js +0 -190
  421. package/src/stories/ButtonGroup.stories.js +0 -123
  422. package/src/stories/Card.stories.js +0 -73
  423. package/src/stories/Changelog.mdx +0 -1006
  424. package/src/stories/Chart.stories.js +0 -2017
  425. package/src/stories/ChatBot.stories.js +0 -668
  426. package/src/stories/Checkbox.stories.js +0 -209
  427. package/src/stories/Chips.stories.js +0 -106
  428. package/src/stories/CreateItemFlow.stories.js +0 -255
  429. package/src/stories/DatePicker.stories.js +0 -311
  430. package/src/stories/DateRangePicker.stories.js +0 -364
  431. package/src/stories/EmptyState.stories.js +0 -110
  432. package/src/stories/FileUpload.stories.js +0 -169
  433. package/src/stories/FilterPanel.stories.js +0 -309
  434. package/src/stories/FiltersStrip.stories.js +0 -244
  435. package/src/stories/GettingStarted.mdx +0 -153
  436. package/src/stories/Header.stories.js +0 -185
  437. package/src/stories/HomePage.stories.js +0 -201
  438. package/src/stories/Input.stories.js +0 -165
  439. package/src/stories/Loader.stories.js +0 -33
  440. package/src/stories/Menu.stories.js +0 -309
  441. package/src/stories/Modal.stories.js +0 -185
  442. package/src/stories/MonthPicker.stories.js +0 -313
  443. package/src/stories/MonthRangePicker.stories.js +0 -255
  444. package/src/stories/Notification.stories.js +0 -500
  445. package/src/stories/Panel.stories.js +0 -179
  446. package/src/stories/Popover.stories.js +0 -125
  447. package/src/stories/ProgressBar.stories.js +0 -93
  448. package/src/stories/Prompt.stories.js +0 -120
  449. package/src/stories/RadioButtonGroup.stories.js +0 -83
  450. package/src/stories/Select.stories.js +0 -753
  451. package/src/stories/Sidebar.stories.js +0 -177
  452. package/src/stories/Slider.stories.js +0 -226
  453. package/src/stories/Stepper.stories.js +0 -158
  454. package/src/stories/Switch.stories.js +0 -72
  455. package/src/stories/Table.stories.js +0 -4323
  456. package/src/stories/TableChat.mdx +0 -992
  457. package/src/stories/TableChat.stories.js +0 -1712
  458. package/src/stories/TableOld.stories.js +0 -954
  459. package/src/stories/Tabs.stories.js +0 -253
  460. package/src/stories/Tag.stories.js +0 -92
  461. package/src/stories/TagGroup.stories.js +0 -39
  462. package/src/stories/TextArea.stories.js +0 -148
  463. package/src/stories/Toast.stories.js +0 -113
  464. package/src/stories/Tooltip.stories.js +0 -86
  465. package/src/stories/storybookLinks.mdx +0 -20
@@ -1,544 +0,0 @@
1
- import React, { useState, useRef, useEffect } from "react";
2
- import moment from "moment";
3
- import calendarIcon from "../../assets/calendar.svg";
4
- export default function DateRangePickerInput({
5
- inputContainerRef,
6
- startDateString,
7
- startDateInputRef,
8
- startDateInputProps,
9
- endDateString,
10
- endDateInputRef,
11
- endDateInputProps,
12
- isDisabled,
13
- isError,
14
- onStartDateFocus,
15
- onEndDateFocus,
16
- displayFormat = "DD-MM-YYYY",
17
- onStartDateStringChange,
18
- onEndDateStringChange,
19
- minDate,
20
- maxDate,
21
- readOnly,
22
- isOutsideRange,
23
- onErrorStateChange,
24
- clearErrorsTrigger,
25
- resetTrigger,
26
- customIcon,
27
- }) {
28
- const [startInputValue, setStartInputValue] = useState("");
29
- const [endInputValue, setEndInputValue] = useState("");
30
- const [startErrorState, setStartErrorState] = useState(false);
31
- const [endErrorState, setEndErrorState] = useState(false);
32
- const [startPendingCursorPosition, setStartPendingCursorPosition] =
33
- useState(null);
34
- const [endPendingCursorPosition, setEndPendingCursorPosition] =
35
- useState(null);
36
-
37
- // Fixed positions for DD-MM-YYYY format
38
- const NUMBER_POSITIONS = [0, 1, 3, 4, 6, 7, 8, 9];
39
-
40
- // Handle cursor positioning after value updates
41
- useEffect(() => {
42
- if (startPendingCursorPosition !== null && startDateInputRef.current) {
43
- startDateInputRef.current.setSelectionRange(
44
- startPendingCursorPosition,
45
- startPendingCursorPosition
46
- );
47
- setStartPendingCursorPosition(null);
48
- }
49
- }, [startInputValue, startPendingCursorPosition]);
50
-
51
- useEffect(() => {
52
- if (endPendingCursorPosition !== null && endDateInputRef.current) {
53
- endDateInputRef.current.setSelectionRange(
54
- endPendingCursorPosition,
55
- endPendingCursorPosition
56
- );
57
- setEndPendingCursorPosition(null);
58
- }
59
- }, [endInputValue, endPendingCursorPosition]);
60
-
61
- useEffect(() => {
62
- if (startDateString) {
63
- setStartInputValue(startDateString);
64
- } else {
65
- setStartInputValue("");
66
- }
67
- }, [startDateString]);
68
-
69
- useEffect(() => {
70
- if (endDateString) {
71
- setEndInputValue(endDateString);
72
- } else {
73
- setEndInputValue("");
74
- }
75
- }, [endDateString]);
76
-
77
- // Notify parent component when error state changes
78
- useEffect(() => {
79
- const hasErrors = startErrorState || endErrorState;
80
- if (onErrorStateChange) {
81
- onErrorStateChange(hasErrors);
82
- }
83
- }, [startErrorState, endErrorState, onErrorStateChange]);
84
-
85
- // Clear error states when valid dates are selected via dropdown
86
- useEffect(() => {
87
- if (clearErrorsTrigger > 0) {
88
- setStartErrorState(false);
89
- setEndErrorState(false);
90
- }
91
- }, [clearErrorsTrigger]);
92
-
93
- // Fully clear inputs and errors when Reset is clicked
94
- useEffect(() => {
95
- if (resetTrigger > 0) {
96
- setStartErrorState(false);
97
- setEndErrorState(false);
98
- setStartInputValue("");
99
- setEndInputValue("");
100
- onStartDateStringChange?.(null);
101
- onEndDateStringChange?.(null);
102
- }
103
- }, [resetTrigger]);
104
-
105
- const validateDate = (date, isStartDate) => {
106
- if (!date) return false;
107
-
108
- // Check if date is within min/max range
109
- if (minDate && moment(date).isBefore(minDate, "day")) {
110
- return false;
111
- }
112
- if (maxDate && moment(date).isAfter(maxDate, "day")) {
113
- return false;
114
- }
115
-
116
- // Get the day and month from the input value
117
- const inputValue = isStartDate ? startInputValue : endInputValue;
118
- const format = displayFormat || "DD-MM-YYYY";
119
- const formatMap = {
120
- "DD-MM-YYYY": { day: [0, 2], month: [3, 5], year: [6, 10] },
121
- "MM-DD-YYYY": { day: [3, 5], month: [0, 2], year: [6, 10] },
122
- "YYYY-MM-DD": { day: [8, 10], month: [5, 7], year: [0, 4] },
123
- };
124
-
125
- const formatInfo = formatMap[format] || formatMap["DD-MM-YYYY"];
126
- const day = parseInt(
127
- inputValue.substring(formatInfo.day[0], formatInfo.day[1])
128
- );
129
- const month = parseInt(
130
- inputValue.substring(formatInfo.month[0], formatInfo.month[1])
131
- );
132
- const year = parseInt(
133
- inputValue.substring(formatInfo.year[0], formatInfo.year[1])
134
- );
135
-
136
- // Validate month (1-12)
137
- if (month < 1 || month > 12) {
138
- return false;
139
- }
140
-
141
- // Get the last day of the month
142
- const lastDayOfMonth = moment(`${year}-${month}`, "YYYY-M").daysInMonth();
143
-
144
- // Validate day (1 to last day of month)
145
- if (day < 1 || day > lastDayOfMonth) {
146
- return false;
147
- }
148
-
149
- // Validate start date is before or equal to end date
150
- if (isStartDate && endInputValue) {
151
- const endDate = moment(endInputValue, displayFormat, true);
152
- if (endDate.isValid() && moment(date).isAfter(endDate, "day")) {
153
- return false;
154
- }
155
- }
156
-
157
- // Validate end date is after or equal to start date
158
- if (!isStartDate && startInputValue) {
159
- const startDate = moment(startInputValue, displayFormat, true);
160
- if (startDate.isValid() && moment(date).isBefore(startDate, "day")) {
161
- return false;
162
- }
163
- }
164
-
165
- // Validate against isOutsideRange function
166
- if (isOutsideRange && isOutsideRange(moment(date))) {
167
- return false;
168
- }
169
-
170
- return true;
171
- };
172
-
173
- const handleStartDateInputFocus = () => {
174
- if (!startInputValue) {
175
- setStartInputValue(displayFormat);
176
- // Use setTimeout to ensure the input is focused before setting selection
177
- setTimeout(() => {
178
- if (startDateInputRef.current) {
179
- startDateInputRef.current.setSelectionRange(0, 0);
180
- }
181
- }, 0);
182
- }
183
- onStartDateFocus();
184
- };
185
-
186
- const handleEndDateInputFocus = () => {
187
- if (!endInputValue) {
188
- setEndInputValue(displayFormat);
189
- // Use setTimeout to ensure the input is focused before setting selection
190
- setTimeout(() => {
191
- if (endDateInputRef.current) {
192
- endDateInputRef.current.setSelectionRange(0, 0);
193
- }
194
- }, 0);
195
- }
196
- onEndDateFocus();
197
- };
198
-
199
- const handleStartDateInputBlur = () => {
200
- const parsedDate = moment(startInputValue, displayFormat, true);
201
- if (parsedDate.isValid()) {
202
- const isValid = validateDate(parsedDate, true);
203
- setStartErrorState(!isValid);
204
- if (isValid) {
205
- onStartDateStringChange?.(parsedDate);
206
- }
207
- } else {
208
- setStartErrorState(true);
209
- }
210
-
211
- if (!startInputValue || startInputValue === displayFormat) {
212
- setStartInputValue("");
213
- setStartErrorState(false);
214
- onStartDateStringChange?.(null);
215
- }
216
- };
217
-
218
- const handleEndDateInputBlur = () => {
219
- const parsedDate = moment(endInputValue, displayFormat, true);
220
- if (parsedDate.isValid()) {
221
- const isValid = validateDate(parsedDate, false);
222
- setEndErrorState(!isValid);
223
- if (isValid) {
224
- onEndDateStringChange?.(parsedDate);
225
- }
226
- } else {
227
- setEndErrorState(true);
228
- }
229
-
230
- if (!endInputValue || endInputValue === displayFormat) {
231
- setEndInputValue("");
232
- setEndErrorState(false);
233
- onEndDateStringChange?.(null);
234
- }
235
- };
236
-
237
- const handleStartDateInputClick = () => {
238
- if (startDateInputRef.current) {
239
- const cursor = startDateInputRef.current.selectionStart;
240
-
241
- // Special case: clicking after last character
242
- if (cursor >= NUMBER_POSITIONS[NUMBER_POSITIONS.length - 1] + 1) {
243
- startDateInputRef.current.setSelectionRange(
244
- NUMBER_POSITIONS[NUMBER_POSITIONS.length - 1] + 1,
245
- NUMBER_POSITIONS[NUMBER_POSITIONS.length - 1] + 1
246
- );
247
- return;
248
- }
249
-
250
- // If click lands on a non-digit position (i.e. separator)
251
- if (!NUMBER_POSITIONS.includes(cursor)) {
252
- // Find the next number position *after* the click
253
- const nextPos = NUMBER_POSITIONS.find((pos) => pos >= cursor);
254
-
255
- // Fallback: go to last number position
256
- const fallbackPos = NUMBER_POSITIONS[NUMBER_POSITIONS.length - 1];
257
-
258
- startDateInputRef.current.setSelectionRange(
259
- nextPos !== undefined ? nextPos : fallbackPos,
260
- nextPos !== undefined ? nextPos : fallbackPos
261
- );
262
- }
263
- // Else: click landed on a number digit, let it be
264
- }
265
- };
266
-
267
- const handleEndDateInputClick = () => {
268
- if (endDateInputRef.current) {
269
- const cursor = endDateInputRef.current.selectionStart;
270
-
271
- // Special case: clicking after last character
272
- if (cursor >= NUMBER_POSITIONS[NUMBER_POSITIONS.length - 1] + 1) {
273
- endDateInputRef.current.setSelectionRange(
274
- NUMBER_POSITIONS[NUMBER_POSITIONS.length - 1] + 1,
275
- NUMBER_POSITIONS[NUMBER_POSITIONS.length - 1] + 1
276
- );
277
- return;
278
- }
279
-
280
- // If click lands on a non-digit position (i.e. separator)
281
- if (!NUMBER_POSITIONS.includes(cursor)) {
282
- // Find the next number position *after* the click
283
- const nextPos = NUMBER_POSITIONS.find((pos) => pos >= cursor);
284
-
285
- // Fallback: go to last number position
286
- const fallbackPos = NUMBER_POSITIONS[NUMBER_POSITIONS.length - 1];
287
-
288
- endDateInputRef.current.setSelectionRange(
289
- nextPos !== undefined ? nextPos : fallbackPos,
290
- nextPos !== undefined ? nextPos : fallbackPos
291
- );
292
- }
293
- // Else: click landed on a number digit, let it be
294
- }
295
- };
296
-
297
- const handleStartDateInputChange = (e) => {
298
- const input = e.target;
299
- const value = input.value;
300
- const cursorPosition = input.selectionStart;
301
-
302
- // Guard: invalid cursor
303
- if (cursorPosition == null || cursorPosition < 1) return;
304
-
305
- const newChar = value[cursorPosition - 1];
306
- if (!/^\d$/.test(newChar)) return;
307
-
308
- const pos = cursorPosition - 1;
309
-
310
- // Guard: only allow typing in number positions
311
- if (!NUMBER_POSITIONS.includes(pos)) {
312
- e.preventDefault?.();
313
- setStartPendingCursorPosition(
314
- NUMBER_POSITIONS.find((p) => p > pos) ??
315
- NUMBER_POSITIONS[NUMBER_POSITIONS.length - 1]
316
- );
317
- return;
318
- }
319
-
320
- const newValue =
321
- startInputValue.slice(0, pos) + newChar + startInputValue.slice(pos + 1);
322
-
323
- if (newValue.length > displayFormat.length) return;
324
- setStartInputValue(newValue);
325
- onStartDateStringChange?.(newValue);
326
-
327
- const currentIndex = NUMBER_POSITIONS.indexOf(pos);
328
- if (currentIndex < NUMBER_POSITIONS.length - 1) {
329
- const nextPos = NUMBER_POSITIONS[currentIndex + 1];
330
- setStartPendingCursorPosition(nextPos);
331
- } else {
332
- const parsedDate = moment(newValue, displayFormat, true);
333
- const isValid = parsedDate.isValid() && validateDate(parsedDate, true);
334
- setStartErrorState(!isValid);
335
- onStartDateStringChange?.(isValid ? parsedDate : newValue);
336
- }
337
- };
338
-
339
- const handleEndDateInputChange = (e) => {
340
- const input = e.target;
341
- const value = input.value;
342
- const cursorPosition = input.selectionStart;
343
-
344
- // Guard: invalid cursor
345
- if (cursorPosition == null || cursorPosition < 1) return;
346
-
347
- const newChar = value[cursorPosition - 1];
348
- if (!/^\d$/.test(newChar)) return;
349
-
350
- const pos = cursorPosition - 1;
351
-
352
- // Guard: only allow typing in number positions
353
- if (!NUMBER_POSITIONS.includes(pos)) {
354
- e.preventDefault?.();
355
- setEndPendingCursorPosition(
356
- NUMBER_POSITIONS.find((p) => p > pos) ??
357
- NUMBER_POSITIONS[NUMBER_POSITIONS.length - 1]
358
- );
359
- return;
360
- }
361
-
362
- const newValue =
363
- endInputValue.slice(0, pos) + newChar + endInputValue.slice(pos + 1);
364
- if (newValue.length > displayFormat.length) return;
365
- setEndInputValue(newValue);
366
- onEndDateStringChange?.(newValue);
367
-
368
- const currentIndex = NUMBER_POSITIONS.indexOf(pos);
369
- if (currentIndex < NUMBER_POSITIONS.length - 1) {
370
- const nextPos = NUMBER_POSITIONS[currentIndex + 1];
371
- setEndPendingCursorPosition(nextPos);
372
- } else {
373
- const parsedDate = moment(newValue, displayFormat, true);
374
- const isValid = parsedDate.isValid() && validateDate(parsedDate, false);
375
- setEndErrorState(!isValid);
376
- onEndDateStringChange?.(isValid ? parsedDate : newValue);
377
- }
378
- };
379
-
380
- const handleStartDateKeyDown = (e) => {
381
- // Allow navigation keys
382
- if (e.key === "ArrowLeft" || e.key === "ArrowRight" || e.key === "Tab") {
383
- return;
384
- }
385
-
386
- if (e.key === "Backspace") {
387
- e.preventDefault();
388
-
389
- const caret = startDateInputRef.current.selectionStart;
390
-
391
- /* 1️⃣ figure out which digit we should delete */
392
- const deletePos = [...NUMBER_POSITIONS] // reverse‑scan
393
- .reverse()
394
- .find((p) => p < caret);
395
-
396
- if (deletePos == null) return; // nothing to delete
397
-
398
- /* 2️⃣ build a new masked value */
399
- const newValue =
400
- startInputValue.slice(0, deletePos) +
401
- displayFormat[deletePos] + // "D" | "M" | "Y"
402
- startInputValue.slice(deletePos + 1);
403
-
404
- setStartInputValue(newValue);
405
- onStartDateStringChange?.(newValue);
406
-
407
- /* 3️⃣ place caret so next Backspace hits the next digit */
408
- let nextCaret = deletePos; // start just after the reset char
409
- while (nextCaret > 0 && !NUMBER_POSITIONS.includes(nextCaret - 1)) {
410
- nextCaret--; // hop over separator(s)
411
- }
412
- setStartPendingCursorPosition(nextCaret);
413
- return;
414
- }
415
-
416
- // Only allow numbers
417
- if (!/^\d$/.test(e.key)) {
418
- e.preventDefault();
419
- }
420
- };
421
-
422
- const handleEndDateKeyDown = (e) => {
423
- // Allow navigation keys
424
- if (e.key === "ArrowLeft" || e.key === "ArrowRight" || e.key === "Tab") {
425
- return;
426
- }
427
-
428
- if (e.key === "Backspace") {
429
- e.preventDefault();
430
-
431
- const caret = endDateInputRef.current.selectionStart;
432
-
433
- /* 1️⃣ figure out which digit we should delete */
434
- const deletePos = [...NUMBER_POSITIONS] // reverse‑scan
435
- .reverse()
436
- .find((p) => p < caret);
437
-
438
- if (deletePos == null) return; // nothing to delete
439
-
440
- /* 2️⃣ build a new masked value */
441
- const newValue =
442
- endInputValue.slice(0, deletePos) +
443
- displayFormat[deletePos] + // "D" | "M" | "Y"
444
- endInputValue.slice(deletePos + 1);
445
-
446
- setEndInputValue(newValue);
447
- onEndDateStringChange?.(newValue);
448
-
449
- /* 3️⃣ place caret so next Backspace hits the next digit */
450
- let nextCaret = deletePos; // start just after the reset char
451
- while (nextCaret > 0 && !NUMBER_POSITIONS.includes(nextCaret - 1)) {
452
- nextCaret--; // hop over separator(s)
453
- }
454
- setEndPendingCursorPosition(nextCaret);
455
- return;
456
- }
457
-
458
- // Only allow numbers
459
- if (!/^\d$/.test(e.key)) {
460
- e.preventDefault();
461
- }
462
- };
463
-
464
- return (
465
- <div
466
- className={`dateRangePicker-input-container ${
467
- isDisabled ? "dateRangePicker-input-disabled" : ""
468
- }
469
- ${
470
- isError || startErrorState || endErrorState
471
- ? "impact-dateRangePicker-error"
472
- : ""
473
- }`}
474
- ref={inputContainerRef}
475
- >
476
- <input
477
- type="text"
478
- placeholder="Start Date"
479
- value={startInputValue}
480
- onFocus={handleStartDateInputFocus}
481
- onBlur={handleStartDateInputBlur}
482
- onClick={handleStartDateInputClick}
483
- onChange={handleStartDateInputChange}
484
- onKeyDown={handleStartDateKeyDown}
485
- ref={startDateInputRef}
486
- readOnly={readOnly}
487
- {...startDateInputProps}
488
- disabled={isDisabled}
489
- className="dateRangePicker-input-start-date"
490
- />
491
- <input
492
- type="text"
493
- placeholder="End Date"
494
- value={endInputValue}
495
- onFocus={handleEndDateInputFocus}
496
- onBlur={handleEndDateInputBlur}
497
- onClick={handleEndDateInputClick}
498
- onChange={handleEndDateInputChange}
499
- onKeyDown={handleEndDateKeyDown}
500
- ref={endDateInputRef}
501
- readOnly={readOnly}
502
- {...endDateInputProps}
503
- disabled={isDisabled}
504
- className="dateRangePicker-input-end-date"
505
- />
506
- {customIcon ? (
507
- <span
508
- className="end-date-icon"
509
- style={{
510
- position: "absolute",
511
- right: 10,
512
- top: "0px",
513
- transform: "translateY(-50%)",
514
- cursor: isDisabled ? "" : "pointer",
515
- opacity: isDisabled ? 0.5 : 1,
516
- }}
517
- >
518
- {customIcon}
519
- </span>
520
- ) : (
521
- <span
522
- className="end-date-icon"
523
- style={{
524
- position: "absolute",
525
- right: 10,
526
- top: "50%",
527
- transform: "translateY(-50%)",
528
- cursor: isDisabled ? "" : "pointer",
529
- width: 14,
530
- height: 14,
531
- background: `url(${calendarIcon}) no-repeat center/contain`,
532
- opacity: isDisabled ? 0.5 : 1,
533
- }}
534
- onClick={(e) => {
535
- e.stopPropagation();
536
- if (startDateInputRef.current && !isDisabled) {
537
- startDateInputRef.current.focus();
538
- }
539
- }}
540
- />
541
- )}
542
- </div>
543
- );
544
- }