@salutejs/plasma-new-hope 0.326.0-canary.2016.15556762192.0 → 0.326.0-dev.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 (281) hide show
  1. package/cjs/components/Carousel/CarouselNew/Carousel.css +41 -0
  2. package/cjs/components/Carousel/CarouselNew/Carousel.js +110 -0
  3. package/cjs/components/Carousel/CarouselNew/Carousel.js.map +1 -0
  4. package/cjs/components/Carousel/CarouselNew/Carousel.styles.js +43 -0
  5. package/cjs/components/Carousel/CarouselNew/Carousel.styles.js.map +1 -0
  6. package/cjs/components/Carousel/CarouselNew/Carousel.styles_151pk3s.css +5 -0
  7. package/cjs/components/Carousel/CarouselNew/Carousel.tokens.js +24 -0
  8. package/cjs/components/Carousel/CarouselNew/Carousel.tokens.js.map +1 -0
  9. package/cjs/components/Carousel/CarouselNew/hooks/useCarousel.js +384 -0
  10. package/cjs/components/Carousel/CarouselNew/hooks/useCarousel.js.map +1 -0
  11. package/cjs/components/Carousel/CarouselNew/ui/Dots/Dots.css +5 -0
  12. package/cjs/components/Carousel/CarouselNew/ui/Dots/Dots.js +227 -0
  13. package/cjs/components/Carousel/CarouselNew/ui/Dots/Dots.js.map +1 -0
  14. package/cjs/components/Carousel/CarouselNew/ui/Dots/Dots.styles.js +39 -0
  15. package/cjs/components/Carousel/CarouselNew/ui/Dots/Dots.styles.js.map +1 -0
  16. package/cjs/components/Carousel/CarouselNew/ui/Dots/Dots.styles_ea836d.css +5 -0
  17. package/cjs/components/Carousel/CarouselNew/ui/Dots/utils/index.js +47 -0
  18. package/cjs/components/Carousel/CarouselNew/ui/Dots/utils/index.js.map +1 -0
  19. package/cjs/components/Carousel/CarouselNew/variations/_size/base.js +9 -0
  20. package/cjs/components/Carousel/CarouselNew/variations/_size/base.js.map +1 -0
  21. package/cjs/components/Carousel/CarouselNew/variations/_size/base_x642ct.css +1 -0
  22. package/cjs/components/Carousel/CarouselNew/variations/_view/base.js +9 -0
  23. package/cjs/components/Carousel/CarouselNew/variations/_view/base.js.map +1 -0
  24. package/cjs/components/Carousel/CarouselNew/variations/_view/base_x642ct.css +1 -0
  25. package/cjs/components/Carousel/CarouselOld/Carousel.css +4 -0
  26. package/cjs/components/Carousel/{Carousel.js → CarouselOld/Carousel.js} +1 -1
  27. package/cjs/components/Carousel/CarouselOld/Carousel.js.map +1 -0
  28. package/cjs/components/Carousel/{Carousel.styles.js → CarouselOld/Carousel.styles.js} +9 -9
  29. package/cjs/components/Carousel/CarouselOld/Carousel.styles.js.map +1 -0
  30. package/cjs/components/Carousel/CarouselOld/Carousel.styles_12r304j.css +4 -0
  31. package/cjs/components/Carousel/{CarouselItem.js → CarouselOld/CarouselItem.js} +5 -5
  32. package/cjs/components/Carousel/CarouselOld/CarouselItem.js.map +1 -0
  33. package/cjs/components/Carousel/CarouselOld/CarouselItem_cghzk7.css +1 -0
  34. package/cjs/components/Carousel/CarouselOld/useCarousel.js.map +1 -0
  35. package/cjs/components/Carousel/{useDragScroll.js → CarouselOld/useDragScroll.js} +1 -1
  36. package/cjs/components/Carousel/CarouselOld/useDragScroll.js.map +1 -0
  37. package/cjs/components/Mask/Mask.js +3 -3
  38. package/cjs/components/Mask/Mask.js.map +1 -1
  39. package/cjs/hooks/useDidMountLayoutEffect.js +19 -0
  40. package/cjs/hooks/useDidMountLayoutEffect.js.map +1 -0
  41. package/cjs/index.css +17 -5
  42. package/cjs/index.js +10 -3
  43. package/cjs/index.js.map +1 -1
  44. package/emotion/cjs/components/Carousel/CarouselNew/Carousel.js +110 -0
  45. package/emotion/cjs/components/Carousel/CarouselNew/Carousel.styles.js +64 -0
  46. package/emotion/cjs/components/Carousel/CarouselNew/Carousel.tokens.js +22 -0
  47. package/emotion/cjs/components/Carousel/CarouselNew/hooks/useCarousel.js +376 -0
  48. package/emotion/cjs/components/Carousel/CarouselNew/ui/Dots/Dots.js +229 -0
  49. package/emotion/cjs/components/Carousel/CarouselNew/ui/Dots/Dots.styles.js +38 -0
  50. package/emotion/cjs/components/Carousel/CarouselNew/ui/Dots/utils/index.js +44 -0
  51. package/emotion/cjs/components/Carousel/CarouselNew/ui/index.js +16 -0
  52. package/emotion/cjs/components/Carousel/CarouselNew/variations/_size/base.js +8 -0
  53. package/emotion/cjs/components/Carousel/CarouselNew/variations/_size/tokens.json +1 -0
  54. package/emotion/cjs/components/Carousel/CarouselNew/variations/_view/base.js +8 -0
  55. package/emotion/cjs/components/Carousel/CarouselNew/variations/_view/tokens.json +1 -0
  56. package/emotion/cjs/components/Carousel/CarouselOld/Carousel.styles.js +49 -0
  57. package/emotion/cjs/components/Carousel/CarouselOld/Carousel.types.js +5 -0
  58. package/emotion/cjs/components/Carousel/{CarouselItem.js → CarouselOld/CarouselItem.js} +2 -2
  59. package/emotion/cjs/components/Carousel/CarouselOld/index.js +32 -0
  60. package/emotion/cjs/components/Carousel/index.js +23 -3
  61. package/emotion/cjs/components/Mask/Mask.js +3 -3
  62. package/emotion/cjs/examples/plasma_b2c/components/Carousel/Carousel.config.js +14 -2
  63. package/emotion/cjs/examples/plasma_b2c/components/Carousel/Carousel.js +1 -1
  64. package/emotion/cjs/examples/plasma_b2c/components/Carousel/Carousel.stories.tsx +90 -32
  65. package/emotion/cjs/examples/plasma_web/components/Carousel/Carousel.config.js +14 -2
  66. package/emotion/cjs/examples/plasma_web/components/Carousel/Carousel.js +1 -1
  67. package/emotion/cjs/examples/plasma_web/components/Carousel/Carousel.stories.tsx +91 -32
  68. package/emotion/cjs/hooks/index.js +7 -0
  69. package/emotion/cjs/hooks/useDidMountLayoutEffect.js +17 -0
  70. package/emotion/es/components/Carousel/CarouselNew/Carousel.js +101 -0
  71. package/emotion/es/components/Carousel/CarouselNew/Carousel.styles.js +57 -0
  72. package/emotion/es/components/Carousel/CarouselNew/Carousel.tokens.js +16 -0
  73. package/emotion/es/components/Carousel/CarouselNew/hooks/useCarousel.js +366 -0
  74. package/emotion/es/components/Carousel/CarouselNew/ui/Dots/Dots.js +219 -0
  75. package/emotion/es/components/Carousel/CarouselNew/ui/Dots/Dots.styles.js +31 -0
  76. package/emotion/es/components/Carousel/CarouselNew/ui/Dots/utils/index.js +38 -0
  77. package/emotion/es/components/Carousel/CarouselNew/ui/index.js +1 -0
  78. package/emotion/es/components/Carousel/CarouselNew/variations/_size/base.js +2 -0
  79. package/emotion/es/components/Carousel/CarouselNew/variations/_size/tokens.json +1 -0
  80. package/emotion/es/components/Carousel/CarouselNew/variations/_view/base.js +2 -0
  81. package/emotion/es/components/Carousel/CarouselNew/variations/_view/tokens.json +1 -0
  82. package/emotion/es/components/Carousel/CarouselOld/Carousel.styles.js +42 -0
  83. package/emotion/es/components/Carousel/CarouselOld/Carousel.types.js +1 -0
  84. package/emotion/es/components/Carousel/{CarouselItem.js → CarouselOld/CarouselItem.js} +2 -2
  85. package/emotion/es/components/Carousel/CarouselOld/index.js +3 -0
  86. package/emotion/es/components/Carousel/index.js +7 -3
  87. package/emotion/es/components/Mask/Mask.js +3 -3
  88. package/emotion/es/examples/plasma_b2c/components/Carousel/Carousel.config.js +14 -2
  89. package/emotion/es/examples/plasma_b2c/components/Carousel/Carousel.js +2 -2
  90. package/emotion/es/examples/plasma_b2c/components/Carousel/Carousel.stories.tsx +90 -32
  91. package/emotion/es/examples/plasma_web/components/Carousel/Carousel.config.js +14 -2
  92. package/emotion/es/examples/plasma_web/components/Carousel/Carousel.js +2 -2
  93. package/emotion/es/examples/plasma_web/components/Carousel/Carousel.stories.tsx +91 -32
  94. package/emotion/es/hooks/index.js +1 -0
  95. package/emotion/es/hooks/useDidMountLayoutEffect.js +11 -0
  96. package/es/components/Carousel/CarouselNew/Carousel.css +41 -0
  97. package/es/components/Carousel/CarouselNew/Carousel.js +101 -0
  98. package/es/components/Carousel/CarouselNew/Carousel.js.map +1 -0
  99. package/es/components/Carousel/CarouselNew/Carousel.styles.js +34 -0
  100. package/es/components/Carousel/CarouselNew/Carousel.styles.js.map +1 -0
  101. package/es/components/Carousel/CarouselNew/Carousel.styles_151pk3s.css +5 -0
  102. package/es/components/Carousel/CarouselNew/Carousel.tokens.js +19 -0
  103. package/es/components/Carousel/CarouselNew/Carousel.tokens.js.map +1 -0
  104. package/es/components/Carousel/CarouselNew/hooks/useCarousel.js +369 -0
  105. package/es/components/Carousel/CarouselNew/hooks/useCarousel.js.map +1 -0
  106. package/es/components/Carousel/CarouselNew/ui/Dots/Dots.css +5 -0
  107. package/es/components/Carousel/CarouselNew/ui/Dots/Dots.js +218 -0
  108. package/es/components/Carousel/CarouselNew/ui/Dots/Dots.js.map +1 -0
  109. package/es/components/Carousel/CarouselNew/ui/Dots/Dots.styles.js +31 -0
  110. package/es/components/Carousel/CarouselNew/ui/Dots/Dots.styles.js.map +1 -0
  111. package/es/components/Carousel/CarouselNew/ui/Dots/Dots.styles_ea836d.css +5 -0
  112. package/es/components/Carousel/CarouselNew/ui/Dots/utils/index.js +41 -0
  113. package/es/components/Carousel/CarouselNew/ui/Dots/utils/index.js.map +1 -0
  114. package/es/components/Carousel/CarouselNew/variations/_size/base.js +5 -0
  115. package/es/components/Carousel/CarouselNew/variations/_size/base.js.map +1 -0
  116. package/es/components/Carousel/CarouselNew/variations/_size/base_x642ct.css +1 -0
  117. package/es/components/Carousel/CarouselNew/variations/_view/base.js +5 -0
  118. package/es/components/Carousel/CarouselNew/variations/_view/base.js.map +1 -0
  119. package/es/components/Carousel/CarouselNew/variations/_view/base_x642ct.css +1 -0
  120. package/es/components/Carousel/CarouselOld/Carousel.css +4 -0
  121. package/es/components/Carousel/{Carousel.js → CarouselOld/Carousel.js} +1 -1
  122. package/es/components/Carousel/CarouselOld/Carousel.js.map +1 -0
  123. package/es/components/Carousel/{Carousel.styles.js → CarouselOld/Carousel.styles.js} +9 -9
  124. package/es/components/Carousel/CarouselOld/Carousel.styles.js.map +1 -0
  125. package/es/components/Carousel/CarouselOld/Carousel.styles_12r304j.css +4 -0
  126. package/es/components/Carousel/{CarouselItem.js → CarouselOld/CarouselItem.js} +5 -5
  127. package/es/components/Carousel/CarouselOld/CarouselItem.js.map +1 -0
  128. package/es/components/Carousel/CarouselOld/CarouselItem_cghzk7.css +1 -0
  129. package/es/components/Carousel/CarouselOld/useCarousel.js.map +1 -0
  130. package/es/components/Carousel/{useDragScroll.js → CarouselOld/useDragScroll.js} +1 -1
  131. package/es/components/Carousel/CarouselOld/useDragScroll.js.map +1 -0
  132. package/es/components/Mask/Mask.js +3 -3
  133. package/es/components/Mask/Mask.js.map +1 -1
  134. package/es/hooks/useDidMountLayoutEffect.js +15 -0
  135. package/es/hooks/useDidMountLayoutEffect.js.map +1 -0
  136. package/es/index.css +17 -5
  137. package/es/index.js +6 -3
  138. package/es/index.js.map +1 -1
  139. package/package.json +5 -5
  140. package/styled-components/cjs/components/Carousel/CarouselNew/Carousel.js +110 -0
  141. package/styled-components/cjs/components/Carousel/CarouselNew/Carousel.styles.js +28 -0
  142. package/styled-components/cjs/components/Carousel/CarouselNew/Carousel.tokens.js +22 -0
  143. package/styled-components/cjs/components/Carousel/CarouselNew/Carousel.types.js +5 -0
  144. package/styled-components/cjs/components/Carousel/CarouselNew/hooks/useCarousel.js +376 -0
  145. package/styled-components/cjs/components/Carousel/CarouselNew/ui/Dots/Dots.js +229 -0
  146. package/styled-components/cjs/components/Carousel/CarouselNew/ui/Dots/Dots.styles.js +24 -0
  147. package/styled-components/cjs/components/Carousel/CarouselNew/ui/Dots/Dots.types.js +5 -0
  148. package/styled-components/cjs/components/Carousel/CarouselNew/ui/Dots/utils/index.js +44 -0
  149. package/styled-components/cjs/components/Carousel/CarouselNew/ui/index.js +16 -0
  150. package/styled-components/cjs/components/Carousel/CarouselNew/variations/_size/base.js +8 -0
  151. package/styled-components/cjs/components/Carousel/CarouselNew/variations/_size/tokens.json +1 -0
  152. package/styled-components/cjs/components/Carousel/CarouselNew/variations/_view/base.js +8 -0
  153. package/styled-components/cjs/components/Carousel/CarouselNew/variations/_view/tokens.json +1 -0
  154. package/styled-components/cjs/components/Carousel/{Carousel.styles.js → CarouselOld/Carousel.styles.js} +3 -3
  155. package/styled-components/cjs/components/Carousel/CarouselOld/Carousel.types.js +5 -0
  156. package/styled-components/cjs/components/Carousel/{CarouselItem.js → CarouselOld/CarouselItem.js} +2 -2
  157. package/styled-components/cjs/components/Carousel/CarouselOld/index.js +32 -0
  158. package/styled-components/cjs/components/Carousel/index.js +23 -3
  159. package/styled-components/cjs/components/Mask/Mask.js +3 -3
  160. package/styled-components/cjs/examples/plasma_b2c/components/Carousel/Carousel.config.js +14 -2
  161. package/styled-components/cjs/examples/plasma_b2c/components/Carousel/Carousel.js +1 -1
  162. package/styled-components/cjs/examples/plasma_b2c/components/Carousel/Carousel.stories.tsx +90 -32
  163. package/styled-components/cjs/examples/plasma_web/components/Carousel/Carousel.config.js +14 -2
  164. package/styled-components/cjs/examples/plasma_web/components/Carousel/Carousel.js +1 -1
  165. package/styled-components/cjs/examples/plasma_web/components/Carousel/Carousel.stories.tsx +91 -32
  166. package/styled-components/cjs/hooks/index.js +7 -0
  167. package/styled-components/cjs/hooks/useDidMountLayoutEffect.js +17 -0
  168. package/styled-components/es/components/Carousel/CarouselNew/Carousel.js +101 -0
  169. package/styled-components/es/components/Carousel/CarouselNew/Carousel.styles.js +20 -0
  170. package/styled-components/es/components/Carousel/CarouselNew/Carousel.tokens.js +16 -0
  171. package/styled-components/es/components/Carousel/CarouselNew/Carousel.types.js +1 -0
  172. package/styled-components/es/components/Carousel/CarouselNew/hooks/useCarousel.js +366 -0
  173. package/styled-components/es/components/Carousel/CarouselNew/ui/Dots/Dots.js +219 -0
  174. package/styled-components/es/components/Carousel/CarouselNew/ui/Dots/Dots.styles.js +17 -0
  175. package/styled-components/es/components/Carousel/CarouselNew/ui/Dots/Dots.types.js +1 -0
  176. package/styled-components/es/components/Carousel/CarouselNew/ui/Dots/utils/index.js +38 -0
  177. package/styled-components/es/components/Carousel/CarouselNew/ui/index.js +1 -0
  178. package/styled-components/es/components/Carousel/CarouselNew/variations/_size/base.js +2 -0
  179. package/styled-components/es/components/Carousel/CarouselNew/variations/_size/tokens.json +1 -0
  180. package/styled-components/es/components/Carousel/CarouselNew/variations/_view/base.js +2 -0
  181. package/styled-components/es/components/Carousel/CarouselNew/variations/_view/tokens.json +1 -0
  182. package/styled-components/es/components/Carousel/{Carousel.styles.js → CarouselOld/Carousel.styles.js} +3 -3
  183. package/styled-components/es/components/Carousel/CarouselOld/Carousel.types.js +1 -0
  184. package/styled-components/es/components/Carousel/{CarouselItem.js → CarouselOld/CarouselItem.js} +2 -2
  185. package/styled-components/es/components/Carousel/CarouselOld/index.js +3 -0
  186. package/styled-components/es/components/Carousel/index.js +7 -3
  187. package/styled-components/es/components/Mask/Mask.js +3 -3
  188. package/styled-components/es/examples/plasma_b2c/components/Carousel/Carousel.config.js +14 -2
  189. package/styled-components/es/examples/plasma_b2c/components/Carousel/Carousel.js +2 -2
  190. package/styled-components/es/examples/plasma_b2c/components/Carousel/Carousel.stories.tsx +90 -32
  191. package/styled-components/es/examples/plasma_web/components/Carousel/Carousel.config.js +14 -2
  192. package/styled-components/es/examples/plasma_web/components/Carousel/Carousel.js +2 -2
  193. package/styled-components/es/examples/plasma_web/components/Carousel/Carousel.stories.tsx +91 -32
  194. package/styled-components/es/hooks/index.js +1 -0
  195. package/styled-components/es/hooks/useDidMountLayoutEffect.js +11 -0
  196. package/types/components/Carousel/CarouselNew/Carousel.d.ts +26 -0
  197. package/types/components/Carousel/CarouselNew/Carousel.d.ts.map +1 -0
  198. package/types/components/Carousel/CarouselNew/Carousel.styles.d.ts +91 -0
  199. package/types/components/Carousel/CarouselNew/Carousel.styles.d.ts.map +1 -0
  200. package/types/components/Carousel/CarouselNew/Carousel.tokens.d.ts +17 -0
  201. package/types/components/Carousel/CarouselNew/Carousel.tokens.d.ts.map +1 -0
  202. package/types/components/Carousel/CarouselNew/Carousel.types.d.ts +45 -0
  203. package/types/components/Carousel/CarouselNew/Carousel.types.d.ts.map +1 -0
  204. package/types/components/Carousel/CarouselNew/hooks/useCarousel.d.ts +63 -0
  205. package/types/components/Carousel/CarouselNew/hooks/useCarousel.d.ts.map +1 -0
  206. package/types/components/Carousel/CarouselNew/ui/Dots/Dots.d.ts +4 -0
  207. package/types/components/Carousel/CarouselNew/ui/Dots/Dots.d.ts.map +1 -0
  208. package/types/components/Carousel/CarouselNew/ui/Dots/Dots.styles.d.ts +6 -0
  209. package/types/components/Carousel/CarouselNew/ui/Dots/Dots.styles.d.ts.map +1 -0
  210. package/types/components/Carousel/CarouselNew/ui/Dots/Dots.types.d.ts +29 -0
  211. package/types/components/Carousel/CarouselNew/ui/Dots/Dots.types.d.ts.map +1 -0
  212. package/types/components/Carousel/CarouselNew/ui/Dots/utils/index.d.ts +4 -0
  213. package/types/components/Carousel/CarouselNew/ui/Dots/utils/index.d.ts.map +1 -0
  214. package/types/components/Carousel/CarouselNew/ui/index.d.ts +2 -0
  215. package/types/components/Carousel/CarouselNew/ui/index.d.ts.map +1 -0
  216. package/types/components/Carousel/CarouselNew/variations/_size/base.d.ts +2 -0
  217. package/types/components/Carousel/CarouselNew/variations/_size/base.d.ts.map +1 -0
  218. package/types/components/Carousel/CarouselNew/variations/_view/base.d.ts +2 -0
  219. package/types/components/Carousel/CarouselNew/variations/_view/base.d.ts.map +1 -0
  220. package/types/components/Carousel/{Carousel.d.ts → CarouselOld/Carousel.d.ts} +1 -1
  221. package/types/components/Carousel/CarouselOld/Carousel.d.ts.map +1 -0
  222. package/types/components/Carousel/CarouselOld/Carousel.styles.d.ts.map +1 -0
  223. package/types/components/Carousel/{Carousel.types.d.ts → CarouselOld/Carousel.types.d.ts} +1 -1
  224. package/types/components/Carousel/CarouselOld/Carousel.types.d.ts.map +1 -0
  225. package/types/components/Carousel/CarouselOld/CarouselItem.d.ts.map +1 -0
  226. package/types/components/Carousel/CarouselOld/index.d.ts +5 -0
  227. package/types/components/Carousel/CarouselOld/index.d.ts.map +1 -0
  228. package/types/components/Carousel/CarouselOld/useCarousel.d.ts.map +1 -0
  229. package/types/components/Carousel/CarouselOld/useDragScroll.d.ts.map +1 -0
  230. package/types/components/Carousel/index.d.ts +7 -4
  231. package/types/components/Carousel/index.d.ts.map +1 -1
  232. package/types/hooks/index.d.ts +1 -0
  233. package/types/hooks/index.d.ts.map +1 -1
  234. package/types/hooks/useDidMountLayoutEffect.d.ts +2 -0
  235. package/types/hooks/useDidMountLayoutEffect.d.ts.map +1 -0
  236. package/cjs/components/Carousel/Carousel.css +0 -4
  237. package/cjs/components/Carousel/Carousel.js.map +0 -1
  238. package/cjs/components/Carousel/Carousel.styles.js.map +0 -1
  239. package/cjs/components/Carousel/Carousel.styles_zmchjj.css +0 -4
  240. package/cjs/components/Carousel/CarouselItem.js.map +0 -1
  241. package/cjs/components/Carousel/CarouselItem_cqjszm.css +0 -1
  242. package/cjs/components/Carousel/useCarousel.js.map +0 -1
  243. package/cjs/components/Carousel/useDragScroll.js.map +0 -1
  244. package/emotion/cjs/components/Carousel/Carousel.styles.js +0 -49
  245. package/emotion/es/components/Carousel/Carousel.styles.js +0 -42
  246. package/es/components/Carousel/Carousel.css +0 -4
  247. package/es/components/Carousel/Carousel.js.map +0 -1
  248. package/es/components/Carousel/Carousel.styles.js.map +0 -1
  249. package/es/components/Carousel/Carousel.styles_zmchjj.css +0 -4
  250. package/es/components/Carousel/CarouselItem.js.map +0 -1
  251. package/es/components/Carousel/CarouselItem_cqjszm.css +0 -1
  252. package/es/components/Carousel/useCarousel.js.map +0 -1
  253. package/es/components/Carousel/useDragScroll.js.map +0 -1
  254. package/types/components/Carousel/Carousel.d.ts.map +0 -1
  255. package/types/components/Carousel/Carousel.styles.d.ts.map +0 -1
  256. package/types/components/Carousel/Carousel.types.d.ts.map +0 -1
  257. package/types/components/Carousel/CarouselItem.d.ts.map +0 -1
  258. package/types/components/Carousel/useCarousel.d.ts.map +0 -1
  259. package/types/components/Carousel/useDragScroll.d.ts.map +0 -1
  260. /package/cjs/components/Carousel/{useCarousel.js → CarouselOld/useCarousel.js} +0 -0
  261. /package/emotion/cjs/components/Carousel/{Carousel.types.js → CarouselNew/Carousel.types.js} +0 -0
  262. /package/{styled-components/cjs/components/Carousel/Carousel.types.js → emotion/cjs/components/Carousel/CarouselNew/ui/Dots/Dots.types.js} +0 -0
  263. /package/emotion/cjs/components/Carousel/{Carousel.js → CarouselOld/Carousel.js} +0 -0
  264. /package/emotion/cjs/components/Carousel/{useCarousel.js → CarouselOld/useCarousel.js} +0 -0
  265. /package/emotion/cjs/components/Carousel/{useDragScroll.js → CarouselOld/useDragScroll.js} +0 -0
  266. /package/emotion/es/components/Carousel/{Carousel.types.js → CarouselNew/Carousel.types.js} +0 -0
  267. /package/{styled-components/es/components/Carousel/Carousel.types.js → emotion/es/components/Carousel/CarouselNew/ui/Dots/Dots.types.js} +0 -0
  268. /package/emotion/es/components/Carousel/{Carousel.js → CarouselOld/Carousel.js} +0 -0
  269. /package/emotion/es/components/Carousel/{useCarousel.js → CarouselOld/useCarousel.js} +0 -0
  270. /package/emotion/es/components/Carousel/{useDragScroll.js → CarouselOld/useDragScroll.js} +0 -0
  271. /package/es/components/Carousel/{useCarousel.js → CarouselOld/useCarousel.js} +0 -0
  272. /package/styled-components/cjs/components/Carousel/{Carousel.js → CarouselOld/Carousel.js} +0 -0
  273. /package/styled-components/cjs/components/Carousel/{useCarousel.js → CarouselOld/useCarousel.js} +0 -0
  274. /package/styled-components/cjs/components/Carousel/{useDragScroll.js → CarouselOld/useDragScroll.js} +0 -0
  275. /package/styled-components/es/components/Carousel/{Carousel.js → CarouselOld/Carousel.js} +0 -0
  276. /package/styled-components/es/components/Carousel/{useCarousel.js → CarouselOld/useCarousel.js} +0 -0
  277. /package/styled-components/es/components/Carousel/{useDragScroll.js → CarouselOld/useDragScroll.js} +0 -0
  278. /package/types/components/Carousel/{Carousel.styles.d.ts → CarouselOld/Carousel.styles.d.ts} +0 -0
  279. /package/types/components/Carousel/{CarouselItem.d.ts → CarouselOld/CarouselItem.d.ts} +0 -0
  280. /package/types/components/Carousel/{useCarousel.d.ts → CarouselOld/useCarousel.d.ts} +0 -0
  281. /package/types/components/Carousel/{useDragScroll.d.ts → CarouselOld/useDragScroll.d.ts} +0 -0
@@ -0,0 +1,101 @@
1
+ var _IconDisclosureLeft, _IconDisclosureRight;
2
+ function _slicedToArray(r, e) { return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest(); }
3
+ function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
4
+ function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } }
5
+ function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; }
6
+ function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t["return"] && (u = t["return"](), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
7
+ function _arrayWithHoles(r) { if (Array.isArray(r)) return r; }
8
+ import React, { forwardRef, useState, Children } from 'react';
9
+ import { IconDisclosureLeft, IconDisclosureRight } from "../../_Icon";
10
+ import { classes } from "./Carousel.tokens";
11
+ import { base as sizeCSS } from "./variations/_size/base";
12
+ import { base as viewCSS } from "./variations/_view/base";
13
+ import { base, CarouselWrapper, CarouselTrack, ControlsWrapper, IconButton } from "./Carousel.styles";
14
+ import { useCarousel } from "./hooks/useCarousel";
15
+ import { Dots } from "./ui";
16
+ var VISIBLE_DOTS_DEFAULT = 10;
17
+ var DOTS_CENTERED_DEFAULT = false;
18
+
19
+ /**
20
+ * Компонент для создания списков с прокруткой.
21
+ */
22
+ export var carouselNewRoot = function carouselNewRoot(Root) {
23
+ return /*#__PURE__*/forwardRef(function (_ref, ref) {
24
+ var view = _ref.view,
25
+ size = _ref.size,
26
+ _ref$scrollAlign = _ref.scrollAlign,
27
+ scrollAlign = _ref$scrollAlign === void 0 ? 'center' : _ref$scrollAlign,
28
+ children = _ref.children,
29
+ _ref$controlArrowsDis = _ref.controlArrowsDisabled,
30
+ controlArrowsDisabled = _ref$controlArrowsDis === void 0 ? false : _ref$controlArrowsDis,
31
+ paginationOptions = _ref.paginationOptions,
32
+ className = _ref.className,
33
+ style = _ref.style;
34
+ var _useState = useState(0),
35
+ _useState2 = _slicedToArray(_useState, 2),
36
+ index = _useState2[0],
37
+ setIndex = _useState2[1];
38
+ var slidesAmount = Children.count(children);
39
+ var handleClickLeft = function handleClickLeft() {
40
+ setIndex(Math.max(0, index - 1));
41
+ };
42
+ var handleClickRight = function handleClickRight() {
43
+ setIndex(Math.min(slidesAmount - 1, index + 1));
44
+ };
45
+ var _useCarousel = useCarousel({
46
+ index: index,
47
+ scrollAlign: scrollAlign,
48
+ onIndexChange: setIndex
49
+ }),
50
+ scrollRef = _useCarousel.scrollRef,
51
+ trackRef = _useCarousel.trackRef;
52
+ return /*#__PURE__*/React.createElement(Root, {
53
+ className: className,
54
+ style: style,
55
+ size: size,
56
+ view: view,
57
+ ref: ref
58
+ }, /*#__PURE__*/React.createElement(ControlsWrapper, null, index !== 0 && !controlArrowsDisabled && /*#__PURE__*/React.createElement(IconButton, {
59
+ pin: "circle-circle",
60
+ onClick: handleClickLeft
61
+ }, _IconDisclosureLeft || (_IconDisclosureLeft = /*#__PURE__*/React.createElement(IconDisclosureLeft, {
62
+ size: "m",
63
+ color: "inherit"
64
+ }))), /*#__PURE__*/React.createElement(CarouselWrapper, {
65
+ ref: scrollRef
66
+ }, /*#__PURE__*/React.createElement(CarouselTrack, {
67
+ ref: trackRef
68
+ }, children)), index !== slidesAmount - 1 && !controlArrowsDisabled && /*#__PURE__*/React.createElement(IconButton, {
69
+ className: classes.rightControlButton,
70
+ pin: "circle-circle",
71
+ onClick: handleClickRight
72
+ }, _IconDisclosureRight || (_IconDisclosureRight = /*#__PURE__*/React.createElement(IconDisclosureRight, {
73
+ size: "m",
74
+ color: "inherit"
75
+ })))), !(paginationOptions !== null && paginationOptions !== void 0 && paginationOptions.disabled) && /*#__PURE__*/React.createElement(Dots, {
76
+ index: index,
77
+ onChange: setIndex,
78
+ visibleCount: (paginationOptions === null || paginationOptions === void 0 ? void 0 : paginationOptions.visibleDots) || VISIBLE_DOTS_DEFAULT,
79
+ count: slidesAmount,
80
+ centered: (paginationOptions === null || paginationOptions === void 0 ? void 0 : paginationOptions.centered) || DOTS_CENTERED_DEFAULT
81
+ }));
82
+ });
83
+ };
84
+ export var carouselNewConfig = {
85
+ name: 'Carousel',
86
+ tag: 'div',
87
+ layout: carouselNewRoot,
88
+ base: base,
89
+ variations: {
90
+ view: {
91
+ css: viewCSS
92
+ },
93
+ size: {
94
+ css: sizeCSS
95
+ }
96
+ },
97
+ defaults: {
98
+ view: 'default',
99
+ size: 's'
100
+ }
101
+ };
@@ -0,0 +1,20 @@
1
+ import styled from 'styled-components';
2
+ import { css } from 'styled-components';
3
+ import { component, mergeConfig } from "../../../engines";
4
+ import { iconButtonConfig, iconButtonTokens } from "../../IconButton";
5
+ import { classes } from "./Carousel.tokens";
6
+ var mergedConfig = /*#__PURE__*/mergeConfig(iconButtonConfig);
7
+ export var IconButtonComponent = /*#__PURE__*/component(mergedConfig);
8
+ export var base = /*#__PURE__*/css(["position:relative;"]);
9
+ export var CarouselWrapper = /*#__PURE__*/styled.div.withConfig({
10
+ componentId: "plasma-new-hope__sc-vln28v-0"
11
+ })(["position:relative;margin-left:calc(var(--plasma_private-carousel-padding) * -1);margin-right:calc(var(--plasma_private-carousel-padding) * -1);padding:0;list-style:none;-ms-overflow-style:none;scrollbar-width:none;::-webkit-scrollbar{display:none;}overflow-x:auto;overflow-y:hidden;scroll-behavior:smooth;scroll-snap-type:x mandatory;user-select:none;-webkit-tap-highlight-color:rgba(0,0,0,0);--plasma_private-carousel-padding:0.625rem;"]);
12
+ export var CarouselTrack = /*#__PURE__*/styled.div.withConfig({
13
+ componentId: "plasma-new-hope__sc-vln28v-1"
14
+ })(["display:inline-flex;flex-direction:row;"]);
15
+ export var IconButton = /*#__PURE__*/styled(IconButtonComponent).withConfig({
16
+ componentId: "plasma-new-hope__sc-vln28v-2"
17
+ })(["position:absolute;top:50%;transform:translateY(-50%);left:0.75rem;z-index:10;", ":var(--text-primary);", ":var(--surface-transparent-secondary);", ":var(", ");", ":var(--surface-transparent-secondary-hover);", ":var(--surface-transparent-secondary-active);", ":2.5rem;", ":2.5rem;", ":1rem;", ":0.625rem;&.", "{left:auto;right:0.75rem;}"], iconButtonTokens.iconButtonColor, iconButtonTokens.iconButtonBackgroundColor, iconButtonTokens.iconButtonLoadingBackgroundColor, iconButtonTokens.iconButtonBackgroundColor, iconButtonTokens.iconButtonBackgroundColorHover, iconButtonTokens.iconButtonBackgroundColorActive, iconButtonTokens.iconButtonHeight, iconButtonTokens.iconButtonWidth, iconButtonTokens.iconButtonPadding, iconButtonTokens.iconButtonRadius, classes.rightControlButton);
18
+ export var ControlsWrapper = /*#__PURE__*/styled.div.withConfig({
19
+ componentId: "plasma-new-hope__sc-vln28v-3"
20
+ })(["position:relative;"]);
@@ -0,0 +1,16 @@
1
+ export var classes = {
2
+ dot: 'dot',
3
+ active: 'dot-active',
4
+ animating: 'dot-animating',
5
+ animateIn: 'dot-animate-in',
6
+ animateOut: 'dot-animate-out',
7
+ temporaryNatural: 'dot-temporary-natural',
8
+ shrinking: 'dot-shrinking',
9
+ availableDotsLeft: 'dot-available-dots-left',
10
+ availableDotsRight: 'dot-available-dots-right',
11
+ rightControlButton: 'carousel-right-control-button'
12
+ };
13
+ export var tokens = {
14
+ paginationDotBackground: '--plasma-carousel-pagination-dot-background',
15
+ paginationDotActiveBackground: '--plasma-carousel-pagination-dot-active-background'
16
+ };
@@ -0,0 +1,366 @@
1
+ import { useEffect, useCallback, useRef, useMemo } from 'react';
2
+ import throttle from 'lodash.throttle';
3
+ /**
4
+ * Подсчет смещения из-за паддингов.
5
+ */
6
+ export var getCalculatedOffset = function getCalculatedOffset(scrollEl, trackEl) {
7
+ var paddingProp = 'paddingLeft';
8
+ return parseInt(getComputedStyle(scrollEl)[paddingProp], 10) + parseInt(getComputedStyle(trackEl)[paddingProp], 10);
9
+ };
10
+ var positionModByScrollAlign = function positionModByScrollAlign(_ref) {
11
+ var scrollAlign = _ref.scrollAlign,
12
+ position = _ref.position,
13
+ carouselSize = _ref.carouselSize,
14
+ itemSize = _ref.itemSize,
15
+ offset = _ref.offset,
16
+ scrollStart = _ref.scrollStart;
17
+ if (scrollAlign === 'start') {
18
+ var paddingOffset = 0;
19
+ return position + paddingOffset;
20
+ }
21
+ if (scrollAlign === 'center') {
22
+ return position - carouselSize / 2 + itemSize / 2;
23
+ }
24
+ if (scrollAlign === 'end') {
25
+ return position - carouselSize + itemSize + offset;
26
+ }
27
+ if (scrollAlign === 'activeDirection') {
28
+ if (position >= scrollStart + carouselSize - itemSize) {
29
+ return position - carouselSize + itemSize + offset;
30
+ }
31
+ if (position > scrollStart) {
32
+ return scrollStart;
33
+ }
34
+ }
35
+ return position;
36
+ };
37
+
38
+ /**
39
+ * Подсчет скролла до переданного индекса.
40
+ */
41
+ export var getCalculatedPos = function getCalculatedPos(_ref2) {
42
+ var _items$item$offsetWid2, _items$item2;
43
+ var scrollEl = _ref2.scrollEl,
44
+ items = _ref2.items,
45
+ index = _ref2.index,
46
+ offset = _ref2.offset,
47
+ scrollAlign = _ref2.scrollAlign;
48
+ var position = scrollAlign === 'center' ? offset : 0;
49
+ if (items.item(index) === null) {
50
+ return position;
51
+ }
52
+ for (var i = 0; i < index; i++) {
53
+ var _items$item$offsetWid, _items$item;
54
+ 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;
55
+ }
56
+ var carouselSize = scrollEl.offsetWidth;
57
+ 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;
58
+ var scrollStart = scrollEl.scrollLeft;
59
+ return positionModByScrollAlign({
60
+ scrollAlign: scrollAlign,
61
+ position: position,
62
+ carouselSize: carouselSize,
63
+ itemSize: itemSize,
64
+ offset: offset,
65
+ scrollStart: scrollStart
66
+ });
67
+ };
68
+ var DEFAULT_DURATION = 300;
69
+
70
+ // https://css-tricks.com/emulating-css-timing-functions-javascript/
71
+ var tfs = {
72
+ linear: function linear(t) {
73
+ return t;
74
+ },
75
+ // eslint-disable-next-line
76
+ easeIn: function easeIn(t) {
77
+ return Math.pow(t, 1.675);
78
+ },
79
+ // eslint-disable-next-line
80
+ easeOut: function easeOut(t) {
81
+ return 1 - Math.pow(1 - t, 1.675);
82
+ },
83
+ easeInOut: function easeInOut(t) {
84
+ return 0.5 * (Math.sin((t - 0.5) * Math.PI) + 1);
85
+ }
86
+ };
87
+ /**
88
+ * Плавная прокрутка по горизонтали
89
+ * @param {Element} elem
90
+ * @param {number} pos
91
+ * @param {number} duration
92
+ * @param {string} timingFunction
93
+ */
94
+ export var animatedScrollToX = function animatedScrollToX(elem, pos) {
95
+ var duration = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : DEFAULT_DURATION;
96
+ var timingFunction = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 'easeInOut';
97
+ var startTime;
98
+ var startX = elem.scrollLeft;
99
+ var endX = Math.max(0, Math.min(elem.scrollWidth - elem.clientWidth, pos));
100
+ var handleNewAnimationFrame = function handleNewAnimationFrame() {
101
+ startTime = startTime || Date.now();
102
+ var timePos = Math.min(1, Math.max(1, Date.now() - startTime) / duration);
103
+ var scrollPos = tfs[timingFunction](timePos);
104
+ var left = startX + (endX - startX) * scrollPos;
105
+ elem.scrollTo({
106
+ left: left
107
+ });
108
+ if (timePos !== 1) window.requestAnimationFrame(handleNewAnimationFrame);
109
+ };
110
+ window.requestAnimationFrame(handleNewAnimationFrame);
111
+ };
112
+
113
+ /**
114
+ * Прокрутка к указанной позиции с анимацией или без.
115
+ */
116
+ export var scrollToPos = function scrollToPos(_ref3) {
117
+ var scrollEl = _ref3.scrollEl,
118
+ pos = _ref3.pos,
119
+ animated = _ref3.animated,
120
+ duration = _ref3.duration,
121
+ timingFunction = _ref3.timingFunction;
122
+ if (Math.abs(pos - scrollEl.scrollLeft) > 1) {
123
+ if (animated) {
124
+ animatedScrollToX(scrollEl, pos, duration, timingFunction);
125
+ } else {
126
+ scrollEl.scrollTo({
127
+ left: pos
128
+ });
129
+ }
130
+ }
131
+ };
132
+ var round = function round(n) {
133
+ return Math.round(n * 100) / 100;
134
+ };
135
+
136
+ /**
137
+ * Получить позицию (слот) айтема в каруселе.
138
+ * Каждый айтем имеет свой слот относительно вьюпорта карусели.
139
+ */
140
+ export var getItemSlot = function getItemSlot(itemIndex, itemEnd, itemSize, scrollStart, scrollSize, scrollAlign) {
141
+ var prevIndex = arguments.length > 6 && arguments[6] !== undefined ? arguments[6] : 0;
142
+ var offset = arguments.length > 7 && arguments[7] !== undefined ? arguments[7] : 0;
143
+ /**
144
+ * Граница и центр скролла (видимой части).
145
+ * Смещение + размер.
146
+ */
147
+ var scrollEnd = scrollStart + scrollSize;
148
+ var scrollCenter = scrollStart + scrollSize / 2;
149
+ var itemCenter = itemEnd - itemSize / 2;
150
+ if (scrollAlign === 'center') {
151
+ return round((itemCenter - scrollCenter) / itemSize);
152
+ }
153
+ if (scrollAlign === 'start') {
154
+ return round((itemEnd - itemSize - scrollStart) / itemSize);
155
+ }
156
+ if (scrollAlign === 'end') {
157
+ return round((itemEnd - (scrollSize + scrollStart)) / itemSize);
158
+ }
159
+ if (scrollAlign === 'activeDirection') {
160
+ var prevStart = offset + itemSize * prevIndex;
161
+ var prevEnd = prevStart + itemSize;
162
+ var prevVisible = prevEnd > scrollStart && prevStart < scrollEnd;
163
+ if (!prevVisible) {
164
+ if (prevIndex < itemIndex) {
165
+ return round((itemEnd - (scrollSize + scrollStart)) / itemSize);
166
+ }
167
+ return round((itemEnd - itemSize - scrollStart) / itemSize);
168
+ }
169
+ }
170
+ return null;
171
+ };
172
+ export function getCarouselItems(track) {
173
+ return track.children;
174
+ }
175
+ export function useDebouncedFunction(func, delay, cleanUp) {
176
+ var timeoutRef = useRef();
177
+
178
+ /**
179
+ * Очистка таймера
180
+ */
181
+ function clearTimer() {
182
+ if (timeoutRef.current) {
183
+ clearTimeout(timeoutRef.current);
184
+ timeoutRef.current = undefined;
185
+ }
186
+ }
187
+
188
+ /**
189
+ * Очищаем таймер при анмаунте компонента, если cleanUp выставлен в true
190
+ * и тем самым отменяем последний запланированный вызов
191
+ */
192
+ useEffect(function () {
193
+ return cleanUp ? clearTimer : undefined;
194
+ }, [cleanUp]);
195
+ return function () {
196
+ for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
197
+ args[_key] = arguments[_key];
198
+ }
199
+ clearTimer();
200
+ timeoutRef.current = setTimeout(function () {
201
+ return func.apply(void 0, args);
202
+ }, delay);
203
+ };
204
+ }
205
+ var THROTTLE_DEFAULT_MS = 100;
206
+ var DEBOUNCE_DEFAULT_MS = 150;
207
+ export var useCarousel = function useCarousel(_ref4) {
208
+ var index = _ref4.index,
209
+ onIndexChange = _ref4.onIndexChange,
210
+ _ref4$detectActive = _ref4.detectActive,
211
+ detectActive = _ref4$detectActive === void 0 ? false : _ref4$detectActive,
212
+ _ref4$detectThreshold = _ref4.detectThreshold,
213
+ detectThreshold = _ref4$detectThreshold === void 0 ? 0.5 : _ref4$detectThreshold,
214
+ _ref4$scrollAlign = _ref4.scrollAlign,
215
+ scrollAlign = _ref4$scrollAlign === void 0 ? 'center' : _ref4$scrollAlign,
216
+ _ref4$throttleMs = _ref4.throttleMs,
217
+ throttleMs = _ref4$throttleMs === void 0 ? THROTTLE_DEFAULT_MS : _ref4$throttleMs,
218
+ _ref4$debounceMs = _ref4.debounceMs,
219
+ debounceMs = _ref4$debounceMs === void 0 ? DEBOUNCE_DEFAULT_MS : _ref4$debounceMs;
220
+ var prevIndex = useRef(null);
221
+ var offset = useRef(0);
222
+ var scrollRef = useRef(null);
223
+ var trackRef = useRef(null);
224
+ var axis = 'x';
225
+
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[axis === 'x' ? 'scrollLeft' : 'scrollTop'];
256
+ var scrollSize = scrollRef.current[axis === 'x' ? 'offsetWidth' : 'offsetHeight'];
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[axis === 'x' ? 'offsetWidth' : 'offsetHeight'];
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]);
332
+ useEffect(function () {
333
+ if (scrollRef.current && trackRef.current) {
334
+ offset.current = getCalculatedOffset(scrollRef.current, trackRef.current);
335
+ }
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);
360
+ }
361
+ }, [index, toIndex]);
362
+ return {
363
+ scrollRef: scrollRef,
364
+ trackRef: trackRef
365
+ };
366
+ };