@salutejs/plasma-new-hope 0.340.0-canary.2305.18873573377.0 → 0.340.0-canary.2316.18995854815.0

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 (373) hide show
  1. package/cjs/components/Calendar/CalendarBase/CalendarBase.js +6 -0
  2. package/cjs/components/Calendar/CalendarBase/CalendarBase.js.map +1 -1
  3. package/cjs/components/Calendar/CalendarDouble/CalendarDouble.js +6 -0
  4. package/cjs/components/Calendar/CalendarDouble/CalendarDouble.js.map +1 -1
  5. package/cjs/components/DatePicker/utils/normalizeDates.js +3 -6
  6. package/cjs/components/DatePicker/utils/normalizeDates.js.map +1 -1
  7. package/cjs/components/DateTimePicker/DateTimePicker.css +200 -0
  8. package/cjs/components/DateTimePicker/DateTimePicker.js +436 -0
  9. package/cjs/components/DateTimePicker/DateTimePicker.js.map +1 -0
  10. package/cjs/components/DateTimePicker/DateTimePicker.styles.js +23 -0
  11. package/cjs/components/DateTimePicker/DateTimePicker.styles.js.map +1 -0
  12. package/cjs/components/DateTimePicker/DateTimePicker.styles_x7parr.css +3 -0
  13. package/cjs/components/DateTimePicker/DateTimePicker.tokens.js +263 -0
  14. package/cjs/components/DateTimePicker/DateTimePicker.tokens.js.map +1 -0
  15. package/cjs/components/DateTimePicker/hooks/useDateTimePicker.js +331 -0
  16. package/cjs/components/DateTimePicker/hooks/useDateTimePicker.js.map +1 -0
  17. package/cjs/components/DateTimePicker/hooks/useKeyboardNavigation.js +49 -0
  18. package/cjs/components/DateTimePicker/hooks/useKeyboardNavigation.js.map +1 -0
  19. package/cjs/components/DateTimePicker/ui/CalendarGrid/CalendarGrid.css +82 -0
  20. package/cjs/components/DateTimePicker/ui/CalendarGrid/CalendarGrid.js +41 -0
  21. package/cjs/components/DateTimePicker/ui/CalendarGrid/CalendarGrid.js.map +1 -0
  22. package/cjs/components/DateTimePicker/ui/CalendarGrid/CalendarGrid.styles.js +83 -0
  23. package/cjs/components/DateTimePicker/ui/CalendarGrid/CalendarGrid.styles.js.map +1 -0
  24. package/cjs/components/DateTimePicker/ui/CalendarGrid/CalendarGrid.styles_1ur6u6r.css +2 -0
  25. package/cjs/components/DateTimePicker/ui/DateShortcut/DateShortcutList.css +34 -0
  26. package/cjs/components/DateTimePicker/ui/DateShortcut/DateShortcutList.js +44 -0
  27. package/cjs/components/DateTimePicker/ui/DateShortcut/DateShortcutList.js.map +1 -0
  28. package/cjs/components/DateTimePicker/ui/DateShortcut/DateShortcutList.styles.js +92 -0
  29. package/cjs/components/DateTimePicker/ui/DateShortcut/DateShortcutList.styles.js.map +1 -0
  30. package/cjs/components/DateTimePicker/ui/DateShortcut/DateShortcutList.styles_ubu846.css +6 -0
  31. package/cjs/components/DateTimePicker/ui/Input/Input.css +80 -0
  32. package/cjs/components/DateTimePicker/ui/Input/Input.js +70 -0
  33. package/cjs/components/DateTimePicker/ui/Input/Input.js.map +1 -0
  34. package/cjs/components/DateTimePicker/ui/Input/Input.styles.js +24 -0
  35. package/cjs/components/DateTimePicker/ui/Input/Input.styles.js.map +1 -0
  36. package/cjs/components/DateTimePicker/ui/Input/Input.styles_1af0tdj.css +1 -0
  37. package/cjs/components/DateTimePicker/ui/Popover/Popover.css +11 -0
  38. package/cjs/components/DateTimePicker/ui/Popover/Popover.js +37 -0
  39. package/cjs/components/DateTimePicker/ui/Popover/Popover.js.map +1 -0
  40. package/cjs/components/DateTimePicker/ui/Popover/Popover.styles.js +44 -0
  41. package/cjs/components/DateTimePicker/ui/Popover/Popover.styles.js.map +1 -0
  42. package/cjs/components/DateTimePicker/ui/Popover/Popover.styles_1v6vurg.css +2 -0
  43. package/cjs/components/DateTimePicker/ui/TimeGrid/TimeGrid.css +12 -0
  44. package/cjs/components/DateTimePicker/ui/TimeGrid/TimeGrid.js +30 -0
  45. package/cjs/components/DateTimePicker/ui/TimeGrid/TimeGrid.js.map +1 -0
  46. package/cjs/components/DateTimePicker/ui/TimeGrid/TimeGrid.styles.js +40 -0
  47. package/cjs/components/DateTimePicker/ui/TimeGrid/TimeGrid.styles.js.map +1 -0
  48. package/cjs/components/DateTimePicker/ui/TimeGrid/TimeGrid.styles_31tnfx.css +1 -0
  49. package/cjs/components/DateTimePicker/utils/getFormattedDateTime.js +81 -0
  50. package/cjs/components/DateTimePicker/utils/getFormattedDateTime.js.map +1 -0
  51. package/cjs/components/DateTimePicker/utils/getMaskedValue.js +53 -0
  52. package/cjs/components/DateTimePicker/utils/getMaskedValue.js.map +1 -0
  53. package/cjs/components/DateTimePicker/utils/getOriginalDateTime.js +77 -0
  54. package/cjs/components/DateTimePicker/utils/getOriginalDateTime.js.map +1 -0
  55. package/cjs/components/DateTimePicker/utils/normalizeDateTime.js +33 -0
  56. package/cjs/components/DateTimePicker/utils/normalizeDateTime.js.map +1 -0
  57. package/cjs/components/DateTimePicker/variations/_disabled/base.js +9 -0
  58. package/cjs/components/DateTimePicker/variations/_disabled/base.js.map +1 -0
  59. package/cjs/components/DateTimePicker/variations/_disabled/base_7ophop.css +1 -0
  60. package/cjs/components/DateTimePicker/variations/_readonly/base.js +9 -0
  61. package/cjs/components/DateTimePicker/variations/_readonly/base.js.map +1 -0
  62. package/cjs/components/DateTimePicker/variations/_readonly/base_rrpgsr.css +1 -0
  63. package/cjs/components/DateTimePicker/variations/_size/base.js +9 -0
  64. package/cjs/components/DateTimePicker/variations/_size/base.js.map +1 -0
  65. package/cjs/components/DateTimePicker/variations/_size/base_19i3bl1.css +1 -0
  66. package/cjs/components/DateTimePicker/variations/_tooltip-size/base.js +9 -0
  67. package/cjs/components/DateTimePicker/variations/_tooltip-size/base.js.map +1 -0
  68. package/cjs/components/DateTimePicker/variations/_tooltip-size/base_x642ct.css +1 -0
  69. package/cjs/components/DateTimePicker/variations/_view/base.js +9 -0
  70. package/cjs/components/DateTimePicker/variations/_view/base.js.map +1 -0
  71. package/cjs/components/DateTimePicker/variations/_view/base_1a1ebsk.css +1 -0
  72. package/cjs/components/TimePickerGrid/TimePickerGrid.js +208 -276
  73. package/cjs/components/TimePickerGrid/TimePickerGrid.js.map +1 -1
  74. package/cjs/components/TimePickerGrid/ui/TimeColumn/TimeColumn.js +2 -1
  75. package/cjs/components/TimePickerGrid/ui/TimeColumn/TimeColumn.js.map +1 -1
  76. package/cjs/index.css +29 -0
  77. package/cjs/index.js +6 -0
  78. package/cjs/index.js.map +1 -1
  79. package/emotion/cjs/components/Calendar/CalendarBase/CalendarBase.js +6 -0
  80. package/emotion/cjs/components/Calendar/CalendarDouble/CalendarDouble.js +6 -0
  81. package/emotion/cjs/components/DatePicker/utils/normalizeDates.js +3 -6
  82. package/emotion/cjs/components/DateTimePicker/DateTimePicker.js +569 -0
  83. package/emotion/cjs/components/DateTimePicker/DateTimePicker.styles.js +39 -0
  84. package/emotion/cjs/components/DateTimePicker/DateTimePicker.tokens.js +268 -0
  85. package/emotion/cjs/components/DateTimePicker/DateTimePicker.types.js +4 -0
  86. package/emotion/cjs/components/DateTimePicker/hooks/useDateTimePicker.js +339 -0
  87. package/emotion/cjs/components/DateTimePicker/hooks/useKeyboardNavigation.js +57 -0
  88. package/emotion/cjs/components/DateTimePicker/index.js +26 -0
  89. package/emotion/cjs/components/DateTimePicker/ui/CalendarGrid/CalendarGrid.js +98 -0
  90. package/emotion/cjs/components/DateTimePicker/ui/CalendarGrid/CalendarGrid.styles.js +61 -0
  91. package/emotion/cjs/components/DateTimePicker/ui/DateShortcut/DateShortcutList.js +53 -0
  92. package/emotion/cjs/components/DateTimePicker/ui/DateShortcut/DateShortcutList.styles.js +88 -0
  93. package/emotion/cjs/components/DateTimePicker/ui/Input/Input.js +167 -0
  94. package/emotion/cjs/components/DateTimePicker/ui/Input/Input.styles.js +25 -0
  95. package/emotion/cjs/components/DateTimePicker/ui/Popover/Popover.js +153 -0
  96. package/emotion/cjs/components/DateTimePicker/ui/Popover/Popover.styles.js +43 -0
  97. package/emotion/cjs/components/DateTimePicker/ui/TimeGrid/TimeGrid.js +87 -0
  98. package/emotion/cjs/components/DateTimePicker/ui/TimeGrid/TimeGrid.styles.js +31 -0
  99. package/emotion/cjs/components/DateTimePicker/ui/index.js +29 -0
  100. package/emotion/cjs/components/DateTimePicker/utils/getFormattedDateTime.js +118 -0
  101. package/emotion/cjs/components/DateTimePicker/utils/getMaskedValue.js +52 -0
  102. package/emotion/cjs/components/DateTimePicker/utils/getOriginalDateTime.js +132 -0
  103. package/emotion/cjs/components/DateTimePicker/utils/index.js +19 -0
  104. package/emotion/cjs/components/DateTimePicker/utils/normalizeDateTime.js +30 -0
  105. package/emotion/cjs/components/DateTimePicker/variations/_disabled/base.js +13 -0
  106. package/emotion/cjs/components/DateTimePicker/variations/_readonly/base.js +14 -0
  107. package/emotion/cjs/components/DateTimePicker/variations/_size/base.js +14 -0
  108. package/emotion/cjs/components/DateTimePicker/variations/_tooltip-size/base.js +12 -0
  109. package/emotion/cjs/components/DateTimePicker/variations/_view/base.js +14 -0
  110. package/emotion/cjs/components/TimePickerGrid/TimePickerGrid.js +214 -282
  111. package/emotion/cjs/components/TimePickerGrid/ui/TimeColumn/TimeColumn.js +2 -2
  112. package/emotion/cjs/examples/components/Combobox/Combobox.js +0 -15
  113. package/emotion/cjs/examples/components/DateTimePicker/DateTimePicker.config.js +40 -0
  114. package/emotion/cjs/examples/components/DateTimePicker/DateTimePicker.js +15 -0
  115. package/emotion/cjs/index.js +1 -0
  116. package/emotion/es/components/Calendar/CalendarBase/CalendarBase.js +6 -0
  117. package/emotion/es/components/Calendar/CalendarDouble/CalendarDouble.js +6 -0
  118. package/emotion/es/components/DatePicker/utils/normalizeDates.js +3 -6
  119. package/emotion/es/components/DateTimePicker/DateTimePicker.js +505 -0
  120. package/emotion/es/components/DateTimePicker/DateTimePicker.styles.js +13 -0
  121. package/emotion/es/components/DateTimePicker/DateTimePicker.tokens.js +247 -0
  122. package/emotion/es/components/DateTimePicker/DateTimePicker.types.js +1 -0
  123. package/emotion/es/components/DateTimePicker/hooks/useDateTimePicker.js +329 -0
  124. package/emotion/es/components/DateTimePicker/hooks/useKeyboardNavigation.js +39 -0
  125. package/emotion/es/components/DateTimePicker/index.js +2 -0
  126. package/emotion/es/components/DateTimePicker/ui/CalendarGrid/CalendarGrid.js +83 -0
  127. package/emotion/es/components/DateTimePicker/ui/CalendarGrid/CalendarGrid.styles.js +36 -0
  128. package/emotion/es/components/DateTimePicker/ui/DateShortcut/DateShortcutList.js +38 -0
  129. package/emotion/es/components/DateTimePicker/ui/DateShortcut/DateShortcutList.styles.js +53 -0
  130. package/emotion/es/components/DateTimePicker/ui/Input/Input.js +111 -0
  131. package/emotion/es/components/DateTimePicker/ui/Input/Input.styles.js +11 -0
  132. package/emotion/es/components/DateTimePicker/ui/Popover/Popover.js +102 -0
  133. package/emotion/es/components/DateTimePicker/ui/Popover/Popover.styles.js +20 -0
  134. package/emotion/es/components/DateTimePicker/ui/TimeGrid/TimeGrid.js +72 -0
  135. package/emotion/es/components/DateTimePicker/ui/TimeGrid/TimeGrid.styles.js +16 -0
  136. package/emotion/es/components/DateTimePicker/ui/index.js +6 -0
  137. package/emotion/es/components/DateTimePicker/utils/getFormattedDateTime.js +108 -0
  138. package/emotion/es/components/DateTimePicker/utils/getMaskedValue.js +42 -0
  139. package/emotion/es/components/DateTimePicker/utils/getOriginalDateTime.js +122 -0
  140. package/emotion/es/components/DateTimePicker/utils/index.js +2 -0
  141. package/emotion/es/components/DateTimePicker/utils/normalizeDateTime.js +20 -0
  142. package/emotion/es/components/DateTimePicker/variations/_disabled/base.js +3 -0
  143. package/emotion/es/components/DateTimePicker/variations/_readonly/base.js +4 -0
  144. package/emotion/es/components/DateTimePicker/variations/_size/base.js +4 -0
  145. package/emotion/es/components/DateTimePicker/variations/_tooltip-size/base.js +2 -0
  146. package/emotion/es/components/DateTimePicker/variations/_view/base.js +4 -0
  147. package/emotion/es/components/TimePickerGrid/TimePickerGrid.js +214 -282
  148. package/emotion/es/components/TimePickerGrid/ui/TimeColumn/TimeColumn.js +2 -2
  149. package/emotion/es/examples/components/Combobox/Combobox.js +7 -0
  150. package/emotion/es/examples/components/DateTimePicker/DateTimePicker.config.js +30 -0
  151. package/emotion/es/examples/components/DateTimePicker/DateTimePicker.js +5 -0
  152. package/emotion/es/index.js +1 -0
  153. package/es/components/Calendar/CalendarBase/CalendarBase.js +6 -0
  154. package/es/components/Calendar/CalendarBase/CalendarBase.js.map +1 -1
  155. package/es/components/Calendar/CalendarDouble/CalendarDouble.js +6 -0
  156. package/es/components/Calendar/CalendarDouble/CalendarDouble.js.map +1 -1
  157. package/es/components/DatePicker/utils/normalizeDates.js +3 -6
  158. package/es/components/DatePicker/utils/normalizeDates.js.map +1 -1
  159. package/es/components/DateTimePicker/DateTimePicker.css +200 -0
  160. package/es/components/DateTimePicker/DateTimePicker.js +426 -0
  161. package/es/components/DateTimePicker/DateTimePicker.js.map +1 -0
  162. package/es/components/DateTimePicker/DateTimePicker.styles.js +17 -0
  163. package/es/components/DateTimePicker/DateTimePicker.styles.js.map +1 -0
  164. package/es/components/DateTimePicker/DateTimePicker.styles_x7parr.css +3 -0
  165. package/es/components/DateTimePicker/DateTimePicker.tokens.js +258 -0
  166. package/es/components/DateTimePicker/DateTimePicker.tokens.js.map +1 -0
  167. package/es/components/DateTimePicker/hooks/useDateTimePicker.js +327 -0
  168. package/es/components/DateTimePicker/hooks/useDateTimePicker.js.map +1 -0
  169. package/es/components/DateTimePicker/hooks/useKeyboardNavigation.js +44 -0
  170. package/es/components/DateTimePicker/hooks/useKeyboardNavigation.js.map +1 -0
  171. package/es/components/DateTimePicker/ui/CalendarGrid/CalendarGrid.css +82 -0
  172. package/es/components/DateTimePicker/ui/CalendarGrid/CalendarGrid.js +33 -0
  173. package/es/components/DateTimePicker/ui/CalendarGrid/CalendarGrid.js.map +1 -0
  174. package/es/components/DateTimePicker/ui/CalendarGrid/CalendarGrid.styles.js +78 -0
  175. package/es/components/DateTimePicker/ui/CalendarGrid/CalendarGrid.styles.js.map +1 -0
  176. package/es/components/DateTimePicker/ui/CalendarGrid/CalendarGrid.styles_1ur6u6r.css +2 -0
  177. package/es/components/DateTimePicker/ui/DateShortcut/DateShortcutList.css +34 -0
  178. package/es/components/DateTimePicker/ui/DateShortcut/DateShortcutList.js +35 -0
  179. package/es/components/DateTimePicker/ui/DateShortcut/DateShortcutList.js.map +1 -0
  180. package/es/components/DateTimePicker/ui/DateShortcut/DateShortcutList.styles.js +83 -0
  181. package/es/components/DateTimePicker/ui/DateShortcut/DateShortcutList.styles.js.map +1 -0
  182. package/es/components/DateTimePicker/ui/DateShortcut/DateShortcutList.styles_ubu846.css +6 -0
  183. package/es/components/DateTimePicker/ui/Input/Input.css +80 -0
  184. package/es/components/DateTimePicker/ui/Input/Input.js +61 -0
  185. package/es/components/DateTimePicker/ui/Input/Input.js.map +1 -0
  186. package/es/components/DateTimePicker/ui/Input/Input.styles.js +20 -0
  187. package/es/components/DateTimePicker/ui/Input/Input.styles.js.map +1 -0
  188. package/es/components/DateTimePicker/ui/Input/Input.styles_1af0tdj.css +1 -0
  189. package/es/components/DateTimePicker/ui/Popover/Popover.css +11 -0
  190. package/es/components/DateTimePicker/ui/Popover/Popover.js +29 -0
  191. package/es/components/DateTimePicker/ui/Popover/Popover.js.map +1 -0
  192. package/es/components/DateTimePicker/ui/Popover/Popover.styles.js +39 -0
  193. package/es/components/DateTimePicker/ui/Popover/Popover.styles.js.map +1 -0
  194. package/es/components/DateTimePicker/ui/Popover/Popover.styles_1v6vurg.css +2 -0
  195. package/es/components/DateTimePicker/ui/TimeGrid/TimeGrid.css +12 -0
  196. package/es/components/DateTimePicker/ui/TimeGrid/TimeGrid.js +22 -0
  197. package/es/components/DateTimePicker/ui/TimeGrid/TimeGrid.js.map +1 -0
  198. package/es/components/DateTimePicker/ui/TimeGrid/TimeGrid.styles.js +36 -0
  199. package/es/components/DateTimePicker/ui/TimeGrid/TimeGrid.styles.js.map +1 -0
  200. package/es/components/DateTimePicker/ui/TimeGrid/TimeGrid.styles_31tnfx.css +1 -0
  201. package/es/components/DateTimePicker/utils/getFormattedDateTime.js +77 -0
  202. package/es/components/DateTimePicker/utils/getFormattedDateTime.js.map +1 -0
  203. package/es/components/DateTimePicker/utils/getMaskedValue.js +49 -0
  204. package/es/components/DateTimePicker/utils/getMaskedValue.js.map +1 -0
  205. package/es/components/DateTimePicker/utils/getOriginalDateTime.js +73 -0
  206. package/es/components/DateTimePicker/utils/getOriginalDateTime.js.map +1 -0
  207. package/es/components/DateTimePicker/utils/normalizeDateTime.js +29 -0
  208. package/es/components/DateTimePicker/utils/normalizeDateTime.js.map +1 -0
  209. package/es/components/DateTimePicker/variations/_disabled/base.js +5 -0
  210. package/es/components/DateTimePicker/variations/_disabled/base.js.map +1 -0
  211. package/es/components/DateTimePicker/variations/_disabled/base_7ophop.css +1 -0
  212. package/es/components/DateTimePicker/variations/_readonly/base.js +5 -0
  213. package/es/components/DateTimePicker/variations/_readonly/base.js.map +1 -0
  214. package/es/components/DateTimePicker/variations/_readonly/base_rrpgsr.css +1 -0
  215. package/es/components/DateTimePicker/variations/_size/base.js +5 -0
  216. package/es/components/DateTimePicker/variations/_size/base.js.map +1 -0
  217. package/es/components/DateTimePicker/variations/_size/base_19i3bl1.css +1 -0
  218. package/es/components/DateTimePicker/variations/_tooltip-size/base.js +5 -0
  219. package/es/components/DateTimePicker/variations/_tooltip-size/base.js.map +1 -0
  220. package/es/components/DateTimePicker/variations/_tooltip-size/base_x642ct.css +1 -0
  221. package/es/components/DateTimePicker/variations/_view/base.js +5 -0
  222. package/es/components/DateTimePicker/variations/_view/base.js.map +1 -0
  223. package/es/components/DateTimePicker/variations/_view/base_1a1ebsk.css +1 -0
  224. package/es/components/TimePickerGrid/TimePickerGrid.js +210 -278
  225. package/es/components/TimePickerGrid/TimePickerGrid.js.map +1 -1
  226. package/es/components/TimePickerGrid/ui/TimeColumn/TimeColumn.js +2 -1
  227. package/es/components/TimePickerGrid/ui/TimeColumn/TimeColumn.js.map +1 -1
  228. package/es/index.css +29 -0
  229. package/es/index.js +2 -0
  230. package/es/index.js.map +1 -1
  231. package/package.json +4 -4
  232. package/styled-components/cjs/components/Calendar/CalendarBase/CalendarBase.js +6 -0
  233. package/styled-components/cjs/components/Calendar/CalendarDouble/CalendarDouble.js +6 -0
  234. package/styled-components/cjs/components/DatePicker/utils/normalizeDates.js +3 -6
  235. package/styled-components/cjs/components/DateTimePicker/DateTimePicker.js +569 -0
  236. package/styled-components/cjs/components/DateTimePicker/DateTimePicker.styles.js +89 -0
  237. package/styled-components/cjs/components/DateTimePicker/DateTimePicker.tokens.js +268 -0
  238. package/styled-components/cjs/components/DateTimePicker/DateTimePicker.types.js +4 -0
  239. package/styled-components/cjs/components/DateTimePicker/hooks/useDateTimePicker.js +339 -0
  240. package/styled-components/cjs/components/DateTimePicker/hooks/useKeyboardNavigation.js +57 -0
  241. package/styled-components/cjs/components/DateTimePicker/index.js +26 -0
  242. package/styled-components/cjs/components/DateTimePicker/ui/CalendarGrid/CalendarGrid.js +98 -0
  243. package/styled-components/cjs/components/DateTimePicker/ui/CalendarGrid/CalendarGrid.styles.js +73 -0
  244. package/styled-components/cjs/components/DateTimePicker/ui/DateShortcut/DateShortcutList.js +53 -0
  245. package/styled-components/cjs/components/DateTimePicker/ui/DateShortcut/DateShortcutList.styles.js +132 -0
  246. package/styled-components/cjs/components/DateTimePicker/ui/Input/Input.js +167 -0
  247. package/styled-components/cjs/components/DateTimePicker/ui/Input/Input.styles.js +176 -0
  248. package/styled-components/cjs/components/DateTimePicker/ui/Popover/Popover.js +153 -0
  249. package/styled-components/cjs/components/DateTimePicker/ui/Popover/Popover.styles.js +56 -0
  250. package/styled-components/cjs/components/DateTimePicker/ui/TimeGrid/TimeGrid.js +87 -0
  251. package/styled-components/cjs/components/DateTimePicker/ui/TimeGrid/TimeGrid.styles.js +69 -0
  252. package/styled-components/cjs/components/DateTimePicker/ui/index.js +29 -0
  253. package/styled-components/cjs/components/DateTimePicker/utils/getFormattedDateTime.js +118 -0
  254. package/styled-components/cjs/components/DateTimePicker/utils/getMaskedValue.js +52 -0
  255. package/styled-components/cjs/components/DateTimePicker/utils/getOriginalDateTime.js +132 -0
  256. package/styled-components/cjs/components/DateTimePicker/utils/index.js +19 -0
  257. package/styled-components/cjs/components/DateTimePicker/utils/normalizeDateTime.js +30 -0
  258. package/styled-components/cjs/components/DateTimePicker/variations/_disabled/base.js +16 -0
  259. package/styled-components/cjs/components/DateTimePicker/variations/_readonly/base.js +18 -0
  260. package/styled-components/cjs/components/DateTimePicker/variations/_size/base.js +24 -0
  261. package/styled-components/cjs/components/DateTimePicker/variations/_tooltip-size/base.js +14 -0
  262. package/styled-components/cjs/components/DateTimePicker/variations/_view/base.js +18 -0
  263. package/styled-components/cjs/components/TimePickerGrid/TimePickerGrid.js +214 -282
  264. package/styled-components/cjs/components/TimePickerGrid/ui/TimeColumn/TimeColumn.js +2 -2
  265. package/styled-components/cjs/examples/components/DateTimePicker/DateTimePicker.config.js +783 -0
  266. package/styled-components/cjs/examples/components/DateTimePicker/DateTimePicker.js +15 -0
  267. package/styled-components/cjs/index.js +1 -0
  268. package/styled-components/es/components/Calendar/CalendarBase/CalendarBase.js +6 -0
  269. package/styled-components/es/components/Calendar/CalendarDouble/CalendarDouble.js +6 -0
  270. package/styled-components/es/components/DatePicker/utils/normalizeDates.js +3 -6
  271. package/styled-components/es/components/DateTimePicker/DateTimePicker.js +505 -0
  272. package/styled-components/es/components/DateTimePicker/DateTimePicker.styles.js +28 -0
  273. package/styled-components/es/components/DateTimePicker/DateTimePicker.tokens.js +247 -0
  274. package/styled-components/es/components/DateTimePicker/DateTimePicker.types.js +1 -0
  275. package/styled-components/es/components/DateTimePicker/hooks/useDateTimePicker.js +329 -0
  276. package/styled-components/es/components/DateTimePicker/hooks/useKeyboardNavigation.js +39 -0
  277. package/styled-components/es/components/DateTimePicker/index.js +2 -0
  278. package/styled-components/es/components/DateTimePicker/ui/CalendarGrid/CalendarGrid.js +83 -0
  279. package/styled-components/es/components/DateTimePicker/ui/CalendarGrid/CalendarGrid.styles.js +48 -0
  280. package/styled-components/es/components/DateTimePicker/ui/DateShortcut/DateShortcutList.js +38 -0
  281. package/styled-components/es/components/DateTimePicker/ui/DateShortcut/DateShortcutList.styles.js +97 -0
  282. package/styled-components/es/components/DateTimePicker/ui/Input/Input.js +111 -0
  283. package/styled-components/es/components/DateTimePicker/ui/Input/Input.styles.js +162 -0
  284. package/styled-components/es/components/DateTimePicker/ui/Popover/Popover.js +102 -0
  285. package/styled-components/es/components/DateTimePicker/ui/Popover/Popover.styles.js +33 -0
  286. package/styled-components/es/components/DateTimePicker/ui/TimeGrid/TimeGrid.js +72 -0
  287. package/styled-components/es/components/DateTimePicker/ui/TimeGrid/TimeGrid.styles.js +54 -0
  288. package/styled-components/es/components/DateTimePicker/ui/index.js +6 -0
  289. package/styled-components/es/components/DateTimePicker/utils/getFormattedDateTime.js +108 -0
  290. package/styled-components/es/components/DateTimePicker/utils/getMaskedValue.js +42 -0
  291. package/styled-components/es/components/DateTimePicker/utils/getOriginalDateTime.js +122 -0
  292. package/styled-components/es/components/DateTimePicker/utils/index.js +2 -0
  293. package/styled-components/es/components/DateTimePicker/utils/normalizeDateTime.js +20 -0
  294. package/styled-components/es/components/DateTimePicker/variations/_disabled/base.js +6 -0
  295. package/styled-components/es/components/DateTimePicker/variations/_readonly/base.js +8 -0
  296. package/styled-components/es/components/DateTimePicker/variations/_size/base.js +14 -0
  297. package/styled-components/es/components/DateTimePicker/variations/_tooltip-size/base.js +4 -0
  298. package/styled-components/es/components/DateTimePicker/variations/_view/base.js +8 -0
  299. package/styled-components/es/components/TimePickerGrid/TimePickerGrid.js +214 -282
  300. package/styled-components/es/components/TimePickerGrid/ui/TimeColumn/TimeColumn.js +2 -2
  301. package/styled-components/es/examples/components/DateTimePicker/DateTimePicker.config.js +773 -0
  302. package/styled-components/es/examples/components/DateTimePicker/DateTimePicker.js +5 -0
  303. package/styled-components/es/index.js +1 -0
  304. package/types/components/Calendar/CalendarBase/CalendarBase.d.ts.map +1 -1
  305. package/types/components/Calendar/CalendarDouble/CalendarDouble.d.ts.map +1 -1
  306. package/types/components/DatePicker/utils/normalizeDates.d.ts.map +1 -1
  307. package/types/components/DateTimePicker/DateTimePicker.d.ts +73 -0
  308. package/types/components/DateTimePicker/DateTimePicker.d.ts.map +1 -0
  309. package/types/components/DateTimePicker/DateTimePicker.styles.d.ts +4 -0
  310. package/types/components/DateTimePicker/DateTimePicker.styles.d.ts.map +1 -0
  311. package/types/components/DateTimePicker/DateTimePicker.tokens.d.ts +256 -0
  312. package/types/components/DateTimePicker/DateTimePicker.tokens.d.ts.map +1 -0
  313. package/types/components/DateTimePicker/DateTimePicker.types.d.ts +161 -0
  314. package/types/components/DateTimePicker/DateTimePicker.types.d.ts.map +1 -0
  315. package/types/components/DateTimePicker/hooks/useDateTimePicker.d.ts +18 -0
  316. package/types/components/DateTimePicker/hooks/useDateTimePicker.d.ts.map +1 -0
  317. package/types/components/DateTimePicker/hooks/useKeyboardNavigation.d.ts +18 -0
  318. package/types/components/DateTimePicker/hooks/useKeyboardNavigation.d.ts.map +1 -0
  319. package/types/components/DateTimePicker/index.d.ts +4 -0
  320. package/types/components/DateTimePicker/index.d.ts.map +1 -0
  321. package/types/components/DateTimePicker/ui/CalendarGrid/CalendarGrid.d.ts +11 -0
  322. package/types/components/DateTimePicker/ui/CalendarGrid/CalendarGrid.d.ts.map +1 -0
  323. package/types/components/DateTimePicker/ui/CalendarGrid/CalendarGrid.styles.d.ts +10 -0
  324. package/types/components/DateTimePicker/ui/CalendarGrid/CalendarGrid.styles.d.ts.map +1 -0
  325. package/types/components/DateTimePicker/ui/DateShortcut/DateShortcutList.d.ts +12 -0
  326. package/types/components/DateTimePicker/ui/DateShortcut/DateShortcutList.d.ts.map +1 -0
  327. package/types/components/DateTimePicker/ui/DateShortcut/DateShortcutList.styles.d.ts +44 -0
  328. package/types/components/DateTimePicker/ui/DateShortcut/DateShortcutList.styles.d.ts.map +1 -0
  329. package/types/components/DateTimePicker/ui/Input/Input.d.ts +8 -0
  330. package/types/components/DateTimePicker/ui/Input/Input.d.ts.map +1 -0
  331. package/types/components/DateTimePicker/ui/Input/Input.styles.d.ts +298 -0
  332. package/types/components/DateTimePicker/ui/Input/Input.styles.d.ts.map +1 -0
  333. package/types/components/DateTimePicker/ui/Popover/Popover.d.ts +8 -0
  334. package/types/components/DateTimePicker/ui/Popover/Popover.d.ts.map +1 -0
  335. package/types/components/DateTimePicker/ui/Popover/Popover.styles.d.ts +6 -0
  336. package/types/components/DateTimePicker/ui/Popover/Popover.styles.d.ts.map +1 -0
  337. package/types/components/DateTimePicker/ui/TimeGrid/TimeGrid.d.ts +9 -0
  338. package/types/components/DateTimePicker/ui/TimeGrid/TimeGrid.d.ts.map +1 -0
  339. package/types/components/DateTimePicker/ui/TimeGrid/TimeGrid.styles.d.ts +23 -0
  340. package/types/components/DateTimePicker/ui/TimeGrid/TimeGrid.styles.d.ts.map +1 -0
  341. package/types/components/DateTimePicker/ui/index.d.ts +7 -0
  342. package/types/components/DateTimePicker/ui/index.d.ts.map +1 -0
  343. package/types/components/DateTimePicker/utils/getFormattedDateTime.d.ts +27 -0
  344. package/types/components/DateTimePicker/utils/getFormattedDateTime.d.ts.map +1 -0
  345. package/types/components/DateTimePicker/utils/getMaskedValue.d.ts +13 -0
  346. package/types/components/DateTimePicker/utils/getMaskedValue.d.ts.map +1 -0
  347. package/types/components/DateTimePicker/utils/getOriginalDateTime.d.ts +19 -0
  348. package/types/components/DateTimePicker/utils/getOriginalDateTime.d.ts.map +1 -0
  349. package/types/components/DateTimePicker/utils/index.d.ts +3 -0
  350. package/types/components/DateTimePicker/utils/index.d.ts.map +1 -0
  351. package/types/components/DateTimePicker/utils/normalizeDateTime.d.ts +15 -0
  352. package/types/components/DateTimePicker/utils/normalizeDateTime.d.ts.map +1 -0
  353. package/types/components/DateTimePicker/variations/_disabled/base.d.ts +2 -0
  354. package/types/components/DateTimePicker/variations/_disabled/base.d.ts.map +1 -0
  355. package/types/components/DateTimePicker/variations/_readonly/base.d.ts +2 -0
  356. package/types/components/DateTimePicker/variations/_readonly/base.d.ts.map +1 -0
  357. package/types/components/DateTimePicker/variations/_size/base.d.ts +2 -0
  358. package/types/components/DateTimePicker/variations/_size/base.d.ts.map +1 -0
  359. package/types/components/DateTimePicker/variations/_tooltip-size/base.d.ts +2 -0
  360. package/types/components/DateTimePicker/variations/_tooltip-size/base.d.ts.map +1 -0
  361. package/types/components/DateTimePicker/variations/_view/base.d.ts +2 -0
  362. package/types/components/DateTimePicker/variations/_view/base.d.ts.map +1 -0
  363. package/types/components/TimePickerGrid/TimePickerGrid.d.ts.map +1 -1
  364. package/types/components/TimePickerGrid/ui/TimeColumn/TimeColumn.d.ts +1 -1
  365. package/types/components/TimePickerGrid/ui/TimeColumn/TimeColumn.d.ts.map +1 -1
  366. package/types/components/TimePickerGrid/ui/TimeColumn/TimeColumn.types.d.ts +2 -1
  367. package/types/components/TimePickerGrid/ui/TimeColumn/TimeColumn.types.d.ts.map +1 -1
  368. package/types/examples/components/DateTimePicker/DateTimePicker.config.d.ts +29 -0
  369. package/types/examples/components/DateTimePicker/DateTimePicker.config.d.ts.map +1 -0
  370. package/types/examples/components/DateTimePicker/DateTimePicker.d.ts +42 -0
  371. package/types/examples/components/DateTimePicker/DateTimePicker.d.ts.map +1 -0
  372. package/types/index.d.ts +1 -0
  373. package/types/index.d.ts.map +1 -1
@@ -158,6 +158,7 @@ export var timePickerGridRoot = function(Root) {
158
158
  "disabledValues",
159
159
  "onChange"
160
160
  ]);
161
+ var _Object_values_;
161
162
  var actualFormat = format || (columnsQuantity === 3 ? 'HH:mm:ss' : 'HH:mm');
162
163
  var columnsConfig = useMemo(function() {
163
164
  return getColumnsFromFormat(actualFormat);
@@ -168,6 +169,7 @@ export var timePickerGridRoot = function(Root) {
168
169
  var minutesColumnRef = useRef(null);
169
170
  var secondsColumnRef = useRef(null);
170
171
  var timeItemRefs = useRef({});
172
+ var itemHeight = ((_Object_values_ = Object.values(timeItemRefs.current)[0]) === null || _Object_values_ === void 0 ? void 0 : _Object_values_.offsetHeight) || 0;
171
173
  var hoursScrollbarRef = useRef(null);
172
174
  var minutesScrollbarRef = useRef(null);
173
175
  var secondsScrollbarRef = useRef(null);
@@ -178,48 +180,44 @@ export var timePickerGridRoot = function(Root) {
178
180
  var minutesHideTimeoutRef = useRef(null);
179
181
  var secondsHideTimeoutRef = useRef(null);
180
182
  var _useState = _sliced_to_array(useState(outerValue || ''), 2), innerTime = _useState[0], setInnerTime = _useState[1];
181
- var _useState1 = _sliced_to_array(useState({
182
- hours: null,
183
- minutes: null,
184
- seconds: null,
185
- currentColumn: null
186
- }), 2), activeTime = _useState1[0], setActiveTime = _useState1[1];
187
- var _useState2 = _sliced_to_array(useState(0), 2), itemHeight = _useState2[0], setItemHeight = _useState2[1];
188
- var _useState3 = _sliced_to_array(useState(0), 2), gap = _useState3[0], setGap = _useState3[1];
189
- var _useState4 = _sliced_to_array(useState({
183
+ // const [itemHeight, setItemHeight] = useState(0);
184
+ var _useState1 = _sliced_to_array(useState(0), 2), gap = _useState1[0], setGap = _useState1[1];
185
+ var _useState2 = _sliced_to_array(useState({
190
186
  isVisible: false,
191
187
  thumbHeight: 0,
192
188
  thumbPosition: 0,
193
189
  isDragging: false
194
- }), 2), hoursScrollbar = _useState4[0], setHoursScrollbar = _useState4[1];
195
- var _useState5 = _sliced_to_array(useState({
190
+ }), 2), hoursScrollbar = _useState2[0], setHoursScrollbar = _useState2[1];
191
+ var _useState3 = _sliced_to_array(useState({
196
192
  isVisible: false,
197
193
  thumbHeight: 0,
198
194
  thumbPosition: 0,
199
195
  isDragging: false
200
- }), 2), minutesScrollbar = _useState5[0], setMinutesScrollbar = _useState5[1];
201
- var _useState6 = _sliced_to_array(useState({
196
+ }), 2), minutesScrollbar = _useState3[0], setMinutesScrollbar = _useState3[1];
197
+ var _useState4 = _sliced_to_array(useState({
202
198
  isVisible: false,
203
199
  thumbHeight: 0,
204
200
  thumbPosition: 0,
205
201
  isDragging: false
206
- }), 2), secondsScrollbar = _useState6[0], setSecondsScrollbar = _useState6[1];
202
+ }), 2), secondsScrollbar = _useState4[0], setSecondsScrollbar = _useState4[1];
207
203
  var viewValue = outerValue !== null && outerValue !== void 0 ? outerValue : innerTime;
208
- useEffect(function() {
209
- if (activeTime.currentColumn && activeTime[activeTime.currentColumn] !== null) {
210
- var _activeTime_activeTime_currentColumn;
211
- var column = activeTime.currentColumn;
212
- var value = (_activeTime_activeTime_currentColumn = activeTime[activeTime.currentColumn]) === null || _activeTime_activeTime_currentColumn === void 0 ? void 0 : _activeTime_activeTime_currentColumn.toString().padStart(2, '0');
213
- var element = timeItemRefs.current["".concat(column, "-").concat(value)];
214
- setTimeout(function() {
215
- if (element) {
216
- element.focus();
217
- }
218
- }, 0);
204
+ var getActiveTime = function() {
205
+ if (viewValue && columnsConfig.length > 0) {
206
+ var timeValues = parseTimeString(viewValue, actualFormat);
207
+ return {
208
+ hours: timeValues.hh,
209
+ minutes: timeValues.mm,
210
+ seconds: timeValues.ss
211
+ };
219
212
  }
220
- }, [
221
- activeTime
222
- ]);
213
+ return {
214
+ hours: null,
215
+ minutes: null,
216
+ seconds: null
217
+ };
218
+ };
219
+ var activeTime = getActiveTime();
220
+ var _useState5 = _sliced_to_array(useState(null), 2), currentColumn = _useState5[0], setCurrentColumn = _useState5[1];
223
221
  var getDisabledValuesForColumn = useCallback(function(columnType) {
224
222
  var disabledFromProps;
225
223
  if (columnType === 'hours') {
@@ -383,166 +381,19 @@ export var timePickerGridRoot = function(Root) {
383
381
  }, [
384
382
  showScrollbarWithDelay
385
383
  ]);
386
- useEffect(function() {
387
- if (viewValue && columnsConfig.length > 0) {
388
- var timeValues = parseTimeString(viewValue, actualFormat);
389
- setActiveTime(function(prev) {
390
- return _object_spread_props(_object_spread({}, prev), {
391
- hours: timeValues.hh,
392
- minutes: timeValues.mm,
393
- seconds: timeValues.ss
394
- });
395
- });
396
- }
397
- }, [
398
- viewValue,
399
- columnsConfig,
400
- actualFormat
401
- ]);
402
384
  var handleContainerFocus = useCallback(function() {
403
- if (activeTime.currentColumn === null && columnsConfig.length > 0) {
385
+ if (currentColumn === null && columnsConfig.length > 0) {
404
386
  var firstColumn = columnsConfig[0].type;
405
- setActiveTime(function(prev) {
406
- return _object_spread_props(_object_spread({}, prev), {
407
- currentColumn: firstColumn
408
- });
387
+ setCurrentColumn(function(prev) {
388
+ return prev !== currentColumn ? firstColumn : currentColumn;
409
389
  });
410
390
  }
411
391
  }, [
412
- activeTime.currentColumn,
392
+ currentColumn,
413
393
  columnsConfig
414
394
  ]);
415
- useEffect(function() {
416
- return function() {
417
- [
418
- hoursHideTimeoutRef,
419
- minutesHideTimeoutRef,
420
- secondsHideTimeoutRef
421
- ].forEach(function(timeoutRef) {
422
- if (timeoutRef.current) {
423
- clearTimeout(timeoutRef.current);
424
- }
425
- });
426
- };
427
- }, []);
428
- useEffect(function() {
429
- if (Object.keys(timeItemRefs.current).length > 0) {
430
- var firstItem = Object.values(timeItemRefs.current)[0];
431
- if (firstItem) {
432
- setItemHeight(firstItem.offsetHeight);
433
- }
434
- }
435
- if (hoursColumnRef.current) {
436
- var computedStyle = getComputedStyle(hoursColumnRef.current);
437
- var gapValue = parseFloat(computedStyle.gap || '0');
438
- setGap(gapValue);
439
- }
440
- }, [
441
- outerValue
442
- ]);
443
- useEffect(function() {
444
- setTimeout(function() {
445
- updateScrollbar(hoursColumnRef, setHoursScrollbar);
446
- updateScrollbar(minutesColumnRef, setMinutesScrollbar);
447
- if (columnsQuantity === 3) {
448
- updateScrollbar(secondsColumnRef, setSecondsScrollbar);
449
- }
450
- }, 100);
451
- }, [
452
- columnsQuantity,
453
- updateScrollbar
454
- ]);
455
- useEffect(function() {
456
- if (itemHeight === 0) return;
457
- var scrollToActiveItem = function(columnRef, index) {
458
- if (columnRef.current && index !== null) {
459
- var scrollPosition = index * (itemHeight + gap);
460
- animateScrollTo(columnRef.current, scrollPosition);
461
- setTimeout(function() {
462
- updateScrollbar(columnRef, setHoursScrollbar);
463
- }, 300);
464
- }
465
- };
466
- scrollToActiveItem(hoursColumnRef, activeTime.hours);
467
- scrollToActiveItem(minutesColumnRef, activeTime.minutes);
468
- scrollToActiveItem(secondsColumnRef, activeTime.seconds);
469
- }, [
470
- activeTime,
471
- itemHeight,
472
- gap,
473
- updateScrollbar
474
- ]);
475
- useEffect(function() {
476
- var hoursColumn = hoursColumnRef.current;
477
- var minutesColumn = minutesColumnRef.current;
478
- var secondsColumn = secondsColumnRef.current;
479
- var handleHoursScroll = function() {
480
- return handleColumnScroll(hoursColumnRef, setHoursScrollbar, hoursHideTimeoutRef);
481
- };
482
- var handleMinutesScroll = function() {
483
- return handleColumnScroll(minutesColumnRef, setMinutesScrollbar, minutesHideTimeoutRef);
484
- };
485
- var handleSecondsScroll = function() {
486
- return handleColumnScroll(secondsColumnRef, setSecondsScrollbar, secondsHideTimeoutRef);
487
- };
488
- if (hoursColumn) {
489
- hoursColumn.addEventListener('scroll', handleHoursScroll);
490
- }
491
- if (minutesColumn) {
492
- minutesColumn.addEventListener('scroll', handleMinutesScroll);
493
- }
494
- if (secondsColumn) {
495
- secondsColumn.addEventListener('scroll', handleSecondsScroll);
496
- }
497
- return function() {
498
- if (hoursColumn) {
499
- hoursColumn.removeEventListener('scroll', handleHoursScroll);
500
- }
501
- if (minutesColumn) {
502
- minutesColumn.removeEventListener('scroll', handleMinutesScroll);
503
- }
504
- if (secondsColumn) {
505
- secondsColumn.removeEventListener('scroll', handleSecondsScroll);
506
- }
507
- };
508
- }, []);
509
- useEffect(function() {
510
- var hoursColumn = hoursColumnRef.current;
511
- var minutesColumn = minutesColumnRef.current;
512
- var secondsColumn = secondsColumnRef.current;
513
- var handleHoursMouseEnter = function() {
514
- return showScrollbarWithDelay(setHoursScrollbar, hoursHideTimeoutRef, hoursColumnRef);
515
- };
516
- var handleMinutesMouseEnter = function() {
517
- return showScrollbarWithDelay(setMinutesScrollbar, minutesHideTimeoutRef, minutesColumnRef);
518
- };
519
- var handleSecondsMouseEnter = function() {
520
- return showScrollbarWithDelay(setSecondsScrollbar, secondsHideTimeoutRef, secondsColumnRef);
521
- };
522
- if (hoursColumn) {
523
- hoursColumn.addEventListener('mouseenter', handleHoursMouseEnter);
524
- }
525
- if (minutesColumn) {
526
- minutesColumn.addEventListener('mouseenter', handleMinutesMouseEnter);
527
- }
528
- if (secondsColumn) {
529
- secondsColumn.addEventListener('mouseenter', handleSecondsMouseEnter);
530
- }
531
- return function() {
532
- if (hoursColumn) {
533
- hoursColumn.removeEventListener('mouseenter', handleHoursMouseEnter);
534
- }
535
- if (minutesColumn) {
536
- minutesColumn.removeEventListener('mouseenter', handleMinutesMouseEnter);
537
- }
538
- if (secondsColumn) {
539
- secondsColumn.removeEventListener('mouseenter', handleSecondsMouseEnter);
540
- }
541
- };
542
- }, []);
543
395
  var handleTimeItemClick = function(value, column) {
544
- var isNextColumn = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : true;
545
- var currentTimeValues = parseTimeString(innerTime, actualFormat);
396
+ var currentTimeValues = parseTimeString(viewValue, actualFormat);
546
397
  var newTimeValues = _object_spread({}, currentTimeValues);
547
398
  switch(column){
548
399
  case 'hours':
@@ -581,20 +432,6 @@ export var timePickerGridRoot = function(Root) {
581
432
  }
582
433
  var newTimeString = buildTimeString(newTimeValues, actualFormat);
583
434
  setInnerTime(newTimeString);
584
- var nextColumn = null;
585
- var currentIndex = columnsConfig.findIndex(function(col) {
586
- return col.type === column;
587
- });
588
- if (currentIndex !== -1 && isNextColumn && currentIndex < columnsConfig.length - 1) {
589
- nextColumn = columnsConfig[currentIndex + 1].type;
590
- }
591
- var newActiveTime = {
592
- hours: newTimeValues.hh,
593
- minutes: newTimeValues.mm,
594
- seconds: newTimeValues.ss,
595
- currentColumn: nextColumn || column
596
- };
597
- setActiveTime(newActiveTime);
598
435
  onChange === null || onChange === void 0 ? void 0 : onChange({
599
436
  value: newTimeString,
600
437
  timeValues: {
@@ -609,9 +446,6 @@ export var timePickerGridRoot = function(Root) {
609
446
  var currentIndex = parseInt(value, 10);
610
447
  var newIndex = null;
611
448
  var newColumn = column;
612
- var currentIndexInColumns = columnsConfig.findIndex(function(col) {
613
- return col.type === column;
614
- });
615
449
  switch(event.key){
616
450
  case 'ArrowUp':
617
451
  event.preventDefault();
@@ -626,7 +460,12 @@ export var timePickerGridRoot = function(Root) {
626
460
  }), disabledValuesForColumn, 'up');
627
461
  if (newIndex !== null) {
628
462
  var newValue = newIndex.toString().padStart(2, '0');
629
- handleTimeItemClick(newValue, column, false);
463
+ var element = timeItemRefs.current["".concat(column, "-").concat(newValue)];
464
+ setTimeout(function() {
465
+ if (element) {
466
+ element.focus();
467
+ }
468
+ }, 0);
630
469
  }
631
470
  break;
632
471
  case 'ArrowDown':
@@ -642,7 +481,12 @@ export var timePickerGridRoot = function(Root) {
642
481
  }), disabledValuesForColumn, 'down');
643
482
  if (newIndex !== null) {
644
483
  var newValue1 = newIndex.toString().padStart(2, '0');
645
- handleTimeItemClick(newValue1, column, false);
484
+ var element1 = timeItemRefs.current["".concat(column, "-").concat(newValue1)];
485
+ setTimeout(function() {
486
+ if (element1) {
487
+ element1.focus();
488
+ }
489
+ }, 0);
646
490
  }
647
491
  break;
648
492
  case 'ArrowRight':
@@ -653,11 +497,15 @@ export var timePickerGridRoot = function(Root) {
653
497
  newColumn = 'seconds';
654
498
  }
655
499
  if (newColumn !== column) {
656
- setActiveTime(function(prev) {
657
- return _object_spread_props(_object_spread({}, prev), {
658
- currentColumn: newColumn
659
- });
660
- });
500
+ var _activeTime_column;
501
+ setCurrentColumn(newColumn);
502
+ var newValue2 = (((_activeTime_column = activeTime[column]) === null || _activeTime_column === void 0 ? void 0 : _activeTime_column.toString()) || '0').padStart(2, '0');
503
+ var element2 = timeItemRefs.current["".concat(newColumn, "-").concat(newValue2)];
504
+ setTimeout(function() {
505
+ if (element2) {
506
+ element2.focus();
507
+ }
508
+ }, 0);
661
509
  }
662
510
  break;
663
511
  case 'ArrowLeft':
@@ -668,11 +516,15 @@ export var timePickerGridRoot = function(Root) {
668
516
  newColumn = 'minutes';
669
517
  }
670
518
  if (newColumn !== column) {
671
- setActiveTime(function(prev) {
672
- return _object_spread_props(_object_spread({}, prev), {
673
- currentColumn: newColumn
674
- });
675
- });
519
+ var _activeTime_column1;
520
+ setCurrentColumn(newColumn);
521
+ var newValue3 = (((_activeTime_column1 = activeTime[column]) === null || _activeTime_column1 === void 0 ? void 0 : _activeTime_column1.toString()) || '0').padStart(2, '0');
522
+ var element3 = timeItemRefs.current["".concat(newColumn, "-").concat(newValue3)];
523
+ setTimeout(function() {
524
+ if (element3) {
525
+ element3.focus();
526
+ }
527
+ }, 0);
676
528
  }
677
529
  break;
678
530
  case 'Enter':
@@ -687,7 +539,13 @@ export var timePickerGridRoot = function(Root) {
687
539
  newIndex++;
688
540
  }
689
541
  if (newIndex < (column === 'hours' ? 24 : 60)) {
690
- handleTimeItemClick(newIndex.toString().padStart(2, '0'), column, false);
542
+ var newValue4 = newIndex.toString().padStart(2, '0');
543
+ var element4 = timeItemRefs.current["".concat(column, "-").concat(newValue4)];
544
+ setTimeout(function() {
545
+ if (element4) {
546
+ element4.focus();
547
+ }
548
+ }, 0);
691
549
  }
692
550
  break;
693
551
  case 'End':
@@ -697,83 +555,156 @@ export var timePickerGridRoot = function(Root) {
697
555
  newIndex--;
698
556
  }
699
557
  if (newIndex >= 0) {
700
- handleTimeItemClick(newIndex.toString().padStart(2, '0'), column, false);
701
- }
702
- break;
703
- case 'Tab':
704
- if (currentIndexInColumns === columnsConfig.length - 1) {
705
- break;
706
- }
707
- event.preventDefault();
708
- if (event.shiftKey) {
709
- if (column === 'minutes') {
710
- newColumn = 'hours';
711
- } else if (column === 'seconds') {
712
- newColumn = 'minutes';
713
- }
714
- } else if (column === 'hours') {
715
- newColumn = 'minutes';
716
- } else if (column === 'minutes' && actualFormat.includes('ss')) {
717
- newColumn = 'seconds';
718
- }
719
- if (newColumn !== column) {
720
- setActiveTime(function(prev) {
721
- return _object_spread_props(_object_spread({}, prev), {
722
- currentColumn: newColumn
723
- });
724
- });
558
+ var newValue5 = newIndex.toString().padStart(2, '0');
559
+ var element5 = timeItemRefs.current["".concat(column, "-").concat(newValue5)];
560
+ setTimeout(function() {
561
+ if (element5) {
562
+ element5.focus();
563
+ }
564
+ }, 0);
725
565
  }
726
566
  break;
727
567
  default:
728
- if (/^[0-9]$/.test(event.key)) {
729
- event.preventDefault();
730
- var inputNumber = parseInt(event.key, 10);
731
- if (column === 'hours') {
732
- if (inputNumber <= 2) {
733
- var tens = inputNumber;
734
- var handleSecondInput = function(e) {
735
- if (/^[0-9]$/.test(e.key)) {
736
- var units = parseInt(e.key, 10);
737
- var total = tens * 10 + units;
738
- if (total < 24 && !disabledValuesForColumn.includes(total)) {
739
- handleTimeItemClick(total.toString().padStart(2, '0'), column);
740
- }
741
- document.removeEventListener('keydown', handleSecondInput);
742
- }
743
- };
744
- document.addEventListener('keydown', handleSecondInput);
745
- setTimeout(function() {
746
- document.removeEventListener('keydown', handleSecondInput);
747
- }, 1000);
748
- } else if (inputNumber <= 9) {
749
- if (!disabledValuesForColumn.includes(inputNumber)) {
750
- handleTimeItemClick(inputNumber.toString().padStart(2, '0'), column);
751
- }
752
- }
753
- } else if (inputNumber <= 5) {
754
- var tens1 = inputNumber;
755
- var handleSecondInput1 = function(e) {
756
- if (/^[0-9]$/.test(e.key)) {
757
- var units = parseInt(e.key, 10);
758
- var total = tens1 * 10 + units;
759
- if (total < 60 && !disabledValuesForColumn.includes(total)) {
760
- handleTimeItemClick(total.toString().padStart(2, '0'), column);
761
- }
762
- document.removeEventListener('keydown', handleSecondInput1);
763
- }
764
- };
765
- document.addEventListener('keydown', handleSecondInput1);
766
- setTimeout(function() {
767
- document.removeEventListener('keydown', handleSecondInput1);
768
- }, 1000);
769
- } else if (inputNumber <= 9) {
770
- if (!disabledValuesForColumn.includes(inputNumber)) {
771
- handleTimeItemClick(inputNumber.toString().padStart(2, '0'), column);
772
- }
773
- }
774
- }
568
+ break;
775
569
  }
776
570
  };
571
+ useEffect(function() {
572
+ if (currentColumn && currentColumn !== null) {
573
+ var _activeTime_currentColumn;
574
+ var column = currentColumn;
575
+ var value = (_activeTime_currentColumn = activeTime[currentColumn]) === null || _activeTime_currentColumn === void 0 ? void 0 : _activeTime_currentColumn.toString().padStart(2, '0');
576
+ var element = timeItemRefs.current["".concat(column, "-").concat(value)];
577
+ setTimeout(function() {
578
+ if (element) {
579
+ element.focus();
580
+ }
581
+ }, 0);
582
+ }
583
+ }, [
584
+ currentColumn
585
+ ]);
586
+ useEffect(function() {
587
+ return function() {
588
+ [
589
+ hoursHideTimeoutRef,
590
+ minutesHideTimeoutRef,
591
+ secondsHideTimeoutRef
592
+ ].forEach(function(timeoutRef) {
593
+ if (timeoutRef.current) {
594
+ clearTimeout(timeoutRef.current);
595
+ }
596
+ });
597
+ };
598
+ }, []);
599
+ useEffect(function() {
600
+ if (hoursColumnRef.current) {
601
+ var computedStyle = getComputedStyle(hoursColumnRef.current);
602
+ var gapValue = parseFloat(computedStyle.gap || '0');
603
+ setGap(gapValue);
604
+ }
605
+ }, [
606
+ hoursColumnRef.current
607
+ ]);
608
+ useEffect(function() {
609
+ setTimeout(function() {
610
+ updateScrollbar(hoursColumnRef, setHoursScrollbar);
611
+ updateScrollbar(minutesColumnRef, setMinutesScrollbar);
612
+ if (columnsQuantity === 3) {
613
+ updateScrollbar(secondsColumnRef, setSecondsScrollbar);
614
+ }
615
+ }, 100);
616
+ }, [
617
+ columnsQuantity
618
+ ]);
619
+ useEffect(function() {
620
+ if (itemHeight === 0) return;
621
+ var scrollToActiveItem = function(columnRef, index) {
622
+ if (columnRef.current && index !== null) {
623
+ var scrollPosition = index * (itemHeight + gap);
624
+ animateScrollTo(columnRef.current, scrollPosition);
625
+ setTimeout(function() {
626
+ updateScrollbar(columnRef, setHoursScrollbar);
627
+ }, 300);
628
+ }
629
+ };
630
+ scrollToActiveItem(hoursColumnRef, activeTime.hours);
631
+ scrollToActiveItem(minutesColumnRef, activeTime.minutes);
632
+ scrollToActiveItem(secondsColumnRef, activeTime.seconds);
633
+ }, [
634
+ activeTime.hours,
635
+ activeTime.minutes,
636
+ activeTime.seconds,
637
+ itemHeight,
638
+ gap
639
+ ]);
640
+ useEffect(function() {
641
+ var hoursColumn = hoursColumnRef.current;
642
+ var minutesColumn = minutesColumnRef.current;
643
+ var secondsColumn = secondsColumnRef.current;
644
+ var handleHoursScroll = function() {
645
+ return handleColumnScroll(hoursColumnRef, setHoursScrollbar, hoursHideTimeoutRef);
646
+ };
647
+ var handleMinutesScroll = function() {
648
+ return handleColumnScroll(minutesColumnRef, setMinutesScrollbar, minutesHideTimeoutRef);
649
+ };
650
+ var handleSecondsScroll = function() {
651
+ return handleColumnScroll(secondsColumnRef, setSecondsScrollbar, secondsHideTimeoutRef);
652
+ };
653
+ if (hoursColumn) {
654
+ hoursColumn.addEventListener('scroll', handleHoursScroll);
655
+ }
656
+ if (minutesColumn) {
657
+ minutesColumn.addEventListener('scroll', handleMinutesScroll);
658
+ }
659
+ if (secondsColumn) {
660
+ secondsColumn.addEventListener('scroll', handleSecondsScroll);
661
+ }
662
+ return function() {
663
+ if (hoursColumn) {
664
+ hoursColumn.removeEventListener('scroll', handleHoursScroll);
665
+ }
666
+ if (minutesColumn) {
667
+ minutesColumn.removeEventListener('scroll', handleMinutesScroll);
668
+ }
669
+ if (secondsColumn) {
670
+ secondsColumn.removeEventListener('scroll', handleSecondsScroll);
671
+ }
672
+ };
673
+ }, []);
674
+ useEffect(function() {
675
+ var hoursColumn = hoursColumnRef.current;
676
+ var minutesColumn = minutesColumnRef.current;
677
+ var secondsColumn = secondsColumnRef.current;
678
+ var handleHoursMouseEnter = function() {
679
+ return showScrollbarWithDelay(setHoursScrollbar, hoursHideTimeoutRef, hoursColumnRef);
680
+ };
681
+ var handleMinutesMouseEnter = function() {
682
+ return showScrollbarWithDelay(setMinutesScrollbar, minutesHideTimeoutRef, minutesColumnRef);
683
+ };
684
+ var handleSecondsMouseEnter = function() {
685
+ return showScrollbarWithDelay(setSecondsScrollbar, secondsHideTimeoutRef, secondsColumnRef);
686
+ };
687
+ if (hoursColumn) {
688
+ hoursColumn.addEventListener('mouseenter', handleHoursMouseEnter);
689
+ }
690
+ if (minutesColumn) {
691
+ minutesColumn.addEventListener('mouseenter', handleMinutesMouseEnter);
692
+ }
693
+ if (secondsColumn) {
694
+ secondsColumn.addEventListener('mouseenter', handleSecondsMouseEnter);
695
+ }
696
+ return function() {
697
+ if (hoursColumn) {
698
+ hoursColumn.removeEventListener('mouseenter', handleHoursMouseEnter);
699
+ }
700
+ if (minutesColumn) {
701
+ minutesColumn.removeEventListener('mouseenter', handleMinutesMouseEnter);
702
+ }
703
+ if (secondsColumn) {
704
+ secondsColumn.removeEventListener('mouseenter', handleSecondsMouseEnter);
705
+ }
706
+ };
707
+ }, []);
777
708
  return /*#__PURE__*/ React.createElement(Root, _object_spread({
778
709
  ref: ref,
779
710
  view: view,
@@ -825,6 +756,7 @@ export var timePickerGridRoot = function(Root) {
825
756
  dropdownHeight: dropdownHeight,
826
757
  column: type,
827
758
  activeTime: activeTime,
759
+ currentColumn: currentColumn,
828
760
  handleTimeItemClick: handleTimeItemClick,
829
761
  handleTimeItemKeyDown: handleTimeItemKeyDown,
830
762
  createScrollbarDragHandler: createScrollbarDragHandler,
@@ -16,7 +16,7 @@ import cls from "classnames";
16
16
  import { classes } from "../../TimePickerGrid.tokens";
17
17
  import { StyledTimeColumn, StyledTimeItem, StyledEmpty, CustomScrollbar, ScrollbarTrack, ScrollbarThumb, StyledRoot } from "./TimeColumn.styles";
18
18
  export var renderTimeColumn = function(param) {
19
- var values = param.values, disabledValues = param.disabledValues, dropdownHeight = param.dropdownHeight, column = param.column, activeTime = param.activeTime, handleTimeItemClick = param.handleTimeItemClick, handleTimeItemKeyDown = param.handleTimeItemKeyDown, createScrollbarDragHandler = param.createScrollbarDragHandler, setScrollbar = param.setScrollbar, columnRef = param.columnRef, scrollbarState = param.scrollbarState, scrollbarRef = param.scrollbarRef, thumbRef = param.thumbRef, timeoutRef = param.timeoutRef, timeItemRefs = param.timeItemRefs;
19
+ var values = param.values, disabledValues = param.disabledValues, dropdownHeight = param.dropdownHeight, column = param.column, activeTime = param.activeTime, currentColumn = param.currentColumn, handleTimeItemClick = param.handleTimeItemClick, handleTimeItemKeyDown = param.handleTimeItemKeyDown, createScrollbarDragHandler = param.createScrollbarDragHandler, setScrollbar = param.setScrollbar, columnRef = param.columnRef, scrollbarState = param.scrollbarState, scrollbarRef = param.scrollbarRef, thumbRef = param.thumbRef, timeoutRef = param.timeoutRef, timeItemRefs = param.timeItemRefs;
20
20
  var handleKeyDown = function(e, columnType, value) {
21
21
  handleTimeItemKeyDown(e, columnType, value);
22
22
  };
@@ -43,7 +43,7 @@ export var renderTimeColumn = function(param) {
43
43
  }
44
44
  return 0;
45
45
  };
46
- var isColumnActive = activeTime.currentColumn === column;
46
+ var isColumnActive = currentColumn === column;
47
47
  var minAvailableIndex = minDisableIndex();
48
48
  return /*#__PURE__*/ React.createElement(StyledRoot, null, /*#__PURE__*/ React.createElement(StyledTimeColumn, {
49
49
  key: column,