@salutejs/plasma-new-hope 0.340.0-canary.2322.19132961849.0 → 0.340.0-canary.2322.19262336998.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 (762) hide show
  1. package/cjs/components/Autocomplete/Autocomplete.css +22 -22
  2. package/cjs/components/Calendar/CalendarBase/CalendarBase.js +6 -0
  3. package/cjs/components/Calendar/CalendarBase/CalendarBase.js.map +1 -1
  4. package/cjs/components/Calendar/CalendarDouble/CalendarDouble.js +6 -0
  5. package/cjs/components/Calendar/CalendarDouble/CalendarDouble.js.map +1 -1
  6. package/cjs/components/Combobox/ComboboxNew/Combobox.css +41 -22
  7. package/cjs/components/Combobox/ComboboxNew/Combobox.js +93 -19
  8. package/cjs/components/Combobox/ComboboxNew/Combobox.js.map +1 -1
  9. package/cjs/components/Combobox/ComboboxNew/Combobox.tokens.js +2 -0
  10. package/cjs/components/Combobox/ComboboxNew/Combobox.tokens.js.map +1 -1
  11. package/cjs/components/Combobox/ComboboxNew/hooks/getPathMaps.js +8 -2
  12. package/cjs/components/Combobox/ComboboxNew/hooks/getPathMaps.js.map +1 -1
  13. package/cjs/components/Combobox/ComboboxNew/hooks/useKeyboardNavigation.js +319 -1
  14. package/cjs/components/Combobox/ComboboxNew/hooks/useKeyboardNavigation.js.map +1 -1
  15. package/cjs/components/Combobox/ComboboxNew/reducers/focusedPathReducer.js +7 -0
  16. package/cjs/components/Combobox/ComboboxNew/reducers/focusedPathReducer.js.map +1 -1
  17. package/cjs/components/Combobox/ComboboxNew/reducers/treePathReducer.js +161 -0
  18. package/cjs/components/Combobox/ComboboxNew/reducers/treePathReducer.js.map +1 -0
  19. package/cjs/components/Combobox/ComboboxNew/ui/TreeList/TreeList.css +57 -0
  20. package/cjs/components/Combobox/ComboboxNew/ui/TreeList/TreeList.js +96 -0
  21. package/cjs/components/Combobox/ComboboxNew/ui/TreeList/TreeList.js.map +1 -0
  22. package/cjs/components/Combobox/ComboboxNew/ui/TreeList/TreeList.styles.js +30 -0
  23. package/cjs/components/Combobox/ComboboxNew/ui/TreeList/TreeList.styles.js.map +1 -0
  24. package/cjs/components/Combobox/ComboboxNew/ui/TreeList/TreeList.styles_1auklgl.css +2 -0
  25. package/cjs/components/Combobox/ComboboxNew/ui/TreeList/ui/Item/Item.css +54 -0
  26. package/cjs/components/Combobox/ComboboxNew/ui/TreeList/ui/Item/Item.js +144 -0
  27. package/cjs/components/Combobox/ComboboxNew/ui/TreeList/ui/Item/Item.js.map +1 -0
  28. package/cjs/components/Combobox/ComboboxNew/ui/TreeList/ui/Item/Item.styles.js +205 -0
  29. package/cjs/components/Combobox/ComboboxNew/ui/TreeList/ui/Item/Item.styles.js.map +1 -0
  30. package/cjs/components/Combobox/ComboboxNew/ui/TreeList/ui/Item/Item.styles_7nhjnm.css +15 -0
  31. package/cjs/components/Combobox/ComboboxNew/utils/filterItems.js +4 -3
  32. package/cjs/components/Combobox/ComboboxNew/utils/filterItems.js.map +1 -1
  33. package/cjs/components/DatePicker/DatePicker.tokens.js +4 -1
  34. package/cjs/components/DatePicker/DatePicker.tokens.js.map +1 -1
  35. package/cjs/components/DatePicker/RangeDate/RangeDate.css +22 -22
  36. package/cjs/components/DatePicker/RangeDate/RangeDate.js +24 -4
  37. package/cjs/components/DatePicker/RangeDate/RangeDate.js.map +1 -1
  38. package/cjs/components/DatePicker/RangeDate/RangeDatePopover/RangeDatePopover.css +22 -22
  39. package/cjs/components/DatePicker/SingleDate/SingleDate.css +25 -25
  40. package/cjs/components/DatePicker/SingleDate/SingleDate.styles.js +1 -1
  41. package/cjs/components/DatePicker/SingleDate/SingleDate.styles.js.map +1 -1
  42. package/cjs/components/DatePicker/SingleDate/{SingleDate.styles_5c37vu.css → SingleDate.styles_slcqbc.css} +1 -1
  43. package/cjs/components/DatePicker/utils/normalizeDates.js +3 -6
  44. package/cjs/components/DatePicker/utils/normalizeDates.js.map +1 -1
  45. package/cjs/components/DateTimePicker/DateTimePicker.css +200 -0
  46. package/cjs/components/DateTimePicker/DateTimePicker.js +337 -0
  47. package/cjs/components/DateTimePicker/DateTimePicker.js.map +1 -0
  48. package/cjs/components/DateTimePicker/DateTimePicker.styles.js +23 -0
  49. package/cjs/components/DateTimePicker/DateTimePicker.styles.js.map +1 -0
  50. package/cjs/components/DateTimePicker/DateTimePicker.styles_x7parr.css +3 -0
  51. package/cjs/components/DateTimePicker/DateTimePicker.tokens.js +271 -0
  52. package/cjs/components/DateTimePicker/DateTimePicker.tokens.js.map +1 -0
  53. package/cjs/components/DateTimePicker/hooks/useDateTimePicker.js +445 -0
  54. package/cjs/components/DateTimePicker/hooks/useDateTimePicker.js.map +1 -0
  55. package/cjs/components/DateTimePicker/hooks/useKeyboardNavigation.js +40 -0
  56. package/cjs/components/DateTimePicker/hooks/useKeyboardNavigation.js.map +1 -0
  57. package/cjs/components/DateTimePicker/ui/CalendarGrid/CalendarGrid.css +82 -0
  58. package/cjs/components/DateTimePicker/ui/CalendarGrid/CalendarGrid.js +36 -0
  59. package/cjs/components/DateTimePicker/ui/CalendarGrid/CalendarGrid.js.map +1 -0
  60. package/cjs/components/DateTimePicker/ui/CalendarGrid/CalendarGrid.styles.js +83 -0
  61. package/cjs/components/DateTimePicker/ui/CalendarGrid/CalendarGrid.styles.js.map +1 -0
  62. package/cjs/components/DateTimePicker/ui/CalendarGrid/CalendarGrid.styles_1yl3xrz.css +2 -0
  63. package/cjs/components/DateTimePicker/ui/DateShortcut/DateShortcutList.css +34 -0
  64. package/cjs/components/DateTimePicker/ui/DateShortcut/DateShortcutList.js +44 -0
  65. package/cjs/components/DateTimePicker/ui/DateShortcut/DateShortcutList.js.map +1 -0
  66. package/cjs/components/DateTimePicker/ui/DateShortcut/DateShortcutList.styles.js +92 -0
  67. package/cjs/components/DateTimePicker/ui/DateShortcut/DateShortcutList.styles.js.map +1 -0
  68. package/cjs/components/DateTimePicker/ui/DateShortcut/DateShortcutList.styles_pdofx1.css +6 -0
  69. package/cjs/components/DateTimePicker/ui/Input/Input.css +80 -0
  70. package/cjs/components/DateTimePicker/ui/Input/Input.js +70 -0
  71. package/cjs/components/DateTimePicker/ui/Input/Input.js.map +1 -0
  72. package/cjs/components/DateTimePicker/ui/Input/Input.styles.js +24 -0
  73. package/cjs/components/DateTimePicker/ui/Input/Input.styles.js.map +1 -0
  74. package/cjs/components/DateTimePicker/ui/Input/Input.styles_1af0tdj.css +1 -0
  75. package/cjs/components/DateTimePicker/ui/Popover/Popover.css +11 -0
  76. package/cjs/components/DateTimePicker/ui/Popover/Popover.js +37 -0
  77. package/cjs/components/DateTimePicker/ui/Popover/Popover.js.map +1 -0
  78. package/cjs/components/DateTimePicker/ui/Popover/Popover.styles.js +44 -0
  79. package/cjs/components/DateTimePicker/ui/Popover/Popover.styles.js.map +1 -0
  80. package/cjs/components/DateTimePicker/ui/Popover/Popover.styles_1v6vurg.css +2 -0
  81. package/cjs/components/DateTimePicker/ui/TimeGrid/TimeGrid.css +12 -0
  82. package/cjs/components/DateTimePicker/ui/TimeGrid/TimeGrid.js +30 -0
  83. package/cjs/components/DateTimePicker/ui/TimeGrid/TimeGrid.js.map +1 -0
  84. package/cjs/components/DateTimePicker/ui/TimeGrid/TimeGrid.styles.js +40 -0
  85. package/cjs/components/DateTimePicker/ui/TimeGrid/TimeGrid.styles.js.map +1 -0
  86. package/cjs/components/DateTimePicker/ui/TimeGrid/TimeGrid.styles_31tnfx.css +1 -0
  87. package/cjs/components/DateTimePicker/utils/getFormattedDateTime.js +81 -0
  88. package/cjs/components/DateTimePicker/utils/getFormattedDateTime.js.map +1 -0
  89. package/cjs/components/DateTimePicker/utils/getMaskedValue.js +53 -0
  90. package/cjs/components/DateTimePicker/utils/getMaskedValue.js.map +1 -0
  91. package/cjs/components/DateTimePicker/utils/getOriginalDateTime.js +73 -0
  92. package/cjs/components/DateTimePicker/utils/getOriginalDateTime.js.map +1 -0
  93. package/cjs/components/DateTimePicker/utils/normalizeDateTime.js +33 -0
  94. package/cjs/components/DateTimePicker/utils/normalizeDateTime.js.map +1 -0
  95. package/cjs/components/DateTimePicker/variations/_disabled/base.js +9 -0
  96. package/cjs/components/DateTimePicker/variations/_disabled/base.js.map +1 -0
  97. package/cjs/components/DateTimePicker/variations/_disabled/base_7ophop.css +1 -0
  98. package/cjs/components/DateTimePicker/variations/_readonly/base.js +9 -0
  99. package/cjs/components/DateTimePicker/variations/_readonly/base.js.map +1 -0
  100. package/cjs/components/DateTimePicker/variations/_readonly/base_rrpgsr.css +1 -0
  101. package/cjs/components/DateTimePicker/variations/_size/base.js +9 -0
  102. package/cjs/components/DateTimePicker/variations/_size/base.js.map +1 -0
  103. package/cjs/components/DateTimePicker/variations/_size/base_19i3bl1.css +1 -0
  104. package/cjs/components/DateTimePicker/variations/_tooltip-size/base.js +9 -0
  105. package/cjs/components/DateTimePicker/variations/_tooltip-size/base.js.map +1 -0
  106. package/cjs/components/DateTimePicker/variations/_tooltip-size/base_x642ct.css +1 -0
  107. package/cjs/components/DateTimePicker/variations/_view/base.js +9 -0
  108. package/cjs/components/DateTimePicker/variations/_view/base.js.map +1 -0
  109. package/cjs/components/DateTimePicker/variations/_view/base_1a1ebsk.css +1 -0
  110. package/cjs/components/Pagination/Pagination.css +22 -22
  111. package/cjs/components/Pagination/ui/PaginationSelectPerPage/PaginationSelectPerPage.css +22 -22
  112. package/cjs/components/Range/Range.css +22 -22
  113. package/cjs/components/Select/Select.css +22 -22
  114. package/cjs/components/Select/Select.js +2 -1
  115. package/cjs/components/Select/Select.js.map +1 -1
  116. package/cjs/components/Select/hooks/useKeyboardNavigation.js +127 -38
  117. package/cjs/components/Select/hooks/useKeyboardNavigation.js.map +1 -1
  118. package/cjs/components/Select/reducers/focusedPathReducer.js +7 -0
  119. package/cjs/components/Select/reducers/focusedPathReducer.js.map +1 -1
  120. package/cjs/components/Select/reducers/treePathReducer.js +12 -0
  121. package/cjs/components/Select/reducers/treePathReducer.js.map +1 -1
  122. package/cjs/components/Select/ui/Target/Target.css +22 -22
  123. package/cjs/components/Select/ui/Target/ui/Textfield/Textfield.css +22 -22
  124. package/cjs/components/Select/ui/Target/ui/Textfield/Textfield.js +5 -2
  125. package/cjs/components/Select/ui/Target/ui/Textfield/Textfield.js.map +1 -1
  126. package/cjs/components/Select/ui/TreeList/TreeList.js +3 -3
  127. package/cjs/components/Select/ui/TreeList/TreeList.js.map +1 -1
  128. package/cjs/components/Select/ui/TreeList/ui/Item/Item.js +22 -5
  129. package/cjs/components/Select/ui/TreeList/ui/Item/Item.js.map +1 -1
  130. package/cjs/components/Slider/Slider.css +22 -22
  131. package/cjs/components/Slider/components/DoubleUncontrolled/DoubleUncontrolled.css +22 -22
  132. package/cjs/components/Table/Table.css +22 -22
  133. package/cjs/components/Table/ui/Cell/Cell.css +22 -22
  134. package/cjs/components/Table/ui/EditableCell/EditableCell.css +22 -22
  135. package/cjs/components/Table/ui/HeadCell/HeadCell.css +22 -22
  136. package/cjs/components/Table/ui/HeadCell/ui/Filter/Filter.css +22 -22
  137. package/cjs/components/Tabs/tokens.js +1 -0
  138. package/cjs/components/Tabs/tokens.js.map +1 -1
  139. package/cjs/components/TextField/TextField.styles.js +7 -7
  140. package/cjs/components/TextField/TextField.styles.js.map +1 -1
  141. package/cjs/components/TextField/{TextField.styles_xvs3tf.css → TextField.styles_1fz6mh6.css} +1 -1
  142. package/cjs/components/TextField/ui/Hint/Hint.css +20 -20
  143. package/cjs/components/TextField/ui/TextFieldChipNew/TextFieldChipNew.css +22 -22
  144. package/cjs/components/TimePicker/TimePicker.css +22 -22
  145. package/cjs/components/TimePickerGrid/TimePickerGrid.js +206 -276
  146. package/cjs/components/TimePickerGrid/TimePickerGrid.js.map +1 -1
  147. package/cjs/components/TimePickerGrid/ui/TimeColumn/TimeColumn.js +2 -1
  148. package/cjs/components/TimePickerGrid/ui/TimeColumn/TimeColumn.js.map +1 -1
  149. package/cjs/components/Tree/utils/deepCopy.js +29 -0
  150. package/cjs/components/Tree/utils/deepCopy.js.map +1 -0
  151. package/cjs/components/Tree/utils/traverseTree.js +1 -1
  152. package/cjs/components/Tree/utils/traverseTree.js.map +1 -1
  153. package/cjs/index.css +73 -25
  154. package/cjs/index.js +8 -0
  155. package/cjs/index.js.map +1 -1
  156. package/cjs/utils/index.js.map +1 -1
  157. package/cjs/utils/isArraysEqual.js +12 -0
  158. package/cjs/utils/isArraysEqual.js.map +1 -0
  159. package/emotion/cjs/components/Calendar/CalendarBase/CalendarBase.js +6 -0
  160. package/emotion/cjs/components/Calendar/CalendarDouble/CalendarDouble.js +6 -0
  161. package/emotion/cjs/components/Combobox/ComboboxNew/Combobox.js +82 -17
  162. package/emotion/cjs/components/Combobox/ComboboxNew/Combobox.tokens.js +2 -0
  163. package/emotion/cjs/components/Combobox/ComboboxNew/hooks/getPathMaps.js +35 -3
  164. package/emotion/cjs/components/Combobox/ComboboxNew/hooks/useKeyboardNavigation.js +312 -0
  165. package/emotion/cjs/components/Combobox/ComboboxNew/reducers/focusedPathReducer.js +7 -0
  166. package/emotion/cjs/components/Combobox/ComboboxNew/reducers/index.js +1 -0
  167. package/emotion/cjs/components/Combobox/ComboboxNew/reducers/treePathReducer.js +174 -0
  168. package/emotion/cjs/components/Combobox/ComboboxNew/ui/TreeList/TreeList.js +130 -0
  169. package/emotion/cjs/components/Combobox/ComboboxNew/ui/TreeList/TreeList.styles.js +36 -0
  170. package/emotion/cjs/components/Combobox/ComboboxNew/ui/TreeList/TreeList.types.js +4 -0
  171. package/emotion/cjs/components/Combobox/ComboboxNew/ui/TreeList/ui/Item/Item.js +192 -0
  172. package/emotion/cjs/components/Combobox/ComboboxNew/ui/TreeList/ui/Item/Item.styles.js +183 -0
  173. package/emotion/cjs/components/Combobox/ComboboxNew/ui/TreeList/ui/Item/Item.types.js +4 -0
  174. package/emotion/cjs/components/Combobox/ComboboxNew/ui/index.js +1 -0
  175. package/emotion/cjs/components/Combobox/ComboboxNew/utils/filterItems.js +14 -6
  176. package/emotion/cjs/components/Combobox/ComboboxNew/utils/index.js +3 -0
  177. package/emotion/cjs/components/DatePicker/DatePicker.tokens.js +4 -1
  178. package/emotion/cjs/components/DatePicker/RangeDate/RangeDate.js +21 -4
  179. package/emotion/cjs/components/DatePicker/SingleDate/SingleDate.styles.js +7 -7
  180. package/emotion/cjs/components/DatePicker/utils/normalizeDates.js +3 -6
  181. package/emotion/cjs/components/DateTimePicker/DateTimePicker.js +459 -0
  182. package/emotion/cjs/components/DateTimePicker/DateTimePicker.styles.js +39 -0
  183. package/emotion/cjs/components/DateTimePicker/DateTimePicker.tokens.js +272 -0
  184. package/emotion/cjs/components/DateTimePicker/DateTimePicker.types.js +4 -0
  185. package/emotion/cjs/components/DateTimePicker/hooks/useDateTimePicker.js +499 -0
  186. package/emotion/cjs/components/DateTimePicker/hooks/useKeyboardNavigation.js +52 -0
  187. package/emotion/cjs/components/DateTimePicker/index.js +26 -0
  188. package/emotion/cjs/components/DateTimePicker/ui/CalendarGrid/CalendarGrid.js +93 -0
  189. package/emotion/cjs/components/DateTimePicker/ui/CalendarGrid/CalendarGrid.styles.js +61 -0
  190. package/emotion/cjs/components/DateTimePicker/ui/DateShortcut/DateShortcutList.js +53 -0
  191. package/emotion/cjs/components/DateTimePicker/ui/DateShortcut/DateShortcutList.styles.js +88 -0
  192. package/emotion/cjs/components/DateTimePicker/ui/Input/Input.js +167 -0
  193. package/emotion/cjs/components/DateTimePicker/ui/Input/Input.styles.js +25 -0
  194. package/emotion/cjs/components/DateTimePicker/ui/Popover/Popover.js +153 -0
  195. package/emotion/cjs/components/DateTimePicker/ui/Popover/Popover.styles.js +43 -0
  196. package/emotion/cjs/components/DateTimePicker/ui/TimeGrid/TimeGrid.js +87 -0
  197. package/emotion/cjs/components/DateTimePicker/ui/TimeGrid/TimeGrid.styles.js +31 -0
  198. package/emotion/cjs/components/DateTimePicker/ui/index.js +29 -0
  199. package/emotion/cjs/components/DateTimePicker/utils/getFormattedDateTime.js +118 -0
  200. package/emotion/cjs/components/DateTimePicker/utils/getMaskedValue.js +52 -0
  201. package/emotion/cjs/components/DateTimePicker/utils/getOriginalDateTime.js +128 -0
  202. package/emotion/cjs/components/DateTimePicker/utils/index.js +19 -0
  203. package/emotion/cjs/components/DateTimePicker/utils/normalizeDateTime.js +30 -0
  204. package/emotion/cjs/components/DateTimePicker/variations/_disabled/base.js +13 -0
  205. package/emotion/cjs/components/DateTimePicker/variations/_readonly/base.js +14 -0
  206. package/emotion/cjs/components/DateTimePicker/variations/_size/base.js +14 -0
  207. package/emotion/cjs/components/DateTimePicker/variations/_tooltip-size/base.js +12 -0
  208. package/emotion/cjs/components/DateTimePicker/variations/_view/base.js +14 -0
  209. package/emotion/cjs/components/Select/Select.js +2 -1
  210. package/emotion/cjs/components/Select/hooks/useKeyboardNavigation.js +156 -44
  211. package/emotion/cjs/components/Select/reducers/focusedPathReducer.js +7 -0
  212. package/emotion/cjs/components/Select/reducers/treePathReducer.js +12 -0
  213. package/emotion/cjs/components/Select/ui/Target/ui/Textfield/Textfield.js +5 -2
  214. package/emotion/cjs/components/Select/ui/TreeList/TreeList.js +7 -3
  215. package/emotion/cjs/components/Select/ui/TreeList/ui/Item/Item.js +49 -5
  216. package/emotion/cjs/components/Tabs/tokens.js +1 -0
  217. package/emotion/cjs/components/TextField/TextField.styles.js +45 -45
  218. package/emotion/cjs/components/TimePickerGrid/TimePickerGrid.js +213 -282
  219. package/emotion/cjs/components/TimePickerGrid/ui/TimeColumn/TimeColumn.js +2 -2
  220. package/emotion/cjs/components/Tree/utils/deepCopy.js +83 -0
  221. package/emotion/cjs/components/Tree/utils/index.js +4 -0
  222. package/emotion/cjs/components/Tree/utils/traverseTree.js +1 -1
  223. package/emotion/cjs/examples/components/ChipGroup/ChipGroup.config.js +35 -0
  224. package/emotion/cjs/examples/components/Combobox/Combobox.config.js +15 -15
  225. package/emotion/cjs/examples/components/DateTimePicker/DateTimePicker.config.js +40 -0
  226. package/emotion/cjs/examples/components/DateTimePicker/DateTimePicker.js +15 -0
  227. package/emotion/cjs/examples/components/Select/Select.config.js +24 -24
  228. package/emotion/cjs/examples/components/Tabs/horizontal/HorizontalTabItem.config.js +16 -16
  229. package/emotion/cjs/examples/components/Tabs/vertical/VerticalTabItem.config.js +7 -7
  230. package/emotion/cjs/index.js +1 -0
  231. package/emotion/cjs/utils/index.js +4 -0
  232. package/emotion/cjs/utils/isArraysEqual.js +15 -0
  233. package/emotion/es/components/Calendar/CalendarBase/CalendarBase.js +6 -0
  234. package/emotion/es/components/Calendar/CalendarDouble/CalendarDouble.js +6 -0
  235. package/emotion/es/components/Combobox/ComboboxNew/Combobox.js +85 -20
  236. package/emotion/es/components/Combobox/ComboboxNew/Combobox.tokens.js +2 -0
  237. package/emotion/es/components/Combobox/ComboboxNew/hooks/getPathMaps.js +35 -3
  238. package/emotion/es/components/Combobox/ComboboxNew/hooks/useKeyboardNavigation.js +313 -0
  239. package/emotion/es/components/Combobox/ComboboxNew/reducers/focusedPathReducer.js +7 -0
  240. package/emotion/es/components/Combobox/ComboboxNew/reducers/index.js +1 -0
  241. package/emotion/es/components/Combobox/ComboboxNew/reducers/treePathReducer.js +157 -0
  242. package/emotion/es/components/Combobox/ComboboxNew/ui/TreeList/TreeList.js +79 -0
  243. package/emotion/es/components/Combobox/ComboboxNew/ui/TreeList/TreeList.styles.js +13 -0
  244. package/emotion/es/components/Combobox/ComboboxNew/ui/TreeList/TreeList.types.js +1 -0
  245. package/emotion/es/components/Combobox/ComboboxNew/ui/TreeList/ui/Item/Item.js +141 -0
  246. package/emotion/es/components/Combobox/ComboboxNew/ui/TreeList/ui/Item/Item.styles.js +119 -0
  247. package/emotion/es/components/Combobox/ComboboxNew/ui/TreeList/ui/Item/Item.types.js +1 -0
  248. package/emotion/es/components/Combobox/ComboboxNew/ui/index.js +1 -0
  249. package/emotion/es/components/Combobox/ComboboxNew/utils/filterItems.js +3 -3
  250. package/emotion/es/components/Combobox/ComboboxNew/utils/index.js +1 -1
  251. package/emotion/es/components/DatePicker/DatePicker.tokens.js +4 -1
  252. package/emotion/es/components/DatePicker/RangeDate/RangeDate.js +21 -4
  253. package/emotion/es/components/DatePicker/SingleDate/SingleDate.styles.js +7 -7
  254. package/emotion/es/components/DatePicker/utils/normalizeDates.js +3 -6
  255. package/emotion/es/components/DateTimePicker/DateTimePicker.js +395 -0
  256. package/emotion/es/components/DateTimePicker/DateTimePicker.styles.js +13 -0
  257. package/emotion/es/components/DateTimePicker/DateTimePicker.tokens.js +251 -0
  258. package/emotion/es/components/DateTimePicker/DateTimePicker.types.js +1 -0
  259. package/emotion/es/components/DateTimePicker/hooks/useDateTimePicker.js +489 -0
  260. package/emotion/es/components/DateTimePicker/hooks/useKeyboardNavigation.js +34 -0
  261. package/emotion/es/components/DateTimePicker/index.js +2 -0
  262. package/emotion/es/components/DateTimePicker/ui/CalendarGrid/CalendarGrid.js +78 -0
  263. package/emotion/es/components/DateTimePicker/ui/CalendarGrid/CalendarGrid.styles.js +36 -0
  264. package/emotion/es/components/DateTimePicker/ui/DateShortcut/DateShortcutList.js +38 -0
  265. package/emotion/es/components/DateTimePicker/ui/DateShortcut/DateShortcutList.styles.js +53 -0
  266. package/emotion/es/components/DateTimePicker/ui/Input/Input.js +111 -0
  267. package/emotion/es/components/DateTimePicker/ui/Input/Input.styles.js +11 -0
  268. package/emotion/es/components/DateTimePicker/ui/Popover/Popover.js +102 -0
  269. package/emotion/es/components/DateTimePicker/ui/Popover/Popover.styles.js +20 -0
  270. package/emotion/es/components/DateTimePicker/ui/TimeGrid/TimeGrid.js +72 -0
  271. package/emotion/es/components/DateTimePicker/ui/TimeGrid/TimeGrid.styles.js +16 -0
  272. package/emotion/es/components/DateTimePicker/ui/index.js +6 -0
  273. package/emotion/es/components/DateTimePicker/utils/getFormattedDateTime.js +108 -0
  274. package/emotion/es/components/DateTimePicker/utils/getMaskedValue.js +42 -0
  275. package/emotion/es/components/DateTimePicker/utils/getOriginalDateTime.js +118 -0
  276. package/emotion/es/components/DateTimePicker/utils/index.js +2 -0
  277. package/emotion/es/components/DateTimePicker/utils/normalizeDateTime.js +20 -0
  278. package/emotion/es/components/DateTimePicker/variations/_disabled/base.js +3 -0
  279. package/emotion/es/components/DateTimePicker/variations/_readonly/base.js +4 -0
  280. package/emotion/es/components/DateTimePicker/variations/_size/base.js +4 -0
  281. package/emotion/es/components/DateTimePicker/variations/_tooltip-size/base.js +2 -0
  282. package/emotion/es/components/DateTimePicker/variations/_view/base.js +4 -0
  283. package/emotion/es/components/Select/Select.js +2 -1
  284. package/emotion/es/components/Select/hooks/useKeyboardNavigation.js +157 -44
  285. package/emotion/es/components/Select/reducers/focusedPathReducer.js +7 -0
  286. package/emotion/es/components/Select/reducers/treePathReducer.js +12 -0
  287. package/emotion/es/components/Select/ui/Target/ui/Textfield/Textfield.js +5 -2
  288. package/emotion/es/components/Select/ui/TreeList/TreeList.js +7 -3
  289. package/emotion/es/components/Select/ui/TreeList/ui/Item/Item.js +50 -6
  290. package/emotion/es/components/Tabs/tokens.js +1 -0
  291. package/emotion/es/components/TextField/TextField.styles.js +45 -45
  292. package/emotion/es/components/TimePickerGrid/TimePickerGrid.js +213 -282
  293. package/emotion/es/components/TimePickerGrid/ui/TimeColumn/TimeColumn.js +2 -2
  294. package/emotion/es/components/Tree/utils/deepCopy.js +73 -0
  295. package/emotion/es/components/Tree/utils/index.js +1 -0
  296. package/emotion/es/components/Tree/utils/traverseTree.js +1 -1
  297. package/emotion/es/examples/components/ChipGroup/ChipGroup.config.js +25 -0
  298. package/emotion/es/examples/components/Combobox/Combobox.config.js +15 -15
  299. package/emotion/es/examples/components/Combobox/Combobox.js +7 -0
  300. package/emotion/es/examples/components/DateTimePicker/DateTimePicker.config.js +30 -0
  301. package/emotion/es/examples/components/DateTimePicker/DateTimePicker.js +5 -0
  302. package/emotion/es/examples/components/Select/Select.config.js +24 -24
  303. package/emotion/es/examples/components/Tabs/horizontal/HorizontalTabItem.config.js +16 -16
  304. package/emotion/es/examples/components/Tabs/vertical/VerticalTabItem.config.js +7 -7
  305. package/emotion/es/index.js +1 -0
  306. package/emotion/es/utils/index.js +1 -0
  307. package/emotion/es/utils/isArraysEqual.js +5 -0
  308. package/es/components/Autocomplete/Autocomplete.css +22 -22
  309. package/es/components/Calendar/CalendarBase/CalendarBase.js +6 -0
  310. package/es/components/Calendar/CalendarBase/CalendarBase.js.map +1 -1
  311. package/es/components/Calendar/CalendarDouble/CalendarDouble.js +6 -0
  312. package/es/components/Calendar/CalendarDouble/CalendarDouble.js.map +1 -1
  313. package/es/components/Combobox/ComboboxNew/Combobox.css +41 -22
  314. package/es/components/Combobox/ComboboxNew/Combobox.js +95 -21
  315. package/es/components/Combobox/ComboboxNew/Combobox.js.map +1 -1
  316. package/es/components/Combobox/ComboboxNew/Combobox.tokens.js +2 -0
  317. package/es/components/Combobox/ComboboxNew/Combobox.tokens.js.map +1 -1
  318. package/es/components/Combobox/ComboboxNew/hooks/getPathMaps.js +8 -2
  319. package/es/components/Combobox/ComboboxNew/hooks/getPathMaps.js.map +1 -1
  320. package/es/components/Combobox/ComboboxNew/hooks/useKeyboardNavigation.js +319 -1
  321. package/es/components/Combobox/ComboboxNew/hooks/useKeyboardNavigation.js.map +1 -1
  322. package/es/components/Combobox/ComboboxNew/reducers/focusedPathReducer.js +7 -0
  323. package/es/components/Combobox/ComboboxNew/reducers/focusedPathReducer.js.map +1 -1
  324. package/es/components/Combobox/ComboboxNew/reducers/treePathReducer.js +156 -0
  325. package/es/components/Combobox/ComboboxNew/reducers/treePathReducer.js.map +1 -0
  326. package/es/components/Combobox/ComboboxNew/ui/TreeList/TreeList.css +57 -0
  327. package/es/components/Combobox/ComboboxNew/ui/TreeList/TreeList.js +88 -0
  328. package/es/components/Combobox/ComboboxNew/ui/TreeList/TreeList.js.map +1 -0
  329. package/es/components/Combobox/ComboboxNew/ui/TreeList/TreeList.styles.js +25 -0
  330. package/es/components/Combobox/ComboboxNew/ui/TreeList/TreeList.styles.js.map +1 -0
  331. package/es/components/Combobox/ComboboxNew/ui/TreeList/TreeList.styles_1auklgl.css +2 -0
  332. package/es/components/Combobox/ComboboxNew/ui/TreeList/ui/Item/Item.css +54 -0
  333. package/es/components/Combobox/ComboboxNew/ui/TreeList/ui/Item/Item.js +136 -0
  334. package/es/components/Combobox/ComboboxNew/ui/TreeList/ui/Item/Item.js.map +1 -0
  335. package/es/components/Combobox/ComboboxNew/ui/TreeList/ui/Item/Item.styles.js +187 -0
  336. package/es/components/Combobox/ComboboxNew/ui/TreeList/ui/Item/Item.styles.js.map +1 -0
  337. package/es/components/Combobox/ComboboxNew/ui/TreeList/ui/Item/Item.styles_7nhjnm.css +15 -0
  338. package/es/components/Combobox/ComboboxNew/utils/filterItems.js +4 -4
  339. package/es/components/Combobox/ComboboxNew/utils/filterItems.js.map +1 -1
  340. package/es/components/DatePicker/DatePicker.tokens.js +4 -1
  341. package/es/components/DatePicker/DatePicker.tokens.js.map +1 -1
  342. package/es/components/DatePicker/RangeDate/RangeDate.css +22 -22
  343. package/es/components/DatePicker/RangeDate/RangeDate.js +24 -4
  344. package/es/components/DatePicker/RangeDate/RangeDate.js.map +1 -1
  345. package/es/components/DatePicker/RangeDate/RangeDatePopover/RangeDatePopover.css +22 -22
  346. package/es/components/DatePicker/SingleDate/SingleDate.css +25 -25
  347. package/es/components/DatePicker/SingleDate/SingleDate.styles.js +1 -1
  348. package/es/components/DatePicker/SingleDate/SingleDate.styles.js.map +1 -1
  349. package/es/components/DatePicker/SingleDate/{SingleDate.styles_5c37vu.css → SingleDate.styles_slcqbc.css} +1 -1
  350. package/es/components/DatePicker/utils/normalizeDates.js +3 -6
  351. package/es/components/DatePicker/utils/normalizeDates.js.map +1 -1
  352. package/es/components/DateTimePicker/DateTimePicker.css +200 -0
  353. package/es/components/DateTimePicker/DateTimePicker.js +327 -0
  354. package/es/components/DateTimePicker/DateTimePicker.js.map +1 -0
  355. package/es/components/DateTimePicker/DateTimePicker.styles.js +17 -0
  356. package/es/components/DateTimePicker/DateTimePicker.styles.js.map +1 -0
  357. package/es/components/DateTimePicker/DateTimePicker.styles_x7parr.css +3 -0
  358. package/es/components/DateTimePicker/DateTimePicker.tokens.js +265 -0
  359. package/es/components/DateTimePicker/DateTimePicker.tokens.js.map +1 -0
  360. package/es/components/DateTimePicker/hooks/useDateTimePicker.js +441 -0
  361. package/es/components/DateTimePicker/hooks/useDateTimePicker.js.map +1 -0
  362. package/es/components/DateTimePicker/hooks/useKeyboardNavigation.js +35 -0
  363. package/es/components/DateTimePicker/hooks/useKeyboardNavigation.js.map +1 -0
  364. package/es/components/DateTimePicker/ui/CalendarGrid/CalendarGrid.css +82 -0
  365. package/es/components/DateTimePicker/ui/CalendarGrid/CalendarGrid.js +28 -0
  366. package/es/components/DateTimePicker/ui/CalendarGrid/CalendarGrid.js.map +1 -0
  367. package/es/components/DateTimePicker/ui/CalendarGrid/CalendarGrid.styles.js +78 -0
  368. package/es/components/DateTimePicker/ui/CalendarGrid/CalendarGrid.styles.js.map +1 -0
  369. package/es/components/DateTimePicker/ui/CalendarGrid/CalendarGrid.styles_1yl3xrz.css +2 -0
  370. package/es/components/DateTimePicker/ui/DateShortcut/DateShortcutList.css +34 -0
  371. package/es/components/DateTimePicker/ui/DateShortcut/DateShortcutList.js +35 -0
  372. package/es/components/DateTimePicker/ui/DateShortcut/DateShortcutList.js.map +1 -0
  373. package/es/components/DateTimePicker/ui/DateShortcut/DateShortcutList.styles.js +83 -0
  374. package/es/components/DateTimePicker/ui/DateShortcut/DateShortcutList.styles.js.map +1 -0
  375. package/es/components/DateTimePicker/ui/DateShortcut/DateShortcutList.styles_pdofx1.css +6 -0
  376. package/es/components/DateTimePicker/ui/Input/Input.css +80 -0
  377. package/es/components/DateTimePicker/ui/Input/Input.js +61 -0
  378. package/es/components/DateTimePicker/ui/Input/Input.js.map +1 -0
  379. package/es/components/DateTimePicker/ui/Input/Input.styles.js +20 -0
  380. package/es/components/DateTimePicker/ui/Input/Input.styles.js.map +1 -0
  381. package/es/components/DateTimePicker/ui/Input/Input.styles_1af0tdj.css +1 -0
  382. package/es/components/DateTimePicker/ui/Popover/Popover.css +11 -0
  383. package/es/components/DateTimePicker/ui/Popover/Popover.js +29 -0
  384. package/es/components/DateTimePicker/ui/Popover/Popover.js.map +1 -0
  385. package/es/components/DateTimePicker/ui/Popover/Popover.styles.js +39 -0
  386. package/es/components/DateTimePicker/ui/Popover/Popover.styles.js.map +1 -0
  387. package/es/components/DateTimePicker/ui/Popover/Popover.styles_1v6vurg.css +2 -0
  388. package/es/components/DateTimePicker/ui/TimeGrid/TimeGrid.css +12 -0
  389. package/es/components/DateTimePicker/ui/TimeGrid/TimeGrid.js +22 -0
  390. package/es/components/DateTimePicker/ui/TimeGrid/TimeGrid.js.map +1 -0
  391. package/es/components/DateTimePicker/ui/TimeGrid/TimeGrid.styles.js +36 -0
  392. package/es/components/DateTimePicker/ui/TimeGrid/TimeGrid.styles.js.map +1 -0
  393. package/es/components/DateTimePicker/ui/TimeGrid/TimeGrid.styles_31tnfx.css +1 -0
  394. package/es/components/DateTimePicker/utils/getFormattedDateTime.js +77 -0
  395. package/es/components/DateTimePicker/utils/getFormattedDateTime.js.map +1 -0
  396. package/es/components/DateTimePicker/utils/getMaskedValue.js +49 -0
  397. package/es/components/DateTimePicker/utils/getMaskedValue.js.map +1 -0
  398. package/es/components/DateTimePicker/utils/getOriginalDateTime.js +69 -0
  399. package/es/components/DateTimePicker/utils/getOriginalDateTime.js.map +1 -0
  400. package/es/components/DateTimePicker/utils/normalizeDateTime.js +29 -0
  401. package/es/components/DateTimePicker/utils/normalizeDateTime.js.map +1 -0
  402. package/es/components/DateTimePicker/variations/_disabled/base.js +5 -0
  403. package/es/components/DateTimePicker/variations/_disabled/base.js.map +1 -0
  404. package/es/components/DateTimePicker/variations/_disabled/base_7ophop.css +1 -0
  405. package/es/components/DateTimePicker/variations/_readonly/base.js +5 -0
  406. package/es/components/DateTimePicker/variations/_readonly/base.js.map +1 -0
  407. package/es/components/DateTimePicker/variations/_readonly/base_rrpgsr.css +1 -0
  408. package/es/components/DateTimePicker/variations/_size/base.js +5 -0
  409. package/es/components/DateTimePicker/variations/_size/base.js.map +1 -0
  410. package/es/components/DateTimePicker/variations/_size/base_19i3bl1.css +1 -0
  411. package/es/components/DateTimePicker/variations/_tooltip-size/base.js +5 -0
  412. package/es/components/DateTimePicker/variations/_tooltip-size/base.js.map +1 -0
  413. package/es/components/DateTimePicker/variations/_tooltip-size/base_x642ct.css +1 -0
  414. package/es/components/DateTimePicker/variations/_view/base.js +5 -0
  415. package/es/components/DateTimePicker/variations/_view/base.js.map +1 -0
  416. package/es/components/DateTimePicker/variations/_view/base_1a1ebsk.css +1 -0
  417. package/es/components/Pagination/Pagination.css +22 -22
  418. package/es/components/Pagination/ui/PaginationSelectPerPage/PaginationSelectPerPage.css +22 -22
  419. package/es/components/Range/Range.css +22 -22
  420. package/es/components/Select/Select.css +22 -22
  421. package/es/components/Select/Select.js +2 -1
  422. package/es/components/Select/Select.js.map +1 -1
  423. package/es/components/Select/hooks/useKeyboardNavigation.js +127 -38
  424. package/es/components/Select/hooks/useKeyboardNavigation.js.map +1 -1
  425. package/es/components/Select/reducers/focusedPathReducer.js +7 -0
  426. package/es/components/Select/reducers/focusedPathReducer.js.map +1 -1
  427. package/es/components/Select/reducers/treePathReducer.js +12 -0
  428. package/es/components/Select/reducers/treePathReducer.js.map +1 -1
  429. package/es/components/Select/ui/Target/Target.css +22 -22
  430. package/es/components/Select/ui/Target/ui/Textfield/Textfield.css +22 -22
  431. package/es/components/Select/ui/Target/ui/Textfield/Textfield.js +5 -2
  432. package/es/components/Select/ui/Target/ui/Textfield/Textfield.js.map +1 -1
  433. package/es/components/Select/ui/TreeList/TreeList.js +3 -3
  434. package/es/components/Select/ui/TreeList/TreeList.js.map +1 -1
  435. package/es/components/Select/ui/TreeList/ui/Item/Item.js +23 -6
  436. package/es/components/Select/ui/TreeList/ui/Item/Item.js.map +1 -1
  437. package/es/components/Slider/Slider.css +22 -22
  438. package/es/components/Slider/components/DoubleUncontrolled/DoubleUncontrolled.css +22 -22
  439. package/es/components/Table/Table.css +22 -22
  440. package/es/components/Table/ui/Cell/Cell.css +22 -22
  441. package/es/components/Table/ui/EditableCell/EditableCell.css +22 -22
  442. package/es/components/Table/ui/HeadCell/HeadCell.css +22 -22
  443. package/es/components/Table/ui/HeadCell/ui/Filter/Filter.css +22 -22
  444. package/es/components/Tabs/tokens.js +1 -0
  445. package/es/components/Tabs/tokens.js.map +1 -1
  446. package/es/components/TextField/TextField.styles.js +7 -7
  447. package/es/components/TextField/TextField.styles.js.map +1 -1
  448. package/es/components/TextField/{TextField.styles_xvs3tf.css → TextField.styles_1fz6mh6.css} +1 -1
  449. package/es/components/TextField/ui/Hint/Hint.css +20 -20
  450. package/es/components/TextField/ui/TextFieldChipNew/TextFieldChipNew.css +22 -22
  451. package/es/components/TimePicker/TimePicker.css +22 -22
  452. package/es/components/TimePickerGrid/TimePickerGrid.js +208 -278
  453. package/es/components/TimePickerGrid/TimePickerGrid.js.map +1 -1
  454. package/es/components/TimePickerGrid/ui/TimeColumn/TimeColumn.js +2 -1
  455. package/es/components/TimePickerGrid/ui/TimeColumn/TimeColumn.js.map +1 -1
  456. package/es/components/Tree/utils/deepCopy.js +25 -0
  457. package/es/components/Tree/utils/deepCopy.js.map +1 -0
  458. package/es/components/Tree/utils/traverseTree.js +1 -1
  459. package/es/components/Tree/utils/traverseTree.js.map +1 -1
  460. package/es/index.css +73 -25
  461. package/es/index.js +3 -0
  462. package/es/index.js.map +1 -1
  463. package/es/utils/index.js.map +1 -1
  464. package/es/utils/isArraysEqual.js +8 -0
  465. package/es/utils/isArraysEqual.js.map +1 -0
  466. package/package.json +2 -2
  467. package/styled-components/cjs/components/Calendar/CalendarBase/CalendarBase.js +6 -0
  468. package/styled-components/cjs/components/Calendar/CalendarDouble/CalendarDouble.js +6 -0
  469. package/styled-components/cjs/components/Combobox/ComboboxNew/Combobox.js +82 -17
  470. package/styled-components/cjs/components/Combobox/ComboboxNew/Combobox.tokens.js +2 -0
  471. package/styled-components/cjs/components/Combobox/ComboboxNew/hooks/getPathMaps.js +35 -3
  472. package/styled-components/cjs/components/Combobox/ComboboxNew/hooks/useKeyboardNavigation.js +312 -0
  473. package/styled-components/cjs/components/Combobox/ComboboxNew/reducers/focusedPathReducer.js +7 -0
  474. package/styled-components/cjs/components/Combobox/ComboboxNew/reducers/index.js +1 -0
  475. package/styled-components/cjs/components/Combobox/ComboboxNew/reducers/treePathReducer.js +174 -0
  476. package/styled-components/cjs/components/Combobox/ComboboxNew/ui/TreeList/TreeList.js +130 -0
  477. package/styled-components/cjs/components/Combobox/ComboboxNew/ui/TreeList/TreeList.styles.js +50 -0
  478. package/styled-components/cjs/components/Combobox/ComboboxNew/ui/TreeList/TreeList.types.js +4 -0
  479. package/styled-components/cjs/components/Combobox/ComboboxNew/ui/TreeList/ui/Item/Item.js +192 -0
  480. package/styled-components/cjs/components/Combobox/ComboboxNew/ui/TreeList/ui/Item/Item.styles.js +296 -0
  481. package/styled-components/cjs/components/Combobox/ComboboxNew/ui/TreeList/ui/Item/Item.types.js +4 -0
  482. package/styled-components/cjs/components/Combobox/ComboboxNew/ui/index.js +1 -0
  483. package/styled-components/cjs/components/Combobox/ComboboxNew/utils/filterItems.js +14 -6
  484. package/styled-components/cjs/components/Combobox/ComboboxNew/utils/index.js +3 -0
  485. package/styled-components/cjs/components/DatePicker/DatePicker.tokens.js +4 -1
  486. package/styled-components/cjs/components/DatePicker/RangeDate/RangeDate.js +21 -4
  487. package/styled-components/cjs/components/DatePicker/SingleDate/SingleDate.styles.js +13 -4
  488. package/styled-components/cjs/components/DatePicker/utils/normalizeDates.js +3 -6
  489. package/styled-components/cjs/components/DateTimePicker/DateTimePicker.js +459 -0
  490. package/styled-components/cjs/components/DateTimePicker/DateTimePicker.styles.js +89 -0
  491. package/styled-components/cjs/components/DateTimePicker/DateTimePicker.tokens.js +272 -0
  492. package/styled-components/cjs/components/DateTimePicker/DateTimePicker.types.js +4 -0
  493. package/styled-components/cjs/components/DateTimePicker/hooks/useDateTimePicker.js +499 -0
  494. package/styled-components/cjs/components/DateTimePicker/hooks/useKeyboardNavigation.js +52 -0
  495. package/styled-components/cjs/components/DateTimePicker/index.js +26 -0
  496. package/styled-components/cjs/components/DateTimePicker/ui/CalendarGrid/CalendarGrid.js +93 -0
  497. package/styled-components/cjs/components/DateTimePicker/ui/CalendarGrid/CalendarGrid.styles.js +75 -0
  498. package/styled-components/cjs/components/DateTimePicker/ui/DateShortcut/DateShortcutList.js +53 -0
  499. package/styled-components/cjs/components/DateTimePicker/ui/DateShortcut/DateShortcutList.styles.js +132 -0
  500. package/styled-components/cjs/components/DateTimePicker/ui/Input/Input.js +167 -0
  501. package/styled-components/cjs/components/DateTimePicker/ui/Input/Input.styles.js +176 -0
  502. package/styled-components/cjs/components/DateTimePicker/ui/Popover/Popover.js +153 -0
  503. package/styled-components/cjs/components/DateTimePicker/ui/Popover/Popover.styles.js +56 -0
  504. package/styled-components/cjs/components/DateTimePicker/ui/TimeGrid/TimeGrid.js +87 -0
  505. package/styled-components/cjs/components/DateTimePicker/ui/TimeGrid/TimeGrid.styles.js +69 -0
  506. package/styled-components/cjs/components/DateTimePicker/ui/index.js +29 -0
  507. package/styled-components/cjs/components/DateTimePicker/utils/getFormattedDateTime.js +118 -0
  508. package/styled-components/cjs/components/DateTimePicker/utils/getMaskedValue.js +52 -0
  509. package/styled-components/cjs/components/DateTimePicker/utils/getOriginalDateTime.js +128 -0
  510. package/styled-components/cjs/components/DateTimePicker/utils/index.js +19 -0
  511. package/styled-components/cjs/components/DateTimePicker/utils/normalizeDateTime.js +30 -0
  512. package/styled-components/cjs/components/DateTimePicker/variations/_disabled/base.js +16 -0
  513. package/styled-components/cjs/components/DateTimePicker/variations/_readonly/base.js +18 -0
  514. package/styled-components/cjs/components/DateTimePicker/variations/_size/base.js +24 -0
  515. package/styled-components/cjs/components/DateTimePicker/variations/_tooltip-size/base.js +14 -0
  516. package/styled-components/cjs/components/DateTimePicker/variations/_view/base.js +18 -0
  517. package/styled-components/cjs/components/Select/Select.js +2 -1
  518. package/styled-components/cjs/components/Select/hooks/useKeyboardNavigation.js +156 -44
  519. package/styled-components/cjs/components/Select/reducers/focusedPathReducer.js +7 -0
  520. package/styled-components/cjs/components/Select/reducers/treePathReducer.js +12 -0
  521. package/styled-components/cjs/components/Select/ui/Target/ui/Textfield/Textfield.js +5 -2
  522. package/styled-components/cjs/components/Select/ui/TreeList/TreeList.js +7 -3
  523. package/styled-components/cjs/components/Select/ui/TreeList/ui/Item/Item.js +49 -5
  524. package/styled-components/cjs/components/Tabs/tokens.js +1 -0
  525. package/styled-components/cjs/components/TextField/TextField.styles.js +29 -27
  526. package/styled-components/cjs/components/TimePickerGrid/TimePickerGrid.js +213 -282
  527. package/styled-components/cjs/components/TimePickerGrid/ui/TimeColumn/TimeColumn.js +2 -2
  528. package/styled-components/cjs/components/Tree/utils/deepCopy.js +83 -0
  529. package/styled-components/cjs/components/Tree/utils/index.js +4 -0
  530. package/styled-components/cjs/components/Tree/utils/traverseTree.js +1 -1
  531. package/styled-components/cjs/examples/components/ChipGroup/ChipGroup.config.js +141 -0
  532. package/styled-components/cjs/examples/components/Combobox/Combobox.config.js +20 -12
  533. package/styled-components/cjs/examples/components/Combobox/Combobox.js +15 -0
  534. package/styled-components/cjs/examples/components/DateTimePicker/DateTimePicker.config.js +786 -0
  535. package/styled-components/cjs/examples/components/DateTimePicker/DateTimePicker.js +15 -0
  536. package/styled-components/cjs/examples/components/Select/Select.config.js +7 -7
  537. package/styled-components/cjs/examples/components/Tabs/horizontal/HorizontalTabItem.config.js +4 -4
  538. package/styled-components/cjs/examples/components/Tabs/vertical/VerticalTabItem.config.js +4 -4
  539. package/styled-components/cjs/index.js +1 -0
  540. package/styled-components/cjs/utils/index.js +4 -0
  541. package/styled-components/cjs/utils/isArraysEqual.js +15 -0
  542. package/styled-components/es/components/Calendar/CalendarBase/CalendarBase.js +6 -0
  543. package/styled-components/es/components/Calendar/CalendarDouble/CalendarDouble.js +6 -0
  544. package/styled-components/es/components/Combobox/ComboboxNew/Combobox.js +85 -20
  545. package/styled-components/es/components/Combobox/ComboboxNew/Combobox.tokens.js +2 -0
  546. package/styled-components/es/components/Combobox/ComboboxNew/hooks/getPathMaps.js +35 -3
  547. package/styled-components/es/components/Combobox/ComboboxNew/hooks/useKeyboardNavigation.js +313 -0
  548. package/styled-components/es/components/Combobox/ComboboxNew/reducers/focusedPathReducer.js +7 -0
  549. package/styled-components/es/components/Combobox/ComboboxNew/reducers/index.js +1 -0
  550. package/styled-components/es/components/Combobox/ComboboxNew/reducers/treePathReducer.js +157 -0
  551. package/styled-components/es/components/Combobox/ComboboxNew/ui/TreeList/TreeList.js +79 -0
  552. package/styled-components/es/components/Combobox/ComboboxNew/ui/TreeList/TreeList.styles.js +27 -0
  553. package/styled-components/es/components/Combobox/ComboboxNew/ui/TreeList/TreeList.types.js +1 -0
  554. package/styled-components/es/components/Combobox/ComboboxNew/ui/TreeList/ui/Item/Item.js +141 -0
  555. package/styled-components/es/components/Combobox/ComboboxNew/ui/TreeList/ui/Item/Item.styles.js +232 -0
  556. package/styled-components/es/components/Combobox/ComboboxNew/ui/TreeList/ui/Item/Item.types.js +1 -0
  557. package/styled-components/es/components/Combobox/ComboboxNew/ui/index.js +1 -0
  558. package/styled-components/es/components/Combobox/ComboboxNew/utils/filterItems.js +3 -3
  559. package/styled-components/es/components/Combobox/ComboboxNew/utils/index.js +1 -1
  560. package/styled-components/es/components/DatePicker/DatePicker.tokens.js +4 -1
  561. package/styled-components/es/components/DatePicker/RangeDate/RangeDate.js +21 -4
  562. package/styled-components/es/components/DatePicker/SingleDate/SingleDate.styles.js +13 -4
  563. package/styled-components/es/components/DatePicker/utils/normalizeDates.js +3 -6
  564. package/styled-components/es/components/DateTimePicker/DateTimePicker.js +395 -0
  565. package/styled-components/es/components/DateTimePicker/DateTimePicker.styles.js +28 -0
  566. package/styled-components/es/components/DateTimePicker/DateTimePicker.tokens.js +251 -0
  567. package/styled-components/es/components/DateTimePicker/DateTimePicker.types.js +1 -0
  568. package/styled-components/es/components/DateTimePicker/hooks/useDateTimePicker.js +489 -0
  569. package/styled-components/es/components/DateTimePicker/hooks/useKeyboardNavigation.js +34 -0
  570. package/styled-components/es/components/DateTimePicker/index.js +2 -0
  571. package/styled-components/es/components/DateTimePicker/ui/CalendarGrid/CalendarGrid.js +78 -0
  572. package/styled-components/es/components/DateTimePicker/ui/CalendarGrid/CalendarGrid.styles.js +50 -0
  573. package/styled-components/es/components/DateTimePicker/ui/DateShortcut/DateShortcutList.js +38 -0
  574. package/styled-components/es/components/DateTimePicker/ui/DateShortcut/DateShortcutList.styles.js +97 -0
  575. package/styled-components/es/components/DateTimePicker/ui/Input/Input.js +111 -0
  576. package/styled-components/es/components/DateTimePicker/ui/Input/Input.styles.js +162 -0
  577. package/styled-components/es/components/DateTimePicker/ui/Popover/Popover.js +102 -0
  578. package/styled-components/es/components/DateTimePicker/ui/Popover/Popover.styles.js +33 -0
  579. package/styled-components/es/components/DateTimePicker/ui/TimeGrid/TimeGrid.js +72 -0
  580. package/styled-components/es/components/DateTimePicker/ui/TimeGrid/TimeGrid.styles.js +54 -0
  581. package/styled-components/es/components/DateTimePicker/ui/index.js +6 -0
  582. package/styled-components/es/components/DateTimePicker/utils/getFormattedDateTime.js +108 -0
  583. package/styled-components/es/components/DateTimePicker/utils/getMaskedValue.js +42 -0
  584. package/styled-components/es/components/DateTimePicker/utils/getOriginalDateTime.js +118 -0
  585. package/styled-components/es/components/DateTimePicker/utils/index.js +2 -0
  586. package/styled-components/es/components/DateTimePicker/utils/normalizeDateTime.js +20 -0
  587. package/styled-components/es/components/DateTimePicker/variations/_disabled/base.js +6 -0
  588. package/styled-components/es/components/DateTimePicker/variations/_readonly/base.js +8 -0
  589. package/styled-components/es/components/DateTimePicker/variations/_size/base.js +14 -0
  590. package/styled-components/es/components/DateTimePicker/variations/_tooltip-size/base.js +4 -0
  591. package/styled-components/es/components/DateTimePicker/variations/_view/base.js +8 -0
  592. package/styled-components/es/components/Select/Select.js +2 -1
  593. package/styled-components/es/components/Select/hooks/useKeyboardNavigation.js +157 -44
  594. package/styled-components/es/components/Select/reducers/focusedPathReducer.js +7 -0
  595. package/styled-components/es/components/Select/reducers/treePathReducer.js +12 -0
  596. package/styled-components/es/components/Select/ui/Target/ui/Textfield/Textfield.js +5 -2
  597. package/styled-components/es/components/Select/ui/TreeList/TreeList.js +7 -3
  598. package/styled-components/es/components/Select/ui/TreeList/ui/Item/Item.js +50 -6
  599. package/styled-components/es/components/Tabs/tokens.js +1 -0
  600. package/styled-components/es/components/TextField/TextField.styles.js +29 -27
  601. package/styled-components/es/components/TimePickerGrid/TimePickerGrid.js +213 -282
  602. package/styled-components/es/components/TimePickerGrid/ui/TimeColumn/TimeColumn.js +2 -2
  603. package/styled-components/es/components/Tree/utils/deepCopy.js +73 -0
  604. package/styled-components/es/components/Tree/utils/index.js +1 -0
  605. package/styled-components/es/components/Tree/utils/traverseTree.js +1 -1
  606. package/styled-components/es/examples/components/ChipGroup/ChipGroup.config.js +131 -0
  607. package/styled-components/es/examples/components/Combobox/Combobox.config.js +20 -12
  608. package/styled-components/es/examples/components/Combobox/Combobox.js +0 -7
  609. package/styled-components/es/examples/components/DateTimePicker/DateTimePicker.config.js +776 -0
  610. package/styled-components/es/examples/components/DateTimePicker/DateTimePicker.js +5 -0
  611. package/styled-components/es/examples/components/Select/Select.config.js +7 -7
  612. package/styled-components/es/examples/components/Tabs/horizontal/HorizontalTabItem.config.js +4 -4
  613. package/styled-components/es/examples/components/Tabs/vertical/VerticalTabItem.config.js +4 -4
  614. package/styled-components/es/index.js +1 -0
  615. package/styled-components/es/utils/index.js +1 -0
  616. package/styled-components/es/utils/isArraysEqual.js +5 -0
  617. package/types/components/Calendar/CalendarBase/CalendarBase.d.ts.map +1 -1
  618. package/types/components/Calendar/CalendarDouble/CalendarDouble.d.ts.map +1 -1
  619. package/types/components/Combobox/ComboboxNew/Combobox.d.ts.map +1 -1
  620. package/types/components/Combobox/ComboboxNew/Combobox.tokens.d.ts +2 -0
  621. package/types/components/Combobox/ComboboxNew/Combobox.tokens.d.ts.map +1 -1
  622. package/types/components/Combobox/ComboboxNew/Combobox.types.d.ts +17 -3
  623. package/types/components/Combobox/ComboboxNew/Combobox.types.d.ts.map +1 -1
  624. package/types/components/Combobox/ComboboxNew/hooks/getPathMaps.d.ts +2 -1
  625. package/types/components/Combobox/ComboboxNew/hooks/getPathMaps.d.ts.map +1 -1
  626. package/types/components/Combobox/ComboboxNew/hooks/useKeyboardNavigation.d.ts +8 -3
  627. package/types/components/Combobox/ComboboxNew/hooks/useKeyboardNavigation.d.ts.map +1 -1
  628. package/types/components/Combobox/ComboboxNew/reducers/focusedPathReducer.d.ts +3 -0
  629. package/types/components/Combobox/ComboboxNew/reducers/focusedPathReducer.d.ts.map +1 -1
  630. package/types/components/Combobox/ComboboxNew/reducers/index.d.ts +1 -0
  631. package/types/components/Combobox/ComboboxNew/reducers/index.d.ts.map +1 -1
  632. package/types/components/Combobox/ComboboxNew/reducers/treePathReducer.d.ts +28 -0
  633. package/types/components/Combobox/ComboboxNew/reducers/treePathReducer.d.ts.map +1 -0
  634. package/types/components/Combobox/ComboboxNew/ui/TreeList/TreeList.d.ts +4 -0
  635. package/types/components/Combobox/ComboboxNew/ui/TreeList/TreeList.d.ts.map +1 -0
  636. package/types/components/Combobox/ComboboxNew/ui/TreeList/TreeList.styles.d.ts +6 -0
  637. package/types/components/Combobox/ComboboxNew/ui/TreeList/TreeList.styles.d.ts.map +1 -0
  638. package/types/components/Combobox/ComboboxNew/ui/TreeList/TreeList.types.d.ts +11 -0
  639. package/types/components/Combobox/ComboboxNew/ui/TreeList/TreeList.types.d.ts.map +1 -0
  640. package/types/components/Combobox/ComboboxNew/ui/TreeList/ui/Item/Item.d.ts +4 -0
  641. package/types/components/Combobox/ComboboxNew/ui/TreeList/ui/Item/Item.d.ts.map +1 -0
  642. package/types/components/Combobox/ComboboxNew/ui/TreeList/ui/Item/Item.styles.d.ts +62 -0
  643. package/types/components/Combobox/ComboboxNew/ui/TreeList/ui/Item/Item.styles.d.ts.map +1 -0
  644. package/types/components/Combobox/ComboboxNew/ui/TreeList/ui/Item/Item.types.d.ts +6 -0
  645. package/types/components/Combobox/ComboboxNew/ui/TreeList/ui/Item/Item.types.d.ts.map +1 -0
  646. package/types/components/Combobox/ComboboxNew/ui/index.d.ts +1 -0
  647. package/types/components/Combobox/ComboboxNew/ui/index.d.ts.map +1 -1
  648. package/types/components/Combobox/ComboboxNew/utils/filterItems.d.ts +1 -0
  649. package/types/components/Combobox/ComboboxNew/utils/filterItems.d.ts.map +1 -1
  650. package/types/components/Combobox/ComboboxNew/utils/index.d.ts +1 -1
  651. package/types/components/Combobox/ComboboxNew/utils/index.d.ts.map +1 -1
  652. package/types/components/DatePicker/DatePicker.tokens.d.ts +3 -0
  653. package/types/components/DatePicker/DatePicker.tokens.d.ts.map +1 -1
  654. package/types/components/DatePicker/RangeDate/RangeDate.d.ts.map +1 -1
  655. package/types/components/DatePicker/SingleDate/SingleDate.styles.d.ts.map +1 -1
  656. package/types/components/DatePicker/utils/normalizeDates.d.ts.map +1 -1
  657. package/types/components/DateTimePicker/DateTimePicker.d.ts +73 -0
  658. package/types/components/DateTimePicker/DateTimePicker.d.ts.map +1 -0
  659. package/types/components/DateTimePicker/DateTimePicker.styles.d.ts +4 -0
  660. package/types/components/DateTimePicker/DateTimePicker.styles.d.ts.map +1 -0
  661. package/types/components/DateTimePicker/DateTimePicker.tokens.d.ts +260 -0
  662. package/types/components/DateTimePicker/DateTimePicker.tokens.d.ts.map +1 -0
  663. package/types/components/DateTimePicker/DateTimePicker.types.d.ts +160 -0
  664. package/types/components/DateTimePicker/DateTimePicker.types.d.ts.map +1 -0
  665. package/types/components/DateTimePicker/hooks/useDateTimePicker.d.ts +26 -0
  666. package/types/components/DateTimePicker/hooks/useDateTimePicker.d.ts.map +1 -0
  667. package/types/components/DateTimePicker/hooks/useKeyboardNavigation.d.ts +18 -0
  668. package/types/components/DateTimePicker/hooks/useKeyboardNavigation.d.ts.map +1 -0
  669. package/types/components/DateTimePicker/index.d.ts +4 -0
  670. package/types/components/DateTimePicker/index.d.ts.map +1 -0
  671. package/types/components/DateTimePicker/ui/CalendarGrid/CalendarGrid.d.ts +11 -0
  672. package/types/components/DateTimePicker/ui/CalendarGrid/CalendarGrid.d.ts.map +1 -0
  673. package/types/components/DateTimePicker/ui/CalendarGrid/CalendarGrid.styles.d.ts +10 -0
  674. package/types/components/DateTimePicker/ui/CalendarGrid/CalendarGrid.styles.d.ts.map +1 -0
  675. package/types/components/DateTimePicker/ui/DateShortcut/DateShortcutList.d.ts +12 -0
  676. package/types/components/DateTimePicker/ui/DateShortcut/DateShortcutList.d.ts.map +1 -0
  677. package/types/components/DateTimePicker/ui/DateShortcut/DateShortcutList.styles.d.ts +44 -0
  678. package/types/components/DateTimePicker/ui/DateShortcut/DateShortcutList.styles.d.ts.map +1 -0
  679. package/types/components/DateTimePicker/ui/Input/Input.d.ts +8 -0
  680. package/types/components/DateTimePicker/ui/Input/Input.d.ts.map +1 -0
  681. package/types/components/DateTimePicker/ui/Input/Input.styles.d.ts +298 -0
  682. package/types/components/DateTimePicker/ui/Input/Input.styles.d.ts.map +1 -0
  683. package/types/components/DateTimePicker/ui/Popover/Popover.d.ts +8 -0
  684. package/types/components/DateTimePicker/ui/Popover/Popover.d.ts.map +1 -0
  685. package/types/components/DateTimePicker/ui/Popover/Popover.styles.d.ts +6 -0
  686. package/types/components/DateTimePicker/ui/Popover/Popover.styles.d.ts.map +1 -0
  687. package/types/components/DateTimePicker/ui/TimeGrid/TimeGrid.d.ts +9 -0
  688. package/types/components/DateTimePicker/ui/TimeGrid/TimeGrid.d.ts.map +1 -0
  689. package/types/components/DateTimePicker/ui/TimeGrid/TimeGrid.styles.d.ts +23 -0
  690. package/types/components/DateTimePicker/ui/TimeGrid/TimeGrid.styles.d.ts.map +1 -0
  691. package/types/components/DateTimePicker/ui/index.d.ts +7 -0
  692. package/types/components/DateTimePicker/ui/index.d.ts.map +1 -0
  693. package/types/components/DateTimePicker/utils/getFormattedDateTime.d.ts +27 -0
  694. package/types/components/DateTimePicker/utils/getFormattedDateTime.d.ts.map +1 -0
  695. package/types/components/DateTimePicker/utils/getMaskedValue.d.ts +13 -0
  696. package/types/components/DateTimePicker/utils/getMaskedValue.d.ts.map +1 -0
  697. package/types/components/DateTimePicker/utils/getOriginalDateTime.d.ts +19 -0
  698. package/types/components/DateTimePicker/utils/getOriginalDateTime.d.ts.map +1 -0
  699. package/types/components/DateTimePicker/utils/index.d.ts +3 -0
  700. package/types/components/DateTimePicker/utils/index.d.ts.map +1 -0
  701. package/types/components/DateTimePicker/utils/normalizeDateTime.d.ts +15 -0
  702. package/types/components/DateTimePicker/utils/normalizeDateTime.d.ts.map +1 -0
  703. package/types/components/DateTimePicker/variations/_disabled/base.d.ts +2 -0
  704. package/types/components/DateTimePicker/variations/_disabled/base.d.ts.map +1 -0
  705. package/types/components/DateTimePicker/variations/_readonly/base.d.ts +2 -0
  706. package/types/components/DateTimePicker/variations/_readonly/base.d.ts.map +1 -0
  707. package/types/components/DateTimePicker/variations/_size/base.d.ts +2 -0
  708. package/types/components/DateTimePicker/variations/_size/base.d.ts.map +1 -0
  709. package/types/components/DateTimePicker/variations/_tooltip-size/base.d.ts +2 -0
  710. package/types/components/DateTimePicker/variations/_tooltip-size/base.d.ts.map +1 -0
  711. package/types/components/DateTimePicker/variations/_view/base.d.ts +2 -0
  712. package/types/components/DateTimePicker/variations/_view/base.d.ts.map +1 -0
  713. package/types/components/Select/Select.d.ts.map +1 -1
  714. package/types/components/Select/hooks/useKeyboardNavigation.d.ts +2 -1
  715. package/types/components/Select/hooks/useKeyboardNavigation.d.ts.map +1 -1
  716. package/types/components/Select/reducers/focusedPathReducer.d.ts +3 -0
  717. package/types/components/Select/reducers/focusedPathReducer.d.ts.map +1 -1
  718. package/types/components/Select/reducers/treePathReducer.d.ts +6 -0
  719. package/types/components/Select/reducers/treePathReducer.d.ts.map +1 -1
  720. package/types/components/Select/ui/Target/ui/Textfield/Textfield.d.ts.map +1 -1
  721. package/types/components/Select/ui/TreeList/ui/Item/Item.d.ts.map +1 -1
  722. package/types/components/Select/ui/TreeList/ui/Item/Item.types.d.ts +1 -9
  723. package/types/components/Select/ui/TreeList/ui/Item/Item.types.d.ts.map +1 -1
  724. package/types/components/Tabs/tokens.d.ts +1 -0
  725. package/types/components/Tabs/tokens.d.ts.map +1 -1
  726. package/types/components/TextField/TextField.styles.d.ts.map +1 -1
  727. package/types/components/TimePickerGrid/TimePickerGrid.d.ts.map +1 -1
  728. package/types/components/TimePickerGrid/ui/TimeColumn/TimeColumn.d.ts +1 -1
  729. package/types/components/TimePickerGrid/ui/TimeColumn/TimeColumn.d.ts.map +1 -1
  730. package/types/components/TimePickerGrid/ui/TimeColumn/TimeColumn.types.d.ts +2 -1
  731. package/types/components/TimePickerGrid/ui/TimeColumn/TimeColumn.types.d.ts.map +1 -1
  732. package/types/components/Tree/utils/deepCopy.d.ts +6 -0
  733. package/types/components/Tree/utils/deepCopy.d.ts.map +1 -0
  734. package/types/components/Tree/utils/index.d.ts +1 -0
  735. package/types/components/Tree/utils/index.d.ts.map +1 -1
  736. package/types/examples/components/ChipGroup/ChipGroup.config.d.ts.map +1 -0
  737. package/types/examples/components/ChipGroup/ChipGroup.d.ts.map +1 -0
  738. package/types/examples/components/Combobox/Combobox.config.d.ts.map +1 -1
  739. package/types/examples/components/Combobox/Combobox.d.ts +48 -0
  740. package/types/examples/components/Combobox/Combobox.d.ts.map +1 -1
  741. package/types/examples/components/DateTimePicker/DateTimePicker.config.d.ts +29 -0
  742. package/types/examples/components/DateTimePicker/DateTimePicker.config.d.ts.map +1 -0
  743. package/types/examples/components/DateTimePicker/DateTimePicker.d.ts +42 -0
  744. package/types/examples/components/DateTimePicker/DateTimePicker.d.ts.map +1 -0
  745. package/types/index.d.ts +1 -0
  746. package/types/index.d.ts.map +1 -1
  747. package/types/utils/index.d.ts +1 -0
  748. package/types/utils/index.d.ts.map +1 -1
  749. package/types/utils/isArraysEqual.d.ts +2 -0
  750. package/types/utils/isArraysEqual.d.ts.map +1 -0
  751. package/emotion/cjs/examples/components/ChipGroup /ChipGroup.config.js +0 -214
  752. package/emotion/es/examples/components/ChipGroup /ChipGroup.config.js +0 -204
  753. package/styled-components/cjs/examples/components/ChipGroup /ChipGroup.config.js +0 -214
  754. package/styled-components/es/examples/components/ChipGroup /ChipGroup.config.js +0 -204
  755. package/types/examples/components/ChipGroup /ChipGroup.config.d.ts.map +0 -1
  756. package/types/examples/components/ChipGroup /ChipGroup.d.ts.map +0 -1
  757. /package/emotion/cjs/examples/components/{ChipGroup → ChipGroup}/ChipGroup.js +0 -0
  758. /package/emotion/es/examples/components/{ChipGroup → ChipGroup}/ChipGroup.js +0 -0
  759. /package/styled-components/cjs/examples/components/{ChipGroup → ChipGroup}/ChipGroup.js +0 -0
  760. /package/styled-components/es/examples/components/{ChipGroup → ChipGroup}/ChipGroup.js +0 -0
  761. /package/types/examples/components/{ChipGroup → ChipGroup}/ChipGroup.config.d.ts +0 -0
  762. /package/types/examples/components/{ChipGroup → ChipGroup}/ChipGroup.d.ts +0 -0
@@ -206,7 +206,7 @@ function _unsupported_iterable_to_array(o, minLen) {
206
206
  var comboboxRoot = function(Root) {
207
207
  return /*#__PURE__*/ (0, _react.forwardRef)(function(props, ref) {
208
208
  var _getItemByFocused;
209
- var name = props.name, multiple = props.multiple, outerValue = props.value, outerOnChange = props.onChange, defaultValue = props.defaultValue, isTargetAmount = props.isTargetAmount, targetAmount = props.targetAmount, items = props.items, _props_placement = props.placement, placement = _props_placement === void 0 ? 'bottom-start' : _props_placement, label = props.label, placeholder = props.placeholder, helperText = props.helperText, contentLeft = props.contentLeft, textBefore = props.textBefore, textAfter = props.textAfter, _props_variant = props.variant, variant = _props_variant === void 0 ? 'normal' : _props_variant, listOverflow = props.listOverflow, listHeight = props.listHeight, listMaxHeight = props.listMaxHeight, listWidth = props.listWidth, portal = props.portal, renderItem = props.renderItem, view = props.view, size = props.size, labelPlacement = props.labelPlacement, keepPlaceholder = props.keepPlaceholder, _props_readOnly = props.readOnly, readOnly = _props_readOnly === void 0 ? false : _props_readOnly, _props_disabled = props.disabled, disabled = _props_disabled === void 0 ? false : _props_disabled, _props_alwaysOpened = props.alwaysOpened, alwaysOpened = _props_alwaysOpened === void 0 ? false : _props_alwaysOpened, filter = props.filter, outerCloseAfterSelect = props.closeAfterSelect, renderValue = props.renderValue, zIndex = props.zIndex, beforeList = props.beforeList, afterList = props.afterList, _props_virtual = props.virtual, virtual = _props_virtual === void 0 ? false : _props_virtual, hintView = props.hintView, hintSize = props.hintSize, emptyStateDescription = props.emptyStateDescription, onChangeValue = props.onChangeValue, onScroll = props.onScroll, onToggle = props.onToggle, _props_mode = props.mode, mode = _props_mode === void 0 ? 'default' : _props_mode, _props_chipClickArea = props.chipClickArea, chipClickArea = _props_chipClickArea === void 0 ? 'full' : _props_chipClickArea, // @ts-ignore
209
+ var name = props.name, multiple = props.multiple, outerValue = props.value, outerOnChange = props.onChange, defaultValue = props.defaultValue, isTargetAmount = props.isTargetAmount, targetAmount = props.targetAmount, items = props.items, _props_treeView = props.treeView, treeView = _props_treeView === void 0 ? false : _props_treeView, _props_arrowPlacement = props.arrowPlacement, arrowPlacement = _props_arrowPlacement === void 0 ? 'left' : _props_arrowPlacement, _props_placement = props.placement, placement = _props_placement === void 0 ? 'bottom-start' : _props_placement, label = props.label, placeholder = props.placeholder, helperText = props.helperText, contentLeft = props.contentLeft, textBefore = props.textBefore, textAfter = props.textAfter, _props_variant = props.variant, variant = _props_variant === void 0 ? 'normal' : _props_variant, listOverflow = props.listOverflow, listHeight = props.listHeight, listMaxHeight = props.listMaxHeight, listWidth = props.listWidth, portal = props.portal, renderItem = props.renderItem, view = props.view, size = props.size, labelPlacement = props.labelPlacement, keepPlaceholder = props.keepPlaceholder, _props_readOnly = props.readOnly, readOnly = _props_readOnly === void 0 ? false : _props_readOnly, _props_disabled = props.disabled, disabled = _props_disabled === void 0 ? false : _props_disabled, _props_alwaysOpened = props.alwaysOpened, alwaysOpened = _props_alwaysOpened === void 0 ? false : _props_alwaysOpened, filter = props.filter, outerCloseAfterSelect = props.closeAfterSelect, renderValue = props.renderValue, zIndex = props.zIndex, beforeList = props.beforeList, afterList = props.afterList, _props_virtual = props.virtual, virtual = _props_virtual === void 0 ? false : _props_virtual, hintView = props.hintView, hintSize = props.hintSize, emptyStateDescription = props.emptyStateDescription, onChangeValue = props.onChangeValue, onScroll = props.onScroll, onToggle = props.onToggle, _props_mode = props.mode, mode = _props_mode === void 0 ? 'default' : _props_mode, _props_chipClickArea = props.chipClickArea, chipClickArea = _props_chipClickArea === void 0 ? 'full' : _props_chipClickArea, // @ts-ignore
210
210
  _offset = props._offset, rest = _object_without_properties(props, [
211
211
  "name",
212
212
  "multiple",
@@ -216,6 +216,8 @@ var comboboxRoot = function(Root) {
216
216
  "isTargetAmount",
217
217
  "targetAmount",
218
218
  "items",
219
+ "treeView",
220
+ "arrowPlacement",
219
221
  "placement",
220
222
  "label",
221
223
  "placeholder",
@@ -264,8 +266,10 @@ var comboboxRoot = function(Root) {
264
266
  return (0, _getPathMaps.getTreeMaps)(transformedItems);
265
267
  }, [
266
268
  items
267
- ]), 2), valueToCheckedMap = _useMemo[0], valueToItemMap = _useMemo[1];
268
- var _useState = _sliced_to_array((0, _react.useState)((0, _utils2.getTextValue)(multiple, outerValue, valueToItemMap, renderValue)), 2), textValue = _useState[0], setTextValue = _useState[1];
269
+ ]), 3), valueToCheckedMap = _useMemo[0], valueToItemMap = _useMemo[1], valueToPathMap = _useMemo[2];
270
+ // Состояние поля поиска в target
271
+ var _useState = _sliced_to_array((0, _react.useState)((0, _utils2.getTextValue)(multiple, outerValue, valueToItemMap, renderValue)), 2), textValue = _useState[0], setTextValueState = _useState[1];
272
+ // Внутреннее состояние выбранных элементов
269
273
  var _useState1 = _sliced_to_array((0, _react.useState)(multiple ? [] : ''), 2), internalValue = _useState1[0], setInternalValue = _useState1[1];
270
274
  var value = outerValue !== null && outerValue !== undefined ? outerValue : internalValue;
271
275
  var rootRef = (0, _react.useRef)(null);
@@ -274,12 +278,14 @@ var comboboxRoot = function(Root) {
274
278
  var inputForkRef = (0, _plasmacore.useForkRef)(inputRef, ref);
275
279
  var listWrapperRef = (0, _react.useRef)(null);
276
280
  var treeId = (0, _utils.safeUseId)();
281
+ var filterCb = filter || _utils2.defaultFilter;
277
282
  var filteredItems = (0, _react.useMemo)(function() {
278
283
  return (0, _utils2.filterItems)(transformedItems, textValue, (0, _utils2.getTextValue)(multiple, value, valueToItemMap, renderValue), filter);
279
284
  }, [
280
285
  transformedItems,
281
286
  textValue,
282
- filter
287
+ filter,
288
+ value
283
289
  ]);
284
290
  var _useMemo1 = _sliced_to_array((0, _react.useMemo)(function() {
285
291
  return (0, _getPathMaps.getPathMap)(filteredItems);
@@ -294,17 +300,22 @@ var comboboxRoot = function(Root) {
294
300
  var _useReducer = _sliced_to_array((0, _react.useReducer)(_reducers.pathReducer, initialPath), 2), path = _useReducer[0], dispatchPath = _useReducer[1];
295
301
  var _useReducer1 = _sliced_to_array((0, _react.useReducer)(_reducers.focusedPathReducer, []), 2), focusedPath = _useReducer1[0], dispatchFocusedPath = _useReducer1[1];
296
302
  var _useState2 = _sliced_to_array((0, _react.useState)(valueToCheckedMap), 2), checked = _useState2[0], setChecked = _useState2[1];
303
+ var _useReducer2 = _sliced_to_array((0, _react.useReducer)(_reducers.treePathReducer, {}), 2), treePath = _useReducer2[0], dispatchTreePath = _useReducer2[1];
297
304
  var isCurrentListOpen = Boolean(path[0]);
298
305
  var activeDescendantItemValue = ((_getItemByFocused = (0, _useKeyboardNavigation.getItemByFocused)(focusedPath, focusedToValueMap)) === null || _getItemByFocused === void 0 ? void 0 : _getItemByFocused.value) || '';
299
306
  var withArrowInverse = isCurrentListOpen ? _Comboboxtokens.classes.arrowInverse : undefined;
300
307
  var closeAfterSelect = outerCloseAfterSelect !== null && outerCloseAfterSelect !== void 0 ? outerCloseAfterSelect : !multiple;
308
+ var setTextValue = function(newTextValue) {
309
+ setTextValueState(newTextValue);
310
+ if (onChangeValue) {
311
+ onChangeValue(newTextValue);
312
+ }
313
+ };
301
314
  /* Логика работы при клике за пределами выпадающего списка */ (0, _hooks.useOutsideClick)(function() {
302
315
  if (!isCurrentListOpen || alwaysOpened) {
303
316
  return;
304
317
  }
305
318
  handleListToggle(false);
306
- // Возвращаем актуальное значение поля ввода после закрытия выпадающего списка.
307
- setTextValue((0, _utils2.getTextValue)(multiple, value, valueToItemMap, renderValue));
308
319
  }, [
309
320
  floatingPopoverRef,
310
321
  listWrapperRef
@@ -354,11 +365,14 @@ var comboboxRoot = function(Root) {
354
365
  onChange(value.filter(function(val) {
355
366
  var _valueToItemMap_get;
356
367
  return valueToItemMap === null || valueToItemMap === void 0 ? void 0 : (_valueToItemMap_get = valueToItemMap.get(val)) === null || _valueToItemMap_get === void 0 ? void 0 : _valueToItemMap_get.disabled;
357
- }));
368
+ }), null);
358
369
  } else {
359
370
  onChange(value.filter(function(val) {
360
371
  return val !== chip.value;
361
- }), valueToItemMap.get(chip.value) || null);
372
+ }), valueToItemMap.get(chip.value) || {
373
+ value: chip.value,
374
+ label: chip.label
375
+ });
362
376
  }
363
377
  };
364
378
  // Обработчик открытия/закрытия выпадающего списка
@@ -378,6 +392,11 @@ var comboboxRoot = function(Root) {
378
392
  dispatchPath({
379
393
  type: 'reset'
380
394
  });
395
+ dispatchTreePath({
396
+ type: 'reset'
397
+ });
398
+ // Возвращаем актуальное значение поля ввода после закрытия выпадающего списка.
399
+ setTextValue((0, _utils2.getTextValue)(multiple, value, valueToItemMap, renderValue));
381
400
  // Скроллим чипы к левому краю при закрытии компонента
382
401
  var el = rootRef === null || rootRef === void 0 ? void 0 : (_rootRef_current = rootRef.current) === null || _rootRef_current === void 0 ? void 0 : _rootRef_current.querySelector('.input-scrollable-wrapper');
383
402
  if (multiple && value.length > 0 && el) {
@@ -441,6 +460,9 @@ var comboboxRoot = function(Root) {
441
460
  dispatchFocusedPath({
442
461
  type: 'reset'
443
462
  });
463
+ dispatchTreePath({
464
+ type: 'reset'
465
+ });
444
466
  }
445
467
  if (onChange) {
446
468
  onChange(newValues, item);
@@ -466,6 +488,9 @@ var comboboxRoot = function(Root) {
466
488
  dispatchFocusedPath({
467
489
  type: 'reset'
468
490
  });
491
+ dispatchTreePath({
492
+ type: 'reset'
493
+ });
469
494
  }
470
495
  // Закрываем список, если элемент уже выбран.
471
496
  if (mode === 'radio' && isCurrentChecked) {
@@ -534,7 +559,12 @@ var comboboxRoot = function(Root) {
534
559
  multiple: multiple,
535
560
  value: value,
536
561
  textValue: textValue,
537
- valueToItemMap: valueToItemMap
562
+ valueToItemMap: valueToItemMap,
563
+ treePath: treePath,
564
+ dispatchTreePath: dispatchTreePath,
565
+ treeView: treeView,
566
+ valueToPathMap: valueToPathMap,
567
+ items: filteredItems
538
568
  }).onKeyDown;
539
569
  // В данном эффекте мы следим за изменениями value снаружи и вносим коррективы в дерево чекбоксов.
540
570
  // Пример: когда юзер очистил value извне, тогда нужно пройтись по элементам и выключить все чекбоксы.
@@ -596,6 +626,30 @@ var comboboxRoot = function(Root) {
596
626
  }, [
597
627
  defaultValue
598
628
  ]);
629
+ // Эффект для раскрытия дерева при поиске.
630
+ (0, _react.useLayoutEffect)(function() {
631
+ if (treeView) {
632
+ // Если поле ввода стало пустым или если пользователь выбирает элемент,
633
+ // то скрываем все узлы дерева и выходим из эффекта.
634
+ if (textValue === '' || textValue === (0, _utils2.getTextValue)(multiple, value, valueToItemMap, renderValue)) {
635
+ dispatchTreePath({
636
+ type: 'reset'
637
+ });
638
+ return;
639
+ }
640
+ // Иначе раскрываем все узлы, когда пользователь начинает вводить текст в поле ввода.
641
+ dispatchTreePath({
642
+ type: 'expand_by_key',
643
+ value: {
644
+ filteredItems: filteredItems,
645
+ filterCb: filterCb,
646
+ textValue: textValue
647
+ }
648
+ });
649
+ }
650
+ }, [
651
+ textValue
652
+ ]);
599
653
  return /*#__PURE__*/ _react.default.createElement(Root, {
600
654
  size: size,
601
655
  view: view,
@@ -628,7 +682,11 @@ var comboboxRoot = function(Root) {
628
682
  // eslint-disable-next-line @typescript-eslint/ban-ts-comment
629
683
  // @ts-ignore
630
684
  // eslint-disable-next-line no-underscore-dangle
631
- _checkboxAppearance: rest._checkboxAppearance
685
+ _checkboxAppearance: rest._checkboxAppearance,
686
+ treePath: treePath,
687
+ dispatchTreePath: dispatchTreePath,
688
+ arrowPlacement: arrowPlacement,
689
+ valueToPathMap: valueToPathMap
632
690
  }
633
691
  }, /*#__PURE__*/ _react.default.createElement(_FloatingPopover.FloatingPopover, {
634
692
  ref: floatingPopoverRef,
@@ -694,7 +752,18 @@ var comboboxRoot = function(Root) {
694
752
  disabled: disabled,
695
753
  readOnly: readOnly,
696
754
  name: name
697
- }, /*#__PURE__*/ _react.default.createElement(_Comboboxstyles.ListWrapper, {
755
+ }, (0, _utils.isEmpty)(filteredItems) ? /*#__PURE__*/ _react.default.createElement(_Comboboxstyles.StyledEmptyState, {
756
+ className: _Comboboxtokens.classes.emptyStateWrapper,
757
+ size: size,
758
+ description: emptyStateDescription || 'Ничего не найдено'
759
+ }) : /*#__PURE__*/ _react.default.createElement(_react.default.Fragment, null, treeView ? /*#__PURE__*/ _react.default.createElement(_ui.TreeList, {
760
+ items: filteredItems,
761
+ listMaxHeight: listMaxHeight || listHeight,
762
+ onScroll: virtual ? undefined : onScroll,
763
+ virtual: virtual,
764
+ beforeList: beforeList,
765
+ afterList: afterList
766
+ }) : /*#__PURE__*/ _react.default.createElement(_Comboboxstyles.ListWrapper, {
698
767
  ref: listWrapperRef,
699
768
  listWidth: listWidth
700
769
  }, /*#__PURE__*/ _react.default.createElement(_Comboboxstyles.Ul, {
@@ -704,11 +773,7 @@ var comboboxRoot = function(Root) {
704
773
  listMaxHeight: listMaxHeight || listHeight,
705
774
  virtual: virtual,
706
775
  onScroll: virtual ? undefined : onScroll
707
- }, beforeList, (0, _utils.isEmpty)(filteredItems) ? /*#__PURE__*/ _react.default.createElement(_Comboboxstyles.StyledEmptyState, {
708
- className: _Comboboxtokens.classes.emptyStateWrapper,
709
- size: size,
710
- description: emptyStateDescription || 'Ничего не найдено'
711
- }) : /*#__PURE__*/ _react.default.createElement(_react.default.Fragment, null, props.multiple && props.selectAllOptions && // TODO: #2004
776
+ }, beforeList, props.multiple && props.selectAllOptions && // TODO: #2004
712
777
  /*#__PURE__*/ _react.default.createElement(_ui.SelectAll, {
713
778
  selectAllOptions: props.selectAllOptions,
714
779
  variant: variant
@@ -727,7 +792,7 @@ var comboboxRoot = function(Root) {
727
792
  listWidth: listWidth,
728
793
  portal: listWrapperRef
729
794
  });
730
- })), afterList)))))));
795
+ }), afterList))))))));
731
796
  });
732
797
  };
733
798
  var comboboxConfig = {
@@ -54,6 +54,8 @@ var tokens = {
54
54
  itemIconMargin: '--plasma-combobox-item-icon-margin',
55
55
  itemBackgroundHover: '--plasma-combobox-item-background-hover',
56
56
  itemIconColor: '--plasma-combobox-item-icon-color',
57
+ itemGap: '--plasma-select-item-gap',
58
+ itemTreeOffsetWidth: '--plasma-select-item-tree-offset-width',
57
59
  cellPadding: '--plasma-combobox-cell-padding',
58
60
  cellPaddingLeftContent: '--plasma-combobox-cell-padding-left-content',
59
61
  cellPaddingContent: '--plasma-combobox-cell-padding-content',
@@ -17,6 +17,31 @@ _export(exports, {
17
17
  }
18
18
  });
19
19
  var _utils = require("../../../../utils");
20
+ function _array_like_to_array(arr, len) {
21
+ if (len == null || len > arr.length) len = arr.length;
22
+ for(var i = 0, arr2 = new Array(len); i < len; i++)arr2[i] = arr[i];
23
+ return arr2;
24
+ }
25
+ function _array_without_holes(arr) {
26
+ if (Array.isArray(arr)) return _array_like_to_array(arr);
27
+ }
28
+ function _iterable_to_array(iter) {
29
+ if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter);
30
+ }
31
+ function _non_iterable_spread() {
32
+ throw new TypeError("Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
33
+ }
34
+ function _to_consumable_array(arr) {
35
+ return _array_without_holes(arr) || _iterable_to_array(arr) || _unsupported_iterable_to_array(arr) || _non_iterable_spread();
36
+ }
37
+ function _unsupported_iterable_to_array(o, minLen) {
38
+ if (!o) return;
39
+ if (typeof o === "string") return _array_like_to_array(o, minLen);
40
+ var n = Object.prototype.toString.call(o).slice(8, -1);
41
+ if (n === "Object" && o.constructor) n = o.constructor.name;
42
+ if (n === "Map" || n === "Set") return Array.from(n);
43
+ if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _array_like_to_array(o, minLen);
44
+ }
20
45
  var getPathMap = function(items) {
21
46
  var pathMap = new Map();
22
47
  var focusedToValueMap = new Map();
@@ -42,22 +67,29 @@ var getPathMap = function(items) {
42
67
  var getTreeMaps = function(items) {
43
68
  var valueToCheckedMap = new Map();
44
69
  var valueToItemMap = new Map();
70
+ var valueToPathMap = new Map();
45
71
  var rec = function(items) {
46
- var prevIndex = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : '';
72
+ var prevIndex = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : '', path = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : [];
47
73
  items === null || items === void 0 ? void 0 : items.forEach(function(item, index) {
48
74
  var value = item.value, innerItems = item.items;
49
75
  var currIndex = "".concat(prevIndex, "/").concat(index).replace(/^(\/)/, '');
50
76
  valueToCheckedMap.set(value, false);
77
+ valueToPathMap.set(value.toString(), _to_consumable_array(path).concat([
78
+ value.toString()
79
+ ]));
51
80
  if ((0, _utils.isEmpty)(innerItems) || !innerItems) {
52
81
  valueToItemMap.set(value, item);
53
82
  } else {
54
- rec(innerItems, currIndex);
83
+ rec(innerItems, currIndex, _to_consumable_array(path).concat([
84
+ value.toString()
85
+ ]));
55
86
  }
56
87
  });
57
88
  };
58
89
  rec(items);
59
90
  return [
60
91
  valueToCheckedMap,
61
- valueToItemMap
92
+ valueToItemMap,
93
+ valueToPathMap
62
94
  ];
63
95
  };
@@ -20,6 +20,32 @@ _export(exports, {
20
20
  }
21
21
  });
22
22
  var _utils = require("../../../../utils");
23
+ var _reducers = require("../../../Select/reducers");
24
+ function _array_like_to_array(arr, len) {
25
+ if (len == null || len > arr.length) len = arr.length;
26
+ for(var i = 0, arr2 = new Array(len); i < len; i++)arr2[i] = arr[i];
27
+ return arr2;
28
+ }
29
+ function _array_without_holes(arr) {
30
+ if (Array.isArray(arr)) return _array_like_to_array(arr);
31
+ }
32
+ function _iterable_to_array(iter) {
33
+ if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter);
34
+ }
35
+ function _non_iterable_spread() {
36
+ throw new TypeError("Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
37
+ }
38
+ function _to_consumable_array(arr) {
39
+ return _array_without_holes(arr) || _iterable_to_array(arr) || _unsupported_iterable_to_array(arr) || _non_iterable_spread();
40
+ }
41
+ function _unsupported_iterable_to_array(o, minLen) {
42
+ if (!o) return;
43
+ if (typeof o === "string") return _array_like_to_array(o, minLen);
44
+ var n = Object.prototype.toString.call(o).slice(8, -1);
45
+ if (n === "Object" && o.constructor) n = o.constructor.name;
46
+ if (n === "Map" || n === "Set") return Array.from(n);
47
+ if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _array_like_to_array(o, minLen);
48
+ }
23
49
  var JUMP_SIZE = 10;
24
50
  var keys = {
25
51
  Enter: 'Enter',
@@ -43,6 +69,51 @@ var getItemByFocused = function(focusedPath, focusedToValueMap) {
43
69
  return focusedToValueMap.get(focusedPathAsString);
44
70
  };
45
71
  var useKeyNavigation = function(param) {
72
+ var focusedPath = param.focusedPath, dispatchFocusedPath = param.dispatchFocusedPath, path = param.path, dispatchPath = param.dispatchPath, pathMap = param.pathMap, focusedToValueMap = param.focusedToValueMap, handleListToggle = param.handleListToggle, handlePressDown = param.handlePressDown, setTextValue = param.setTextValue, multiple = param.multiple, value = param.value, textValue = param.textValue, valueToItemMap = param.valueToItemMap, treePath = param.treePath, dispatchTreePath = param.dispatchTreePath, treeView = param.treeView, valueToPathMap = param.valueToPathMap, items = param.items;
73
+ if (treeView) {
74
+ return keyboardNavigationTree({
75
+ focusedPath: focusedPath,
76
+ dispatchFocusedPath: dispatchFocusedPath,
77
+ path: path,
78
+ dispatchPath: dispatchPath,
79
+ pathMap: pathMap,
80
+ focusedToValueMap: focusedToValueMap,
81
+ handleListToggle: handleListToggle,
82
+ handlePressDown: handlePressDown,
83
+ setTextValue: setTextValue,
84
+ multiple: multiple,
85
+ value: value,
86
+ textValue: textValue,
87
+ valueToItemMap: valueToItemMap,
88
+ treePath: treePath,
89
+ dispatchTreePath: dispatchTreePath,
90
+ treeView: treeView,
91
+ valueToPathMap: valueToPathMap,
92
+ items: items
93
+ });
94
+ }
95
+ return keyboardNavigationDefault({
96
+ focusedPath: focusedPath,
97
+ dispatchFocusedPath: dispatchFocusedPath,
98
+ path: path,
99
+ dispatchPath: dispatchPath,
100
+ pathMap: pathMap,
101
+ focusedToValueMap: focusedToValueMap,
102
+ handleListToggle: handleListToggle,
103
+ handlePressDown: handlePressDown,
104
+ setTextValue: setTextValue,
105
+ multiple: multiple,
106
+ value: value,
107
+ textValue: textValue,
108
+ valueToItemMap: valueToItemMap,
109
+ treePath: treePath,
110
+ dispatchTreePath: dispatchTreePath,
111
+ treeView: treeView,
112
+ valueToPathMap: valueToPathMap,
113
+ items: items
114
+ });
115
+ };
116
+ var keyboardNavigationDefault = function(param) {
46
117
  var focusedPath = param.focusedPath, dispatchFocusedPath = param.dispatchFocusedPath, path = param.path, dispatchPath = param.dispatchPath, pathMap = param.pathMap, focusedToValueMap = param.focusedToValueMap, handleListToggle = param.handleListToggle, handlePressDown = param.handlePressDown, setTextValue = param.setTextValue, multiple = param.multiple, value = param.value, textValue = param.textValue, valueToItemMap = param.valueToItemMap;
47
118
  var currentIndex = (focusedPath === null || focusedPath === void 0 ? void 0 : focusedPath[focusedPath.length - 1]) || 0;
48
119
  var currentLength = pathMap.get(path === null || path === void 0 ? void 0 : path[focusedPath.length - 1]) || 0;
@@ -301,3 +372,244 @@ var useKeyNavigation = function(param) {
301
372
  onKeyDown: onKeyDown
302
373
  };
303
374
  };
375
+ var keyboardNavigationTree = function(param) {
376
+ var focusedPath = param.focusedPath, dispatchFocusedPath = param.dispatchFocusedPath, path = param.path, dispatchPath = param.dispatchPath, pathMap = param.pathMap, focusedToValueMap = param.focusedToValueMap, handleListToggle = param.handleListToggle, handlePressDown = param.handlePressDown, setTextValue = param.setTextValue, multiple = param.multiple, value = param.value, textValue = param.textValue, valueToItemMap = param.valueToItemMap, treePath = param.treePath, dispatchTreePath = param.dispatchTreePath, valueToPathMap = param.valueToPathMap, items = param.items;
377
+ var _currentItem_parent_items, _currentItem_parent;
378
+ var currentItem = getItemByFocused(focusedPath, focusedToValueMap);
379
+ var currentIndex = (focusedPath === null || focusedPath === void 0 ? void 0 : focusedPath[focusedPath.length - 1]) || 0;
380
+ var currentLength = (currentItem === null || currentItem === void 0 ? void 0 : (_currentItem_parent = currentItem.parent) === null || _currentItem_parent === void 0 ? void 0 : (_currentItem_parent_items = _currentItem_parent.items) === null || _currentItem_parent_items === void 0 ? void 0 : _currentItem_parent_items.length) || pathMap.get('root') || 0;
381
+ var isValidFocus = function(focusCandidate) {
382
+ if (!Array.isArray(items) || !Array.isArray(focusCandidate)) return false;
383
+ var currentLevel = items;
384
+ var _iteratorNormalCompletion = true, _didIteratorError = false, _iteratorError = undefined;
385
+ try {
386
+ for(var _iterator = focusCandidate[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true){
387
+ var index = _step.value;
388
+ if (!Array.isArray(currentLevel) || index >= currentLevel.length) {
389
+ return false;
390
+ }
391
+ var node = currentLevel[index];
392
+ currentLevel = node.items || [];
393
+ }
394
+ } catch (err) {
395
+ _didIteratorError = true;
396
+ _iteratorError = err;
397
+ } finally{
398
+ try {
399
+ if (!_iteratorNormalCompletion && _iterator.return != null) {
400
+ _iterator.return();
401
+ }
402
+ } finally{
403
+ if (_didIteratorError) {
404
+ throw _iteratorError;
405
+ }
406
+ }
407
+ }
408
+ return true;
409
+ };
410
+ var onKeyDown = function(event) {
411
+ switch(event.code){
412
+ case keys.ArrowUp:
413
+ {
414
+ if (path[0]) {
415
+ event.stopPropagation();
416
+ event.preventDefault();
417
+ }
418
+ /**
419
+ * Если список открыт и фокус уже установлен на каком-либо элементе.
420
+ * */ if (focusedPath.length) {
421
+ /**
422
+ * Если это не первый элемент, то нужно вначале найти элемент для фокуса.
423
+ * Т.к. если верхний элемент раскрыт, то и перемещаться нужно не на него,
424
+ * а на его самый нижний дочерний элемент.
425
+ * */ if (currentIndex > 0) {
426
+ var nextFocus = _to_consumable_array(focusedPath.slice(0, -1)).concat([
427
+ currentIndex - 1
428
+ ]);
429
+ for(var i = 0; i <= focusedPath.length; i++){
430
+ var focusedPathAsString = nextFocus.reduce(function(acc, n) {
431
+ return "".concat(acc, "/").concat(n);
432
+ }, '').replace(/^(\/)/, '');
433
+ var item = focusedToValueMap.get(focusedPathAsString);
434
+ var isLevelOpened = (0, _reducers.keyExists)(treePath, valueToPathMap.get(item === null || item === void 0 ? void 0 : item.value.toString()) || []);
435
+ if (isLevelOpened) {
436
+ var _item_items;
437
+ nextFocus = _to_consumable_array(nextFocus).concat([
438
+ ((item === null || item === void 0 ? void 0 : (_item_items = item.items) === null || _item_items === void 0 ? void 0 : _item_items.length) || 0) - 1
439
+ ]);
440
+ } else {
441
+ break;
442
+ }
443
+ }
444
+ dispatchFocusedPath({
445
+ type: 'set_focus',
446
+ value: nextFocus
447
+ });
448
+ } else {
449
+ /**
450
+ * Если элемент первый, то нужно лишь подняться к его родителю.
451
+ * */ dispatchFocusedPath({
452
+ type: 'return_prev_focus'
453
+ });
454
+ }
455
+ } else {
456
+ /**
457
+ * Если список закрыт, то нужно его открыть и установить фокус на первый элемент.
458
+ * */ dispatchPath({
459
+ type: 'opened_first_level'
460
+ });
461
+ dispatchFocusedPath({
462
+ type: 'set_initial_focus'
463
+ });
464
+ handleListToggle(true);
465
+ }
466
+ break;
467
+ }
468
+ case keys.ArrowDown:
469
+ {
470
+ if (path[0]) {
471
+ event.stopPropagation();
472
+ event.preventDefault();
473
+ }
474
+ /**
475
+ * Если список открыт и фокус уже установлен на каком-либо элементе.
476
+ * */ if (focusedPath.length) {
477
+ /**
478
+ * Заходим сюда если у элемента есть другие вложенные элементы.
479
+ * */ if ((currentItem === null || currentItem === void 0 ? void 0 : currentItem.items) && (currentItem === null || currentItem === void 0 ? void 0 : currentItem.items.length)) {
480
+ var isCurrentLevelOpened = (0, _reducers.keyExists)(treePath, valueToPathMap.get(currentItem.value.toString()) || []);
481
+ /**
482
+ * Если у этого элемента открыт его дочерний список,
483
+ * то устанавливаем фокус на первый элемент из этого списка
484
+ * и сразу же выходим из обработчика события.
485
+ * */ if (isCurrentLevelOpened) {
486
+ dispatchFocusedPath({
487
+ type: 'add_focus',
488
+ value: 0
489
+ });
490
+ break;
491
+ }
492
+ }
493
+ /**
494
+ * Если мы еще не достигли конца списка, то движемся к следующему элементу.
495
+ * */ if (currentIndex + 1 < currentLength) {
496
+ dispatchFocusedPath({
497
+ type: 'change_last_focus',
498
+ value: currentIndex + 1
499
+ });
500
+ } else {
501
+ /**
502
+ * Если же достигли последнего элемента на текущем уровне, то нужно определить,
503
+ * на какой из элементов ниже мы перейдем.
504
+ * Переход фокуса отсюда может быть только на уровни выше, при чем сразу на несколько.
505
+ * */ var focusCandidate = _to_consumable_array(focusedPath);
506
+ var nextFocus1 = null;
507
+ while(focusCandidate.length > 1){
508
+ focusCandidate = _to_consumable_array(focusCandidate.slice(0, -2)).concat([
509
+ (focusCandidate.at(-2) || 0) + 1
510
+ ]);
511
+ if (isValidFocus(focusCandidate)) {
512
+ nextFocus1 = focusCandidate;
513
+ break;
514
+ }
515
+ }
516
+ if (nextFocus1) {
517
+ dispatchFocusedPath({
518
+ type: 'set_focus',
519
+ value: nextFocus1
520
+ });
521
+ } else {
522
+ break;
523
+ }
524
+ }
525
+ } else {
526
+ /**
527
+ * Если список закрыт, то нужно его открыть и установить фокус на первый элемент.
528
+ * */ dispatchPath({
529
+ type: 'opened_first_level'
530
+ });
531
+ dispatchFocusedPath({
532
+ type: 'set_initial_focus'
533
+ });
534
+ handleListToggle(true);
535
+ }
536
+ break;
537
+ }
538
+ case keys.ArrowLeft:
539
+ {
540
+ if (path[0]) {
541
+ event.stopPropagation();
542
+ event.preventDefault();
543
+ if (focusedPath.length) {
544
+ dispatchTreePath({
545
+ type: 'close_level',
546
+ value: valueToPathMap.get((currentItem === null || currentItem === void 0 ? void 0 : currentItem.value.toString()) || '') || []
547
+ });
548
+ }
549
+ }
550
+ break;
551
+ }
552
+ case keys.ArrowRight:
553
+ {
554
+ if (path[0]) {
555
+ event.stopPropagation();
556
+ event.preventDefault();
557
+ if (!focusedPath.length || (currentItem === null || currentItem === void 0 ? void 0 : currentItem.disabled) || !(currentItem === null || currentItem === void 0 ? void 0 : currentItem.items)) {
558
+ break;
559
+ }
560
+ dispatchTreePath({
561
+ type: 'open_level',
562
+ value: valueToPathMap.get(currentItem.value.toString()) || []
563
+ });
564
+ }
565
+ break;
566
+ }
567
+ case keys.Enter:
568
+ {
569
+ event.preventDefault();
570
+ if (!currentItem || (currentItem === null || currentItem === void 0 ? void 0 : currentItem.disabled)) {
571
+ break;
572
+ }
573
+ if (!path[0]) {
574
+ dispatchPath({
575
+ type: 'opened_first_level'
576
+ });
577
+ dispatchFocusedPath({
578
+ type: 'set_initial_focus'
579
+ });
580
+ break;
581
+ }
582
+ handlePressDown(currentItem);
583
+ break;
584
+ }
585
+ case keys.Tab:
586
+ case keys.Escape:
587
+ {
588
+ if (path[0]) {
589
+ handleListToggle(false);
590
+ }
591
+ if (multiple) {
592
+ setTextValue('');
593
+ } else if (textValue !== value) {
594
+ // Проверяем, отличается ли значение в инпуте от выбранного value после нажатия Tab/Enter.
595
+ // Если изменилось, то возвращаем label выбранного айтема.
596
+ // Если нет выбранного элемента, то стираем значение инпута.
597
+ if ((0, _utils.isEmpty)(value)) {
598
+ setTextValue('');
599
+ } else {
600
+ var _valueToItemMap_get;
601
+ setTextValue(((_valueToItemMap_get = valueToItemMap.get(value)) === null || _valueToItemMap_get === void 0 ? void 0 : _valueToItemMap_get.label) || '');
602
+ }
603
+ }
604
+ break;
605
+ }
606
+ default:
607
+ {
608
+ break;
609
+ }
610
+ }
611
+ };
612
+ return {
613
+ onKeyDown: onKeyDown
614
+ };
615
+ };
@@ -39,6 +39,10 @@ function focusedPathReducer(state, action) {
39
39
  {
40
40
  return [];
41
41
  }
42
+ case 'set_focus':
43
+ {
44
+ return action.value;
45
+ }
42
46
  case 'set_initial_focus':
43
47
  {
44
48
  return [
@@ -59,6 +63,9 @@ function focusedPathReducer(state, action) {
59
63
  }
60
64
  case 'return_prev_focus':
61
65
  {
66
+ if (state.length === 1) {
67
+ return state;
68
+ }
62
69
  return state.slice(0, -1);
63
70
  }
64
71
  default:
@@ -4,6 +4,7 @@ Object.defineProperty(exports, "__esModule", {
4
4
  });
5
5
  _export_star(require("./pathReducer"), exports);
6
6
  _export_star(require("./focusedPathReducer"), exports);
7
+ _export_star(require("./treePathReducer"), exports);
7
8
  function _export_star(from, to) {
8
9
  Object.keys(from).forEach(function(k) {
9
10
  if (k !== "default" && !Object.prototype.hasOwnProperty.call(to, k)) {