@salutejs/plasma-new-hope 0.326.1-canary.2018.15778039519.0 → 0.326.1-canary.2019.15674501487.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 (499) hide show
  1. package/cjs/components/Autocomplete/Autocomplete.js +3 -3
  2. package/cjs/components/Autocomplete/Autocomplete.js.map +1 -1
  3. package/cjs/components/Autocomplete/FloatingPopover.js +2 -2
  4. package/cjs/components/Autocomplete/FloatingPopover.js.map +1 -1
  5. package/cjs/components/Calendar/CalendarBase/CalendarBase.js +0 -12
  6. package/cjs/components/Calendar/CalendarBase/CalendarBase.js.map +1 -1
  7. package/cjs/components/Calendar/CalendarDouble/CalendarDouble.js +0 -12
  8. package/cjs/components/Calendar/CalendarDouble/CalendarDouble.js.map +1 -1
  9. package/cjs/components/Calendar/ui/CalendarDays/CalendarDays.js +0 -3
  10. package/cjs/components/Calendar/ui/CalendarDays/CalendarDays.js.map +1 -1
  11. package/cjs/components/Calendar/ui/CalendarMonths/CalendarMonths.js +0 -3
  12. package/cjs/components/Calendar/ui/CalendarMonths/CalendarMonths.js.map +1 -1
  13. package/cjs/components/Calendar/ui/CalendarQuarters/CalendarQuarters.js +0 -3
  14. package/cjs/components/Calendar/ui/CalendarQuarters/CalendarQuarters.js.map +1 -1
  15. package/cjs/components/Calendar/ui/CalendarYears/CalendarYears.js +0 -3
  16. package/cjs/components/Calendar/ui/CalendarYears/CalendarYears.js.map +1 -1
  17. package/cjs/components/Carousel/CarouselNew/Carousel.css +5 -5
  18. package/cjs/components/Carousel/CarouselNew/Carousel.js +6 -9
  19. package/cjs/components/Carousel/CarouselNew/Carousel.js.map +1 -1
  20. package/cjs/components/Carousel/CarouselNew/Carousel.styles.js +4 -13
  21. package/cjs/components/Carousel/CarouselNew/Carousel.styles.js.map +1 -1
  22. package/cjs/components/Carousel/CarouselNew/Carousel.styles_151pk3s.css +5 -0
  23. package/cjs/components/Carousel/CarouselNew/Carousel.tokens.js +1 -9
  24. package/cjs/components/Carousel/CarouselNew/Carousel.tokens.js.map +1 -1
  25. package/cjs/components/Carousel/CarouselNew/hooks/useCarousel.js +357 -49
  26. package/cjs/components/Carousel/CarouselNew/hooks/useCarousel.js.map +1 -1
  27. package/cjs/components/Carousel/CarouselNew/ui/Dots/Dots.js +38 -52
  28. package/cjs/components/Carousel/CarouselNew/ui/Dots/Dots.js.map +1 -1
  29. package/cjs/components/Carousel/CarouselOld/CarouselItem.js +1 -1
  30. package/cjs/components/Carousel/CarouselOld/CarouselItem.js.map +1 -1
  31. package/{es/components/Carousel/CarouselOld/CarouselItem_uvoxfy.css → cjs/components/Carousel/CarouselOld/CarouselItem_cghzk7.css} +1 -1
  32. package/cjs/components/Checkbox/Checkbox.js +1 -2
  33. package/cjs/components/Checkbox/Checkbox.js.map +1 -1
  34. package/cjs/components/CodeField/CodeField.css +6 -6
  35. package/cjs/components/CodeField/CodeField.styles.js +1 -1
  36. package/cjs/components/CodeField/CodeField.styles.js.map +1 -1
  37. package/{es/components/CodeField/CodeField.styles_7zxgpc.css → cjs/components/CodeField/CodeField.styles_ebdpd0.css} +1 -1
  38. package/cjs/components/Combobox/ComboboxNew/Combobox.js +1 -2
  39. package/cjs/components/Combobox/ComboboxNew/Combobox.js.map +1 -1
  40. package/cjs/components/Combobox/ComboboxNew/FloatingPopover.js +2 -2
  41. package/cjs/components/Combobox/ComboboxNew/FloatingPopover.js.map +1 -1
  42. package/cjs/components/Combobox/ComboboxNew/ui/Inner/Inner.js +2 -2
  43. package/cjs/components/Combobox/ComboboxNew/ui/Inner/Inner.js.map +1 -1
  44. package/cjs/components/Combobox/ComboboxOld/Combobox.js +1 -2
  45. package/cjs/components/Combobox/ComboboxOld/Combobox.js.map +1 -1
  46. package/cjs/components/Combobox/ComboboxOld/ui/ComboboxItem/ComboboxItem.js +3 -3
  47. package/cjs/components/Combobox/ComboboxOld/ui/ComboboxItem/ComboboxItem.js.map +1 -1
  48. package/cjs/components/Drawer/Drawer.js +3 -4
  49. package/cjs/components/Drawer/Drawer.js.map +1 -1
  50. package/cjs/components/Drawer/hooks/useDrawer.js +2 -2
  51. package/cjs/components/Drawer/hooks/useDrawer.js.map +1 -1
  52. package/cjs/components/Dropdown/Dropdown.js +2 -2
  53. package/cjs/components/Dropdown/Dropdown.js.map +1 -1
  54. package/cjs/components/Dropdown/FloatingPopover.js +2 -2
  55. package/cjs/components/Dropdown/FloatingPopover.js.map +1 -1
  56. package/cjs/components/Dropdown/ui/DropdownDivider/DropdownDivider.js.map +1 -1
  57. package/cjs/components/Dropdown/ui/DropdownFooter/DropdownFooter.js.map +1 -1
  58. package/cjs/components/Dropdown/ui/DropdownGroup/DropdownGroup.js.map +1 -1
  59. package/cjs/components/Dropdown/ui/DropdownHeader/DropdownHeader.js.map +1 -1
  60. package/cjs/components/Dropdown/ui/DropdownInner/DropdownInner.js +2 -2
  61. package/cjs/components/Dropdown/ui/DropdownInner/DropdownInner.js.map +1 -1
  62. package/cjs/components/Dropdown/ui/DropdownItemOld/DropdownItemOld.js +3 -3
  63. package/cjs/components/Dropdown/ui/DropdownItemOld/DropdownItemOld.js.map +1 -1
  64. package/cjs/components/Dropdown/ui/DropdownOld/DropdownOld.js.map +1 -1
  65. package/cjs/components/Mask/Mask.js +3 -3
  66. package/cjs/components/Mask/Mask.js.map +1 -1
  67. package/cjs/components/Modal/Modal.js +2 -3
  68. package/cjs/components/Modal/Modal.js.map +1 -1
  69. package/cjs/components/Modal/hooks/useModal.js +1 -1
  70. package/cjs/components/Modal/hooks/useModal.js.map +1 -1
  71. package/cjs/components/Popup/Popup.js +1 -2
  72. package/cjs/components/Popup/Popup.js.map +1 -1
  73. package/cjs/components/Popup/PopupContext.js +15 -13
  74. package/cjs/components/Popup/PopupContext.js.map +1 -1
  75. package/cjs/components/Radiobox/Radiobox.js +2 -3
  76. package/cjs/components/Radiobox/Radiobox.js.map +1 -1
  77. package/cjs/components/Rating/Rating.css +6 -6
  78. package/cjs/components/Rating/Rating.styles.js +1 -1
  79. package/cjs/components/Rating/Rating.styles.js.map +1 -1
  80. package/{es/components/Rating/Rating.styles_hi5qwl.css → cjs/components/Rating/Rating.styles_dg76kk.css} +1 -1
  81. package/cjs/components/Rating/utils/getIcons.css +6 -6
  82. package/cjs/components/Segment/ui/SegmentGroup/SegmentGroup.js +3 -3
  83. package/cjs/components/Segment/ui/SegmentGroup/SegmentGroup.js.map +1 -1
  84. package/cjs/components/Segment/ui/SegmentItem/SegmentItem.js +2 -2
  85. package/cjs/components/Segment/ui/SegmentItem/SegmentItem.js.map +1 -1
  86. package/cjs/components/Select/FloatingPopover.js +2 -2
  87. package/cjs/components/Select/FloatingPopover.js.map +1 -1
  88. package/cjs/components/Select/Select.js +2 -2
  89. package/cjs/components/Select/Select.js.map +1 -1
  90. package/cjs/components/Select/ui/Inner/Inner.js +2 -2
  91. package/cjs/components/Select/ui/Inner/Inner.js.map +1 -1
  92. package/cjs/components/Spinner/Spinner.js +2 -2
  93. package/cjs/components/Spinner/Spinner.js.map +1 -1
  94. package/cjs/components/Tabs/ui/horizontal/HorizontalTabs/HorizontalTabs.js +3 -3
  95. package/cjs/components/Tabs/ui/horizontal/HorizontalTabs/HorizontalTabs.js.map +1 -1
  96. package/cjs/components/Tabs/ui/vertical/VerticalTabs/VerticalTabs.css +4 -4
  97. package/cjs/components/Tabs/ui/vertical/VerticalTabs/VerticalTabs.js +3 -3
  98. package/cjs/components/Tabs/ui/vertical/VerticalTabs/VerticalTabs.js.map +1 -1
  99. package/cjs/components/Tabs/ui/vertical/VerticalTabs/VerticalTabs.styles.js +1 -1
  100. package/cjs/components/Tabs/ui/vertical/VerticalTabs/VerticalTabs.styles.js.map +1 -1
  101. package/cjs/components/Tabs/ui/vertical/VerticalTabs/{VerticalTabs.styles_1egpt45.css → VerticalTabs.styles_1khdtzl.css} +1 -1
  102. package/cjs/components/TextArea/ui/Hint/Hint.js.map +1 -1
  103. package/cjs/components/TextField/TextField.js +3 -4
  104. package/cjs/components/TextField/TextField.js.map +1 -1
  105. package/cjs/components/TextField/ui/Hint/Hint.js.map +1 -1
  106. package/cjs/index.css +22 -22
  107. package/cjs/index.js +0 -2
  108. package/cjs/index.js.map +1 -1
  109. package/emotion/cjs/components/Autocomplete/Autocomplete.js +3 -3
  110. package/emotion/cjs/components/Autocomplete/FloatingPopover.js +2 -2
  111. package/emotion/cjs/components/Calendar/CalendarBase/CalendarBase.js +0 -12
  112. package/emotion/cjs/components/Calendar/CalendarDouble/CalendarDouble.js +0 -12
  113. package/emotion/cjs/components/Calendar/ui/CalendarDays/CalendarDays.js +0 -3
  114. package/emotion/cjs/components/Calendar/ui/CalendarMonths/CalendarMonths.js +0 -3
  115. package/emotion/cjs/components/Calendar/ui/CalendarQuarters/CalendarQuarters.js +0 -3
  116. package/emotion/cjs/components/Calendar/ui/CalendarYears/CalendarYears.js +0 -3
  117. package/emotion/cjs/components/Carousel/CarouselNew/Carousel.js +6 -9
  118. package/emotion/cjs/components/Carousel/CarouselNew/Carousel.styles.js +17 -12
  119. package/emotion/cjs/components/Carousel/CarouselNew/Carousel.tokens.js +1 -9
  120. package/emotion/cjs/components/Carousel/CarouselNew/hooks/useCarousel.js +353 -50
  121. package/emotion/cjs/components/Carousel/CarouselNew/ui/Dots/Dots.js +38 -52
  122. package/emotion/cjs/components/Carousel/CarouselOld/CarouselItem.js +1 -1
  123. package/emotion/cjs/components/Checkbox/Checkbox.js +1 -1
  124. package/emotion/cjs/components/CodeField/CodeField.styles.js +6 -6
  125. package/emotion/cjs/components/Combobox/ComboboxNew/Combobox.js +1 -1
  126. package/emotion/cjs/components/Combobox/ComboboxNew/FloatingPopover.js +2 -2
  127. package/emotion/cjs/components/Combobox/ComboboxNew/ui/Inner/Inner.js +3 -2
  128. package/emotion/cjs/components/Combobox/ComboboxOld/Combobox.js +1 -1
  129. package/emotion/cjs/components/Combobox/ComboboxOld/ui/ComboboxItem/ComboboxItem.js +7 -6
  130. package/emotion/cjs/components/Drawer/Drawer.js +8 -8
  131. package/emotion/cjs/components/Drawer/hooks/useDrawer.js +2 -2
  132. package/emotion/cjs/components/Dropdown/Dropdown.js +2 -1
  133. package/emotion/cjs/components/Dropdown/FloatingPopover.js +2 -2
  134. package/emotion/cjs/components/Dropdown/ui/DropdownInner/DropdownInner.js +4 -4
  135. package/emotion/cjs/components/Dropdown/ui/DropdownItemOld/DropdownItemOld.js +3 -2
  136. package/emotion/cjs/components/Dropdown/ui/DropdownOld/DropdownOld.js +1 -1
  137. package/emotion/cjs/components/Mask/Mask.js +3 -3
  138. package/emotion/cjs/components/Modal/Modal.js +5 -6
  139. package/emotion/cjs/components/Modal/hooks/useModal.js +1 -1
  140. package/emotion/cjs/components/Popup/Popup.js +1 -1
  141. package/emotion/cjs/components/Popup/PopupContext.js +20 -14
  142. package/emotion/cjs/components/Radiobox/Radiobox.js +2 -2
  143. package/emotion/cjs/components/Rating/Rating.styles.js +11 -11
  144. package/emotion/cjs/components/Segment/ui/SegmentGroup/SegmentGroup.js +3 -2
  145. package/emotion/cjs/components/Segment/ui/SegmentItem/SegmentItem.js +2 -1
  146. package/emotion/cjs/components/Select/FloatingPopover.js +5 -5
  147. package/emotion/cjs/components/Select/Select.js +2 -1
  148. package/emotion/cjs/components/Select/ui/Inner/Inner.js +2 -1
  149. package/emotion/cjs/components/Spinner/Spinner.js +2 -2
  150. package/emotion/cjs/components/Tabs/ui/horizontal/HorizontalTabs/HorizontalTabs.js +3 -2
  151. package/emotion/cjs/components/Tabs/ui/vertical/VerticalTabs/VerticalTabs.js +3 -2
  152. package/emotion/cjs/components/Tabs/ui/vertical/VerticalTabs/VerticalTabs.styles.js +8 -8
  153. package/emotion/cjs/components/TextArea/ui/Hint/Hint.js +1 -1
  154. package/emotion/cjs/components/TextField/TextField.js +4 -4
  155. package/emotion/cjs/components/TextField/ui/Hint/Hint.js +1 -1
  156. package/emotion/cjs/examples/plasma_b2c/components/Carousel/Carousel.config.js +2 -2
  157. package/emotion/cjs/examples/plasma_b2c/components/Carousel/Carousel.stories.tsx +14 -10
  158. package/emotion/cjs/examples/plasma_web/components/Carousel/Carousel.config.js +2 -2
  159. package/emotion/cjs/examples/plasma_web/components/Carousel/Carousel.stories.tsx +15 -10
  160. package/emotion/cjs/hooks/index.js +1 -8
  161. package/emotion/es/components/Autocomplete/Autocomplete.js +1 -1
  162. package/emotion/es/components/Autocomplete/FloatingPopover.js +1 -1
  163. package/emotion/es/components/Calendar/CalendarBase/CalendarBase.js +0 -12
  164. package/emotion/es/components/Calendar/CalendarDouble/CalendarDouble.js +0 -12
  165. package/emotion/es/components/Calendar/ui/CalendarDays/CalendarDays.js +0 -3
  166. package/emotion/es/components/Calendar/ui/CalendarMonths/CalendarMonths.js +0 -3
  167. package/emotion/es/components/Calendar/ui/CalendarQuarters/CalendarQuarters.js +0 -3
  168. package/emotion/es/components/Calendar/ui/CalendarYears/CalendarYears.js +0 -3
  169. package/emotion/es/components/Carousel/CarouselNew/Carousel.js +6 -9
  170. package/emotion/es/components/Carousel/CarouselNew/Carousel.styles.js +18 -13
  171. package/emotion/es/components/Carousel/CarouselNew/Carousel.tokens.js +1 -9
  172. package/emotion/es/components/Carousel/CarouselNew/hooks/useCarousel.js +349 -50
  173. package/emotion/es/components/Carousel/CarouselNew/ui/Dots/Dots.js +38 -52
  174. package/emotion/es/components/Carousel/CarouselOld/CarouselItem.js +1 -1
  175. package/emotion/es/components/Checkbox/Checkbox.js +1 -2
  176. package/emotion/es/components/CodeField/CodeField.styles.js +6 -6
  177. package/emotion/es/components/Combobox/ComboboxNew/Combobox.js +1 -2
  178. package/emotion/es/components/Combobox/ComboboxNew/FloatingPopover.js +1 -1
  179. package/emotion/es/components/Combobox/ComboboxNew/ui/Inner/Inner.js +1 -1
  180. package/emotion/es/components/Combobox/ComboboxOld/Combobox.js +1 -2
  181. package/emotion/es/components/Combobox/ComboboxOld/ui/ComboboxItem/ComboboxItem.js +1 -1
  182. package/emotion/es/components/Drawer/Drawer.js +3 -3
  183. package/emotion/es/components/Drawer/hooks/useDrawer.js +2 -2
  184. package/emotion/es/components/Dropdown/Dropdown.js +1 -1
  185. package/emotion/es/components/Dropdown/FloatingPopover.js +1 -1
  186. package/emotion/es/components/Dropdown/ui/DropdownInner/DropdownInner.js +1 -1
  187. package/emotion/es/components/Dropdown/ui/DropdownItemOld/DropdownItemOld.js +2 -1
  188. package/emotion/es/components/Dropdown/ui/DropdownOld/DropdownOld.js +1 -1
  189. package/emotion/es/components/Mask/Mask.js +3 -3
  190. package/emotion/es/components/Modal/Modal.js +3 -4
  191. package/emotion/es/components/Modal/hooks/useModal.js +1 -1
  192. package/emotion/es/components/Popup/Popup.js +2 -2
  193. package/emotion/es/components/Popup/PopupContext.js +20 -14
  194. package/emotion/es/components/Radiobox/Radiobox.js +2 -2
  195. package/emotion/es/components/Rating/Rating.styles.js +11 -11
  196. package/emotion/es/components/Segment/ui/SegmentGroup/SegmentGroup.js +2 -1
  197. package/emotion/es/components/Segment/ui/SegmentItem/SegmentItem.js +2 -1
  198. package/emotion/es/components/Select/FloatingPopover.js +1 -1
  199. package/emotion/es/components/Select/Select.js +2 -1
  200. package/emotion/es/components/Select/ui/Inner/Inner.js +2 -1
  201. package/emotion/es/components/Spinner/Spinner.js +1 -1
  202. package/emotion/es/components/Tabs/ui/horizontal/HorizontalTabs/HorizontalTabs.js +2 -1
  203. package/emotion/es/components/Tabs/ui/vertical/VerticalTabs/VerticalTabs.js +2 -1
  204. package/emotion/es/components/Tabs/ui/vertical/VerticalTabs/VerticalTabs.styles.js +8 -8
  205. package/emotion/es/components/TextArea/ui/Hint/Hint.js +1 -1
  206. package/emotion/es/components/TextField/TextField.js +3 -3
  207. package/emotion/es/components/TextField/ui/Hint/Hint.js +1 -1
  208. package/emotion/es/examples/plasma_b2c/components/Carousel/Carousel.config.js +2 -2
  209. package/emotion/es/examples/plasma_b2c/components/Carousel/Carousel.stories.tsx +14 -10
  210. package/emotion/es/examples/plasma_web/components/Carousel/Carousel.config.js +2 -2
  211. package/emotion/es/examples/plasma_web/components/Carousel/Carousel.stories.tsx +15 -10
  212. package/emotion/es/hooks/index.js +1 -2
  213. package/es/components/Autocomplete/Autocomplete.js +1 -1
  214. package/es/components/Autocomplete/Autocomplete.js.map +1 -1
  215. package/es/components/Autocomplete/FloatingPopover.js +1 -1
  216. package/es/components/Autocomplete/FloatingPopover.js.map +1 -1
  217. package/es/components/Calendar/CalendarBase/CalendarBase.js +0 -12
  218. package/es/components/Calendar/CalendarBase/CalendarBase.js.map +1 -1
  219. package/es/components/Calendar/CalendarDouble/CalendarDouble.js +0 -12
  220. package/es/components/Calendar/CalendarDouble/CalendarDouble.js.map +1 -1
  221. package/es/components/Calendar/ui/CalendarDays/CalendarDays.js +0 -3
  222. package/es/components/Calendar/ui/CalendarDays/CalendarDays.js.map +1 -1
  223. package/es/components/Calendar/ui/CalendarMonths/CalendarMonths.js +0 -3
  224. package/es/components/Calendar/ui/CalendarMonths/CalendarMonths.js.map +1 -1
  225. package/es/components/Calendar/ui/CalendarQuarters/CalendarQuarters.js +0 -3
  226. package/es/components/Calendar/ui/CalendarQuarters/CalendarQuarters.js.map +1 -1
  227. package/es/components/Calendar/ui/CalendarYears/CalendarYears.js +0 -3
  228. package/es/components/Calendar/ui/CalendarYears/CalendarYears.js.map +1 -1
  229. package/es/components/Carousel/CarouselNew/Carousel.css +5 -5
  230. package/es/components/Carousel/CarouselNew/Carousel.js +6 -9
  231. package/es/components/Carousel/CarouselNew/Carousel.js.map +1 -1
  232. package/es/components/Carousel/CarouselNew/Carousel.styles.js +4 -13
  233. package/es/components/Carousel/CarouselNew/Carousel.styles.js.map +1 -1
  234. package/es/components/Carousel/CarouselNew/Carousel.styles_151pk3s.css +5 -0
  235. package/es/components/Carousel/CarouselNew/Carousel.tokens.js +1 -9
  236. package/es/components/Carousel/CarouselNew/Carousel.tokens.js.map +1 -1
  237. package/es/components/Carousel/CarouselNew/hooks/useCarousel.js +349 -51
  238. package/es/components/Carousel/CarouselNew/hooks/useCarousel.js.map +1 -1
  239. package/es/components/Carousel/CarouselNew/ui/Dots/Dots.js +38 -52
  240. package/es/components/Carousel/CarouselNew/ui/Dots/Dots.js.map +1 -1
  241. package/es/components/Carousel/CarouselOld/CarouselItem.js +1 -1
  242. package/es/components/Carousel/CarouselOld/CarouselItem.js.map +1 -1
  243. package/{cjs/components/Carousel/CarouselOld/CarouselItem_uvoxfy.css → es/components/Carousel/CarouselOld/CarouselItem_cghzk7.css} +1 -1
  244. package/es/components/Checkbox/Checkbox.js +1 -2
  245. package/es/components/Checkbox/Checkbox.js.map +1 -1
  246. package/es/components/CodeField/CodeField.css +6 -6
  247. package/es/components/CodeField/CodeField.styles.js +1 -1
  248. package/es/components/CodeField/CodeField.styles.js.map +1 -1
  249. package/{cjs/components/CodeField/CodeField.styles_7zxgpc.css → es/components/CodeField/CodeField.styles_ebdpd0.css} +1 -1
  250. package/es/components/Combobox/ComboboxNew/Combobox.js +1 -2
  251. package/es/components/Combobox/ComboboxNew/Combobox.js.map +1 -1
  252. package/es/components/Combobox/ComboboxNew/FloatingPopover.js +1 -1
  253. package/es/components/Combobox/ComboboxNew/FloatingPopover.js.map +1 -1
  254. package/es/components/Combobox/ComboboxNew/ui/Inner/Inner.js +1 -1
  255. package/es/components/Combobox/ComboboxNew/ui/Inner/Inner.js.map +1 -1
  256. package/es/components/Combobox/ComboboxOld/Combobox.js +1 -2
  257. package/es/components/Combobox/ComboboxOld/Combobox.js.map +1 -1
  258. package/es/components/Combobox/ComboboxOld/ui/ComboboxItem/ComboboxItem.js +2 -2
  259. package/es/components/Combobox/ComboboxOld/ui/ComboboxItem/ComboboxItem.js.map +1 -1
  260. package/es/components/Drawer/Drawer.js +3 -4
  261. package/es/components/Drawer/Drawer.js.map +1 -1
  262. package/es/components/Drawer/hooks/useDrawer.js +2 -2
  263. package/es/components/Drawer/hooks/useDrawer.js.map +1 -1
  264. package/es/components/Dropdown/Dropdown.js +1 -1
  265. package/es/components/Dropdown/Dropdown.js.map +1 -1
  266. package/es/components/Dropdown/FloatingPopover.js +1 -1
  267. package/es/components/Dropdown/FloatingPopover.js.map +1 -1
  268. package/es/components/Dropdown/ui/DropdownDivider/DropdownDivider.js.map +1 -1
  269. package/es/components/Dropdown/ui/DropdownFooter/DropdownFooter.js.map +1 -1
  270. package/es/components/Dropdown/ui/DropdownGroup/DropdownGroup.js.map +1 -1
  271. package/es/components/Dropdown/ui/DropdownHeader/DropdownHeader.js.map +1 -1
  272. package/es/components/Dropdown/ui/DropdownInner/DropdownInner.js +1 -1
  273. package/es/components/Dropdown/ui/DropdownInner/DropdownInner.js.map +1 -1
  274. package/es/components/Dropdown/ui/DropdownItemOld/DropdownItemOld.js +2 -2
  275. package/es/components/Dropdown/ui/DropdownItemOld/DropdownItemOld.js.map +1 -1
  276. package/es/components/Dropdown/ui/DropdownOld/DropdownOld.js.map +1 -1
  277. package/es/components/Mask/Mask.js +3 -3
  278. package/es/components/Mask/Mask.js.map +1 -1
  279. package/es/components/Modal/Modal.js +2 -3
  280. package/es/components/Modal/Modal.js.map +1 -1
  281. package/es/components/Modal/hooks/useModal.js +1 -1
  282. package/es/components/Modal/hooks/useModal.js.map +1 -1
  283. package/es/components/Popup/Popup.js +1 -2
  284. package/es/components/Popup/Popup.js.map +1 -1
  285. package/es/components/Popup/PopupContext.js +16 -14
  286. package/es/components/Popup/PopupContext.js.map +1 -1
  287. package/es/components/Radiobox/Radiobox.js +2 -3
  288. package/es/components/Radiobox/Radiobox.js.map +1 -1
  289. package/es/components/Rating/Rating.css +6 -6
  290. package/es/components/Rating/Rating.styles.js +1 -1
  291. package/es/components/Rating/Rating.styles.js.map +1 -1
  292. package/{cjs/components/Rating/Rating.styles_hi5qwl.css → es/components/Rating/Rating.styles_dg76kk.css} +1 -1
  293. package/es/components/Rating/utils/getIcons.css +6 -6
  294. package/es/components/Segment/ui/SegmentGroup/SegmentGroup.js +2 -2
  295. package/es/components/Segment/ui/SegmentGroup/SegmentGroup.js.map +1 -1
  296. package/es/components/Segment/ui/SegmentItem/SegmentItem.js +1 -1
  297. package/es/components/Segment/ui/SegmentItem/SegmentItem.js.map +1 -1
  298. package/es/components/Select/FloatingPopover.js +1 -1
  299. package/es/components/Select/FloatingPopover.js.map +1 -1
  300. package/es/components/Select/Select.js +1 -1
  301. package/es/components/Select/Select.js.map +1 -1
  302. package/es/components/Select/ui/Inner/Inner.js +1 -1
  303. package/es/components/Select/ui/Inner/Inner.js.map +1 -1
  304. package/es/components/Spinner/Spinner.js +1 -1
  305. package/es/components/Spinner/Spinner.js.map +1 -1
  306. package/es/components/Tabs/ui/horizontal/HorizontalTabs/HorizontalTabs.js +2 -2
  307. package/es/components/Tabs/ui/horizontal/HorizontalTabs/HorizontalTabs.js.map +1 -1
  308. package/es/components/Tabs/ui/vertical/VerticalTabs/VerticalTabs.css +4 -4
  309. package/es/components/Tabs/ui/vertical/VerticalTabs/VerticalTabs.js +2 -2
  310. package/es/components/Tabs/ui/vertical/VerticalTabs/VerticalTabs.js.map +1 -1
  311. package/es/components/Tabs/ui/vertical/VerticalTabs/VerticalTabs.styles.js +1 -1
  312. package/es/components/Tabs/ui/vertical/VerticalTabs/VerticalTabs.styles.js.map +1 -1
  313. package/es/components/Tabs/ui/vertical/VerticalTabs/{VerticalTabs.styles_1egpt45.css → VerticalTabs.styles_1khdtzl.css} +1 -1
  314. package/es/components/TextArea/ui/Hint/Hint.js.map +1 -1
  315. package/es/components/TextField/TextField.js +1 -2
  316. package/es/components/TextField/TextField.js.map +1 -1
  317. package/es/components/TextField/ui/Hint/Hint.js.map +1 -1
  318. package/es/index.css +22 -22
  319. package/es/index.js +0 -1
  320. package/es/index.js.map +1 -1
  321. package/package.json +2 -2
  322. package/styled-components/cjs/components/Autocomplete/Autocomplete.js +3 -3
  323. package/styled-components/cjs/components/Autocomplete/FloatingPopover.js +2 -2
  324. package/styled-components/cjs/components/Calendar/CalendarBase/CalendarBase.js +0 -12
  325. package/styled-components/cjs/components/Calendar/CalendarDouble/CalendarDouble.js +0 -12
  326. package/styled-components/cjs/components/Calendar/ui/CalendarDays/CalendarDays.js +0 -3
  327. package/styled-components/cjs/components/Calendar/ui/CalendarMonths/CalendarMonths.js +0 -3
  328. package/styled-components/cjs/components/Calendar/ui/CalendarQuarters/CalendarQuarters.js +0 -3
  329. package/styled-components/cjs/components/Calendar/ui/CalendarYears/CalendarYears.js +0 -3
  330. package/styled-components/cjs/components/Carousel/CarouselNew/Carousel.js +6 -9
  331. package/styled-components/cjs/components/Carousel/CarouselNew/Carousel.styles.js +3 -6
  332. package/styled-components/cjs/components/Carousel/CarouselNew/Carousel.tokens.js +1 -9
  333. package/styled-components/cjs/components/Carousel/CarouselNew/hooks/useCarousel.js +353 -50
  334. package/styled-components/cjs/components/Carousel/CarouselNew/ui/Dots/Dots.js +38 -52
  335. package/styled-components/cjs/components/Carousel/CarouselOld/CarouselItem.js +1 -1
  336. package/styled-components/cjs/components/Checkbox/Checkbox.js +1 -1
  337. package/styled-components/cjs/components/CodeField/CodeField.styles.js +1 -1
  338. package/styled-components/cjs/components/Combobox/ComboboxNew/Combobox.js +1 -1
  339. package/styled-components/cjs/components/Combobox/ComboboxNew/FloatingPopover.js +2 -2
  340. package/styled-components/cjs/components/Combobox/ComboboxNew/ui/Inner/Inner.js +3 -2
  341. package/styled-components/cjs/components/Combobox/ComboboxOld/Combobox.js +1 -1
  342. package/styled-components/cjs/components/Combobox/ComboboxOld/ui/ComboboxItem/ComboboxItem.js +7 -6
  343. package/styled-components/cjs/components/Drawer/Drawer.js +8 -8
  344. package/styled-components/cjs/components/Drawer/hooks/useDrawer.js +2 -2
  345. package/styled-components/cjs/components/Dropdown/Dropdown.js +2 -1
  346. package/styled-components/cjs/components/Dropdown/FloatingPopover.js +2 -2
  347. package/styled-components/cjs/components/Dropdown/ui/DropdownInner/DropdownInner.js +4 -4
  348. package/styled-components/cjs/components/Dropdown/ui/DropdownItemOld/DropdownItemOld.js +3 -2
  349. package/styled-components/cjs/components/Dropdown/ui/DropdownOld/DropdownOld.js +1 -1
  350. package/styled-components/cjs/components/Mask/Mask.js +3 -3
  351. package/styled-components/cjs/components/Modal/Modal.js +5 -6
  352. package/styled-components/cjs/components/Modal/hooks/useModal.js +1 -1
  353. package/styled-components/cjs/components/Popup/Popup.js +1 -1
  354. package/styled-components/cjs/components/Popup/PopupContext.js +20 -14
  355. package/styled-components/cjs/components/Radiobox/Radiobox.js +2 -2
  356. package/styled-components/cjs/components/Rating/Rating.styles.js +1 -1
  357. package/styled-components/cjs/components/Segment/ui/SegmentGroup/SegmentGroup.js +3 -2
  358. package/styled-components/cjs/components/Segment/ui/SegmentItem/SegmentItem.js +2 -1
  359. package/styled-components/cjs/components/Select/FloatingPopover.js +5 -5
  360. package/styled-components/cjs/components/Select/Select.js +2 -1
  361. package/styled-components/cjs/components/Select/ui/Inner/Inner.js +2 -1
  362. package/styled-components/cjs/components/Spinner/Spinner.js +2 -2
  363. package/styled-components/cjs/components/Tabs/ui/horizontal/HorizontalTabs/HorizontalTabs.js +3 -2
  364. package/styled-components/cjs/components/Tabs/ui/vertical/VerticalTabs/VerticalTabs.js +3 -2
  365. package/styled-components/cjs/components/Tabs/ui/vertical/VerticalTabs/VerticalTabs.styles.js +1 -1
  366. package/styled-components/cjs/components/TextArea/ui/Hint/Hint.js +1 -1
  367. package/styled-components/cjs/components/TextField/TextField.js +3 -3
  368. package/styled-components/cjs/components/TextField/ui/Hint/Hint.js +1 -1
  369. package/styled-components/cjs/examples/plasma_b2c/components/Carousel/Carousel.config.js +2 -2
  370. package/styled-components/cjs/examples/plasma_b2c/components/Carousel/Carousel.stories.tsx +14 -10
  371. package/styled-components/cjs/examples/plasma_web/components/Carousel/Carousel.config.js +2 -2
  372. package/styled-components/cjs/examples/plasma_web/components/Carousel/Carousel.stories.tsx +15 -10
  373. package/styled-components/cjs/hooks/index.js +1 -8
  374. package/styled-components/es/components/Autocomplete/Autocomplete.js +1 -1
  375. package/styled-components/es/components/Autocomplete/FloatingPopover.js +1 -1
  376. package/styled-components/es/components/Calendar/CalendarBase/CalendarBase.js +0 -12
  377. package/styled-components/es/components/Calendar/CalendarDouble/CalendarDouble.js +0 -12
  378. package/styled-components/es/components/Calendar/ui/CalendarDays/CalendarDays.js +0 -3
  379. package/styled-components/es/components/Calendar/ui/CalendarMonths/CalendarMonths.js +0 -3
  380. package/styled-components/es/components/Calendar/ui/CalendarQuarters/CalendarQuarters.js +0 -3
  381. package/styled-components/es/components/Calendar/ui/CalendarYears/CalendarYears.js +0 -3
  382. package/styled-components/es/components/Carousel/CarouselNew/Carousel.js +6 -9
  383. package/styled-components/es/components/Carousel/CarouselNew/Carousel.styles.js +4 -7
  384. package/styled-components/es/components/Carousel/CarouselNew/Carousel.tokens.js +1 -9
  385. package/styled-components/es/components/Carousel/CarouselNew/hooks/useCarousel.js +349 -50
  386. package/styled-components/es/components/Carousel/CarouselNew/ui/Dots/Dots.js +38 -52
  387. package/styled-components/es/components/Carousel/CarouselOld/CarouselItem.js +1 -1
  388. package/styled-components/es/components/Checkbox/Checkbox.js +1 -2
  389. package/styled-components/es/components/CodeField/CodeField.styles.js +1 -1
  390. package/styled-components/es/components/Combobox/ComboboxNew/Combobox.js +1 -2
  391. package/styled-components/es/components/Combobox/ComboboxNew/FloatingPopover.js +1 -1
  392. package/styled-components/es/components/Combobox/ComboboxNew/ui/Inner/Inner.js +1 -1
  393. package/styled-components/es/components/Combobox/ComboboxOld/Combobox.js +1 -2
  394. package/styled-components/es/components/Combobox/ComboboxOld/ui/ComboboxItem/ComboboxItem.js +1 -1
  395. package/styled-components/es/components/Drawer/Drawer.js +3 -3
  396. package/styled-components/es/components/Drawer/hooks/useDrawer.js +2 -2
  397. package/styled-components/es/components/Dropdown/Dropdown.js +1 -1
  398. package/styled-components/es/components/Dropdown/FloatingPopover.js +1 -1
  399. package/styled-components/es/components/Dropdown/ui/DropdownInner/DropdownInner.js +1 -1
  400. package/styled-components/es/components/Dropdown/ui/DropdownItemOld/DropdownItemOld.js +2 -1
  401. package/styled-components/es/components/Dropdown/ui/DropdownOld/DropdownOld.js +1 -1
  402. package/styled-components/es/components/Mask/Mask.js +3 -3
  403. package/styled-components/es/components/Modal/Modal.js +3 -4
  404. package/styled-components/es/components/Modal/hooks/useModal.js +1 -1
  405. package/styled-components/es/components/Popup/Popup.js +2 -2
  406. package/styled-components/es/components/Popup/PopupContext.js +20 -14
  407. package/styled-components/es/components/Radiobox/Radiobox.js +2 -2
  408. package/styled-components/es/components/Rating/Rating.styles.js +1 -1
  409. package/styled-components/es/components/Segment/ui/SegmentGroup/SegmentGroup.js +2 -1
  410. package/styled-components/es/components/Segment/ui/SegmentItem/SegmentItem.js +2 -1
  411. package/styled-components/es/components/Select/FloatingPopover.js +1 -1
  412. package/styled-components/es/components/Select/Select.js +2 -1
  413. package/styled-components/es/components/Select/ui/Inner/Inner.js +2 -1
  414. package/styled-components/es/components/Spinner/Spinner.js +1 -1
  415. package/styled-components/es/components/Tabs/ui/horizontal/HorizontalTabs/HorizontalTabs.js +2 -1
  416. package/styled-components/es/components/Tabs/ui/vertical/VerticalTabs/VerticalTabs.js +2 -1
  417. package/styled-components/es/components/Tabs/ui/vertical/VerticalTabs/VerticalTabs.styles.js +1 -1
  418. package/styled-components/es/components/TextArea/ui/Hint/Hint.js +1 -1
  419. package/styled-components/es/components/TextField/TextField.js +2 -2
  420. package/styled-components/es/components/TextField/ui/Hint/Hint.js +1 -1
  421. package/styled-components/es/examples/plasma_b2c/components/Carousel/Carousel.config.js +2 -2
  422. package/styled-components/es/examples/plasma_b2c/components/Carousel/Carousel.stories.tsx +14 -10
  423. package/styled-components/es/examples/plasma_web/components/Carousel/Carousel.config.js +2 -2
  424. package/styled-components/es/examples/plasma_web/components/Carousel/Carousel.stories.tsx +15 -10
  425. package/styled-components/es/hooks/index.js +1 -2
  426. package/types/components/Calendar/CalendarBase/CalendarBase.d.ts.map +1 -1
  427. package/types/components/Calendar/CalendarDouble/CalendarDouble.d.ts.map +1 -1
  428. package/types/components/Calendar/ui/CalendarDays/CalendarDays.d.ts.map +1 -1
  429. package/types/components/Calendar/ui/CalendarMonths/CalendarMonths.d.ts.map +1 -1
  430. package/types/components/Calendar/ui/CalendarQuarters/CalendarQuarters.d.ts.map +1 -1
  431. package/types/components/Calendar/ui/CalendarYears/CalendarYears.d.ts.map +1 -1
  432. package/types/components/Carousel/CarouselNew/Carousel.d.ts.map +1 -1
  433. package/types/components/Carousel/CarouselNew/Carousel.styles.d.ts +1 -4
  434. package/types/components/Carousel/CarouselNew/Carousel.styles.d.ts.map +1 -1
  435. package/types/components/Carousel/CarouselNew/Carousel.tokens.d.ts +0 -8
  436. package/types/components/Carousel/CarouselNew/Carousel.tokens.d.ts.map +1 -1
  437. package/types/components/Carousel/CarouselNew/Carousel.types.d.ts +3 -8
  438. package/types/components/Carousel/CarouselNew/Carousel.types.d.ts.map +1 -1
  439. package/types/components/Carousel/CarouselNew/hooks/useCarousel.d.ts +52 -11
  440. package/types/components/Carousel/CarouselNew/hooks/useCarousel.d.ts.map +1 -1
  441. package/types/components/Carousel/CarouselNew/ui/Dots/Dots.d.ts.map +1 -1
  442. package/types/components/Carousel/CarouselOld/CarouselItem.d.ts.map +1 -1
  443. package/types/components/Checkbox/Checkbox.d.ts.map +1 -1
  444. package/types/components/Combobox/ComboboxNew/Combobox.d.ts.map +1 -1
  445. package/types/components/Combobox/ComboboxOld/Combobox.d.ts.map +1 -1
  446. package/types/components/Combobox/ComboboxOld/ui/ComboboxItem/ComboboxItem.d.ts.map +1 -1
  447. package/types/components/Drawer/Drawer.d.ts +1 -1
  448. package/types/components/Drawer/Drawer.d.ts.map +1 -1
  449. package/types/components/Drawer/hooks/useDrawer.d.ts.map +1 -1
  450. package/types/components/Dropdown/Dropdown.d.ts.map +1 -1
  451. package/types/components/Dropdown/ui/DropdownDivider/DropdownDivider.d.ts +1 -1
  452. package/types/components/Dropdown/ui/DropdownDivider/DropdownDivider.d.ts.map +1 -1
  453. package/types/components/Dropdown/ui/DropdownFooter/DropdownFooter.d.ts +1 -1
  454. package/types/components/Dropdown/ui/DropdownFooter/DropdownFooter.d.ts.map +1 -1
  455. package/types/components/Dropdown/ui/DropdownGroup/DropdownGroup.d.ts +1 -1
  456. package/types/components/Dropdown/ui/DropdownGroup/DropdownGroup.d.ts.map +1 -1
  457. package/types/components/Dropdown/ui/DropdownHeader/DropdownHeader.d.ts +1 -1
  458. package/types/components/Dropdown/ui/DropdownHeader/DropdownHeader.d.ts.map +1 -1
  459. package/types/components/Dropdown/ui/DropdownItemOld/DropdownItemOld.d.ts +1 -1
  460. package/types/components/Dropdown/ui/DropdownItemOld/DropdownItemOld.d.ts.map +1 -1
  461. package/types/components/Dropdown/ui/DropdownOld/DropdownOld.d.ts +1 -1
  462. package/types/components/Dropdown/ui/DropdownOld/DropdownOld.d.ts.map +1 -1
  463. package/types/components/Modal/Modal.d.ts +1 -1
  464. package/types/components/Modal/Modal.d.ts.map +1 -1
  465. package/types/components/Popup/Popup.d.ts +1 -1
  466. package/types/components/Popup/Popup.d.ts.map +1 -1
  467. package/types/components/Popup/Popup.types.d.ts +1 -1
  468. package/types/components/Popup/Popup.types.d.ts.map +1 -1
  469. package/types/components/Popup/PopupContext.d.ts.map +1 -1
  470. package/types/components/Radiobox/Radiobox.d.ts +2 -2
  471. package/types/components/Radiobox/Radiobox.d.ts.map +1 -1
  472. package/types/components/Segment/ui/SegmentGroup/SegmentGroup.d.ts +1 -1
  473. package/types/components/Segment/ui/SegmentGroup/SegmentGroup.d.ts.map +1 -1
  474. package/types/components/Segment/ui/SegmentItem/SegmentItem.d.ts +1 -1
  475. package/types/components/Segment/ui/SegmentItem/SegmentItem.d.ts.map +1 -1
  476. package/types/components/Select/Select.d.ts.map +1 -1
  477. package/types/components/Select/ui/Inner/Inner.d.ts.map +1 -1
  478. package/types/components/Spinner/Spinner.d.ts +1 -1
  479. package/types/components/Spinner/Spinner.d.ts.map +1 -1
  480. package/types/components/Tabs/ui/horizontal/HorizontalTabs/HorizontalTabs.d.ts +1 -1
  481. package/types/components/Tabs/ui/horizontal/HorizontalTabs/HorizontalTabs.d.ts.map +1 -1
  482. package/types/components/Tabs/ui/vertical/VerticalTabs/VerticalTabs.d.ts +1 -1
  483. package/types/components/Tabs/ui/vertical/VerticalTabs/VerticalTabs.d.ts.map +1 -1
  484. package/types/components/TextField/TextField.d.ts +1 -1
  485. package/types/components/TextField/TextField.d.ts.map +1 -1
  486. package/types/hooks/index.d.ts +0 -1
  487. package/types/hooks/index.d.ts.map +1 -1
  488. package/cjs/components/Carousel/CarouselNew/Carousel.styles_1benby5.css +0 -5
  489. package/cjs/hooks/useDisableScroll.js +0 -30
  490. package/cjs/hooks/useDisableScroll.js.map +0 -1
  491. package/emotion/cjs/hooks/useDisableScroll.js +0 -28
  492. package/emotion/es/hooks/useDisableScroll.js +0 -22
  493. package/es/components/Carousel/CarouselNew/Carousel.styles_1benby5.css +0 -5
  494. package/es/hooks/useDisableScroll.js +0 -26
  495. package/es/hooks/useDisableScroll.js.map +0 -1
  496. package/styled-components/cjs/hooks/useDisableScroll.js +0 -28
  497. package/styled-components/es/hooks/useDisableScroll.js +0 -22
  498. package/types/hooks/useDisableScroll.d.ts +0 -3
  499. package/types/hooks/useDisableScroll.d.ts.map +0 -1
@@ -1,71 +1,369 @@
1
- import { useRef, useEffect } from 'react';
1
+ import { useRef, useMemo, useCallback, useEffect } from 'react';
2
+ import throttle from 'lodash.throttle';
2
3
 
3
4
  /**
4
- * Подсчет отступа для скролла до переданного индекса.
5
+ * Подсчет смещения из-за паддингов.
5
6
  */
6
- var getCalculatedPos = function getCalculatedPos(_ref) {
7
- var scrollRef = _ref.scrollRef,
8
- trackRef = _ref.trackRef,
9
- itemsCollection = _ref.itemsCollection,
10
- index = _ref.index,
11
- scrollAlign = _ref.scrollAlign;
12
- var item = itemsCollection.item(index);
13
- if (!item || !trackRef.current || !scrollRef.current) {
14
- return 0;
7
+ var getCalculatedOffset = function getCalculatedOffset(scrollEl, trackEl) {
8
+ var paddingProp = 'paddingLeft';
9
+ return parseInt(getComputedStyle(scrollEl)[paddingProp], 10) + parseInt(getComputedStyle(trackEl)[paddingProp], 10);
10
+ };
11
+ var positionModByScrollAlign = function positionModByScrollAlign(_ref) {
12
+ var scrollAlign = _ref.scrollAlign,
13
+ position = _ref.position,
14
+ carouselSize = _ref.carouselSize,
15
+ itemSize = _ref.itemSize,
16
+ offset = _ref.offset,
17
+ scrollStart = _ref.scrollStart;
18
+ if (scrollAlign === 'start') {
19
+ var paddingOffset = 0;
20
+ return position + paddingOffset;
15
21
  }
16
- var itemRect = item.getBoundingClientRect();
17
- var trackRect = trackRef.current.getBoundingClientRect();
18
- var scrollRect = scrollRef.current.getBoundingClientRect();
19
- var left = itemRect.left - trackRect.left + trackRef.current.scrollLeft;
20
- switch (scrollAlign) {
21
- case 'start':
22
- {
23
- return left;
24
- }
25
- case 'center':
26
- {
27
- return left - scrollRect.width / 2 + itemRect.width / 2;
28
- }
29
- case 'end':
30
- {
31
- return left - scrollRect.width + itemRect.width;
32
- }
33
- default:
34
- {
35
- return 0;
36
- }
22
+ if (scrollAlign === 'center') {
23
+ return position - carouselSize / 2 + itemSize / 2;
24
+ }
25
+ if (scrollAlign === 'end') {
26
+ return position - carouselSize + itemSize + offset;
27
+ }
28
+ if (scrollAlign === 'activeDirection') {
29
+ if (position >= scrollStart + carouselSize - itemSize) {
30
+ return position - carouselSize + itemSize + offset;
31
+ }
32
+ if (position > scrollStart) {
33
+ return scrollStart;
34
+ }
37
35
  }
36
+ return position;
38
37
  };
39
- var useCarousel = function useCarousel(_ref2) {
40
- var index = _ref2.index,
38
+
39
+ /**
40
+ * Подсчет скролла до переданного индекса.
41
+ */
42
+ var getCalculatedPos = function getCalculatedPos(_ref2) {
43
+ var _items$item$offsetWid2, _items$item2;
44
+ var scrollEl = _ref2.scrollEl,
45
+ items = _ref2.items,
46
+ index = _ref2.index,
47
+ offset = _ref2.offset,
41
48
  scrollAlign = _ref2.scrollAlign;
49
+ var position = scrollAlign === 'center' ? offset : 0;
50
+ if (items.item(index) === null) {
51
+ return position;
52
+ }
53
+ for (var i = 0; i < index; i++) {
54
+ var _items$item$offsetWid, _items$item;
55
+ position += (_items$item$offsetWid = (_items$item = items.item(i)) === null || _items$item === void 0 ? void 0 : _items$item.offsetWidth) !== null && _items$item$offsetWid !== void 0 ? _items$item$offsetWid : 0;
56
+ }
57
+ var carouselSize = scrollEl.offsetWidth;
58
+ var itemSize = (_items$item$offsetWid2 = (_items$item2 = items.item(index)) === null || _items$item2 === void 0 ? void 0 : _items$item2.offsetWidth) !== null && _items$item$offsetWid2 !== void 0 ? _items$item$offsetWid2 : 0;
59
+ var scrollStart = scrollEl.scrollLeft;
60
+ return positionModByScrollAlign({
61
+ scrollAlign: scrollAlign,
62
+ position: position,
63
+ carouselSize: carouselSize,
64
+ itemSize: itemSize,
65
+ offset: offset,
66
+ scrollStart: scrollStart
67
+ });
68
+ };
69
+ var DEFAULT_DURATION = 300;
70
+
71
+ // https://css-tricks.com/emulating-css-timing-functions-javascript/
72
+ var tfs = {
73
+ linear: function linear(t) {
74
+ return t;
75
+ },
76
+ // eslint-disable-next-line
77
+ easeIn: function easeIn(t) {
78
+ return Math.pow(t, 1.675);
79
+ },
80
+ // eslint-disable-next-line
81
+ easeOut: function easeOut(t) {
82
+ return 1 - Math.pow(1 - t, 1.675);
83
+ },
84
+ easeInOut: function easeInOut(t) {
85
+ return 0.5 * (Math.sin((t - 0.5) * Math.PI) + 1);
86
+ }
87
+ };
88
+ /**
89
+ * Плавная прокрутка по горизонтали
90
+ * @param {Element} elem
91
+ * @param {number} pos
92
+ * @param {number} duration
93
+ * @param {string} timingFunction
94
+ */
95
+ var animatedScrollToX = function animatedScrollToX(elem, pos) {
96
+ var duration = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : DEFAULT_DURATION;
97
+ var timingFunction = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 'easeInOut';
98
+ var startTime;
99
+ var startX = elem.scrollLeft;
100
+ var endX = Math.max(0, Math.min(elem.scrollWidth - elem.clientWidth, pos));
101
+ var handleNewAnimationFrame = function handleNewAnimationFrame() {
102
+ startTime = startTime || Date.now();
103
+ var timePos = Math.min(1, Math.max(1, Date.now() - startTime) / duration);
104
+ var scrollPos = tfs[timingFunction](timePos);
105
+ var left = startX + (endX - startX) * scrollPos;
106
+ elem.scrollTo({
107
+ left: left
108
+ });
109
+ if (timePos !== 1) window.requestAnimationFrame(handleNewAnimationFrame);
110
+ };
111
+ window.requestAnimationFrame(handleNewAnimationFrame);
112
+ };
113
+
114
+ /**
115
+ * Прокрутка к указанной позиции с анимацией или без.
116
+ */
117
+ var scrollToPos = function scrollToPos(_ref3) {
118
+ var scrollEl = _ref3.scrollEl,
119
+ pos = _ref3.pos,
120
+ animated = _ref3.animated,
121
+ duration = _ref3.duration,
122
+ timingFunction = _ref3.timingFunction;
123
+ if (Math.abs(pos - scrollEl.scrollLeft) > 1) {
124
+ if (animated) {
125
+ animatedScrollToX(scrollEl, pos, duration, timingFunction);
126
+ } else {
127
+ scrollEl.scrollTo({
128
+ left: pos
129
+ });
130
+ }
131
+ }
132
+ };
133
+ var round = function round(n) {
134
+ return Math.round(n * 100) / 100;
135
+ };
136
+
137
+ /**
138
+ * Получить позицию (слот) айтема в каруселе.
139
+ * Каждый айтем имеет свой слот относительно вьюпорта карусели.
140
+ */
141
+ var getItemSlot = function getItemSlot(itemIndex, itemEnd, itemSize, scrollStart, scrollSize, scrollAlign) {
142
+ var prevIndex = arguments.length > 6 && arguments[6] !== undefined ? arguments[6] : 0;
143
+ var offset = arguments.length > 7 && arguments[7] !== undefined ? arguments[7] : 0;
144
+ /**
145
+ * Граница и центр скролла (видимой части).
146
+ * Смещение + размер.
147
+ */
148
+ var scrollEnd = scrollStart + scrollSize;
149
+ var scrollCenter = scrollStart + scrollSize / 2;
150
+ var itemCenter = itemEnd - itemSize / 2;
151
+ if (scrollAlign === 'center') {
152
+ return round((itemCenter - scrollCenter) / itemSize);
153
+ }
154
+ if (scrollAlign === 'start') {
155
+ return round((itemEnd - itemSize - scrollStart) / itemSize);
156
+ }
157
+ if (scrollAlign === 'end') {
158
+ return round((itemEnd - (scrollSize + scrollStart)) / itemSize);
159
+ }
160
+ if (scrollAlign === 'activeDirection') {
161
+ var prevStart = offset + itemSize * prevIndex;
162
+ var prevEnd = prevStart + itemSize;
163
+ var prevVisible = prevEnd > scrollStart && prevStart < scrollEnd;
164
+ if (!prevVisible) {
165
+ if (prevIndex < itemIndex) {
166
+ return round((itemEnd - (scrollSize + scrollStart)) / itemSize);
167
+ }
168
+ return round((itemEnd - itemSize - scrollStart) / itemSize);
169
+ }
170
+ }
171
+ return null;
172
+ };
173
+ function getCarouselItems(track) {
174
+ return track.children;
175
+ }
176
+ function useDebouncedFunction(func, delay, cleanUp) {
177
+ var timeoutRef = useRef();
178
+
179
+ /**
180
+ * Очистка таймера
181
+ */
182
+ function clearTimer() {
183
+ if (timeoutRef.current) {
184
+ clearTimeout(timeoutRef.current);
185
+ timeoutRef.current = undefined;
186
+ }
187
+ }
188
+
189
+ /**
190
+ * Очищаем таймер при анмаунте компонента, если cleanUp выставлен в true
191
+ * и тем самым отменяем последний запланированный вызов
192
+ */
193
+ useEffect(function () {
194
+ return cleanUp ? clearTimer : undefined;
195
+ }, [cleanUp]);
196
+ return function () {
197
+ for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
198
+ args[_key] = arguments[_key];
199
+ }
200
+ clearTimer();
201
+ timeoutRef.current = setTimeout(function () {
202
+ return func.apply(void 0, args);
203
+ }, delay);
204
+ };
205
+ }
206
+ var THROTTLE_DEFAULT_MS = 100;
207
+ var DEBOUNCE_DEFAULT_MS = 150;
208
+ var useCarousel = function useCarousel(_ref4) {
209
+ var index = _ref4.index,
210
+ onIndexChange = _ref4.onIndexChange,
211
+ _ref4$detectActive = _ref4.detectActive,
212
+ detectActive = _ref4$detectActive === void 0 ? false : _ref4$detectActive,
213
+ _ref4$detectThreshold = _ref4.detectThreshold,
214
+ detectThreshold = _ref4$detectThreshold === void 0 ? 0.5 : _ref4$detectThreshold,
215
+ _ref4$scrollAlign = _ref4.scrollAlign,
216
+ scrollAlign = _ref4$scrollAlign === void 0 ? 'center' : _ref4$scrollAlign,
217
+ _ref4$throttleMs = _ref4.throttleMs,
218
+ throttleMs = _ref4$throttleMs === void 0 ? THROTTLE_DEFAULT_MS : _ref4$throttleMs,
219
+ _ref4$debounceMs = _ref4.debounceMs,
220
+ debounceMs = _ref4$debounceMs === void 0 ? DEBOUNCE_DEFAULT_MS : _ref4$debounceMs;
221
+ var prevIndex = useRef(null);
222
+ var offset = useRef(0);
42
223
  var scrollRef = useRef(null);
43
224
  var trackRef = useRef(null);
44
225
 
45
- // Прокрутка до нужной позиции индекса, если индекс изменился.
226
+ /**
227
+ * Для того, чтобы не спамить изменениями индекса.
228
+ * Задержка дебаунса слегка больше, чем у тротлинга.
229
+ * Таким образом, событие срабатывает при завершении скролла.
230
+ */
231
+ var debouncedOnIndexChange = useDebouncedFunction(function (i) {
232
+ return onIndexChange === null || onIndexChange === void 0 ? void 0 : onIndexChange(i);
233
+ }, debounceMs);
234
+
235
+ /**
236
+ * Вычисление центрального элемента.
237
+ * Подсчет: от 0 до 1, какое количество ширины/высоты
238
+ * каждого элемента находится по центру скролла.
239
+ */
240
+ var throttledDetectActiveItem = useMemo(function () {
241
+ return throttle(function () {
242
+ if (!detectActive || scrollRef.current === null || trackRef.current === null) {
243
+ return;
244
+ }
245
+
246
+ /**
247
+ * Правая (или нижняя для Оу) граница элемента.
248
+ */
249
+ var itemEdge = offset.current;
250
+
251
+ /**
252
+ * Смещение (отрицательный или положительный отступ)
253
+ * и размер карусели (для Ox - ширина, для Oy - высота).
254
+ */
255
+ var scrollPos = scrollRef.current['scrollLeft' ];
256
+ var scrollSize = scrollRef.current['offsetWidth' ];
257
+
258
+ /**
259
+ * Граница скролла (видимой части).
260
+ * Смещение + размер.
261
+ */
262
+ var scrollEdge = scrollPos + scrollSize;
263
+ var items = getCarouselItems(trackRef.current);
264
+
265
+ /**
266
+ * Проходим по всему списку, суммируя ширины элементов,
267
+ * пока не найдем один элемент, чей центр будет в центре карусели.
268
+ */
269
+ for (var itemIndex = 0; itemIndex < items.length; itemIndex++) {
270
+ var _prevIndex$current;
271
+ var item = items.item(itemIndex);
272
+ if (item === null) {
273
+ // eslint-disable-next-line no-continue
274
+ continue;
275
+ }
276
+
277
+ /**
278
+ * Для Ox - ширина, для Oy - высота.
279
+ */
280
+ var itemSize = item['offsetWidth' ];
281
+
282
+ /**
283
+ * Все элементы правее вьюпорта выпадают из процедуры.
284
+ * Сравниваем по предыдущему элементу.
285
+ * [ ... ] ...|n| <- Левый край элемента за пределами начала видимой части
286
+ */
287
+ if (itemEdge > scrollEdge) {
288
+ // eslint-disable-next-line no-continue
289
+ continue;
290
+ }
291
+ itemEdge += itemSize;
292
+
293
+ /**
294
+ * Все элементы левее вьюпорта выпадают из процедуры.
295
+ * Сравниваем по текущему элементу.
296
+ * Правый край элемента за пределами начала видимой части -> |p|... [ ... ]
297
+ */
298
+ if (scrollPos > itemEdge) {
299
+ // eslint-disable-next-line no-continue
300
+ continue;
301
+ }
302
+ var itemSlot = getItemSlot(itemIndex, itemEdge, itemSize, scrollPos, scrollSize, scrollAlign, (_prevIndex$current = prevIndex.current) !== null && _prevIndex$current !== void 0 ? _prevIndex$current : 0, offset.current);
303
+ if (itemSlot !== null) {
304
+ if (detectThreshold && Math.abs(itemSlot) <= detectThreshold) {
305
+ debouncedOnIndexChange === null || debouncedOnIndexChange === void 0 || debouncedOnIndexChange(itemIndex);
306
+ }
307
+ }
308
+ }
309
+ }, throttleMs);
310
+ }, [debouncedOnIndexChange, detectActive, detectThreshold, scrollAlign, throttleMs]);
311
+
312
+ /**
313
+ * Прокрутка до нужной позиции индекса.
314
+ */
315
+ var toIndex = useCallback(function (i) {
316
+ var scrollEl = scrollRef.current;
317
+ var items = trackRef.current ? getCarouselItems(trackRef.current) : null;
318
+ if (scrollEl && items && items.length > 0 && i >= 0) {
319
+ scrollToPos({
320
+ scrollEl: scrollEl,
321
+ pos: getCalculatedPos({
322
+ scrollEl: scrollEl,
323
+ items: items,
324
+ index: i,
325
+ offset: offset.current,
326
+ scrollAlign: scrollAlign
327
+ })
328
+ });
329
+ prevIndex.current = i;
330
+ }
331
+ }, [scrollAlign]);
46
332
  useEffect(function () {
47
- if (!scrollRef.current || !trackRef.current) {
48
- return;
333
+ if (scrollRef.current && trackRef.current) {
334
+ offset.current = getCalculatedOffset(scrollRef.current, trackRef.current);
49
335
  }
50
- var itemsCollection = trackRef.current.children;
51
- if (itemsCollection && itemsCollection.length > 0) {
52
- var pos = getCalculatedPos({
53
- scrollRef: scrollRef,
54
- trackRef: trackRef,
55
- itemsCollection: itemsCollection,
56
- index: index,
57
- scrollAlign: scrollAlign
58
- });
59
- scrollRef.current.scrollTo({
60
- left: pos
61
- });
336
+ }, []);
337
+
338
+ /**
339
+ * Операции на маунте/анмаунте компонента.
340
+ * Создать слушатели событи и т.п.
341
+ */
342
+ useEffect(function () {
343
+ var carouselElement = scrollRef.current;
344
+ if (carouselElement) {
345
+ carouselElement.addEventListener('scroll', throttledDetectActiveItem);
346
+ }
347
+ return function () {
348
+ if (carouselElement) {
349
+ carouselElement.removeEventListener('scroll', throttledDetectActiveItem);
350
+ }
351
+ };
352
+ }, [throttledDetectActiveItem]);
353
+
354
+ /**
355
+ * Прокрутка до нужной позиции индекса, если индекс изменился.
356
+ */
357
+ useEffect(function () {
358
+ if (index !== prevIndex.current) {
359
+ toIndex(index);
62
360
  }
63
- }, [index]);
361
+ }, [index, toIndex]);
64
362
  return {
65
363
  scrollRef: scrollRef,
66
364
  trackRef: trackRef
67
365
  };
68
366
  };
69
367
 
70
- export { getCalculatedPos, useCarousel };
368
+ export { animatedScrollToX, getCalculatedOffset, getCalculatedPos, getCarouselItems, getItemSlot, scrollToPos, useCarousel, useDebouncedFunction };
71
369
  //# sourceMappingURL=useCarousel.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"useCarousel.js","sources":["../../../../../src/components/Carousel/CarouselNew/hooks/useCarousel.tsx"],"sourcesContent":["import { useEffect, useRef, RefObject } from 'react';\n\nimport { CarouselNewProps as CarouselProps } from '../Carousel.types';\n\n/**\n * Подсчет отступа для скролла до переданного индекса.\n */\nexport const getCalculatedPos = ({\n scrollRef,\n trackRef,\n itemsCollection,\n index,\n scrollAlign,\n}: {\n scrollRef: RefObject<HTMLDivElement>;\n trackRef: RefObject<HTMLDivElement>;\n itemsCollection: HTMLCollection;\n index: number;\n scrollAlign: CarouselProps['scrollAlign'];\n}): number => {\n const item = itemsCollection.item(index);\n\n if (!item || !trackRef.current || !scrollRef.current) {\n return 0;\n }\n\n const itemRect = item.getBoundingClientRect();\n const trackRect = trackRef.current.getBoundingClientRect();\n const scrollRect = scrollRef.current.getBoundingClientRect();\n\n const left = itemRect.left - trackRect.left + trackRef.current.scrollLeft;\n\n switch (scrollAlign) {\n case 'start': {\n return left;\n }\n case 'center': {\n return left - scrollRect.width / 2 + itemRect.width / 2;\n }\n case 'end': {\n return left - scrollRect.width + itemRect.width;\n }\n default: {\n return 0;\n }\n }\n};\n\ntype UseCarouselOptions = Pick<CarouselProps, 'scrollAlign'> & {\n index: number;\n};\n\ntype UseCarouselHookResult = {\n scrollRef: RefObject<HTMLDivElement>;\n trackRef: RefObject<HTMLDivElement>;\n};\n\nexport const useCarousel = ({ index, scrollAlign }: UseCarouselOptions): UseCarouselHookResult => {\n const scrollRef = useRef<HTMLDivElement>(null);\n const trackRef = useRef<HTMLDivElement>(null);\n\n // Прокрутка до нужной позиции индекса, если индекс изменился.\n useEffect(() => {\n if (!scrollRef.current || !trackRef.current) {\n return;\n }\n\n const itemsCollection = trackRef.current.children;\n\n if (itemsCollection && itemsCollection.length > 0) {\n const pos = getCalculatedPos({\n scrollRef,\n trackRef,\n itemsCollection,\n index,\n scrollAlign,\n });\n\n scrollRef.current.scrollTo({ left: pos });\n }\n }, [index]);\n\n return {\n scrollRef,\n trackRef,\n };\n};\n"],"names":["getCalculatedPos","_ref","scrollRef","trackRef","itemsCollection","index","scrollAlign","item","current","itemRect","getBoundingClientRect","trackRect","scrollRect","left","scrollLeft","width","useCarousel","_ref2","useRef","useEffect","children","length","pos","scrollTo"],"mappings":"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"}
1
+ {"version":3,"file":"useCarousel.js","sources":["../../../../../src/components/Carousel/CarouselNew/hooks/useCarousel.tsx"],"sourcesContent":["import React, { useEffect, useCallback, useRef, useMemo } from 'react';\nimport throttle from 'lodash.throttle';\n\nimport { CarouselNewProps as CarouselProps, ScrollAlign } from '../Carousel.types';\n\n/**\n * Подсчет смещения из-за паддингов.\n */\nexport const getCalculatedOffset = (scrollEl: Element, trackEl: Element) => {\n const paddingProp = 'paddingLeft';\n return parseInt(getComputedStyle(scrollEl)[paddingProp], 10) + parseInt(getComputedStyle(trackEl)[paddingProp], 10);\n};\n\nconst positionModByScrollAlign = ({\n scrollAlign,\n position,\n carouselSize,\n itemSize,\n offset,\n scrollStart,\n}: {\n scrollAlign: ScrollAlign;\n position: number;\n carouselSize: number;\n itemSize: number;\n offset: number;\n scrollStart: number;\n}) => {\n if (scrollAlign === 'start') {\n const paddingOffset = 0;\n return position + paddingOffset;\n }\n if (scrollAlign === 'center') {\n return position - carouselSize / 2 + itemSize / 2;\n }\n if (scrollAlign === 'end') {\n return position - carouselSize + itemSize + offset;\n }\n if (scrollAlign === 'activeDirection') {\n if (position >= scrollStart + carouselSize - itemSize) {\n return position - carouselSize + itemSize + offset;\n }\n if (position > scrollStart) {\n return scrollStart;\n }\n }\n return position;\n};\n\n/**\n * Подсчет скролла до переданного индекса.\n */\nexport const getCalculatedPos = ({\n scrollEl,\n items,\n index,\n offset,\n scrollAlign,\n}: {\n scrollEl: HTMLElement;\n items: HTMLCollectionOf<HTMLElement>;\n index: number;\n offset: number;\n scrollAlign: ScrollAlign;\n}) => {\n let position = scrollAlign === 'center' ? offset : 0;\n\n if (items.item(index) === null) {\n return position;\n }\n\n for (let i = 0; i < index; i++) {\n position += items.item(i)?.offsetWidth ?? 0;\n }\n\n const carouselSize = scrollEl.offsetWidth;\n const itemSize = items.item(index)?.offsetWidth ?? 0;\n const scrollStart = scrollEl.scrollLeft;\n\n return positionModByScrollAlign({\n scrollAlign,\n position,\n carouselSize,\n itemSize,\n offset,\n scrollStart,\n });\n};\n\nconst DEFAULT_DURATION = 300;\n\n// https://css-tricks.com/emulating-css-timing-functions-javascript/\nconst tfs = {\n linear: (t: number) => t,\n // eslint-disable-next-line\n easeIn: (t: number) => Math.pow(t, 1.675),\n // eslint-disable-next-line\n easeOut: (t: number) => 1 - Math.pow(1 - t, 1.675),\n easeInOut: (t: number) => 0.5 * (Math.sin((t - 0.5) * Math.PI) + 1),\n};\n\nexport type TimingFunction = keyof typeof tfs;\n\n/**\n * Плавная прокрутка по горизонтали\n * @param {Element} elem\n * @param {number} pos\n * @param {number} duration\n * @param {string} timingFunction\n */\nexport const animatedScrollToX = (\n elem: Element,\n pos: number,\n duration: number = DEFAULT_DURATION,\n timingFunction: TimingFunction = 'easeInOut',\n): void => {\n let startTime: number;\n const startX = elem.scrollLeft;\n const endX = Math.max(0, Math.min(elem.scrollWidth - elem.clientWidth, pos));\n\n const handleNewAnimationFrame = (): void => {\n startTime = startTime || Date.now();\n const timePos = Math.min(1, Math.max(1, Date.now() - startTime) / duration);\n const scrollPos = tfs[timingFunction](timePos);\n const left = startX + (endX - startX) * scrollPos;\n elem.scrollTo({ left });\n if (timePos !== 1) window.requestAnimationFrame(handleNewAnimationFrame);\n };\n\n window.requestAnimationFrame(handleNewAnimationFrame);\n};\n\n/**\n * Прокрутка к указанной позиции с анимацией или без.\n */\nexport const scrollToPos = ({\n scrollEl,\n pos,\n animated,\n duration,\n timingFunction,\n}: {\n scrollEl: HTMLElement;\n pos: number;\n animated?: boolean;\n duration?: number;\n timingFunction?: TimingFunction;\n}) => {\n if (Math.abs(pos - scrollEl.scrollLeft) > 1) {\n if (animated) {\n animatedScrollToX(scrollEl, pos, duration, timingFunction);\n } else {\n scrollEl.scrollTo({ left: pos });\n }\n }\n};\n\nconst round = (n: number) => Math.round(n * 100) / 100;\n\n/**\n * Получить позицию (слот) айтема в каруселе.\n * Каждый айтем имеет свой слот относительно вьюпорта карусели.\n */\nexport const getItemSlot = (\n itemIndex: number,\n itemEnd: number,\n itemSize: number,\n scrollStart: number,\n scrollSize: number,\n scrollAlign: ScrollAlign,\n prevIndex = 0,\n offset = 0,\n) => {\n /**\n * Граница и центр скролла (видимой части).\n * Смещение + размер.\n */\n const scrollEnd = scrollStart + scrollSize;\n const scrollCenter = scrollStart + scrollSize / 2;\n const itemCenter = itemEnd - itemSize / 2;\n\n if (scrollAlign === 'center') {\n return round((itemCenter - scrollCenter) / itemSize);\n }\n if (scrollAlign === 'start') {\n return round((itemEnd - itemSize - scrollStart) / itemSize);\n }\n if (scrollAlign === 'end') {\n return round((itemEnd - (scrollSize + scrollStart)) / itemSize);\n }\n if (scrollAlign === 'activeDirection') {\n const prevStart = offset + itemSize * prevIndex;\n const prevEnd = prevStart + itemSize;\n const prevVisible = prevEnd > scrollStart && prevStart < scrollEnd;\n\n if (!prevVisible) {\n if (prevIndex < itemIndex) {\n return round((itemEnd - (scrollSize + scrollStart)) / itemSize);\n }\n return round((itemEnd - itemSize - scrollStart) / itemSize);\n }\n }\n return null;\n};\n\nexport function getCarouselItems(track: HTMLElement): HTMLCollectionOf<HTMLElement> {\n return track.children as HTMLCollectionOf<HTMLElement>;\n}\n\nexport function useDebouncedFunction(func: (...args: any) => any, delay: number, cleanUp?: boolean) {\n const timeoutRef = useRef<number>();\n\n /**\n * Очистка таймера\n */\n function clearTimer() {\n if (timeoutRef.current) {\n clearTimeout(timeoutRef.current);\n timeoutRef.current = undefined;\n }\n }\n\n /**\n * Очищаем таймер при анмаунте компонента, если cleanUp выставлен в true\n * и тем самым отменяем последний запланированный вызов\n */\n useEffect(() => (cleanUp ? clearTimer : undefined), [cleanUp]);\n\n return (...args: any[]) => {\n clearTimer();\n timeoutRef.current = setTimeout(() => func(...args), delay);\n };\n}\n\ntype UseCarouselOptions = Pick<CarouselProps, 'scrollAlign'> & {\n index: number;\n throttleMs?: number;\n debounceMs?: number;\n detectActive?: boolean;\n detectThreshold?: number;\n onIndexChange?: (e: any) => void;\n};\n\ntype UseCarouselHookResult = {\n scrollRef: React.RefObject<HTMLDivElement>;\n trackRef: React.RefObject<HTMLDivElement>;\n};\n\nconst THROTTLE_DEFAULT_MS = 100;\nconst DEBOUNCE_DEFAULT_MS = 150;\n\nexport const useCarousel = ({\n index,\n onIndexChange,\n detectActive = false,\n detectThreshold = 0.5,\n scrollAlign = 'center',\n throttleMs = THROTTLE_DEFAULT_MS,\n debounceMs = DEBOUNCE_DEFAULT_MS,\n}: UseCarouselOptions): UseCarouselHookResult => {\n const prevIndex = useRef<number | null>(null);\n const offset = useRef(0);\n const scrollRef = useRef<HTMLDivElement>(null);\n const trackRef = useRef<HTMLDivElement>(null);\n const axis = 'x';\n\n /**\n * Для того, чтобы не спамить изменениями индекса.\n * Задержка дебаунса слегка больше, чем у тротлинга.\n * Таким образом, событие срабатывает при завершении скролла.\n */\n const debouncedOnIndexChange = useDebouncedFunction((i: number) => onIndexChange?.(i), debounceMs);\n\n /**\n * Вычисление центрального элемента.\n * Подсчет: от 0 до 1, какое количество ширины/высоты\n * каждого элемента находится по центру скролла.\n */\n const throttledDetectActiveItem = useMemo(() => {\n return throttle(() => {\n if (!detectActive || scrollRef.current === null || trackRef.current === null) {\n return;\n }\n\n /**\n * Правая (или нижняя для Оу) граница элемента.\n */\n let itemEdge = offset.current;\n\n /**\n * Смещение (отрицательный или положительный отступ)\n * и размер карусели (для Ox - ширина, для Oy - высота).\n */\n const scrollPos = scrollRef.current[axis === 'x' ? 'scrollLeft' : 'scrollTop'];\n const scrollSize = scrollRef.current[axis === 'x' ? 'offsetWidth' : 'offsetHeight'];\n\n /**\n * Граница скролла (видимой части).\n * Смещение + размер.\n */\n const scrollEdge = scrollPos + scrollSize;\n\n const items = getCarouselItems(trackRef.current);\n\n /**\n * Проходим по всему списку, суммируя ширины элементов,\n * пока не найдем один элемент, чей центр будет в центре карусели.\n */\n for (let itemIndex = 0; itemIndex < items.length; itemIndex++) {\n const item = items.item(itemIndex);\n\n if (item === null) {\n // eslint-disable-next-line no-continue\n continue;\n }\n\n /**\n * Для Ox - ширина, для Oy - высота.\n */\n const itemSize = item[axis === 'x' ? 'offsetWidth' : 'offsetHeight'];\n\n /**\n * Все элементы правее вьюпорта выпадают из процедуры.\n * Сравниваем по предыдущему элементу.\n * [ ... ] ...|n| <- Левый край элемента за пределами начала видимой части\n */\n if (itemEdge > scrollEdge) {\n // eslint-disable-next-line no-continue\n continue;\n }\n\n itemEdge += itemSize;\n\n /**\n * Все элементы левее вьюпорта выпадают из процедуры.\n * Сравниваем по текущему элементу.\n * Правый край элемента за пределами начала видимой части -> |p|... [ ... ]\n */\n if (scrollPos > itemEdge) {\n // eslint-disable-next-line no-continue\n continue;\n }\n\n const itemSlot = getItemSlot(\n itemIndex,\n itemEdge,\n itemSize,\n scrollPos,\n scrollSize,\n scrollAlign,\n prevIndex.current ?? 0,\n offset.current,\n );\n\n if (itemSlot !== null) {\n if (detectThreshold && Math.abs(itemSlot) <= detectThreshold) {\n debouncedOnIndexChange?.(itemIndex);\n }\n }\n }\n }, throttleMs);\n }, [debouncedOnIndexChange, detectActive, detectThreshold, scrollAlign, throttleMs]);\n\n /**\n * Прокрутка до нужной позиции индекса.\n */\n const toIndex = useCallback(\n (i: number) => {\n const scrollEl = scrollRef.current;\n const items = trackRef.current ? getCarouselItems(trackRef.current) : null;\n\n if (scrollEl && items && items.length > 0 && i >= 0) {\n scrollToPos({\n scrollEl,\n pos: getCalculatedPos({\n scrollEl,\n items,\n index: i,\n offset: offset.current,\n scrollAlign,\n }),\n });\n prevIndex.current = i;\n }\n },\n [scrollAlign],\n );\n\n useEffect(() => {\n if (scrollRef.current && trackRef.current) {\n offset.current = getCalculatedOffset(scrollRef.current, trackRef.current);\n }\n }, []);\n\n /**\n * Операции на маунте/анмаунте компонента.\n * Создать слушатели событи и т.п.\n */\n useEffect(() => {\n const carouselElement = scrollRef.current;\n\n if (carouselElement) {\n carouselElement.addEventListener('scroll', throttledDetectActiveItem);\n }\n\n return () => {\n if (carouselElement) {\n carouselElement.removeEventListener('scroll', throttledDetectActiveItem);\n }\n };\n }, [throttledDetectActiveItem]);\n\n /**\n * Прокрутка до нужной позиции индекса, если индекс изменился.\n */\n useEffect(() => {\n if (index !== prevIndex.current) {\n toIndex(index);\n }\n }, [index, toIndex]);\n\n return {\n scrollRef,\n trackRef,\n };\n};\n"],"names":["getCalculatedOffset","scrollEl","trackEl","paddingProp","parseInt","getComputedStyle","positionModByScrollAlign","_ref","scrollAlign","position","carouselSize","itemSize","offset","scrollStart","paddingOffset","getCalculatedPos","_ref2","_items$item$offsetWid2","_items$item2","items","index","item","i","_items$item$offsetWid","_items$item","offsetWidth","scrollLeft","DEFAULT_DURATION","tfs","linear","t","easeIn","Math","pow","easeOut","easeInOut","sin","PI","animatedScrollToX","elem","pos","duration","arguments","length","undefined","timingFunction","startTime","startX","endX","max","min","scrollWidth","clientWidth","handleNewAnimationFrame","Date","now","timePos","scrollPos","left","scrollTo","window","requestAnimationFrame","scrollToPos","_ref3","animated","abs","round","n","getItemSlot","itemIndex","itemEnd","scrollSize","prevIndex","scrollEnd","scrollCenter","itemCenter","prevStart","prevEnd","prevVisible","getCarouselItems","track","children","useDebouncedFunction","func","delay","cleanUp","timeoutRef","useRef","clearTimer","current","clearTimeout","useEffect","_len","args","Array","_key","setTimeout","apply","THROTTLE_DEFAULT_MS","DEBOUNCE_DEFAULT_MS","useCarousel","_ref4","onIndexChange","_ref4$detectActive","detectActive","_ref4$detectThreshold","detectThreshold","_ref4$scrollAlign","_ref4$throttleMs","throttleMs","_ref4$debounceMs","debounceMs","scrollRef","trackRef","debouncedOnIndexChange","throttledDetectActiveItem","useMemo","throttle","itemEdge","scrollEdge","_prevIndex$current","itemSlot","toIndex","useCallback","carouselElement","addEventListener","removeEventListener"],"mappings":"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"}
@@ -128,33 +128,26 @@ var Dots = /*#__PURE__*/memo(function (_ref) {
128
128
  }
129
129
  if (dotsToAdd > 0) {
130
130
  var _loop = function _loop() {
131
- var _dotWrapperRef$curren4;
132
- var node = document.createElement('div');
133
- node.textContent = '';
134
- node.classList.add(classes.dot);
135
- node.style.opacity = '0';
136
- var delay = i * (ANIMATION_DURATION / dotsToAdd);
137
- node.style.animationDelay = "".concat(delay, "s");
138
- rightAnimationWrapperRef.current.appendChild(node);
139
- var duration = ANIMATION_DURATION / dotsToAdd;
140
- requestAnimationFrame(function () {
141
- node.classList.add(classes.animateIn);
142
- node.style.animationDuration = "".concat(duration, "s");
143
- });
144
- var currentDomNode = (_dotWrapperRef$curren4 = dotWrapperRef.current.children) === null || _dotWrapperRef$curren4 === void 0 ? void 0 : _dotWrapperRef$curren4[i];
145
- if (!currentDomNode) {
146
- return {
147
- v: void 0
148
- };
149
- }
150
- currentDomNode.classList.add(classes.animateOut);
151
- currentDomNode.style.animationDelay = "".concat(delay, "s");
152
- currentDomNode.style.animationDuration = "".concat(duration, "s");
153
- },
154
- _ret;
131
+ var _dotWrapperRef$curren4;
132
+ var node = document.createElement('div');
133
+ node.textContent = '';
134
+ node.classList.add(classes.dot);
135
+ node.style.opacity = '0';
136
+ var delay = i * (ANIMATION_DURATION / dotsToAdd);
137
+ node.style.animationDelay = "".concat(delay, "s");
138
+ rightAnimationWrapperRef.current.appendChild(node);
139
+ var duration = ANIMATION_DURATION / dotsToAdd;
140
+ requestAnimationFrame(function () {
141
+ node.classList.add(classes.animateIn);
142
+ node.style.animationDuration = "".concat(duration, "s");
143
+ });
144
+ var currentDomNode = (_dotWrapperRef$curren4 = dotWrapperRef.current.children) === null || _dotWrapperRef$curren4 === void 0 ? void 0 : _dotWrapperRef$curren4[i];
145
+ currentDomNode === null || currentDomNode === void 0 || currentDomNode.classList.add(classes.animateOut);
146
+ currentDomNode.style.animationDelay = "".concat(delay, "s");
147
+ currentDomNode.style.animationDuration = "".concat(duration, "s");
148
+ };
155
149
  for (var i = 0; i < dotsToAdd; i++) {
156
- _ret = _loop();
157
- if (_ret) return _ret.v;
150
+ _loop();
158
151
  }
159
152
  }
160
153
  } else {
@@ -176,33 +169,26 @@ var Dots = /*#__PURE__*/memo(function (_ref) {
176
169
  }
177
170
  if (dotsToAdd > 0) {
178
171
  var _loop2 = function _loop2() {
179
- var _dotWrapperRef$curren7;
180
- var node = document.createElement('div');
181
- node.textContent = '';
182
- node.classList.add(classes.dot);
183
- node.style.opacity = '0';
184
- var delay = (dotsToAdd - 1 - _i) * (ANIMATION_DURATION / dotsToAdd);
185
- node.style.animationDelay = "".concat(delay, "s");
186
- leftAnimationWrapperRef.current.prepend(node);
187
- var duration = ANIMATION_DURATION / dotsToAdd;
188
- requestAnimationFrame(function () {
189
- node.classList.add(classes.animateIn);
190
- node.style.animationDuration = "".concat(duration, "s");
191
- });
192
- var currentDomNode = (_dotWrapperRef$curren7 = dotWrapperRef.current.children) === null || _dotWrapperRef$curren7 === void 0 ? void 0 : _dotWrapperRef$curren7[dotWrapperRef.current.children.length - 1 - _i];
193
- if (!currentDomNode) {
194
- return {
195
- v: void 0
196
- };
197
- }
198
- currentDomNode.classList.add(classes.animateOut);
199
- currentDomNode.style.animationDelay = "".concat(_i * (ANIMATION_DURATION / dotsToAdd), "s");
200
- currentDomNode.style.animationDuration = "".concat(duration, "s");
201
- },
202
- _ret2;
172
+ var _dotWrapperRef$curren7;
173
+ var node = document.createElement('div');
174
+ node.textContent = '';
175
+ node.classList.add(classes.dot);
176
+ node.style.opacity = '0';
177
+ var delay = (dotsToAdd - 1 - _i) * (ANIMATION_DURATION / dotsToAdd);
178
+ node.style.animationDelay = "".concat(delay, "s");
179
+ leftAnimationWrapperRef.current.prepend(node);
180
+ var duration = ANIMATION_DURATION / dotsToAdd;
181
+ requestAnimationFrame(function () {
182
+ node.classList.add(classes.animateIn);
183
+ node.style.animationDuration = "".concat(duration, "s");
184
+ });
185
+ var currentDomNode = (_dotWrapperRef$curren7 = dotWrapperRef.current.children) === null || _dotWrapperRef$curren7 === void 0 ? void 0 : _dotWrapperRef$curren7[dotWrapperRef.current.children.length - 1 - _i];
186
+ currentDomNode === null || currentDomNode === void 0 || currentDomNode.classList.add(classes.animateOut);
187
+ currentDomNode.style.animationDelay = "".concat(_i * (ANIMATION_DURATION / dotsToAdd), "s");
188
+ currentDomNode.style.animationDuration = "".concat(duration, "s");
189
+ };
203
190
  for (var _i = dotsToAdd - 1; _i >= 0; _i--) {
204
- _ret2 = _loop2();
205
- if (_ret2) return _ret2.v;
191
+ _loop2();
206
192
  }
207
193
  }
208
194
  }