@salutejs/plasma-new-hope 0.335.0-dev.0 → 0.335.1-canary.2202.17587528278.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 (241) hide show
  1. package/cjs/components/Combobox/ComboboxNew/Combobox.css +6 -6
  2. package/cjs/components/Combobox/ComboboxNew/Combobox.js +30 -24
  3. package/cjs/components/Combobox/ComboboxNew/Combobox.js.map +1 -1
  4. package/cjs/components/Combobox/ComboboxNew/Combobox.styles.js +3 -4
  5. package/cjs/components/Combobox/ComboboxNew/Combobox.styles.js.map +1 -1
  6. package/cjs/components/Combobox/ComboboxNew/{Combobox.styles_isfa46.css → Combobox.styles_261unw.css} +1 -1
  7. package/cjs/components/Combobox/ComboboxNew/Combobox.tokens.js +1 -1
  8. package/cjs/components/Combobox/ComboboxNew/Combobox.tokens.js.map +1 -1
  9. package/cjs/components/Combobox/ComboboxNew/hooks/useKeyboardNavigation.js +3 -7
  10. package/cjs/components/Combobox/ComboboxNew/hooks/useKeyboardNavigation.js.map +1 -1
  11. package/cjs/components/Combobox/ComboboxNew/ui/Inner/Inner.css +6 -6
  12. package/cjs/components/Combobox/ComboboxNew/ui/Inner/Inner.js +11 -5
  13. package/cjs/components/Combobox/ComboboxNew/ui/Inner/Inner.js.map +1 -1
  14. package/cjs/components/Combobox/ComboboxOld/Combobox.css +2 -2
  15. package/cjs/components/Combobox/ComboboxOld/ui/ComboboxDivider/ComboboxDivider.css +2 -2
  16. package/cjs/components/Combobox/ComboboxOld/ui/ComboboxFooter/ComboboxFooter.css +2 -2
  17. package/cjs/components/Combobox/ComboboxOld/ui/ComboboxGroup/ComboboxGroup.css +2 -2
  18. package/cjs/components/Combobox/ComboboxOld/ui/ComboboxHeader/ComboboxHeader.css +2 -2
  19. package/cjs/components/Drawer/hooks/useDrawer.js +12 -0
  20. package/cjs/components/Drawer/hooks/useDrawer.js.map +1 -1
  21. package/cjs/components/Dropdown/Dropdown.css +2 -2
  22. package/cjs/components/Dropdown/Dropdown.js +6 -10
  23. package/cjs/components/Dropdown/Dropdown.js.map +1 -1
  24. package/cjs/components/Dropdown/Dropdown.styles.js +2 -9
  25. package/cjs/components/Dropdown/Dropdown.styles.js.map +1 -1
  26. package/{es/components/Dropdown/Dropdown.styles_zheit5.css → cjs/components/Dropdown/Dropdown.styles_kkvnr1.css} +1 -1
  27. package/cjs/components/Dropdown/FloatingPopover.js +22 -40
  28. package/cjs/components/Dropdown/FloatingPopover.js.map +1 -1
  29. package/cjs/components/Dropdown/hooks/useKeyboardNavigation.js +3 -7
  30. package/cjs/components/Dropdown/hooks/useKeyboardNavigation.js.map +1 -1
  31. package/cjs/components/Dropdown/ui/DropdownInner/DropdownInner.css +2 -2
  32. package/cjs/components/Dropdown/ui/DropdownInner/DropdownInner.js +9 -9
  33. package/cjs/components/Dropdown/ui/DropdownInner/DropdownInner.js.map +1 -1
  34. package/cjs/components/Dropdown/ui/DropdownItem/DropdownItem.js +1 -1
  35. package/cjs/components/Dropdown/ui/DropdownItem/DropdownItem.js.map +1 -1
  36. package/cjs/components/Pagination/Pagination.css +2 -2
  37. package/cjs/components/Pagination/Pagination.js +2 -1
  38. package/cjs/components/Pagination/Pagination.js.map +1 -1
  39. package/cjs/components/Pagination/ui/PaginationSelectPerPage/PaginationSelectPerPage.css +2 -2
  40. package/cjs/components/Select/Select.css +2 -2
  41. package/cjs/components/Select/Select.js +12 -4
  42. package/cjs/components/Select/Select.js.map +1 -1
  43. package/cjs/components/Select/Select.styles.js +3 -4
  44. package/cjs/components/Select/Select.styles.js.map +1 -1
  45. package/cjs/components/Select/{Select.styles_bjoo18.css → Select.styles_dta4dl.css} +1 -1
  46. package/cjs/components/Select/hooks/useKeyboardNavigation.js +3 -7
  47. package/cjs/components/Select/hooks/useKeyboardNavigation.js.map +1 -1
  48. package/cjs/components/Select/ui/Inner/Inner.css +2 -2
  49. package/cjs/components/Select/ui/Inner/Inner.js +11 -5
  50. package/cjs/components/Select/ui/Inner/Inner.js.map +1 -1
  51. package/cjs/components/Table/Table.css +2 -2
  52. package/cjs/components/Table/ui/Cell/Cell.css +2 -2
  53. package/cjs/components/Table/ui/EditableCell/EditableCell.css +2 -2
  54. package/cjs/components/Table/ui/HeadCell/HeadCell.css +2 -2
  55. package/cjs/components/Table/ui/HeadCell/ui/Filter/Filter.css +2 -2
  56. package/cjs/engines/common.js +11 -1
  57. package/cjs/engines/common.js.map +1 -1
  58. package/cjs/index.css +10 -10
  59. package/emotion/cjs/components/Combobox/ComboboxNew/Combobox.js +26 -23
  60. package/emotion/cjs/components/Combobox/ComboboxNew/Combobox.styles.js +16 -16
  61. package/emotion/cjs/components/Combobox/ComboboxNew/Combobox.tokens.js +1 -1
  62. package/emotion/cjs/components/Combobox/ComboboxNew/hooks/useKeyboardNavigation.js +3 -7
  63. package/emotion/cjs/components/Combobox/ComboboxNew/ui/Inner/Inner.js +50 -9
  64. package/emotion/cjs/components/Drawer/hooks/useDrawer.js +11 -0
  65. package/emotion/cjs/components/Dropdown/Dropdown.js +6 -10
  66. package/emotion/cjs/components/Dropdown/Dropdown.styles.js +5 -8
  67. package/emotion/cjs/components/Dropdown/FloatingPopover.js +23 -47
  68. package/emotion/cjs/components/Dropdown/hooks/useKeyboardNavigation.js +3 -7
  69. package/emotion/cjs/components/Dropdown/ui/DropdownInner/DropdownInner.js +48 -11
  70. package/emotion/cjs/components/Dropdown/ui/DropdownItem/DropdownItem.js +1 -1
  71. package/emotion/cjs/components/Pagination/Pagination.js +1 -1
  72. package/emotion/cjs/components/Select/Select.js +10 -3
  73. package/emotion/cjs/components/Select/Select.styles.js +8 -8
  74. package/emotion/cjs/components/Select/hooks/useKeyboardNavigation.js +3 -7
  75. package/emotion/cjs/components/Select/ui/Inner/Inner.js +50 -9
  76. package/emotion/cjs/engines/common.js +14 -1
  77. package/emotion/es/components/Combobox/ComboboxNew/Combobox.js +26 -23
  78. package/emotion/es/components/Combobox/ComboboxNew/Combobox.styles.js +16 -16
  79. package/emotion/es/components/Combobox/ComboboxNew/Combobox.tokens.js +1 -1
  80. package/emotion/es/components/Combobox/ComboboxNew/hooks/useKeyboardNavigation.js +3 -7
  81. package/emotion/es/components/Combobox/ComboboxNew/ui/Inner/Inner.js +11 -6
  82. package/emotion/es/components/Drawer/hooks/useDrawer.js +11 -0
  83. package/emotion/es/components/Dropdown/Dropdown.js +6 -10
  84. package/emotion/es/components/Dropdown/Dropdown.styles.js +5 -8
  85. package/emotion/es/components/Dropdown/FloatingPopover.js +24 -48
  86. package/emotion/es/components/Dropdown/hooks/useKeyboardNavigation.js +3 -7
  87. package/emotion/es/components/Dropdown/ui/DropdownInner/DropdownInner.js +9 -8
  88. package/emotion/es/components/Dropdown/ui/DropdownItem/DropdownItem.js +1 -1
  89. package/emotion/es/components/Pagination/Pagination.js +1 -1
  90. package/emotion/es/components/Select/Select.js +10 -3
  91. package/emotion/es/components/Select/Select.styles.js +8 -8
  92. package/emotion/es/components/Select/hooks/useKeyboardNavigation.js +3 -7
  93. package/emotion/es/components/Select/ui/Inner/Inner.js +11 -6
  94. package/emotion/es/engines/common.js +14 -1
  95. package/emotion/es/examples/components/Combobox/Combobox.js +0 -7
  96. package/es/components/Combobox/ComboboxNew/Combobox.css +6 -6
  97. package/es/components/Combobox/ComboboxNew/Combobox.js +30 -24
  98. package/es/components/Combobox/ComboboxNew/Combobox.js.map +1 -1
  99. package/es/components/Combobox/ComboboxNew/Combobox.styles.js +3 -4
  100. package/es/components/Combobox/ComboboxNew/Combobox.styles.js.map +1 -1
  101. package/es/components/Combobox/ComboboxNew/{Combobox.styles_isfa46.css → Combobox.styles_261unw.css} +1 -1
  102. package/es/components/Combobox/ComboboxNew/Combobox.tokens.js +1 -1
  103. package/es/components/Combobox/ComboboxNew/Combobox.tokens.js.map +1 -1
  104. package/es/components/Combobox/ComboboxNew/hooks/useKeyboardNavigation.js +3 -7
  105. package/es/components/Combobox/ComboboxNew/hooks/useKeyboardNavigation.js.map +1 -1
  106. package/es/components/Combobox/ComboboxNew/ui/Inner/Inner.css +6 -6
  107. package/es/components/Combobox/ComboboxNew/ui/Inner/Inner.js +12 -6
  108. package/es/components/Combobox/ComboboxNew/ui/Inner/Inner.js.map +1 -1
  109. package/es/components/Combobox/ComboboxOld/Combobox.css +2 -2
  110. package/es/components/Combobox/ComboboxOld/ui/ComboboxDivider/ComboboxDivider.css +2 -2
  111. package/es/components/Combobox/ComboboxOld/ui/ComboboxFooter/ComboboxFooter.css +2 -2
  112. package/es/components/Combobox/ComboboxOld/ui/ComboboxGroup/ComboboxGroup.css +2 -2
  113. package/es/components/Combobox/ComboboxOld/ui/ComboboxHeader/ComboboxHeader.css +2 -2
  114. package/es/components/Drawer/hooks/useDrawer.js +12 -0
  115. package/es/components/Drawer/hooks/useDrawer.js.map +1 -1
  116. package/es/components/Dropdown/Dropdown.css +2 -2
  117. package/es/components/Dropdown/Dropdown.js +6 -10
  118. package/es/components/Dropdown/Dropdown.js.map +1 -1
  119. package/es/components/Dropdown/Dropdown.styles.js +2 -9
  120. package/es/components/Dropdown/Dropdown.styles.js.map +1 -1
  121. package/{cjs/components/Dropdown/Dropdown.styles_zheit5.css → es/components/Dropdown/Dropdown.styles_kkvnr1.css} +1 -1
  122. package/es/components/Dropdown/FloatingPopover.js +24 -42
  123. package/es/components/Dropdown/FloatingPopover.js.map +1 -1
  124. package/es/components/Dropdown/hooks/useKeyboardNavigation.js +3 -7
  125. package/es/components/Dropdown/hooks/useKeyboardNavigation.js.map +1 -1
  126. package/es/components/Dropdown/ui/DropdownInner/DropdownInner.css +2 -2
  127. package/es/components/Dropdown/ui/DropdownInner/DropdownInner.js +10 -10
  128. package/es/components/Dropdown/ui/DropdownInner/DropdownInner.js.map +1 -1
  129. package/es/components/Dropdown/ui/DropdownItem/DropdownItem.js +1 -1
  130. package/es/components/Dropdown/ui/DropdownItem/DropdownItem.js.map +1 -1
  131. package/es/components/Pagination/Pagination.css +2 -2
  132. package/es/components/Pagination/Pagination.js +2 -1
  133. package/es/components/Pagination/Pagination.js.map +1 -1
  134. package/es/components/Pagination/ui/PaginationSelectPerPage/PaginationSelectPerPage.css +2 -2
  135. package/es/components/Select/Select.css +2 -2
  136. package/es/components/Select/Select.js +12 -4
  137. package/es/components/Select/Select.js.map +1 -1
  138. package/es/components/Select/Select.styles.js +3 -4
  139. package/es/components/Select/Select.styles.js.map +1 -1
  140. package/es/components/Select/{Select.styles_bjoo18.css → Select.styles_dta4dl.css} +1 -1
  141. package/es/components/Select/hooks/useKeyboardNavigation.js +3 -7
  142. package/es/components/Select/hooks/useKeyboardNavigation.js.map +1 -1
  143. package/es/components/Select/ui/Inner/Inner.css +2 -2
  144. package/es/components/Select/ui/Inner/Inner.js +12 -6
  145. package/es/components/Select/ui/Inner/Inner.js.map +1 -1
  146. package/es/components/Table/Table.css +2 -2
  147. package/es/components/Table/ui/Cell/Cell.css +2 -2
  148. package/es/components/Table/ui/EditableCell/EditableCell.css +2 -2
  149. package/es/components/Table/ui/HeadCell/HeadCell.css +2 -2
  150. package/es/components/Table/ui/HeadCell/ui/Filter/Filter.css +2 -2
  151. package/es/engines/common.js +12 -2
  152. package/es/engines/common.js.map +1 -1
  153. package/es/index.css +10 -10
  154. package/package.json +7 -7
  155. package/styled-components/cjs/components/Combobox/ComboboxNew/Combobox.js +26 -23
  156. package/styled-components/cjs/components/Combobox/ComboboxNew/Combobox.styles.js +9 -9
  157. package/styled-components/cjs/components/Combobox/ComboboxNew/Combobox.tokens.js +1 -1
  158. package/styled-components/cjs/components/Combobox/ComboboxNew/hooks/useKeyboardNavigation.js +3 -7
  159. package/styled-components/cjs/components/Combobox/ComboboxNew/ui/Inner/Inner.js +50 -9
  160. package/styled-components/cjs/components/Drawer/hooks/useDrawer.js +11 -0
  161. package/styled-components/cjs/components/Dropdown/Dropdown.js +6 -10
  162. package/styled-components/cjs/components/Dropdown/Dropdown.styles.js +3 -7
  163. package/styled-components/cjs/components/Dropdown/FloatingPopover.js +23 -47
  164. package/styled-components/cjs/components/Dropdown/hooks/useKeyboardNavigation.js +3 -7
  165. package/styled-components/cjs/components/Dropdown/ui/DropdownInner/DropdownInner.js +48 -11
  166. package/styled-components/cjs/components/Dropdown/ui/DropdownItem/DropdownItem.js +1 -1
  167. package/styled-components/cjs/components/Pagination/Pagination.js +1 -1
  168. package/styled-components/cjs/components/Select/Select.js +10 -3
  169. package/styled-components/cjs/components/Select/Select.styles.js +5 -5
  170. package/styled-components/cjs/components/Select/hooks/useKeyboardNavigation.js +3 -7
  171. package/styled-components/cjs/components/Select/ui/Inner/Inner.js +50 -9
  172. package/styled-components/cjs/engines/common.js +14 -1
  173. package/styled-components/es/components/Combobox/ComboboxNew/Combobox.js +26 -23
  174. package/styled-components/es/components/Combobox/ComboboxNew/Combobox.styles.js +9 -9
  175. package/styled-components/es/components/Combobox/ComboboxNew/Combobox.tokens.js +1 -1
  176. package/styled-components/es/components/Combobox/ComboboxNew/hooks/useKeyboardNavigation.js +3 -7
  177. package/styled-components/es/components/Combobox/ComboboxNew/ui/Inner/Inner.js +11 -6
  178. package/styled-components/es/components/Drawer/hooks/useDrawer.js +11 -0
  179. package/styled-components/es/components/Dropdown/Dropdown.js +6 -10
  180. package/styled-components/es/components/Dropdown/Dropdown.styles.js +3 -7
  181. package/styled-components/es/components/Dropdown/FloatingPopover.js +24 -48
  182. package/styled-components/es/components/Dropdown/hooks/useKeyboardNavigation.js +3 -7
  183. package/styled-components/es/components/Dropdown/ui/DropdownInner/DropdownInner.js +9 -8
  184. package/styled-components/es/components/Dropdown/ui/DropdownItem/DropdownItem.js +1 -1
  185. package/styled-components/es/components/Pagination/Pagination.js +1 -1
  186. package/styled-components/es/components/Select/Select.js +10 -3
  187. package/styled-components/es/components/Select/Select.styles.js +5 -5
  188. package/styled-components/es/components/Select/hooks/useKeyboardNavigation.js +3 -7
  189. package/styled-components/es/components/Select/ui/Inner/Inner.js +11 -6
  190. package/styled-components/es/engines/common.js +14 -1
  191. package/types/components/Autocomplete/Autocomplete.types.d.ts +6 -6
  192. package/types/components/Autocomplete/Autocomplete.types.d.ts.map +1 -1
  193. package/types/components/Combobox/ComboboxNew/Combobox.d.ts.map +1 -1
  194. package/types/components/Combobox/ComboboxNew/Combobox.styles.d.ts +0 -1
  195. package/types/components/Combobox/ComboboxNew/Combobox.styles.d.ts.map +1 -1
  196. package/types/components/Combobox/ComboboxNew/Combobox.tokens.d.ts +1 -1
  197. package/types/components/Combobox/ComboboxNew/Combobox.types.d.ts +13 -6
  198. package/types/components/Combobox/ComboboxNew/Combobox.types.d.ts.map +1 -1
  199. package/types/components/Combobox/ComboboxNew/ui/Inner/Inner.d.ts.map +1 -1
  200. package/types/components/Combobox/ComboboxNew/ui/Inner/Inner.type.d.ts +2 -1
  201. package/types/components/Combobox/ComboboxNew/ui/Inner/Inner.type.d.ts.map +1 -1
  202. package/types/components/Combobox/ComboboxNew/ui/Inner/ui/Item/Item.types.d.ts +6 -2
  203. package/types/components/Combobox/ComboboxNew/ui/Inner/ui/Item/Item.types.d.ts.map +1 -1
  204. package/types/components/Drawer/hooks/useDrawer.d.ts.map +1 -1
  205. package/types/components/Dropdown/Dropdown.d.ts +6 -6
  206. package/types/components/Dropdown/Dropdown.d.ts.map +1 -1
  207. package/types/components/Dropdown/Dropdown.styles.d.ts +0 -1
  208. package/types/components/Dropdown/Dropdown.styles.d.ts.map +1 -1
  209. package/types/components/Dropdown/Dropdown.types.d.ts +9 -9
  210. package/types/components/Dropdown/Dropdown.types.d.ts.map +1 -1
  211. package/types/components/Dropdown/FloatingPopover.d.ts.map +1 -1
  212. package/types/components/Dropdown/ui/DropdownInner/DropdownInner.d.ts.map +1 -1
  213. package/types/components/Dropdown/ui/DropdownInner/DropdownInner.type.d.ts +2 -3
  214. package/types/components/Dropdown/ui/DropdownInner/DropdownInner.type.d.ts.map +1 -1
  215. package/types/components/Dropdown/ui/DropdownItem/DropdownItem.type.d.ts +7 -3
  216. package/types/components/Dropdown/ui/DropdownItem/DropdownItem.type.d.ts.map +1 -1
  217. package/types/components/Pagination/Pagination.types.d.ts +75 -0
  218. package/types/components/Pagination/Pagination.types.d.ts.map +1 -1
  219. package/types/components/Pagination/ui/PaginationSelectPerPage/PaginationSelectPerPage.styles.d.ts +12 -6
  220. package/types/components/Pagination/ui/PaginationSelectPerPage/PaginationSelectPerPage.styles.d.ts.map +1 -1
  221. package/types/components/Select/Select.d.ts.map +1 -1
  222. package/types/components/Select/Select.styles.d.ts +0 -1
  223. package/types/components/Select/Select.styles.d.ts.map +1 -1
  224. package/types/components/Select/Select.types.d.ts +24 -10
  225. package/types/components/Select/Select.types.d.ts.map +1 -1
  226. package/types/components/Select/ui/Inner/Inner.d.ts.map +1 -1
  227. package/types/components/Select/ui/Inner/Inner.type.d.ts +2 -1
  228. package/types/components/Select/ui/Inner/Inner.type.d.ts.map +1 -1
  229. package/types/components/Select/ui/Inner/ui/Item/Item.types.d.ts +11 -3
  230. package/types/components/Select/ui/Inner/ui/Item/Item.types.d.ts.map +1 -1
  231. package/types/components/Table/ui/HeadCell/ui/Filter/Filter.styles.d.ts +12 -6
  232. package/types/components/Table/ui/HeadCell/ui/Filter/Filter.styles.d.ts.map +1 -1
  233. package/types/engines/common.d.ts.map +1 -1
  234. package/types/examples/components/Autocomplete/Autocomplete.d.ts +40 -40
  235. package/types/examples/components/Autocomplete/Autocomplete.d.ts.map +1 -1
  236. package/types/examples/components/Combobox/Combobox.d.ts +48 -24
  237. package/types/examples/components/Combobox/Combobox.d.ts.map +1 -1
  238. package/types/examples/components/Dropdown/Dropdown.d.ts +3 -3
  239. package/types/examples/components/Dropdown/Dropdown.d.ts.map +1 -1
  240. package/types/examples/components/Select/Select.d.ts +12 -6
  241. package/types/examples/components/Select/Select.d.ts.map +1 -1
@@ -133,7 +133,7 @@ export var DropdownItem = function(param) {
133
133
  };
134
134
  var handleHover = function() {
135
135
  if (onHover) {
136
- onHover(index);
136
+ onHover(index, item);
137
137
  }
138
138
  };
139
139
  return /*#__PURE__*/ React.createElement(React.Fragment, null, dividerBefore && /*#__PURE__*/ React.createElement(Divider, {
@@ -111,7 +111,7 @@ import { PaginationQuickJumpToPage } from "./ui/PaginationQuickJumpToPage/Pagina
111
111
  import { PaginationSelectPerPage } from "./ui/PaginationSelectPerPage/PaginationSelectPerPage";
112
112
  export var paginationRoot = function(Root) {
113
113
  return /*#__PURE__*/ forwardRef(function(_param, ref) {
114
- var outerValue = _param.value, defaultValue = _param.defaultValue, outerPerPage = _param.perPage, defaultPerPage = _param.defaultPerPage, _param_slots = _param.slots, slots = _param_slots === void 0 ? defaultValues.slots : _param_slots, view = _param.view, viewCurrentPage = _param.viewCurrentPage, _param_type = _param.type, type = _param_type === void 0 ? defaultValues.type : _param_type, size = _param.size, _param_pilled = _param.pilled, pilled = _param_pilled === void 0 ? defaultValues.pilled : _param_pilled, _param_square = _param.square, square = _param_square === void 0 ? defaultValues.square : _param_square, _param_disabledPages = _param.disabledPages, disabledPages = _param_disabledPages === void 0 ? defaultValues.disabledPages : _param_disabledPages, _param_count = _param.count, count = _param_count === void 0 ? defaultValues.value : _param_count, _param_hasQuickJump = _param.hasQuickJump, hasQuickJump = _param_hasQuickJump === void 0 ? defaultValues.hasQuickJump : _param_hasQuickJump, _param_hasPerPage = _param.hasPerPage, hasPerPage = _param_hasPerPage === void 0 ? defaultValues.hasPerPage : _param_hasPerPage, _param_perPageList = _param.perPageList, perPageList = _param_perPageList === void 0 ? defaultValues.perPageList : _param_perPageList, _param_isCommonButtonStyles = _param.isCommonButtonStyles, isCommonButtonStyles = _param_isCommonButtonStyles === void 0 ? defaultValues.isCommonButtonStyles : _param_isCommonButtonStyles, _param_placeholderQuickJump = _param.placeholderQuickJump, placeholderQuickJump = _param_placeholderQuickJump === void 0 ? defaultValues.placeholderQuickJump : _param_placeholderQuickJump, _param_textQuickJump = _param.textQuickJump, textQuickJump = _param_textQuickJump === void 0 ? defaultValues.textQuickJump : _param_textQuickJump, _param_textPerPage = _param.textPerPage, textPerPage = _param_textPerPage === void 0 ? defaultValues.textPerPage : _param_textPerPage, leftContent = _param.leftContent, rightContent = _param.rightContent, listWidth = _param.listWidth, onChangePageValue = _param.onChangePageValue, onChangePerPageValue = _param.onChangePerPageValue, onChange = _param.onChange, rest = _object_without_properties(_param, [
114
+ var outerValue = _param.value, defaultValue = _param.defaultValue, outerPerPage = _param.perPage, defaultPerPage = _param.defaultPerPage, _param_slots = _param.slots, slots = _param_slots === void 0 ? defaultValues.slots : _param_slots, view = _param.view, viewCurrentPage = _param.viewCurrentPage, _param_type = _param.type, type = _param_type === void 0 ? defaultValues.type : _param_type, size = _param.size, _param_pilled = _param.pilled, pilled = _param_pilled === void 0 ? defaultValues.pilled : _param_pilled, _param_square = _param.square, square = _param_square === void 0 ? defaultValues.square : _param_square, _param_disabledPages = _param.disabledPages, disabledPages = _param_disabledPages === void 0 ? defaultValues.disabledPages : _param_disabledPages, _param_count = _param.count, count = _param_count === void 0 ? defaultValues.value : _param_count, _param_hasQuickJump = _param.hasQuickJump, hasQuickJump = _param_hasQuickJump === void 0 ? defaultValues.hasQuickJump : _param_hasQuickJump, _param_hasPerPage = _param.hasPerPage, hasPerPage = _param_hasPerPage === void 0 ? defaultValues.hasPerPage : _param_hasPerPage, _param_perPageList = _param.perPageList, perPageList = _param_perPageList === void 0 ? defaultValues.perPageList : _param_perPageList, _param_isCommonButtonStyles = _param.isCommonButtonStyles, isCommonButtonStyles = _param_isCommonButtonStyles === void 0 ? defaultValues.isCommonButtonStyles : _param_isCommonButtonStyles, _param_placeholderQuickJump = _param.placeholderQuickJump, placeholderQuickJump = _param_placeholderQuickJump === void 0 ? defaultValues.placeholderQuickJump : _param_placeholderQuickJump, _param_textQuickJump = _param.textQuickJump, textQuickJump = _param_textQuickJump === void 0 ? defaultValues.textQuickJump : _param_textQuickJump, _param_textPerPage = _param.textPerPage, textPerPage = _param_textPerPage === void 0 ? defaultValues.textPerPage : _param_textPerPage, leftContent = _param.leftContent, rightContent = _param.rightContent, _param_listWidth = _param.listWidth, listWidth = _param_listWidth === void 0 ? 'fit-content' : _param_listWidth, onChangePageValue = _param.onChangePageValue, onChangePerPageValue = _param.onChangePerPageValue, onChange = _param.onChange, rest = _object_without_properties(_param, [
115
115
  "value",
116
116
  "defaultValue",
117
117
  "perPage",
@@ -121,7 +121,7 @@ import { Context } from "./Select.context";
121
121
  return /*#__PURE__*/ forwardRef(function(props, ref) {
122
122
  var _getItemByFocused;
123
123
  var // eslint-disable-block @typescript-eslint/ban-ts-comment
124
- id = props.id, outerValue = props.value, outerOnChange = props.onChange, _props_target = props.target, target = _props_target === void 0 ? 'textfield-like' : _props_target, items = props.items, _props_placement = props.placement, placement = _props_placement === void 0 ? 'bottom' : _props_placement, label = props.label, labelPlacement = props.labelPlacement, placeholder = props.placeholder, helperText = props.helperText, _props_disabled = props.disabled, disabled = _props_disabled === void 0 ? false : _props_disabled, _props_readOnly = props.readOnly, readOnly = _props_readOnly === void 0 ? false : _props_readOnly, outerView = props.view, size = props.size, listOverflow = props.listOverflow, listHeight = props.listHeight, listMaxHeight = props.listMaxHeight, listWidth = props.listWidth, contentLeft = props.contentLeft, onScrollBottom = props.onScrollBottom, onScroll = props.onScroll, chipView = props.chipView, _props_variant = props.variant, variant = _props_variant === void 0 ? 'normal' : _props_variant, portal = props.portal, renderValue = props.renderValue, renderItem = props.renderItem, status = props.status, onItemSelect = props.onItemSelect, separator = props.separator, outerCloseAfterSelect = props.closeAfterSelect, isTargetAmount = props.isTargetAmount, beforeList = props.beforeList, afterList = props.afterList, zIndex = props.zIndex, name = props.name, defaultValue = props.defaultValue, _props_virtual = props.virtual, virtual = _props_virtual === void 0 ? false : _props_virtual, onToggle = props.onToggle, chipType = props.chipType, multiselect = props.multiselect, // @ts-ignore
124
+ id = props.id, outerValue = props.value, outerOnChange = props.onChange, _props_target = props.target, target = _props_target === void 0 ? 'textfield-like' : _props_target, items = props.items, _props_placement = props.placement, placement = _props_placement === void 0 ? 'bottom' : _props_placement, label = props.label, labelPlacement = props.labelPlacement, placeholder = props.placeholder, helperText = props.helperText, _props_disabled = props.disabled, disabled = _props_disabled === void 0 ? false : _props_disabled, _props_readOnly = props.readOnly, readOnly = _props_readOnly === void 0 ? false : _props_readOnly, outerView = props.view, size = props.size, listOverflow = props.listOverflow, listHeight = props.listHeight, listMaxHeight = props.listMaxHeight, listWidth = props.listWidth, contentLeft = props.contentLeft, onScrollBottom = props.onScrollBottom, onScroll = props.onScroll, chipView = props.chipView, _props_variant = props.variant, variant = _props_variant === void 0 ? 'normal' : _props_variant, portal = props.portal, renderValue = props.renderValue, renderItem = props.renderItem, status = props.status, onItemSelect = props.onItemSelect, separator = props.separator, outerCloseAfterSelect = props.closeAfterSelect, isTargetAmount = props.isTargetAmount, beforeList = props.beforeList, afterList = props.afterList, zIndex = props.zIndex, name = props.name, defaultValue = props.defaultValue, _props_virtual = props.virtual, virtual = _props_virtual === void 0 ? false : _props_virtual, onToggle = props.onToggle, chipType = props.chipType, multiselect = props.multiselect, _props_mode = props.mode, mode = _props_mode === void 0 ? 'default' : _props_mode, // @ts-ignore
125
125
  _offset = props._offset, // Извлекаем пропсы для required и hint, чтобы они не попадали в DOM.
126
126
  // @ts-ignore
127
127
  required = props.required, // @ts-ignore
@@ -177,6 +177,7 @@ import { Context } from "./Select.context";
177
177
  "onToggle",
178
178
  "chipType",
179
179
  "multiselect",
180
+ "mode",
180
181
  "_offset",
181
182
  "required",
182
183
  "requiredPlacement",
@@ -210,6 +211,7 @@ import { Context } from "./Select.context";
210
211
  var activeDescendantItemValue = ((_getItemByFocused = getItemByFocused(focusedPath, focusedToValueMap)) === null || _getItemByFocused === void 0 ? void 0 : _getItemByFocused.value.toString()) || '';
211
212
  var closeAfterSelect = outerCloseAfterSelect !== null && outerCloseAfterSelect !== void 0 ? outerCloseAfterSelect : !props.multiselect;
212
213
  var treeId = safeUseId();
214
+ var listWrapperRef = useRef(null);
213
215
  var view = target === 'textfield-like' && (disabled || readOnly) ? 'default' : getView(status, outerView);
214
216
  // Собираем объект с пропсами для required и прокидываем их напрямую в компонент Textfield.
215
217
  var requiredProps = props.target === 'button-like' ? undefined : {
@@ -339,6 +341,10 @@ import { Context } from "./Select.context";
339
341
  type: 'reset'
340
342
  });
341
343
  }
344
+ // Закрываем список, если элемент уже выбран.
345
+ if (mode === 'radio' && isCurrentChecked) {
346
+ return;
347
+ }
342
348
  if (onChange) {
343
349
  onChange(isCurrentChecked ? '' : item.value, item);
344
350
  }
@@ -496,12 +502,12 @@ import { Context } from "./Select.context";
496
502
  disabled: disabled,
497
503
  readOnly: readOnly
498
504
  }, rest), /*#__PURE__*/ React.createElement(ListWrapper, {
505
+ ref: listWrapperRef,
499
506
  listWidth: listWidth
500
507
  }, /*#__PURE__*/ React.createElement(Ul, {
501
508
  role: "tree",
502
509
  id: "".concat(treeId, "_tree_level_1"),
503
510
  "aria-multiselectable": Boolean(props.multiselect),
504
- listOverflow: listOverflow,
505
511
  listMaxHeight: listMaxHeight || listHeight,
506
512
  onScroll: virtual ? undefined : handleScroll,
507
513
  ref: targetRef,
@@ -522,7 +528,8 @@ import { Context } from "./Select.context";
522
528
  path: path,
523
529
  dispatchPath: dispatchPath,
524
530
  index: index,
525
- listWidth: listWidth
531
+ listWidth: listWidth,
532
+ portal: listWrapperRef
526
533
  });
527
534
  }), afterList))))));
528
535
  });
@@ -3,21 +3,21 @@ import { css } from "@emotion/react";
3
3
  import { getCorrectHeight } from "./utils";
4
4
  import { tokens, constants } from "./Select.tokens";
5
5
  export var ListWrapper = /*#__PURE__*/ styled("div", {
6
- target: "e1xzgqp00",
6
+ target: "e28p6sx0",
7
7
  label: "ListWrapper"
8
8
  })("width:", function(param) {
9
9
  var listWidth = param.listWidth;
10
10
  return listWidth || '100%';
11
- }, ";padding:calc(var(", tokens.padding, ") + var(", tokens.dropdownBorderWidth, ",0rem));border-radius:var(", tokens.borderRadius, ");box-sizing:border-box;background:var(", constants.background, ");box-shadow:", constants.boxShadow, ",inset 0 0 0 var(", tokens.dropdownBorderWidth, ",0rem) var(", tokens.dropdownBorderColor, ",transparent);", "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjLWVtb3Rpb24vY29tcG9uZW50cy9TZWxlY3QvU2VsZWN0LnN0eWxlcy50cyIsInNvdXJjZXMiOlsic3JjLWVtb3Rpb24vY29tcG9uZW50cy9TZWxlY3QvU2VsZWN0LnN0eWxlcy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5cbmltcG9ydCB7IGdldENvcnJlY3RIZWlnaHQgfSBmcm9tICcuL3V0aWxzJztcbmltcG9ydCB7IFNlbGVjdFByb3BzIH0gZnJvbSAnLi9TZWxlY3QudHlwZXMnO1xuaW1wb3J0IHsgdG9rZW5zLCBjb25zdGFudHMgfSBmcm9tICcuL1NlbGVjdC50b2tlbnMnO1xuXG5leHBvcnQgY29uc3QgTGlzdFdyYXBwZXIgPSBzdHlsZWQuZGl2PHtcbiAgICBsaXN0V2lkdGg/OiBTZWxlY3RQcm9wc1snbGlzdFdpZHRoJ107XG59PmBcbiAgICB3aWR0aDogJHsoeyBsaXN0V2lkdGggfSkgPT4gbGlzdFdpZHRoIHx8ICcxMDAlJ307XG4gICAgcGFkZGluZzogY2FsYyh2YXIoJHt0b2tlbnMucGFkZGluZ30pICsgdmFyKCR7dG9rZW5zLmRyb3Bkb3duQm9yZGVyV2lkdGh9LCAwcmVtKSk7XG4gICAgYm9yZGVyLXJhZGl1czogdmFyKCR7dG9rZW5zLmJvcmRlclJhZGl1c30pO1xuICAgIGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG4gICAgYmFja2dyb3VuZDogdmFyKCR7Y29uc3RhbnRzLmJhY2tncm91bmR9KTtcbiAgICBib3gtc2hhZG93OiAke2NvbnN0YW50cy5ib3hTaGFkb3d9LFxuICAgICAgICBpbnNldCAwIDAgMCB2YXIoJHt0b2tlbnMuZHJvcGRvd25Cb3JkZXJXaWR0aH0sIDByZW0pIHZhcigke3Rva2Vucy5kcm9wZG93bkJvcmRlckNvbG9yfSwgdHJhbnNwYXJlbnQpO1xuYDtcblxuZXhwb3J0IGNvbnN0IFVsID0gc3R5bGVkLnVsPHtcbiAgICB2aXJ0dWFsOiBTZWxlY3RQcm9wc1sndmlydHVhbCddO1xuICAgIGxpc3RPdmVyZmxvdz86IFNlbGVjdFByb3BzWydsaXN0T3ZlcmZsb3cnXTtcbiAgICBsaXN0TWF4SGVpZ2h0PzogU2VsZWN0UHJvcHNbJ2xpc3RNYXhIZWlnaHQnXTtcbn0+YFxuICAgIG1heC1oZWlnaHQ6ICR7KHsgdmlydHVhbCwgbGlzdE1heEhlaWdodCB9KSA9PlxuICAgICAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgbm8tbmVzdGVkLXRlcm5hcnlcbiAgICAgICAgdmlydHVhbCA/ICdhdXRvJyA6IGxpc3RNYXhIZWlnaHQgPyBnZXRDb3JyZWN0SGVpZ2h0KGxpc3RNYXhIZWlnaHQpIDogJ2F1dG8nfTtcbiAgICBvdmVyZmxvdy15OiAkeyh7IHZpcnR1YWwsIGxpc3RPdmVyZmxvdyB9KSA9PiAodmlydHVhbCA/ICd2aXNpYmxlJyA6IGxpc3RPdmVyZmxvdyB8fCAndmlzaWJsZScpfTtcbiAgICBib3JkZXItcmFkaXVzOiBjYWxjKHZhcigke3Rva2Vucy5ib3JkZXJSYWRpdXN9KSAtIDAuMTI1cmVtIC0gdmFyKCR7dG9rZW5zLmRyb3Bkb3duQm9yZGVyV2lkdGh9LCAwcmVtKSk7XG4gICAgbWFyZ2luOiAwO1xuICAgIHBhZGRpbmc6IDA7XG5gO1xuXG5leHBvcnQgY29uc3QgYmFzZSA9IGNzc2BgO1xuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQU8yQiJ9 */");
11
+ }, ";padding:calc(var(", tokens.padding, ") + var(", tokens.dropdownBorderWidth, ",0rem));border-radius:var(", tokens.borderRadius, ");box-sizing:border-box;background:var(", constants.background, ");box-shadow:", constants.boxShadow, ",inset 0 0 0 var(", tokens.dropdownBorderWidth, ",0rem) var(", tokens.dropdownBorderColor, ",transparent);", "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjLWVtb3Rpb24vY29tcG9uZW50cy9TZWxlY3QvU2VsZWN0LnN0eWxlcy50cyIsInNvdXJjZXMiOlsic3JjLWVtb3Rpb24vY29tcG9uZW50cy9TZWxlY3QvU2VsZWN0LnN0eWxlcy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5cbmltcG9ydCB7IGdldENvcnJlY3RIZWlnaHQgfSBmcm9tICcuL3V0aWxzJztcbmltcG9ydCB7IFNlbGVjdFByb3BzIH0gZnJvbSAnLi9TZWxlY3QudHlwZXMnO1xuaW1wb3J0IHsgdG9rZW5zLCBjb25zdGFudHMgfSBmcm9tICcuL1NlbGVjdC50b2tlbnMnO1xuXG5leHBvcnQgY29uc3QgTGlzdFdyYXBwZXIgPSBzdHlsZWQuZGl2PHtcbiAgICBsaXN0V2lkdGg/OiBTZWxlY3RQcm9wc1snbGlzdFdpZHRoJ107XG59PmBcbiAgICB3aWR0aDogJHsoeyBsaXN0V2lkdGggfSkgPT4gbGlzdFdpZHRoIHx8ICcxMDAlJ307XG4gICAgcGFkZGluZzogY2FsYyh2YXIoJHt0b2tlbnMucGFkZGluZ30pICsgdmFyKCR7dG9rZW5zLmRyb3Bkb3duQm9yZGVyV2lkdGh9LCAwcmVtKSk7XG4gICAgYm9yZGVyLXJhZGl1czogdmFyKCR7dG9rZW5zLmJvcmRlclJhZGl1c30pO1xuICAgIGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG4gICAgYmFja2dyb3VuZDogdmFyKCR7Y29uc3RhbnRzLmJhY2tncm91bmR9KTtcbiAgICBib3gtc2hhZG93OiAke2NvbnN0YW50cy5ib3hTaGFkb3d9LFxuICAgICAgICBpbnNldCAwIDAgMCB2YXIoJHt0b2tlbnMuZHJvcGRvd25Cb3JkZXJXaWR0aH0sIDByZW0pIHZhcigke3Rva2Vucy5kcm9wZG93bkJvcmRlckNvbG9yfSwgdHJhbnNwYXJlbnQpO1xuYDtcblxuZXhwb3J0IGNvbnN0IFVsID0gc3R5bGVkLnVsPHtcbiAgICB2aXJ0dWFsOiBTZWxlY3RQcm9wc1sndmlydHVhbCddO1xuICAgIGxpc3RNYXhIZWlnaHQ/OiBTZWxlY3RQcm9wc1snbGlzdE1heEhlaWdodCddO1xufT5gXG4gICAgbWF4LWhlaWdodDogJHsoeyB2aXJ0dWFsLCBsaXN0TWF4SGVpZ2h0IH0pID0+XG4gICAgICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuby1uZXN0ZWQtdGVybmFyeVxuICAgICAgICB2aXJ0dWFsID8gJ2F1dG8nIDogbGlzdE1heEhlaWdodCA/IGdldENvcnJlY3RIZWlnaHQobGlzdE1heEhlaWdodCkgOiAnYXV0byd9O1xuICAgIG92ZXJmbG93LXg6IGhpZGRlbjtcbiAgICBvdmVyZmxvdy15OiAkeyh7IHZpcnR1YWwgfSkgPT4gKHZpcnR1YWwgPyAndmlzaWJsZScgOiAnYXV0bycpfTtcbiAgICBib3JkZXItcmFkaXVzOiBjYWxjKHZhcigke3Rva2Vucy5ib3JkZXJSYWRpdXN9KSAtIDAuMTI1cmVtIC0gdmFyKCR7dG9rZW5zLmRyb3Bkb3duQm9yZGVyV2lkdGh9LCAwcmVtKSk7XG4gICAgbWFyZ2luOiAwO1xuICAgIHBhZGRpbmc6IDA7XG5gO1xuXG5leHBvcnQgY29uc3QgYmFzZSA9IGNzc2BgO1xuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQU8yQiJ9 */");
12
12
  export var Ul = /*#__PURE__*/ styled("ul", {
13
- target: "e1xzgqp01",
13
+ target: "e28p6sx1",
14
14
  label: "Ul"
15
15
  })("max-height:", function(param) {
16
16
  var virtual = param.virtual, listMaxHeight = param.listMaxHeight;
17
17
  return(// eslint-disable-next-line no-nested-ternary
18
18
  virtual ? 'auto' : listMaxHeight ? getCorrectHeight(listMaxHeight) : 'auto');
19
- }, ";overflow-y:", function(param) {
20
- var virtual = param.virtual, listOverflow = param.listOverflow;
21
- return virtual ? 'visible' : listOverflow || 'visible';
22
- }, ";border-radius:calc(var(", tokens.borderRadius, ") - 0.125rem - var(", tokens.dropdownBorderWidth, ",0rem));margin:0;padding:0;", "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjLWVtb3Rpb24vY29tcG9uZW50cy9TZWxlY3QvU2VsZWN0LnN0eWxlcy50cyIsInNvdXJjZXMiOlsic3JjLWVtb3Rpb24vY29tcG9uZW50cy9TZWxlY3QvU2VsZWN0LnN0eWxlcy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5cbmltcG9ydCB7IGdldENvcnJlY3RIZWlnaHQgfSBmcm9tICcuL3V0aWxzJztcbmltcG9ydCB7IFNlbGVjdFByb3BzIH0gZnJvbSAnLi9TZWxlY3QudHlwZXMnO1xuaW1wb3J0IHsgdG9rZW5zLCBjb25zdGFudHMgfSBmcm9tICcuL1NlbGVjdC50b2tlbnMnO1xuXG5leHBvcnQgY29uc3QgTGlzdFdyYXBwZXIgPSBzdHlsZWQuZGl2PHtcbiAgICBsaXN0V2lkdGg/OiBTZWxlY3RQcm9wc1snbGlzdFdpZHRoJ107XG59PmBcbiAgICB3aWR0aDogJHsoeyBsaXN0V2lkdGggfSkgPT4gbGlzdFdpZHRoIHx8ICcxMDAlJ307XG4gICAgcGFkZGluZzogY2FsYyh2YXIoJHt0b2tlbnMucGFkZGluZ30pICsgdmFyKCR7dG9rZW5zLmRyb3Bkb3duQm9yZGVyV2lkdGh9LCAwcmVtKSk7XG4gICAgYm9yZGVyLXJhZGl1czogdmFyKCR7dG9rZW5zLmJvcmRlclJhZGl1c30pO1xuICAgIGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG4gICAgYmFja2dyb3VuZDogdmFyKCR7Y29uc3RhbnRzLmJhY2tncm91bmR9KTtcbiAgICBib3gtc2hhZG93OiAke2NvbnN0YW50cy5ib3hTaGFkb3d9LFxuICAgICAgICBpbnNldCAwIDAgMCB2YXIoJHt0b2tlbnMuZHJvcGRvd25Cb3JkZXJXaWR0aH0sIDByZW0pIHZhcigke3Rva2Vucy5kcm9wZG93bkJvcmRlckNvbG9yfSwgdHJhbnNwYXJlbnQpO1xuYDtcblxuZXhwb3J0IGNvbnN0IFVsID0gc3R5bGVkLnVsPHtcbiAgICB2aXJ0dWFsOiBTZWxlY3RQcm9wc1sndmlydHVhbCddO1xuICAgIGxpc3RPdmVyZmxvdz86IFNlbGVjdFByb3BzWydsaXN0T3ZlcmZsb3cnXTtcbiAgICBsaXN0TWF4SGVpZ2h0PzogU2VsZWN0UHJvcHNbJ2xpc3RNYXhIZWlnaHQnXTtcbn0+YFxuICAgIG1heC1oZWlnaHQ6ICR7KHsgdmlydHVhbCwgbGlzdE1heEhlaWdodCB9KSA9PlxuICAgICAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgbm8tbmVzdGVkLXRlcm5hcnlcbiAgICAgICAgdmlydHVhbCA/ICdhdXRvJyA6IGxpc3RNYXhIZWlnaHQgPyBnZXRDb3JyZWN0SGVpZ2h0KGxpc3RNYXhIZWlnaHQpIDogJ2F1dG8nfTtcbiAgICBvdmVyZmxvdy15OiAkeyh7IHZpcnR1YWwsIGxpc3RPdmVyZmxvdyB9KSA9PiAodmlydHVhbCA/ICd2aXNpYmxlJyA6IGxpc3RPdmVyZmxvdyB8fCAndmlzaWJsZScpfTtcbiAgICBib3JkZXItcmFkaXVzOiBjYWxjKHZhcigke3Rva2Vucy5ib3JkZXJSYWRpdXN9KSAtIDAuMTI1cmVtIC0gdmFyKCR7dG9rZW5zLmRyb3Bkb3duQm9yZGVyV2lkdGh9LCAwcmVtKSk7XG4gICAgbWFyZ2luOiAwO1xuICAgIHBhZGRpbmc6IDA7XG5gO1xuXG5leHBvcnQgY29uc3QgYmFzZSA9IGNzc2BgO1xuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW1Ca0IifQ== */");
23
- export var base = /*#__PURE__*/ css("base", "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjLWVtb3Rpb24vY29tcG9uZW50cy9TZWxlY3QvU2VsZWN0LnN0eWxlcy50cyIsInNvdXJjZXMiOlsic3JjLWVtb3Rpb24vY29tcG9uZW50cy9TZWxlY3QvU2VsZWN0LnN0eWxlcy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5cbmltcG9ydCB7IGdldENvcnJlY3RIZWlnaHQgfSBmcm9tICcuL3V0aWxzJztcbmltcG9ydCB7IFNlbGVjdFByb3BzIH0gZnJvbSAnLi9TZWxlY3QudHlwZXMnO1xuaW1wb3J0IHsgdG9rZW5zLCBjb25zdGFudHMgfSBmcm9tICcuL1NlbGVjdC50b2tlbnMnO1xuXG5leHBvcnQgY29uc3QgTGlzdFdyYXBwZXIgPSBzdHlsZWQuZGl2PHtcbiAgICBsaXN0V2lkdGg/OiBTZWxlY3RQcm9wc1snbGlzdFdpZHRoJ107XG59PmBcbiAgICB3aWR0aDogJHsoeyBsaXN0V2lkdGggfSkgPT4gbGlzdFdpZHRoIHx8ICcxMDAlJ307XG4gICAgcGFkZGluZzogY2FsYyh2YXIoJHt0b2tlbnMucGFkZGluZ30pICsgdmFyKCR7dG9rZW5zLmRyb3Bkb3duQm9yZGVyV2lkdGh9LCAwcmVtKSk7XG4gICAgYm9yZGVyLXJhZGl1czogdmFyKCR7dG9rZW5zLmJvcmRlclJhZGl1c30pO1xuICAgIGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG4gICAgYmFja2dyb3VuZDogdmFyKCR7Y29uc3RhbnRzLmJhY2tncm91bmR9KTtcbiAgICBib3gtc2hhZG93OiAke2NvbnN0YW50cy5ib3hTaGFkb3d9LFxuICAgICAgICBpbnNldCAwIDAgMCB2YXIoJHt0b2tlbnMuZHJvcGRvd25Cb3JkZXJXaWR0aH0sIDByZW0pIHZhcigke3Rva2Vucy5kcm9wZG93bkJvcmRlckNvbG9yfSwgdHJhbnNwYXJlbnQpO1xuYDtcblxuZXhwb3J0IGNvbnN0IFVsID0gc3R5bGVkLnVsPHtcbiAgICB2aXJ0dWFsOiBTZWxlY3RQcm9wc1sndmlydHVhbCddO1xuICAgIGxpc3RPdmVyZmxvdz86IFNlbGVjdFByb3BzWydsaXN0T3ZlcmZsb3cnXTtcbiAgICBsaXN0TWF4SGVpZ2h0PzogU2VsZWN0UHJvcHNbJ2xpc3RNYXhIZWlnaHQnXTtcbn0+YFxuICAgIG1heC1oZWlnaHQ6ICR7KHsgdmlydHVhbCwgbGlzdE1heEhlaWdodCB9KSA9PlxuICAgICAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgbm8tbmVzdGVkLXRlcm5hcnlcbiAgICAgICAgdmlydHVhbCA/ICdhdXRvJyA6IGxpc3RNYXhIZWlnaHQgPyBnZXRDb3JyZWN0SGVpZ2h0KGxpc3RNYXhIZWlnaHQpIDogJ2F1dG8nfTtcbiAgICBvdmVyZmxvdy15OiAkeyh7IHZpcnR1YWwsIGxpc3RPdmVyZmxvdyB9KSA9PiAodmlydHVhbCA/ICd2aXNpYmxlJyA6IGxpc3RPdmVyZmxvdyB8fCAndmlzaWJsZScpfTtcbiAgICBib3JkZXItcmFkaXVzOiBjYWxjKHZhcigke3Rva2Vucy5ib3JkZXJSYWRpdXN9KSAtIDAuMTI1cmVtIC0gdmFyKCR7dG9rZW5zLmRyb3Bkb3duQm9yZGVyV2lkdGh9LCAwcmVtKSk7XG4gICAgbWFyZ2luOiAwO1xuICAgIHBhZGRpbmc6IDA7XG5gO1xuXG5leHBvcnQgY29uc3QgYmFzZSA9IGNzc2BgO1xuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWlDb0IifQ== */");
19
+ }, ";overflow-x:hidden;overflow-y:", function(param) {
20
+ var virtual = param.virtual;
21
+ return virtual ? 'visible' : 'auto';
22
+ }, ";border-radius:calc(var(", tokens.borderRadius, ") - 0.125rem - var(", tokens.dropdownBorderWidth, ",0rem));margin:0;padding:0;", "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjLWVtb3Rpb24vY29tcG9uZW50cy9TZWxlY3QvU2VsZWN0LnN0eWxlcy50cyIsInNvdXJjZXMiOlsic3JjLWVtb3Rpb24vY29tcG9uZW50cy9TZWxlY3QvU2VsZWN0LnN0eWxlcy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5cbmltcG9ydCB7IGdldENvcnJlY3RIZWlnaHQgfSBmcm9tICcuL3V0aWxzJztcbmltcG9ydCB7IFNlbGVjdFByb3BzIH0gZnJvbSAnLi9TZWxlY3QudHlwZXMnO1xuaW1wb3J0IHsgdG9rZW5zLCBjb25zdGFudHMgfSBmcm9tICcuL1NlbGVjdC50b2tlbnMnO1xuXG5leHBvcnQgY29uc3QgTGlzdFdyYXBwZXIgPSBzdHlsZWQuZGl2PHtcbiAgICBsaXN0V2lkdGg/OiBTZWxlY3RQcm9wc1snbGlzdFdpZHRoJ107XG59PmBcbiAgICB3aWR0aDogJHsoeyBsaXN0V2lkdGggfSkgPT4gbGlzdFdpZHRoIHx8ICcxMDAlJ307XG4gICAgcGFkZGluZzogY2FsYyh2YXIoJHt0b2tlbnMucGFkZGluZ30pICsgdmFyKCR7dG9rZW5zLmRyb3Bkb3duQm9yZGVyV2lkdGh9LCAwcmVtKSk7XG4gICAgYm9yZGVyLXJhZGl1czogdmFyKCR7dG9rZW5zLmJvcmRlclJhZGl1c30pO1xuICAgIGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG4gICAgYmFja2dyb3VuZDogdmFyKCR7Y29uc3RhbnRzLmJhY2tncm91bmR9KTtcbiAgICBib3gtc2hhZG93OiAke2NvbnN0YW50cy5ib3hTaGFkb3d9LFxuICAgICAgICBpbnNldCAwIDAgMCB2YXIoJHt0b2tlbnMuZHJvcGRvd25Cb3JkZXJXaWR0aH0sIDByZW0pIHZhcigke3Rva2Vucy5kcm9wZG93bkJvcmRlckNvbG9yfSwgdHJhbnNwYXJlbnQpO1xuYDtcblxuZXhwb3J0IGNvbnN0IFVsID0gc3R5bGVkLnVsPHtcbiAgICB2aXJ0dWFsOiBTZWxlY3RQcm9wc1sndmlydHVhbCddO1xuICAgIGxpc3RNYXhIZWlnaHQ/OiBTZWxlY3RQcm9wc1snbGlzdE1heEhlaWdodCddO1xufT5gXG4gICAgbWF4LWhlaWdodDogJHsoeyB2aXJ0dWFsLCBsaXN0TWF4SGVpZ2h0IH0pID0+XG4gICAgICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuby1uZXN0ZWQtdGVybmFyeVxuICAgICAgICB2aXJ0dWFsID8gJ2F1dG8nIDogbGlzdE1heEhlaWdodCA/IGdldENvcnJlY3RIZWlnaHQobGlzdE1heEhlaWdodCkgOiAnYXV0byd9O1xuICAgIG92ZXJmbG93LXg6IGhpZGRlbjtcbiAgICBvdmVyZmxvdy15OiAkeyh7IHZpcnR1YWwgfSkgPT4gKHZpcnR1YWwgPyAndmlzaWJsZScgOiAnYXV0bycpfTtcbiAgICBib3JkZXItcmFkaXVzOiBjYWxjKHZhcigke3Rva2Vucy5ib3JkZXJSYWRpdXN9KSAtIDAuMTI1cmVtIC0gdmFyKCR7dG9rZW5zLmRyb3Bkb3duQm9yZGVyV2lkdGh9LCAwcmVtKSk7XG4gICAgbWFyZ2luOiAwO1xuICAgIHBhZGRpbmc6IDA7XG5gO1xuXG5leHBvcnQgY29uc3QgYmFzZSA9IGNzc2BgO1xuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW1Ca0IifQ== */");
23
+ export var base = /*#__PURE__*/ css("base", "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjLWVtb3Rpb24vY29tcG9uZW50cy9TZWxlY3QvU2VsZWN0LnN0eWxlcy50cyIsInNvdXJjZXMiOlsic3JjLWVtb3Rpb24vY29tcG9uZW50cy9TZWxlY3QvU2VsZWN0LnN0eWxlcy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5cbmltcG9ydCB7IGdldENvcnJlY3RIZWlnaHQgfSBmcm9tICcuL3V0aWxzJztcbmltcG9ydCB7IFNlbGVjdFByb3BzIH0gZnJvbSAnLi9TZWxlY3QudHlwZXMnO1xuaW1wb3J0IHsgdG9rZW5zLCBjb25zdGFudHMgfSBmcm9tICcuL1NlbGVjdC50b2tlbnMnO1xuXG5leHBvcnQgY29uc3QgTGlzdFdyYXBwZXIgPSBzdHlsZWQuZGl2PHtcbiAgICBsaXN0V2lkdGg/OiBTZWxlY3RQcm9wc1snbGlzdFdpZHRoJ107XG59PmBcbiAgICB3aWR0aDogJHsoeyBsaXN0V2lkdGggfSkgPT4gbGlzdFdpZHRoIHx8ICcxMDAlJ307XG4gICAgcGFkZGluZzogY2FsYyh2YXIoJHt0b2tlbnMucGFkZGluZ30pICsgdmFyKCR7dG9rZW5zLmRyb3Bkb3duQm9yZGVyV2lkdGh9LCAwcmVtKSk7XG4gICAgYm9yZGVyLXJhZGl1czogdmFyKCR7dG9rZW5zLmJvcmRlclJhZGl1c30pO1xuICAgIGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG4gICAgYmFja2dyb3VuZDogdmFyKCR7Y29uc3RhbnRzLmJhY2tncm91bmR9KTtcbiAgICBib3gtc2hhZG93OiAke2NvbnN0YW50cy5ib3hTaGFkb3d9LFxuICAgICAgICBpbnNldCAwIDAgMCB2YXIoJHt0b2tlbnMuZHJvcGRvd25Cb3JkZXJXaWR0aH0sIDByZW0pIHZhcigke3Rva2Vucy5kcm9wZG93bkJvcmRlckNvbG9yfSwgdHJhbnNwYXJlbnQpO1xuYDtcblxuZXhwb3J0IGNvbnN0IFVsID0gc3R5bGVkLnVsPHtcbiAgICB2aXJ0dWFsOiBTZWxlY3RQcm9wc1sndmlydHVhbCddO1xuICAgIGxpc3RNYXhIZWlnaHQ/OiBTZWxlY3RQcm9wc1snbGlzdE1heEhlaWdodCddO1xufT5gXG4gICAgbWF4LWhlaWdodDogJHsoeyB2aXJ0dWFsLCBsaXN0TWF4SGVpZ2h0IH0pID0+XG4gICAgICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuby1uZXN0ZWQtdGVybmFyeVxuICAgICAgICB2aXJ0dWFsID8gJ2F1dG8nIDogbGlzdE1heEhlaWdodCA/IGdldENvcnJlY3RIZWlnaHQobGlzdE1heEhlaWdodCkgOiAnYXV0byd9O1xuICAgIG92ZXJmbG93LXg6IGhpZGRlbjtcbiAgICBvdmVyZmxvdy15OiAkeyh7IHZpcnR1YWwgfSkgPT4gKHZpcnR1YWwgPyAndmlzaWJsZScgOiAnYXV0bycpfTtcbiAgICBib3JkZXItcmFkaXVzOiBjYWxjKHZhcigke3Rva2Vucy5ib3JkZXJSYWRpdXN9KSAtIDAuMTI1cmVtIC0gdmFyKCR7dG9rZW5zLmRyb3Bkb3duQm9yZGVyV2lkdGh9LCAwcmVtKSk7XG4gICAgbWFyZ2luOiAwO1xuICAgIHBhZGRpbmc6IDA7XG5gO1xuXG5leHBvcnQgY29uc3QgYmFzZSA9IGNzc2BgO1xuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWlDb0IifQ== */");
@@ -177,13 +177,9 @@ export var useKeyNavigation = function(param) {
177
177
  case keys.Tab:
178
178
  case keys.Escape:
179
179
  {
180
- dispatchFocusedPath({
181
- type: 'reset'
182
- });
183
- dispatchPath({
184
- type: 'reset'
185
- });
186
- handleListToggle(false);
180
+ if (path[0]) {
181
+ handleListToggle(false);
182
+ }
187
183
  break;
188
184
  }
189
185
  case keys.Home:
@@ -1,10 +1,10 @@
1
- import React from "react";
1
+ import React, { useRef } from "react";
2
2
  import { isEmpty, safeUseId } from "../../../../utils";
3
3
  import { Ul, ListWrapper } from "../../Select.styles";
4
4
  import { FloatingPopover } from "../../FloatingPopover";
5
5
  import { Item } from "./ui/Item/Item";
6
6
  export var Inner = function(param) {
7
- var item = param.item, currentLevel = param.currentLevel, path = param.path, dispatchPath = param.dispatchPath, index = param.index, listWidth = param.listWidth;
7
+ var item = param.item, currentLevel = param.currentLevel, path = param.path, dispatchPath = param.dispatchPath, index = param.index, listWidth = param.listWidth, portal = param.portal;
8
8
  var handleToggle = function(opened) {
9
9
  if (opened) {
10
10
  dispatchPath({
@@ -19,6 +19,7 @@ export var Inner = function(param) {
19
19
  });
20
20
  }
21
21
  };
22
+ var listWrapperRef = useRef(null);
22
23
  var isCurrentListOpen = path[currentLevel + 1] === item.value.toString();
23
24
  var treeId = safeUseId();
24
25
  var listId = "".concat(treeId, "_tree_level_").concat(currentLevel + 2);
@@ -39,13 +40,16 @@ export var Inner = function(param) {
39
40
  ariaLevel: nextLevel,
40
41
  ariaLabel: item.label
41
42
  }),
42
- isInner: true
43
+ isInner: true,
44
+ portal: portal
43
45
  }, /*#__PURE__*/ React.createElement(ListWrapper, {
44
- listWidth: listWidth
46
+ listWidth: listWidth,
47
+ ref: listWrapperRef
45
48
  }, /*#__PURE__*/ React.createElement(Ul, {
46
49
  role: "group",
47
50
  id: listId,
48
- virtual: false
51
+ virtual: false,
52
+ listMaxHeight: item === null || item === void 0 ? void 0 : item.listMaxHeight
49
53
  }, (_item_items = item.items) === null || _item_items === void 0 ? void 0 : _item_items.map(function(innerItem, innerIndex) {
50
54
  return /*#__PURE__*/ React.createElement(Inner, {
51
55
  key: "".concat(innerIndex, "/").concat(currentLevel),
@@ -54,7 +58,8 @@ export var Inner = function(param) {
54
58
  path: path,
55
59
  dispatchPath: dispatchPath,
56
60
  index: innerIndex,
57
- listWidth: listWidth
61
+ listWidth: listWidth,
62
+ portal: listWrapperRef
58
63
  });
59
64
  }))));
60
65
  }
@@ -76,10 +76,23 @@ export var mergeConfig = function(baseConfig, userConfig) {
76
76
  }
77
77
  return res;
78
78
  };
79
+ // INFO: Метод, который проводит слияние двух объектов
80
+ // INFO: если значение явно указанно как undefined/null/пустая строка, то будет взято значение указанное в default
81
+ function mergeWithoutUndefined(defaults, componentProps) {
82
+ var props = Object.keys(defaults).reduce(function(acc, key) {
83
+ return _object_spread_props(_object_spread({}, acc), _define_property({}, key, [
84
+ null,
85
+ undefined,
86
+ ''
87
+ ].includes(componentProps[key]) ? defaults[key] : componentProps[key]));
88
+ }, {});
89
+ return _object_spread({}, componentProps, props);
90
+ }
79
91
  export function component(config) {
80
92
  var Comp = config.layout(_component(config));
81
93
  return /*#__PURE__*/ React.forwardRef(function(props, ref) {
82
- return /*#__PURE__*/ React.createElement(Comp, _object_spread_props(_object_spread({}, config === null || config === void 0 ? void 0 : config.defaults, props), {
94
+ var mergedProps = mergeWithoutUndefined(config === null || config === void 0 ? void 0 : config.defaults, props);
95
+ return /*#__PURE__*/ React.createElement(Comp, _object_spread_props(_object_spread({}, mergedProps), {
83
96
  ref: ref
84
97
  }));
85
98
  });
@@ -1,7 +0,0 @@
1
- import { component, mergeConfig } from "../../../engines";
2
- import { comboboxNewConfig } from "../../..";
3
- import { config } from "./Combobox.config";
4
- var mergedConfig = mergeConfig(comboboxNewConfig, config);
5
- var ComboboxComponent = component(mergedConfig);
6
- var Combobox = ComboboxComponent;
7
- export { Combobox };
@@ -161,12 +161,12 @@
161
161
 
162
162
  .IconRoot_7pl7ig_svvlqhf__32c458a1{display:-webkit-inline-box;display:-webkit-inline-flex;display:-ms-inline-flexbox;display:inline-flex;width:var(--svvlqhf-0);height:var(--svvlqhf-0);-webkit-flex:0 0 var(--svvlqhf-0);-ms-flex:0 0 var(--svvlqhf-0);flex:0 0 var(--svvlqhf-0);}
163
163
 
164
- .Combobox_styles_isfa46_lxiiees__91df7bfb{width:var(--lxiiees-0);padding:calc(var(--plasma-combobox-padding) + var(--plasma-select-dropdown-border-width,0rem));border-radius:var(--plasma-combobox-border-radius);box-sizing:border-box;background:var(--surface-solid-card);box-shadow:0px 4px 14px -4px rgba(8,8,8,0.08),0px 1px 4px -1px rgba(0,0,0,0.04), inset 0 0 0 var(--plasma-select-dropdown-border-width,0rem) var(--plasma-select-dropdown-border-color,transparent);}
165
- .Combobox_styles_isfa46_u1veo3wn__91df7bfb{max-height:var(--u1veo3wn-0);overflow-y:var(--u1veo3wn-1);border-radius:calc(var(--plasma-combobox-border-radius) - 0.125rem - var(--plasma-select-dropdown-border-width,0rem));margin:0;padding:0;}.Combobox_styles_isfa46_u1veo3wn__91df7bfb .Combobox_styles_isfa46_comboboxEmptyStateWrapper__91df7bfb{box-shadow:none;}
166
- .Combobox_styles_isfa46_i1hxiinv__91df7bfb{line-height:0;color:var(--plasma-combobox-disclosure-icon-color);cursor:var(--i1hxiinv-0);}.Combobox_styles_isfa46_i1hxiinv__91df7bfb .Combobox_styles_isfa46_arrowInverse__91df7bfb{-webkit-transform:rotate(-180deg);-ms-transform:rotate(-180deg);transform:rotate(-180deg);}.Combobox_styles_isfa46_i1hxiinv__91df7bfb:hover,.Combobox_styles_isfa46_i1hxiinv__91df7bfb:active{color:var(--i1hxiinv-1);}
167
- .Combobox_styles_isfa46_sr87xox__91df7bfb{width:var(--sr87xox-0);height:var(--sr87xox-0);}
164
+ .Combobox_styles_261unw_lxiiees__2c339479{width:var(--lxiiees-0);padding:calc(var(--plasma-combobox-padding) + var(--plasma-select-dropdown-border-width,0rem));border-radius:var(--plasma-combobox-border-radius);box-sizing:border-box;background:var(--surface-solid-card);box-shadow:0px 4px 14px -4px rgba(8,8,8,0.08),0px 1px 4px -1px rgba(0,0,0,0.04), inset 0 0 0 var(--plasma-select-dropdown-border-width,0rem) var(--plasma-select-dropdown-border-color,transparent);}
165
+ .Combobox_styles_261unw_u1veo3wn__2c339479{max-height:var(--u1veo3wn-0);overflow-x:hidden;overflow-y:var(--u1veo3wn-1);border-radius:calc(var(--plasma-combobox-border-radius) - 0.125rem - var(--plasma-select-dropdown-border-width,0rem));margin:0;padding:0;}.Combobox_styles_261unw_u1veo3wn__2c339479 .Combobox_styles_261unw_comboboxEmptyStateWrapper__2c339479{box-shadow:none;}
166
+ .Combobox_styles_261unw_i1hxiinv__2c339479{line-height:0;color:var(--plasma-combobox-disclosure-icon-color);cursor:var(--i1hxiinv-0);}.Combobox_styles_261unw_i1hxiinv__2c339479 .Combobox_styles_261unw_arrowInverse__2c339479{-webkit-transform:rotate(-180deg);-ms-transform:rotate(-180deg);transform:rotate(-180deg);}.Combobox_styles_261unw_i1hxiinv__2c339479:hover,.Combobox_styles_261unw_i1hxiinv__2c339479:active{color:var(--i1hxiinv-1);}
167
+ .Combobox_styles_261unw_sr87xox__2c339479{width:var(--sr87xox-0);height:var(--sr87xox-0);}
168
168
 
169
- .Combobox_styles_isfa46_spp7ogj__91df7bfb{--plasma-emptystate-border-radius:var(--plasma-combobox-new-textfield-border-radius);--plasma-emptystate-padding:var(--plasma-combobox-new-empty-state-padding);--plasma-emptystate-font-family:var(--plasma-combobox-new-textfield-font-family);--plasma-emptystate-font-size:var(--plasma-combobox-new-textfield-font-size);--plasma-emptystate-font-style:var(--plasma-combobox-new-textfield-font-style);--plasma-emptystate-font-weight:var(--plasma-combobox-new-textfield-font-weight);--plasma-emptystate-font-letter-spacing:var(--plasma-combobox-new-textfield-letter-spacing);--plasma-emptystate-font-line-height:var(--plasma-combobox-new-textfield-line-height);}
170
- .Combobox_styles_isfa46_s3gft12__91df7bfb{margin:0;padding:0;}
169
+ .Combobox_styles_261unw_spp7ogj__2c339479{--plasma-emptystate-border-radius:var(--plasma-combobox-new-textfield-border-radius);--plasma-emptystate-padding:var(--plasma-combobox-new-empty-state-padding);--plasma-emptystate-font-family:var(--plasma-combobox-new-textfield-font-family);--plasma-emptystate-font-size:var(--plasma-combobox-new-textfield-font-size);--plasma-emptystate-font-style:var(--plasma-combobox-new-textfield-font-style);--plasma-emptystate-font-weight:var(--plasma-combobox-new-textfield-font-weight);--plasma-emptystate-font-letter-spacing:var(--plasma-combobox-new-textfield-letter-spacing);--plasma-emptystate-font-line-height:var(--plasma-combobox-new-textfield-line-height);}
170
+ .Combobox_styles_261unw_s3gft12__2c339479{margin:0;padding:0;}
171
171
 
172
172
  .SelectNative_styles_18yw2bf_st8j5fy__14a96fe5{visibility:hidden;width:0;height:0;opacity:0;margin:0;padding:0;border:none;}
@@ -30,7 +30,7 @@ import { VirtualList } from './ui/VirtualList/VirtualList.js';
30
30
  import { Inner } from './ui/Inner/Inner.js';
31
31
  import { getRemovedElement } from './utils/getRemovedElement.js';
32
32
 
33
- var _excluded = ["name", "multiple", "value", "onChange", "defaultValue", "isTargetAmount", "targetAmount", "items", "placement", "label", "placeholder", "helperText", "contentLeft", "textBefore", "textAfter", "variant", "listOverflow", "listHeight", "listMaxHeight", "listWidth", "portal", "renderItem", "view", "size", "labelPlacement", "keepPlaceholder", "readOnly", "disabled", "alwaysOpened", "filter", "closeAfterSelect", "renderValue", "zIndex", "beforeList", "afterList", "virtual", "hintView", "hintSize", "emptyStateDescription", "onChangeValue", "onScroll", "onToggle", "_offset"];
33
+ var _excluded = ["name", "multiple", "value", "onChange", "defaultValue", "isTargetAmount", "targetAmount", "items", "placement", "label", "placeholder", "helperText", "contentLeft", "textBefore", "textAfter", "variant", "listOverflow", "listHeight", "listMaxHeight", "listWidth", "portal", "renderItem", "view", "size", "labelPlacement", "keepPlaceholder", "readOnly", "disabled", "alwaysOpened", "filter", "closeAfterSelect", "renderValue", "zIndex", "beforeList", "afterList", "virtual", "hintView", "hintSize", "emptyStateDescription", "onChangeValue", "onScroll", "onToggle", "mode", "_offset"];
34
34
 
35
35
  /**
36
36
  * Поле ввода с выпадающим списком и возможностью фильтрации и выбора элементов.
@@ -56,7 +56,6 @@ var comboboxRoot = function comboboxRoot(Root) {
56
56
  textAfter = props.textAfter,
57
57
  _props$variant = props.variant,
58
58
  variant = _props$variant === void 0 ? 'normal' : _props$variant,
59
- listOverflow = props.listOverflow,
60
59
  listHeight = props.listHeight,
61
60
  listMaxHeight = props.listMaxHeight,
62
61
  listWidth = props.listWidth,
@@ -86,6 +85,8 @@ var comboboxRoot = function comboboxRoot(Root) {
86
85
  onChangeValue = props.onChangeValue,
87
86
  onScroll = props.onScroll,
88
87
  onToggle = props.onToggle,
88
+ _props$mode = props.mode,
89
+ mode = _props$mode === void 0 ? 'default' : _props$mode,
89
90
  _offset = props._offset,
90
91
  rest = _objectWithoutProperties(props, _excluded);
91
92
  var transformedItems = useMemo(function () {
@@ -113,6 +114,7 @@ var comboboxRoot = function comboboxRoot(Root) {
113
114
  var floatingPopoverRef = useRef(null);
114
115
  var inputForkRef = useForkRef(inputRef, ref);
115
116
  var treeId = safeUseId();
117
+ var listWrapperRef = useRef(null);
116
118
  var filteredItems = useMemo(function () {
117
119
  return filterItems(transformedItems, textValue, getTextValue(multiple, value, valueToItemMap, renderValue), filter);
118
120
  }, [transformedItems, textValue, filter]);
@@ -182,22 +184,11 @@ var comboboxRoot = function comboboxRoot(Root) {
182
184
  setInternalValue(newValue);
183
185
  }
184
186
  };
185
- var handleClickArrow = function handleClickArrow() {
186
- if (disabled || readOnly) {
187
- return;
188
- }
189
- if (isCurrentListOpen) {
190
- dispatchPath({
191
- type: 'reset'
192
- });
193
- } else {
194
- dispatchPath({
195
- type: 'opened_first_level'
196
- });
197
- }
198
- dispatchFocusedPath({
199
- type: 'reset'
200
- });
187
+ var handleClickArrow = function handleClickArrow(e) {
188
+ handleListToggle(!isCurrentListOpen);
189
+
190
+ // При клике на иконку закрытия фокус не должен становиться в инпут.
191
+ e.stopPropagation();
201
192
  };
202
193
 
203
194
  // Обработчик изменения значения в инпуте
@@ -337,10 +328,22 @@ var comboboxRoot = function comboboxRoot(Root) {
337
328
  type: 'reset'
338
329
  });
339
330
  }
331
+
332
+ // Закрываем список, если элемент уже выбран.
333
+ if (mode === 'radio' && isCurrentChecked) {
334
+ return;
335
+ }
340
336
  if (onChange) {
341
337
  onChange(isCurrentChecked ? '' : item.value, item);
342
338
  }
343
339
  };
340
+
341
+ // Обработчик клика на таргет
342
+ var handleTargetClick = function handleTargetClick() {
343
+ if (!isCurrentListOpen) {
344
+ handleListToggle(true);
345
+ }
346
+ };
344
347
  var getChips = function getChips() {
345
348
  if (multiple && Array.isArray(value)) {
346
349
  if (value.length === 0) return [];
@@ -466,13 +469,14 @@ var comboboxRoot = function comboboxRoot(Root) {
466
469
  }, /*#__PURE__*/React.createElement(FloatingPopover, {
467
470
  ref: floatingPopoverRef,
468
471
  opened: isCurrentListOpen,
469
- onToggle: handleListToggle,
470
472
  placement: placement,
471
473
  portal: portal,
472
474
  listWidth: listWidth,
473
475
  offset: _offset,
474
476
  target: function target(referenceRef) {
475
- return /*#__PURE__*/React.createElement(StyledTextField, _extends({
477
+ return /*#__PURE__*/React.createElement("div", {
478
+ onClick: handleTargetClick
479
+ }, /*#__PURE__*/React.createElement(StyledTextField, _extends({
476
480
  ref: name ? inputRef : inputForkRef,
477
481
  inputWrapperRef: referenceRef,
478
482
  value: textValue,
@@ -486,7 +490,8 @@ var comboboxRoot = function comboboxRoot(Root) {
486
490
  contentLeft: contentLeft,
487
491
  contentRight: /*#__PURE__*/React.createElement(IconArrowWrapper, {
488
492
  disabled: disabled,
489
- onClick: handleClickArrow
493
+ onClick: handleClickArrow,
494
+ className: classes.comboboxTargetArrow
490
495
  }, /*#__PURE__*/React.createElement(StyledArrow, {
491
496
  color: "inherit",
492
497
  size: sizeToIconSize(size),
@@ -513,7 +518,7 @@ var comboboxRoot = function comboboxRoot(Root) {
513
518
  enumerationType: 'plain'
514
519
  }, rest, {
515
520
  _onEnterDisabled: true // Пропс для отключения обработчика Enter внутри Textfield
516
- }));
521
+ })));
517
522
  },
518
523
  zIndex: zIndex,
519
524
  isInner: false
@@ -525,6 +530,7 @@ var comboboxRoot = function comboboxRoot(Root) {
525
530
  readOnly: readOnly,
526
531
  name: name
527
532
  }, /*#__PURE__*/React.createElement(ListWrapper, {
533
+ ref: listWrapperRef,
528
534
  listWidth: listWidth
529
535
  }, /*#__PURE__*/React.createElement(Ul, {
530
536
  role: "tree",
@@ -533,7 +539,6 @@ var comboboxRoot = function comboboxRoot(Root) {
533
539
  listMaxHeight: listMaxHeight || listHeight,
534
540
  ref: targetRef,
535
541
  virtual: virtual,
536
- listOverflow: listOverflow,
537
542
  onScroll: virtual ? undefined : onScroll
538
543
  }, beforeList, isEmpty(filteredItems) ? /*#__PURE__*/React.createElement(StyledEmptyState, {
539
544
  className: classes.emptyStateWrapper,
@@ -557,7 +562,8 @@ var comboboxRoot = function comboboxRoot(Root) {
557
562
  path: path,
558
563
  dispatchPath: dispatchPath,
559
564
  index: index,
560
- listWidth: listWidth
565
+ listWidth: listWidth,
566
+ portal: listWrapperRef
561
567
  });
562
568
  })), afterList)))))));
563
569
  });