@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,376 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.getCalculatedPos = exports.getCalculatedOffset = exports.animatedScrollToX = void 0;
7
+ exports.getCarouselItems = getCarouselItems;
8
+ exports.useCarousel = exports.scrollToPos = exports.getItemSlot = void 0;
9
+ exports.useDebouncedFunction = useDebouncedFunction;
10
+ var _react = /*#__PURE__*/require("react");
11
+ var _lodash = /*#__PURE__*/_interopRequireDefault(/*#__PURE__*/require("lodash.throttle"));
12
+ function _interopRequireDefault(e) { return e && e.__esModule ? e : { "default": e }; }
13
+ /**
14
+ * Подсчет смещения из-за паддингов.
15
+ */
16
+ var getCalculatedOffset = exports.getCalculatedOffset = function getCalculatedOffset(scrollEl, trackEl) {
17
+ var paddingProp = 'paddingLeft';
18
+ return parseInt(getComputedStyle(scrollEl)[paddingProp], 10) + parseInt(getComputedStyle(trackEl)[paddingProp], 10);
19
+ };
20
+ var positionModByScrollAlign = function positionModByScrollAlign(_ref) {
21
+ var scrollAlign = _ref.scrollAlign,
22
+ position = _ref.position,
23
+ carouselSize = _ref.carouselSize,
24
+ itemSize = _ref.itemSize,
25
+ offset = _ref.offset,
26
+ scrollStart = _ref.scrollStart;
27
+ if (scrollAlign === 'start') {
28
+ var paddingOffset = 0;
29
+ return position + paddingOffset;
30
+ }
31
+ if (scrollAlign === 'center') {
32
+ return position - carouselSize / 2 + itemSize / 2;
33
+ }
34
+ if (scrollAlign === 'end') {
35
+ return position - carouselSize + itemSize + offset;
36
+ }
37
+ if (scrollAlign === 'activeDirection') {
38
+ if (position >= scrollStart + carouselSize - itemSize) {
39
+ return position - carouselSize + itemSize + offset;
40
+ }
41
+ if (position > scrollStart) {
42
+ return scrollStart;
43
+ }
44
+ }
45
+ return position;
46
+ };
47
+
48
+ /**
49
+ * Подсчет скролла до переданного индекса.
50
+ */
51
+ var getCalculatedPos = exports.getCalculatedPos = function getCalculatedPos(_ref2) {
52
+ var _items$item$offsetWid2, _items$item2;
53
+ var scrollEl = _ref2.scrollEl,
54
+ items = _ref2.items,
55
+ index = _ref2.index,
56
+ offset = _ref2.offset,
57
+ scrollAlign = _ref2.scrollAlign;
58
+ var position = scrollAlign === 'center' ? offset : 0;
59
+ if (items.item(index) === null) {
60
+ return position;
61
+ }
62
+ for (var i = 0; i < index; i++) {
63
+ var _items$item$offsetWid, _items$item;
64
+ 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;
65
+ }
66
+ var carouselSize = scrollEl.offsetWidth;
67
+ 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;
68
+ var scrollStart = scrollEl.scrollLeft;
69
+ return positionModByScrollAlign({
70
+ scrollAlign: scrollAlign,
71
+ position: position,
72
+ carouselSize: carouselSize,
73
+ itemSize: itemSize,
74
+ offset: offset,
75
+ scrollStart: scrollStart
76
+ });
77
+ };
78
+ var DEFAULT_DURATION = 300;
79
+
80
+ // https://css-tricks.com/emulating-css-timing-functions-javascript/
81
+ var tfs = {
82
+ linear: function linear(t) {
83
+ return t;
84
+ },
85
+ // eslint-disable-next-line
86
+ easeIn: function easeIn(t) {
87
+ return Math.pow(t, 1.675);
88
+ },
89
+ // eslint-disable-next-line
90
+ easeOut: function easeOut(t) {
91
+ return 1 - Math.pow(1 - t, 1.675);
92
+ },
93
+ easeInOut: function easeInOut(t) {
94
+ return 0.5 * (Math.sin((t - 0.5) * Math.PI) + 1);
95
+ }
96
+ };
97
+ /**
98
+ * Плавная прокрутка по горизонтали
99
+ * @param {Element} elem
100
+ * @param {number} pos
101
+ * @param {number} duration
102
+ * @param {string} timingFunction
103
+ */
104
+ var animatedScrollToX = exports.animatedScrollToX = function animatedScrollToX(elem, pos) {
105
+ var duration = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : DEFAULT_DURATION;
106
+ var timingFunction = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 'easeInOut';
107
+ var startTime;
108
+ var startX = elem.scrollLeft;
109
+ var endX = Math.max(0, Math.min(elem.scrollWidth - elem.clientWidth, pos));
110
+ var handleNewAnimationFrame = function handleNewAnimationFrame() {
111
+ startTime = startTime || Date.now();
112
+ var timePos = Math.min(1, Math.max(1, Date.now() - startTime) / duration);
113
+ var scrollPos = tfs[timingFunction](timePos);
114
+ var left = startX + (endX - startX) * scrollPos;
115
+ elem.scrollTo({
116
+ left: left
117
+ });
118
+ if (timePos !== 1) window.requestAnimationFrame(handleNewAnimationFrame);
119
+ };
120
+ window.requestAnimationFrame(handleNewAnimationFrame);
121
+ };
122
+
123
+ /**
124
+ * Прокрутка к указанной позиции с анимацией или без.
125
+ */
126
+ var scrollToPos = exports.scrollToPos = function scrollToPos(_ref3) {
127
+ var scrollEl = _ref3.scrollEl,
128
+ pos = _ref3.pos,
129
+ animated = _ref3.animated,
130
+ duration = _ref3.duration,
131
+ timingFunction = _ref3.timingFunction;
132
+ if (Math.abs(pos - scrollEl.scrollLeft) > 1) {
133
+ if (animated) {
134
+ animatedScrollToX(scrollEl, pos, duration, timingFunction);
135
+ } else {
136
+ scrollEl.scrollTo({
137
+ left: pos
138
+ });
139
+ }
140
+ }
141
+ };
142
+ var round = function round(n) {
143
+ return Math.round(n * 100) / 100;
144
+ };
145
+
146
+ /**
147
+ * Получить позицию (слот) айтема в каруселе.
148
+ * Каждый айтем имеет свой слот относительно вьюпорта карусели.
149
+ */
150
+ var getItemSlot = exports.getItemSlot = function getItemSlot(itemIndex, itemEnd, itemSize, scrollStart, scrollSize, scrollAlign) {
151
+ var prevIndex = arguments.length > 6 && arguments[6] !== undefined ? arguments[6] : 0;
152
+ var offset = arguments.length > 7 && arguments[7] !== undefined ? arguments[7] : 0;
153
+ /**
154
+ * Граница и центр скролла (видимой части).
155
+ * Смещение + размер.
156
+ */
157
+ var scrollEnd = scrollStart + scrollSize;
158
+ var scrollCenter = scrollStart + scrollSize / 2;
159
+ var itemCenter = itemEnd - itemSize / 2;
160
+ if (scrollAlign === 'center') {
161
+ return round((itemCenter - scrollCenter) / itemSize);
162
+ }
163
+ if (scrollAlign === 'start') {
164
+ return round((itemEnd - itemSize - scrollStart) / itemSize);
165
+ }
166
+ if (scrollAlign === 'end') {
167
+ return round((itemEnd - (scrollSize + scrollStart)) / itemSize);
168
+ }
169
+ if (scrollAlign === 'activeDirection') {
170
+ var prevStart = offset + itemSize * prevIndex;
171
+ var prevEnd = prevStart + itemSize;
172
+ var prevVisible = prevEnd > scrollStart && prevStart < scrollEnd;
173
+ if (!prevVisible) {
174
+ if (prevIndex < itemIndex) {
175
+ return round((itemEnd - (scrollSize + scrollStart)) / itemSize);
176
+ }
177
+ return round((itemEnd - itemSize - scrollStart) / itemSize);
178
+ }
179
+ }
180
+ return null;
181
+ };
182
+ function getCarouselItems(track) {
183
+ return track.children;
184
+ }
185
+ function useDebouncedFunction(func, delay, cleanUp) {
186
+ var timeoutRef = (0, _react.useRef)();
187
+
188
+ /**
189
+ * Очистка таймера
190
+ */
191
+ function clearTimer() {
192
+ if (timeoutRef.current) {
193
+ clearTimeout(timeoutRef.current);
194
+ timeoutRef.current = undefined;
195
+ }
196
+ }
197
+
198
+ /**
199
+ * Очищаем таймер при анмаунте компонента, если cleanUp выставлен в true
200
+ * и тем самым отменяем последний запланированный вызов
201
+ */
202
+ (0, _react.useEffect)(function () {
203
+ return cleanUp ? clearTimer : undefined;
204
+ }, [cleanUp]);
205
+ return function () {
206
+ for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
207
+ args[_key] = arguments[_key];
208
+ }
209
+ clearTimer();
210
+ timeoutRef.current = setTimeout(function () {
211
+ return func.apply(void 0, args);
212
+ }, delay);
213
+ };
214
+ }
215
+ var THROTTLE_DEFAULT_MS = 100;
216
+ var DEBOUNCE_DEFAULT_MS = 150;
217
+ var useCarousel = exports.useCarousel = function useCarousel(_ref4) {
218
+ var index = _ref4.index,
219
+ onIndexChange = _ref4.onIndexChange,
220
+ _ref4$detectActive = _ref4.detectActive,
221
+ detectActive = _ref4$detectActive === void 0 ? false : _ref4$detectActive,
222
+ _ref4$detectThreshold = _ref4.detectThreshold,
223
+ detectThreshold = _ref4$detectThreshold === void 0 ? 0.5 : _ref4$detectThreshold,
224
+ _ref4$scrollAlign = _ref4.scrollAlign,
225
+ scrollAlign = _ref4$scrollAlign === void 0 ? 'center' : _ref4$scrollAlign,
226
+ _ref4$throttleMs = _ref4.throttleMs,
227
+ throttleMs = _ref4$throttleMs === void 0 ? THROTTLE_DEFAULT_MS : _ref4$throttleMs,
228
+ _ref4$debounceMs = _ref4.debounceMs,
229
+ debounceMs = _ref4$debounceMs === void 0 ? DEBOUNCE_DEFAULT_MS : _ref4$debounceMs;
230
+ var prevIndex = (0, _react.useRef)(null);
231
+ var offset = (0, _react.useRef)(0);
232
+ var scrollRef = (0, _react.useRef)(null);
233
+ var trackRef = (0, _react.useRef)(null);
234
+ var axis = 'x';
235
+
236
+ /**
237
+ * Для того, чтобы не спамить изменениями индекса.
238
+ * Задержка дебаунса слегка больше, чем у тротлинга.
239
+ * Таким образом, событие срабатывает при завершении скролла.
240
+ */
241
+ var debouncedOnIndexChange = useDebouncedFunction(function (i) {
242
+ return onIndexChange === null || onIndexChange === void 0 ? void 0 : onIndexChange(i);
243
+ }, debounceMs);
244
+
245
+ /**
246
+ * Вычисление центрального элемента.
247
+ * Подсчет: от 0 до 1, какое количество ширины/высоты
248
+ * каждого элемента находится по центру скролла.
249
+ */
250
+ var throttledDetectActiveItem = (0, _react.useMemo)(function () {
251
+ return (0, _lodash["default"])(function () {
252
+ if (!detectActive || scrollRef.current === null || trackRef.current === null) {
253
+ return;
254
+ }
255
+
256
+ /**
257
+ * Правая (или нижняя для Оу) граница элемента.
258
+ */
259
+ var itemEdge = offset.current;
260
+
261
+ /**
262
+ * Смещение (отрицательный или положительный отступ)
263
+ * и размер карусели (для Ox - ширина, для Oy - высота).
264
+ */
265
+ var scrollPos = scrollRef.current[axis === 'x' ? 'scrollLeft' : 'scrollTop'];
266
+ var scrollSize = scrollRef.current[axis === 'x' ? 'offsetWidth' : 'offsetHeight'];
267
+
268
+ /**
269
+ * Граница скролла (видимой части).
270
+ * Смещение + размер.
271
+ */
272
+ var scrollEdge = scrollPos + scrollSize;
273
+ var items = getCarouselItems(trackRef.current);
274
+
275
+ /**
276
+ * Проходим по всему списку, суммируя ширины элементов,
277
+ * пока не найдем один элемент, чей центр будет в центре карусели.
278
+ */
279
+ for (var itemIndex = 0; itemIndex < items.length; itemIndex++) {
280
+ var _prevIndex$current;
281
+ var item = items.item(itemIndex);
282
+ if (item === null) {
283
+ // eslint-disable-next-line no-continue
284
+ continue;
285
+ }
286
+
287
+ /**
288
+ * Для Ox - ширина, для Oy - высота.
289
+ */
290
+ var itemSize = item[axis === 'x' ? 'offsetWidth' : 'offsetHeight'];
291
+
292
+ /**
293
+ * Все элементы правее вьюпорта выпадают из процедуры.
294
+ * Сравниваем по предыдущему элементу.
295
+ * [ ... ] ...|n| <- Левый край элемента за пределами начала видимой части
296
+ */
297
+ if (itemEdge > scrollEdge) {
298
+ // eslint-disable-next-line no-continue
299
+ continue;
300
+ }
301
+ itemEdge += itemSize;
302
+
303
+ /**
304
+ * Все элементы левее вьюпорта выпадают из процедуры.
305
+ * Сравниваем по текущему элементу.
306
+ * Правый край элемента за пределами начала видимой части -> |p|... [ ... ]
307
+ */
308
+ if (scrollPos > itemEdge) {
309
+ // eslint-disable-next-line no-continue
310
+ continue;
311
+ }
312
+ var itemSlot = getItemSlot(itemIndex, itemEdge, itemSize, scrollPos, scrollSize, scrollAlign, (_prevIndex$current = prevIndex.current) !== null && _prevIndex$current !== void 0 ? _prevIndex$current : 0, offset.current);
313
+ if (itemSlot !== null) {
314
+ if (detectThreshold && Math.abs(itemSlot) <= detectThreshold) {
315
+ debouncedOnIndexChange === null || debouncedOnIndexChange === void 0 || debouncedOnIndexChange(itemIndex);
316
+ }
317
+ }
318
+ }
319
+ }, throttleMs);
320
+ }, [debouncedOnIndexChange, detectActive, detectThreshold, scrollAlign, throttleMs]);
321
+
322
+ /**
323
+ * Прокрутка до нужной позиции индекса.
324
+ */
325
+ var toIndex = (0, _react.useCallback)(function (i) {
326
+ var scrollEl = scrollRef.current;
327
+ var items = trackRef.current ? getCarouselItems(trackRef.current) : null;
328
+ if (scrollEl && items && items.length > 0 && i >= 0) {
329
+ scrollToPos({
330
+ scrollEl: scrollEl,
331
+ pos: getCalculatedPos({
332
+ scrollEl: scrollEl,
333
+ items: items,
334
+ index: i,
335
+ offset: offset.current,
336
+ scrollAlign: scrollAlign
337
+ })
338
+ });
339
+ prevIndex.current = i;
340
+ }
341
+ }, [scrollAlign]);
342
+ (0, _react.useEffect)(function () {
343
+ if (scrollRef.current && trackRef.current) {
344
+ offset.current = getCalculatedOffset(scrollRef.current, trackRef.current);
345
+ }
346
+ }, []);
347
+
348
+ /**
349
+ * Операции на маунте/анмаунте компонента.
350
+ * Создать слушатели событи и т.п.
351
+ */
352
+ (0, _react.useEffect)(function () {
353
+ var carouselElement = scrollRef.current;
354
+ if (carouselElement) {
355
+ carouselElement.addEventListener('scroll', throttledDetectActiveItem);
356
+ }
357
+ return function () {
358
+ if (carouselElement) {
359
+ carouselElement.removeEventListener('scroll', throttledDetectActiveItem);
360
+ }
361
+ };
362
+ }, [throttledDetectActiveItem]);
363
+
364
+ /**
365
+ * Прокрутка до нужной позиции индекса, если индекс изменился.
366
+ */
367
+ (0, _react.useEffect)(function () {
368
+ if (index !== prevIndex.current) {
369
+ toIndex(index);
370
+ }
371
+ }, [index, toIndex]);
372
+ return {
373
+ scrollRef: scrollRef,
374
+ trackRef: trackRef
375
+ };
376
+ };
@@ -0,0 +1,229 @@
1
+ "use strict";
2
+
3
+ function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.Dots = void 0;
8
+ var _react = /*#__PURE__*/_interopRequireWildcard(/*#__PURE__*/require("react"));
9
+ var _classnames = /*#__PURE__*/_interopRequireDefault(/*#__PURE__*/require("classnames"));
10
+ var _hooks = /*#__PURE__*/require("../../../../../hooks");
11
+ var _Carousel = /*#__PURE__*/require("../../Carousel.tokens");
12
+ var _index = /*#__PURE__*/require("./utils/index");
13
+ var _Dots = /*#__PURE__*/require("./Dots.styles");
14
+ function _interopRequireDefault(e) { return e && e.__esModule ? e : { "default": e }; }
15
+ function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
16
+ function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
17
+ function _slicedToArray(r, e) { return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest(); }
18
+ 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."); }
19
+ 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; } }
20
+ 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; }
21
+ 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; } }
22
+ function _arrayWithHoles(r) { if (Array.isArray(r)) return r; }
23
+ var SIZE = 16; // размер точки в px
24
+ var ANIMATION_DURATION = 0.3; // скорость анимации в секундах
25
+
26
+ var Dots = exports.Dots = /*#__PURE__*/(0, _react.memo)(function (_ref) {
27
+ var _ref$index = _ref.index,
28
+ originalIndex = _ref$index === void 0 ? 0 : _ref$index,
29
+ onChange = _ref.onChange,
30
+ _ref$centered = _ref.centered,
31
+ centered = _ref$centered === void 0 ? false : _ref$centered,
32
+ _ref$count = _ref.count,
33
+ count = _ref$count === void 0 ? 0 : _ref$count,
34
+ _ref$visibleCount = _ref.visibleCount,
35
+ originalVisibleCount = _ref$visibleCount === void 0 ? 0 : _ref$visibleCount;
36
+ // Трансформируем входные параметры для корректной работы в дальнейшем
37
+ var _getInitialData = (0, _index.getInitialData)(originalIndex, count, originalVisibleCount),
38
+ _getInitialData2 = _slicedToArray(_getInitialData, 2),
39
+ index = _getInitialData2[0],
40
+ visibleCount = _getInitialData2[1];
41
+
42
+ // Рефки на DOM-ноды
43
+ var transitionWrapperRef = (0, _react.useRef)(null);
44
+ var dotWrapperRef = (0, _react.useRef)(null);
45
+ var leftAnimationWrapperRef = (0, _react.useRef)(null);
46
+ var rightAnimationWrapperRef = (0, _react.useRef)(null);
47
+
48
+ // Консистентные переменные
49
+ var isAnimating = (0, _react.useRef)(false);
50
+ var prevIndex = (0, _react.useRef)(-Infinity);
51
+ var prevActiveIndex = (0, _react.useRef)(Infinity);
52
+ var isRightDirection = index > prevIndex.current;
53
+ var diffDotsRange = Math.abs(index - prevIndex.current);
54
+ var activeIndex = (0, _index.getActiveIndex)(index, isRightDirection, count, visibleCount);
55
+ var hiddenDotsLeft = activeIndex < index;
56
+ var hiddenDotsRight = index + (visibleCount - 1 - activeIndex) < count - 1;
57
+ var handleClick = function handleClick(i) {
58
+ if (isAnimating.current) return;
59
+ if (onChange) {
60
+ onChange(index + (i - activeIndex));
61
+ }
62
+ };
63
+ var handleTransitionEnd = function handleTransitionEnd() {
64
+ if (!dotWrapperRef || !dotWrapperRef.current || !transitionWrapperRef || !transitionWrapperRef.current || !rightAnimationWrapperRef || !rightAnimationWrapperRef.current || !leftAnimationWrapperRef || !leftAnimationWrapperRef.current) {
65
+ return;
66
+ }
67
+ dotWrapperRef.current.classList.remove(_Carousel.classes.animating);
68
+ transitionWrapperRef.current.classList.remove(_Carousel.classes.animating);
69
+ Array.from(dotWrapperRef.current.children).forEach(function (child) {
70
+ var _child$classList;
71
+ (_child$classList = child.classList).remove.apply(_child$classList, [_Carousel.classes.active, _Carousel.classes.animateOut, _Carousel.classes.temporaryNatural, _Carousel.classes.shrinking]);
72
+ });
73
+ dotWrapperRef.current.children[activeIndex].classList.add(_Carousel.classes.active);
74
+ if (centered) {
75
+ transitionWrapperRef.current.style.transform = "translateX(".concat(visibleCount * SIZE / 2 - SIZE / 2 - activeIndex * SIZE, "px)");
76
+ } else {
77
+ transitionWrapperRef.current.style.transform = 'translateX(0)';
78
+ }
79
+ setTimeout(function () {
80
+ if (transitionWrapperRef && transitionWrapperRef.current) {
81
+ isAnimating.current = false;
82
+ }
83
+ });
84
+
85
+ // Очищаем блоки с анимированными точками
86
+ leftAnimationWrapperRef.current.innerText = '';
87
+ rightAnimationWrapperRef.current.innerText = '';
88
+ prevIndex.current = index;
89
+ prevActiveIndex.current = activeIndex;
90
+ isAnimating.current = false;
91
+ };
92
+ (0, _react.useLayoutEffect)(function () {
93
+ if (!dotWrapperRef || !dotWrapperRef.current || !transitionWrapperRef || !transitionWrapperRef.current) {
94
+ return;
95
+ }
96
+
97
+ // Вычисляем начальный сдвиг по горизонтали, чтобы точка стала по центру
98
+ if (centered) {
99
+ transitionWrapperRef.current.style.transform = "translateX(".concat(visibleCount * SIZE / 2 - SIZE / 2 - activeIndex * SIZE, "px)");
100
+ }
101
+ prevIndex.current = index;
102
+ prevActiveIndex.current = activeIndex;
103
+ }, []);
104
+ (0, _hooks.useDidMountLayoutEffect)(function () {
105
+ var _dotWrapperRef$curren;
106
+ if (!dotWrapperRef || !dotWrapperRef.current || !transitionWrapperRef || !transitionWrapperRef.current || !leftAnimationWrapperRef || !leftAnimationWrapperRef.current || !rightAnimationWrapperRef || !rightAnimationWrapperRef.current || isAnimating.current) {
107
+ return;
108
+ }
109
+ isAnimating.current = true;
110
+ dotWrapperRef.current.classList.add(_Carousel.classes.animating);
111
+ transitionWrapperRef.current.classList.add(_Carousel.classes.animating);
112
+ var targetIndex = (0, _index.getTargetIndex)(index, prevIndex.current, prevActiveIndex.current, diffDotsRange);
113
+ var dotsToAdd = Math.abs(targetIndex - activeIndex);
114
+ if (centered) {
115
+ transitionWrapperRef.current.style.transform = "translateX(".concat(visibleCount * SIZE / 2 - SIZE / 2 - targetIndex * SIZE, "px)");
116
+ } else if (dotsToAdd > 0) {
117
+ transitionWrapperRef.current.style.transform = "translateX(".concat(-SIZE * (targetIndex - activeIndex), "px)");
118
+ }
119
+
120
+ // Стираем все активные классы и устанавливаем активный класс на таргет.
121
+ // В конце анимации произойдет переопределение активного класса.
122
+ Array.from(dotWrapperRef.current.children).forEach(function (child) {
123
+ child.classList.remove(_Carousel.classes.active);
124
+ });
125
+ (_dotWrapperRef$curren = dotWrapperRef.current.children[targetIndex]) === null || _dotWrapperRef$curren === void 0 || _dotWrapperRef$curren.classList.add(_Carousel.classes.active);
126
+ if (index > prevIndex.current) {
127
+ // Двигаемся вправо
128
+
129
+ // Если мы добавляем 1 и более точек, то нужно начать
130
+ // приводить размер крайней правой точки (что будет в m размере?)
131
+ // к натуральному размеру
132
+ if (dotsToAdd >= 1) {
133
+ var _dotWrapperRef$curren2;
134
+ (_dotWrapperRef$curren2 = dotWrapperRef.current.children[visibleCount - 1]) === null || _dotWrapperRef$curren2 === void 0 || _dotWrapperRef$curren2.classList.add(_Carousel.classes.temporaryNatural);
135
+ }
136
+
137
+ // Т.к. мы двигаемся вправо, то нужно начать уменьшать размер крайней левой точки
138
+ // (опять же, что в m size?)
139
+ if (dotsToAdd >= 1) {
140
+ var _dotWrapperRef$curren3;
141
+ (_dotWrapperRef$curren3 = dotWrapperRef.current.children[dotsToAdd]) === null || _dotWrapperRef$curren3 === void 0 || _dotWrapperRef$curren3.classList.add(_Carousel.classes.shrinking);
142
+ }
143
+ if (dotsToAdd > 0) {
144
+ var _loop = function _loop() {
145
+ var _dotWrapperRef$curren4;
146
+ var node = document.createElement('div');
147
+ node.textContent = '';
148
+ node.classList.add(_Carousel.classes.dot);
149
+ node.style.opacity = '0';
150
+ var delay = i * (ANIMATION_DURATION / dotsToAdd);
151
+ node.style.animationDelay = "".concat(delay, "s");
152
+ rightAnimationWrapperRef.current.appendChild(node);
153
+ var duration = ANIMATION_DURATION / dotsToAdd;
154
+ requestAnimationFrame(function () {
155
+ node.classList.add(_Carousel.classes.animateIn);
156
+ node.style.animationDuration = "".concat(duration, "s");
157
+ });
158
+ var currentDomNode = (_dotWrapperRef$curren4 = dotWrapperRef.current.children) === null || _dotWrapperRef$curren4 === void 0 ? void 0 : _dotWrapperRef$curren4[i];
159
+ currentDomNode === null || currentDomNode === void 0 || currentDomNode.classList.add(_Carousel.classes.animateOut);
160
+ currentDomNode.style.animationDelay = "".concat(delay, "s");
161
+ currentDomNode.style.animationDuration = "".concat(duration, "s");
162
+ };
163
+ for (var i = 0; i < dotsToAdd; i++) {
164
+ _loop();
165
+ }
166
+ }
167
+ } else {
168
+ // Двигаемся влево
169
+
170
+ // Если мы добавляем 1 и более точек, то нужно начать
171
+ // приводить размер крайней левой точки (что будет в m размере?)
172
+ // к натуральному размеру.
173
+ if (dotsToAdd >= 1) {
174
+ var _dotWrapperRef$curren5;
175
+ (_dotWrapperRef$curren5 = dotWrapperRef.current.children[0]) === null || _dotWrapperRef$curren5 === void 0 || _dotWrapperRef$curren5.classList.add(_Carousel.classes.temporaryNatural);
176
+ }
177
+
178
+ // Т.к. мы двигаемся влево, то нужно начать уменьшать размер крайней правой точки
179
+ // (опять же, что в m size?)
180
+ if (dotsToAdd >= 1) {
181
+ var _dotWrapperRef$curren6;
182
+ (_dotWrapperRef$curren6 = dotWrapperRef.current.children[visibleCount - 1 - dotsToAdd]) === null || _dotWrapperRef$curren6 === void 0 || _dotWrapperRef$curren6.classList.add(_Carousel.classes.shrinking);
183
+ }
184
+ if (dotsToAdd > 0) {
185
+ var _loop2 = function _loop2() {
186
+ var _dotWrapperRef$curren7;
187
+ var node = document.createElement('div');
188
+ node.textContent = '';
189
+ node.classList.add(_Carousel.classes.dot);
190
+ node.style.opacity = '0';
191
+ var delay = (dotsToAdd - 1 - _i) * (ANIMATION_DURATION / dotsToAdd);
192
+ node.style.animationDelay = "".concat(delay, "s");
193
+ leftAnimationWrapperRef.current.prepend(node);
194
+ var duration = ANIMATION_DURATION / dotsToAdd;
195
+ requestAnimationFrame(function () {
196
+ node.classList.add(_Carousel.classes.animateIn);
197
+ node.style.animationDuration = "".concat(duration, "s");
198
+ });
199
+ var currentDomNode = (_dotWrapperRef$curren7 = dotWrapperRef.current.children) === null || _dotWrapperRef$curren7 === void 0 ? void 0 : _dotWrapperRef$curren7[dotWrapperRef.current.children.length - 1 - _i];
200
+ currentDomNode === null || currentDomNode === void 0 || currentDomNode.classList.add(_Carousel.classes.animateOut);
201
+ currentDomNode.style.animationDelay = "".concat(_i * (ANIMATION_DURATION / dotsToAdd), "s");
202
+ currentDomNode.style.animationDuration = "".concat(duration, "s");
203
+ };
204
+ for (var _i = dotsToAdd - 1; _i >= 0; _i--) {
205
+ _loop2();
206
+ }
207
+ }
208
+ }
209
+ }, [index]);
210
+ return /*#__PURE__*/_react["default"].createElement(_Dots.Wrapper, null, /*#__PURE__*/_react["default"].createElement(_Dots.TransitionWrapper, {
211
+ ref: transitionWrapperRef,
212
+ onTransitionEnd: handleTransitionEnd
213
+ }, /*#__PURE__*/_react["default"].createElement(_Dots.LeftAnimationWrapper, {
214
+ ref: leftAnimationWrapperRef
215
+ }), /*#__PURE__*/_react["default"].createElement(_Dots.DotWrapper, {
216
+ ref: dotWrapperRef,
217
+ className: (0, _classnames["default"])(hiddenDotsLeft && _Carousel.classes.availableDotsLeft, hiddenDotsRight && _Carousel.classes.availableDotsRight)
218
+ }, Array(visibleCount).fill(0).map(function (_, i) {
219
+ return /*#__PURE__*/_react["default"].createElement("div", {
220
+ key: i,
221
+ className: (0, _classnames["default"])(_Carousel.classes.dot, i === activeIndex && _Carousel.classes.active),
222
+ onClick: function onClick() {
223
+ return handleClick(i);
224
+ }
225
+ });
226
+ })), /*#__PURE__*/_react["default"].createElement(_Dots.RightAnimationWrapper, {
227
+ ref: rightAnimationWrapperRef
228
+ })));
229
+ });
@@ -0,0 +1,24 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.Wrapper = exports.TransitionWrapper = exports.RightAnimationWrapper = exports.LeftAnimationWrapper = exports.DotWrapper = void 0;
7
+ var _styledComponents = /*#__PURE__*/_interopRequireDefault(/*#__PURE__*/require("styled-components"));
8
+ var _Carousel = /*#__PURE__*/require("../../Carousel.tokens");
9
+ function _interopRequireDefault(e) { return e && e.__esModule ? e : { "default": e }; }
10
+ var Wrapper = exports.Wrapper = /*#__PURE__*/_styledComponents["default"].div.withConfig({
11
+ componentId: "plasma-new-hope__sc-feybgn-0"
12
+ })(["display:flex;align-items:center;justify-content:center;margin-top:0.75rem;--duration:0.3s;--half-duration:0.15s;"]);
13
+ var TransitionWrapper = exports.TransitionWrapper = /*#__PURE__*/_styledComponents["default"].div.withConfig({
14
+ componentId: "plasma-new-hope__sc-feybgn-1"
15
+ })(["position:relative;display:flex;transition:transform 0s ease;&.", "{transition:transform var(--duration) ease;}& .", "{width:0.5rem;height:0.5rem;margin:0 0.25rem;cursor:pointer;background-color:var(", ");border-radius:100%;&.", "{background-color:var(", ");}@keyframes fadeOut{from{transform:scale(0.75);opacity:1;}to{transform:scale(0);opacity:0;}}&.", "{animation:fadeOut var(--half-duration) ease forwards;}@keyframes shrinking{from{transform:scale(1);}to{transform:scale(0.75);}}&.", "{animation:shrinking var(--half-duration) var(--half-duration) ease forwards;}}"], _Carousel.classes.animating, _Carousel.classes.dot, _Carousel.tokens.paginationDotBackground, _Carousel.classes.active, _Carousel.tokens.paginationDotActiveBackground, _Carousel.classes.animateOut, _Carousel.classes.shrinking);
16
+ var DotWrapper = exports.DotWrapper = /*#__PURE__*/_styledComponents["default"].div.withConfig({
17
+ componentId: "plasma-new-hope__sc-feybgn-2"
18
+ })(["display:flex;&.", "{.", ":not(.", "):first-child{transform:scale(0.75);}}&.", "{.", ":not(.", "):last-child{transform:scale(0.75);}}&.", " .", "{transition:background-color var(--duration) ease;}"], _Carousel.classes.availableDotsLeft, _Carousel.classes.dot, _Carousel.classes.temporaryNatural, _Carousel.classes.availableDotsRight, _Carousel.classes.dot, _Carousel.classes.temporaryNatural, _Carousel.classes.animating, _Carousel.classes.dot);
19
+ var LeftAnimationWrapper = exports.LeftAnimationWrapper = /*#__PURE__*/_styledComponents["default"].div.withConfig({
20
+ componentId: "plasma-new-hope__sc-feybgn-3"
21
+ })(["position:absolute;top:0;right:100%;bottom:0;display:flex;& .", "{transition:transform var(--duration) ease;@keyframes fadeIn{from{transform:scale(0);opacity:0;}to{transform:scale(1);opacity:1;}}&.", "{animation:fadeIn var(--half-duration) ease forwards;}&:first-child{@keyframes fadeInFirst{from{transform:scale(0);opacity:0;}to{transform:scale(0.75);opacity:1;}}&.", "{animation:fadeInFirst var(--half-duration) ease forwards;}}}"], _Carousel.classes.dot, _Carousel.classes.animateIn, _Carousel.classes.animateIn);
22
+ var RightAnimationWrapper = exports.RightAnimationWrapper = /*#__PURE__*/_styledComponents["default"].div.withConfig({
23
+ componentId: "plasma-new-hope__sc-feybgn-4"
24
+ })(["position:absolute;top:0;left:100%;bottom:0;display:flex;& .", "{transition:transform var(--duration) ease;@keyframes fadeIn{from{transform:scale(0);opacity:0;}to{transform:scale(1);opacity:1;}}&.", "{animation:fadeIn var(--half-duration) ease forwards;}&:last-child{@keyframes fadeInLast{from{transform:scale(0);opacity:0;}to{transform:scale(0.75);opacity:1;}}&.", "{animation:fadeInLast var(--half-duration) ease forwards;}}}"], _Carousel.classes.dot, _Carousel.classes.animateIn, _Carousel.classes.animateIn);
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });