@gravity-ui/page-constructor 6.8.2-alpha.1 → 7.0.0-alpha.3

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 (385) hide show
  1. package/README.md +108 -10
  2. package/build/cjs/blocks/ExtendedFeatures/ExtendedFeatures.css +11 -6
  3. package/build/cjs/blocks/ExtendedFeatures/ExtendedFeatures.js +3 -5
  4. package/build/cjs/blocks/ExtendedFeatures/ExtendedFeatures.js.map +1 -1
  5. package/build/cjs/blocks/Header/Header.css +15 -10
  6. package/build/cjs/blocks/Header/Header.js +6 -1
  7. package/build/cjs/blocks/Header/Header.js.map +1 -1
  8. package/build/cjs/blocks/HeaderSlider/HeaderSlider.css +0 -10
  9. package/build/cjs/blocks/HeaderSlider/HeaderSlider.js +2 -2
  10. package/build/cjs/blocks/HeaderSlider/HeaderSlider.js.map +1 -1
  11. package/build/cjs/blocks/HeaderSlider/schema.d.ts +9 -1
  12. package/build/cjs/blocks/Questions/QuestionBlockItem/QuestionBlockItem.css +43 -21
  13. package/build/cjs/blocks/Questions/QuestionBlockItem/QuestionBlockItem.js +3 -1
  14. package/build/cjs/blocks/Questions/QuestionBlockItem/QuestionBlockItem.js.map +1 -1
  15. package/build/cjs/blocks/Share/Share.css +3 -2
  16. package/build/cjs/blocks/Share/Share.js +4 -1
  17. package/build/cjs/blocks/Share/Share.js.map +1 -1
  18. package/build/cjs/blocks/Slider/Arrow/Arrow.css +22 -21
  19. package/build/cjs/blocks/Slider/Arrow/Arrow.d.ts +4 -2
  20. package/build/cjs/blocks/Slider/Arrow/Arrow.js +1 -1
  21. package/build/cjs/blocks/Slider/Arrow/Arrow.js.map +1 -1
  22. package/build/cjs/blocks/Slider/Slider.css +549 -329
  23. package/build/cjs/blocks/Slider/Slider.d.ts +6 -5
  24. package/build/cjs/blocks/Slider/Slider.js +32 -275
  25. package/build/cjs/blocks/Slider/Slider.js.map +1 -1
  26. package/build/cjs/blocks/Slider/i18n/en.json +1 -1
  27. package/build/cjs/blocks/Slider/i18n/ru.json +1 -1
  28. package/build/cjs/blocks/Slider/models.d.ts +2 -2
  29. package/build/cjs/blocks/Slider/models.js +1 -1
  30. package/build/cjs/blocks/Slider/models.js.map +1 -1
  31. package/build/cjs/blocks/Slider/schema.d.ts +18 -1
  32. package/build/cjs/blocks/Slider/schema.js +9 -0
  33. package/build/cjs/blocks/Slider/schema.js.map +1 -1
  34. package/build/cjs/blocks/{SliderNew → Slider}/useSlider.d.ts +1 -0
  35. package/build/cjs/blocks/{SliderNew → Slider}/useSlider.js +4 -0
  36. package/build/cjs/blocks/Slider/useSlider.js.map +1 -0
  37. package/build/cjs/blocks/Slider/useSliderPagination.js.map +1 -0
  38. package/build/cjs/blocks/Slider/utils.d.ts +7 -28
  39. package/build/cjs/blocks/Slider/utils.js +28 -109
  40. package/build/cjs/blocks/Slider/utils.js.map +1 -1
  41. package/build/cjs/blocks/{SliderNew → SliderOld}/Arrow/Arrow.css +14 -11
  42. package/build/cjs/blocks/SliderOld/Arrow/Arrow.d.ts +9 -0
  43. package/build/cjs/blocks/SliderOld/Arrow/Arrow.js +11 -0
  44. package/build/cjs/blocks/SliderOld/Arrow/Arrow.js.map +1 -0
  45. package/build/cjs/blocks/SliderOld/SliderOld.css +703 -0
  46. package/build/cjs/blocks/SliderOld/SliderOld.d.ts +17 -0
  47. package/build/cjs/blocks/SliderOld/SliderOld.js +293 -0
  48. package/build/cjs/blocks/SliderOld/SliderOld.js.map +1 -0
  49. package/build/cjs/blocks/{SliderNew → SliderOld}/i18n/en.json +1 -1
  50. package/build/cjs/blocks/{SliderNew → SliderOld}/i18n/index.d.ts +1 -1
  51. package/build/cjs/blocks/{SliderNew → SliderOld}/i18n/index.js +1 -1
  52. package/build/cjs/blocks/{SliderNew → SliderOld}/i18n/index.js.map +1 -1
  53. package/build/cjs/blocks/{SliderNew → SliderOld}/i18n/ru.json +1 -1
  54. package/build/cjs/blocks/{SliderNew → SliderOld}/models.d.ts +2 -2
  55. package/build/cjs/blocks/{SliderNew → SliderOld}/models.js +1 -1
  56. package/build/cjs/blocks/{SliderNew → SliderOld}/models.js.map +1 -1
  57. package/build/cjs/blocks/{SliderNew → SliderOld}/schema.d.ts +5 -21
  58. package/build/cjs/blocks/{SliderNew → SliderOld}/schema.js +6 -14
  59. package/build/cjs/blocks/SliderOld/schema.js.map +1 -0
  60. package/build/cjs/blocks/SliderOld/utils.d.ts +37 -0
  61. package/build/cjs/blocks/SliderOld/utils.js +129 -0
  62. package/build/cjs/blocks/SliderOld/utils.js.map +1 -0
  63. package/build/cjs/blocks/Table/Table.css +4 -3
  64. package/build/cjs/blocks/Table/Table.js +3 -1
  65. package/build/cjs/blocks/Table/Table.js.map +1 -1
  66. package/build/cjs/blocks/index.d.ts +2 -0
  67. package/build/cjs/blocks/index.js +3 -1
  68. package/build/cjs/blocks/index.js.map +1 -1
  69. package/build/cjs/blocks/validators.d.ts +1 -0
  70. package/build/cjs/blocks/validators.js +1 -0
  71. package/build/cjs/blocks/validators.js.map +1 -1
  72. package/build/cjs/components/BackgroundImage/BackgroundImage.js +2 -2
  73. package/build/cjs/components/BackgroundImage/BackgroundImage.js.map +1 -1
  74. package/build/cjs/components/ContentList/ContentList.css +10 -6
  75. package/build/cjs/components/ContentList/ContentList.js +1 -1
  76. package/build/cjs/components/ContentList/ContentList.js.map +1 -1
  77. package/build/cjs/components/FullscreenImage/FullscreenImage.css +99 -18
  78. package/build/cjs/components/FullscreenImage/FullscreenImage.d.ts +5 -0
  79. package/build/cjs/components/FullscreenImage/FullscreenImage.js +14 -2
  80. package/build/cjs/components/FullscreenImage/FullscreenImage.js.map +1 -1
  81. package/build/cjs/components/FullscreenMedia/FullscreenMedia.css +1 -3
  82. package/build/cjs/components/HTML/HTML.d.ts +15 -8
  83. package/build/cjs/components/HTML/HTML.js +19 -10
  84. package/build/cjs/components/HTML/HTML.js.map +1 -1
  85. package/build/cjs/components/Image/Image.d.ts +2 -4
  86. package/build/cjs/components/Image/Image.js +8 -22
  87. package/build/cjs/components/Image/Image.js.map +1 -1
  88. package/build/cjs/components/Media/Image/Image.d.ts +1 -0
  89. package/build/cjs/components/Media/Image/Image.js +7 -5
  90. package/build/cjs/components/Media/Image/Image.js.map +1 -1
  91. package/build/cjs/components/Media/Media.css +4 -0
  92. package/build/cjs/components/Media/Media.d.ts +1 -0
  93. package/build/cjs/components/Media/Media.js +3 -2
  94. package/build/cjs/components/Media/Media.js.map +1 -1
  95. package/build/cjs/components/MetaInfo/MetaInfo.css +1 -1
  96. package/build/cjs/components/MetaInfo/MetaInfo.js +1 -1
  97. package/build/cjs/components/MetaInfo/MetaInfo.js.map +1 -1
  98. package/build/cjs/components/Table/Table.css +2 -1
  99. package/build/cjs/components/Table/Table.js +4 -2
  100. package/build/cjs/components/Table/Table.js.map +1 -1
  101. package/build/cjs/components/Title/TitleItem.css +7 -4
  102. package/build/cjs/components/Title/TitleItem.js +3 -1
  103. package/build/cjs/components/Title/TitleItem.js.map +1 -1
  104. package/build/cjs/components/VideoBlock/VideoBlock.js +1 -1
  105. package/build/cjs/components/VideoBlock/VideoBlock.js.map +1 -1
  106. package/build/cjs/components/YFMWrapper/YFMWrapper.d.ts +4 -2
  107. package/build/cjs/components/YFMWrapper/YFMWrapper.js +3 -3
  108. package/build/cjs/components/YFMWrapper/YFMWrapper.js.map +1 -1
  109. package/build/cjs/components/YandexForm/YandexForm.js +1 -1
  110. package/build/cjs/components/YandexForm/YandexForm.js.map +1 -1
  111. package/build/cjs/constructor-items.d.ts +2 -2
  112. package/build/cjs/constructor-items.js +2 -4
  113. package/build/cjs/constructor-items.js.map +1 -1
  114. package/build/cjs/containers/Loadable/Loadable.js +1 -1
  115. package/build/cjs/containers/Loadable/Loadable.js.map +1 -1
  116. package/build/cjs/editor/data/index.js +1 -1
  117. package/build/cjs/editor/data/index.js.map +1 -1
  118. package/build/cjs/editor/data/templates/{slider-new-block.json → slider-old-block.json} +2 -2
  119. package/build/cjs/editor/widget/utils.js +1 -1
  120. package/build/cjs/editor/widget/utils.js.map +1 -1
  121. package/build/cjs/models/common.d.ts +1 -0
  122. package/build/cjs/models/common.js.map +1 -1
  123. package/build/cjs/models/constructor-items/blocks.d.ts +17 -15
  124. package/build/cjs/models/constructor-items/blocks.js +3 -2
  125. package/build/cjs/models/constructor-items/blocks.js.map +1 -1
  126. package/build/cjs/models/constructor-items/common.d.ts +6 -13
  127. package/build/cjs/models/constructor-items/common.js +1 -8
  128. package/build/cjs/models/constructor-items/common.js.map +1 -1
  129. package/build/cjs/navigation/components/NavigationItem/components/GithubButton/GithubButton.js +1 -1
  130. package/build/cjs/navigation/components/NavigationItem/components/GithubButton/GithubButton.js.map +1 -1
  131. package/build/cjs/schema/constants.js +4 -2
  132. package/build/cjs/schema/constants.js.map +1 -1
  133. package/build/cjs/schema/validators/blocks.d.ts +2 -1
  134. package/build/cjs/schema/validators/blocks.js +2 -1
  135. package/build/cjs/schema/validators/blocks.js.map +1 -1
  136. package/build/cjs/sub-blocks/BannerCard/BannerCard.css +14 -8
  137. package/build/cjs/sub-blocks/BannerCard/BannerCard.js +3 -1
  138. package/build/cjs/sub-blocks/BannerCard/BannerCard.js.map +1 -1
  139. package/build/cjs/sub-blocks/Content/Content.css +27 -25
  140. package/build/cjs/sub-blocks/Content/Content.js +1 -1
  141. package/build/cjs/sub-blocks/Content/Content.js.map +1 -1
  142. package/build/cjs/sub-blocks/PriceCard/PriceCard.css +2 -1
  143. package/build/cjs/sub-blocks/PriceCard/PriceCard.js +1 -1
  144. package/build/cjs/sub-blocks/PriceCard/PriceCard.js.map +1 -1
  145. package/build/cjs/sub-blocks/Quote/Quote.css +8 -4
  146. package/build/cjs/sub-blocks/Quote/Quote.js +2 -1
  147. package/build/cjs/sub-blocks/Quote/Quote.js.map +1 -1
  148. package/build/cjs/text-transform/common.d.ts +4 -3
  149. package/build/cjs/text-transform/common.js +50 -21
  150. package/build/cjs/text-transform/common.js.map +1 -1
  151. package/build/cjs/text-transform/config.d.ts +5 -2
  152. package/build/cjs/text-transform/config.js +87 -43
  153. package/build/cjs/text-transform/config.js.map +1 -1
  154. package/build/cjs/text-transform/transformers.js +2 -2
  155. package/build/cjs/text-transform/transformers.js.map +1 -1
  156. package/build/cjs/utils/blocks.d.ts +10 -2
  157. package/build/cjs/utils/blocks.js +9 -3
  158. package/build/cjs/utils/blocks.js.map +1 -1
  159. package/build/esm/blocks/ExtendedFeatures/ExtendedFeatures.css +11 -6
  160. package/build/esm/blocks/ExtendedFeatures/ExtendedFeatures.js +4 -6
  161. package/build/esm/blocks/ExtendedFeatures/ExtendedFeatures.js.map +1 -1
  162. package/build/esm/blocks/Header/Header.css +15 -10
  163. package/build/esm/blocks/Header/Header.js +7 -2
  164. package/build/esm/blocks/Header/Header.js.map +1 -1
  165. package/build/esm/blocks/HeaderSlider/HeaderSlider.css +0 -10
  166. package/build/esm/blocks/HeaderSlider/HeaderSlider.js +1 -1
  167. package/build/esm/blocks/HeaderSlider/HeaderSlider.js.map +1 -1
  168. package/build/esm/blocks/HeaderSlider/schema.d.ts +9 -1
  169. package/build/esm/blocks/Questions/QuestionBlockItem/QuestionBlockItem.css +43 -21
  170. package/build/esm/blocks/Questions/QuestionBlockItem/QuestionBlockItem.js +4 -2
  171. package/build/esm/blocks/Questions/QuestionBlockItem/QuestionBlockItem.js.map +1 -1
  172. package/build/esm/blocks/Share/Share.css +3 -2
  173. package/build/esm/blocks/Share/Share.js +4 -1
  174. package/build/esm/blocks/Share/Share.js.map +1 -1
  175. package/build/esm/blocks/Slider/Arrow/Arrow.css +22 -21
  176. package/build/esm/blocks/Slider/Arrow/Arrow.d.ts +4 -2
  177. package/build/esm/blocks/Slider/Arrow/Arrow.js +1 -1
  178. package/build/esm/blocks/Slider/Arrow/Arrow.js.map +1 -1
  179. package/build/esm/blocks/Slider/Slider.css +549 -329
  180. package/build/esm/blocks/Slider/Slider.d.ts +6 -5
  181. package/build/esm/blocks/Slider/Slider.js +33 -276
  182. package/build/esm/blocks/Slider/Slider.js.map +1 -1
  183. package/build/esm/blocks/Slider/i18n/en.json +1 -1
  184. package/build/esm/blocks/Slider/i18n/ru.json +1 -1
  185. package/build/esm/blocks/Slider/models.d.ts +2 -2
  186. package/build/esm/blocks/Slider/models.js +1 -1
  187. package/build/esm/blocks/Slider/models.js.map +1 -1
  188. package/build/esm/blocks/Slider/schema.d.ts +18 -1
  189. package/build/esm/blocks/Slider/schema.js +9 -0
  190. package/build/esm/blocks/Slider/schema.js.map +1 -1
  191. package/build/esm/blocks/{SliderNew → Slider}/useSlider.d.ts +1 -0
  192. package/build/esm/blocks/{SliderNew → Slider}/useSlider.js +4 -0
  193. package/build/esm/blocks/Slider/useSlider.js.map +1 -0
  194. package/build/esm/blocks/Slider/useSliderPagination.js.map +1 -0
  195. package/build/esm/blocks/Slider/utils.d.ts +7 -28
  196. package/build/esm/blocks/Slider/utils.js +25 -103
  197. package/build/esm/blocks/Slider/utils.js.map +1 -1
  198. package/build/esm/blocks/{SliderNew → SliderOld}/Arrow/Arrow.css +14 -11
  199. package/build/esm/blocks/SliderOld/Arrow/Arrow.d.ts +10 -0
  200. package/build/esm/blocks/SliderOld/Arrow/Arrow.js +9 -0
  201. package/build/esm/blocks/SliderOld/Arrow/Arrow.js.map +1 -0
  202. package/build/esm/blocks/SliderOld/SliderOld.css +703 -0
  203. package/build/esm/blocks/SliderOld/SliderOld.d.ts +18 -0
  204. package/build/esm/blocks/SliderOld/SliderOld.js +289 -0
  205. package/build/esm/blocks/SliderOld/SliderOld.js.map +1 -0
  206. package/build/esm/blocks/{SliderNew → SliderOld}/i18n/en.json +1 -1
  207. package/build/esm/blocks/{SliderNew → SliderOld}/i18n/index.d.ts +1 -1
  208. package/build/esm/blocks/{SliderNew → SliderOld}/i18n/index.js +1 -1
  209. package/build/esm/blocks/{SliderNew → SliderOld}/i18n/index.js.map +1 -1
  210. package/build/esm/blocks/{SliderNew → SliderOld}/i18n/ru.json +1 -1
  211. package/build/esm/blocks/{SliderNew → SliderOld}/models.d.ts +2 -2
  212. package/build/esm/blocks/{SliderNew → SliderOld}/models.js +1 -1
  213. package/build/esm/blocks/{SliderNew → SliderOld}/models.js.map +1 -1
  214. package/build/esm/blocks/{SliderNew → SliderOld}/schema.d.ts +5 -21
  215. package/build/esm/blocks/{SliderNew → SliderOld}/schema.js +5 -13
  216. package/build/esm/blocks/SliderOld/schema.js.map +1 -0
  217. package/build/esm/blocks/SliderOld/utils.d.ts +37 -0
  218. package/build/esm/blocks/SliderOld/utils.js +119 -0
  219. package/build/esm/blocks/SliderOld/utils.js.map +1 -0
  220. package/build/esm/blocks/Table/Table.css +4 -3
  221. package/build/esm/blocks/Table/Table.js +4 -2
  222. package/build/esm/blocks/Table/Table.js.map +1 -1
  223. package/build/esm/blocks/index.d.ts +2 -0
  224. package/build/esm/blocks/index.js +1 -0
  225. package/build/esm/blocks/index.js.map +1 -1
  226. package/build/esm/blocks/validators.d.ts +1 -0
  227. package/build/esm/blocks/validators.js +1 -0
  228. package/build/esm/blocks/validators.js.map +1 -1
  229. package/build/esm/components/BackgroundImage/BackgroundImage.js +2 -2
  230. package/build/esm/components/BackgroundImage/BackgroundImage.js.map +1 -1
  231. package/build/esm/components/ContentList/ContentList.css +10 -6
  232. package/build/esm/components/ContentList/ContentList.js +1 -1
  233. package/build/esm/components/ContentList/ContentList.js.map +1 -1
  234. package/build/esm/components/FullscreenImage/FullscreenImage.css +99 -18
  235. package/build/esm/components/FullscreenImage/FullscreenImage.d.ts +5 -0
  236. package/build/esm/components/FullscreenImage/FullscreenImage.js +14 -2
  237. package/build/esm/components/FullscreenImage/FullscreenImage.js.map +1 -1
  238. package/build/esm/components/FullscreenMedia/FullscreenMedia.css +1 -3
  239. package/build/esm/components/HTML/HTML.d.ts +15 -8
  240. package/build/esm/components/HTML/HTML.js +20 -11
  241. package/build/esm/components/HTML/HTML.js.map +1 -1
  242. package/build/esm/components/Image/Image.d.ts +2 -4
  243. package/build/esm/components/Image/Image.js +8 -21
  244. package/build/esm/components/Image/Image.js.map +1 -1
  245. package/build/esm/components/Media/Image/Image.d.ts +1 -0
  246. package/build/esm/components/Media/Image/Image.js +7 -5
  247. package/build/esm/components/Media/Image/Image.js.map +1 -1
  248. package/build/esm/components/Media/Media.css +4 -0
  249. package/build/esm/components/Media/Media.d.ts +1 -0
  250. package/build/esm/components/Media/Media.js +3 -2
  251. package/build/esm/components/Media/Media.js.map +1 -1
  252. package/build/esm/components/MetaInfo/MetaInfo.css +1 -1
  253. package/build/esm/components/MetaInfo/MetaInfo.js +1 -1
  254. package/build/esm/components/MetaInfo/MetaInfo.js.map +1 -1
  255. package/build/esm/components/Table/Table.css +2 -1
  256. package/build/esm/components/Table/Table.js +5 -3
  257. package/build/esm/components/Table/Table.js.map +1 -1
  258. package/build/esm/components/Title/TitleItem.css +7 -4
  259. package/build/esm/components/Title/TitleItem.js +4 -2
  260. package/build/esm/components/Title/TitleItem.js.map +1 -1
  261. package/build/esm/components/VideoBlock/VideoBlock.js +1 -1
  262. package/build/esm/components/VideoBlock/VideoBlock.js.map +1 -1
  263. package/build/esm/components/YFMWrapper/YFMWrapper.d.ts +4 -2
  264. package/build/esm/components/YFMWrapper/YFMWrapper.js +3 -3
  265. package/build/esm/components/YFMWrapper/YFMWrapper.js.map +1 -1
  266. package/build/esm/components/YandexForm/YandexForm.js +1 -1
  267. package/build/esm/components/YandexForm/YandexForm.js.map +1 -1
  268. package/build/esm/constructor-items.d.ts +2 -2
  269. package/build/esm/constructor-items.js +3 -5
  270. package/build/esm/constructor-items.js.map +1 -1
  271. package/build/esm/containers/Loadable/Loadable.js +1 -1
  272. package/build/esm/containers/Loadable/Loadable.js.map +1 -1
  273. package/build/esm/editor/data/index.js +1 -1
  274. package/build/esm/editor/data/index.js.map +1 -1
  275. package/build/esm/editor/data/templates/{slider-new-block.json → slider-old-block.json} +2 -2
  276. package/build/esm/editor/widget/utils.js +1 -1
  277. package/build/esm/editor/widget/utils.js.map +1 -1
  278. package/build/esm/models/common.d.ts +1 -0
  279. package/build/esm/models/common.js.map +1 -1
  280. package/build/esm/models/constructor-items/blocks.d.ts +17 -15
  281. package/build/esm/models/constructor-items/blocks.js +3 -2
  282. package/build/esm/models/constructor-items/blocks.js.map +1 -1
  283. package/build/esm/models/constructor-items/common.d.ts +6 -13
  284. package/build/esm/models/constructor-items/common.js +0 -7
  285. package/build/esm/models/constructor-items/common.js.map +1 -1
  286. package/build/esm/navigation/components/NavigationItem/components/GithubButton/GithubButton.js +1 -1
  287. package/build/esm/navigation/components/NavigationItem/components/GithubButton/GithubButton.js.map +1 -1
  288. package/build/esm/schema/constants.js +5 -3
  289. package/build/esm/schema/constants.js.map +1 -1
  290. package/build/esm/schema/validators/blocks.d.ts +2 -1
  291. package/build/esm/schema/validators/blocks.js +2 -1
  292. package/build/esm/schema/validators/blocks.js.map +1 -1
  293. package/build/esm/sub-blocks/BannerCard/BannerCard.css +14 -8
  294. package/build/esm/sub-blocks/BannerCard/BannerCard.js +4 -2
  295. package/build/esm/sub-blocks/BannerCard/BannerCard.js.map +1 -1
  296. package/build/esm/sub-blocks/Content/Content.css +27 -25
  297. package/build/esm/sub-blocks/Content/Content.js +1 -1
  298. package/build/esm/sub-blocks/Content/Content.js.map +1 -1
  299. package/build/esm/sub-blocks/PriceCard/PriceCard.css +2 -1
  300. package/build/esm/sub-blocks/PriceCard/PriceCard.js +2 -2
  301. package/build/esm/sub-blocks/PriceCard/PriceCard.js.map +1 -1
  302. package/build/esm/sub-blocks/Quote/Quote.css +8 -4
  303. package/build/esm/sub-blocks/Quote/Quote.js +3 -2
  304. package/build/esm/sub-blocks/Quote/Quote.js.map +1 -1
  305. package/build/esm/text-transform/common.d.ts +4 -3
  306. package/build/esm/text-transform/common.js +50 -21
  307. package/build/esm/text-transform/common.js.map +1 -1
  308. package/build/esm/text-transform/config.d.ts +5 -2
  309. package/build/esm/text-transform/config.js +87 -43
  310. package/build/esm/text-transform/config.js.map +1 -1
  311. package/build/esm/text-transform/transformers.js +2 -2
  312. package/build/esm/text-transform/transformers.js.map +1 -1
  313. package/build/esm/utils/blocks.d.ts +10 -2
  314. package/build/esm/utils/blocks.js +8 -2
  315. package/build/esm/utils/blocks.js.map +1 -1
  316. package/package.json +2 -2
  317. package/schema/index.js +1 -1
  318. package/server/models/common.d.ts +1 -0
  319. package/server/models/constructor-items/blocks.d.ts +17 -15
  320. package/server/models/constructor-items/blocks.js +3 -2
  321. package/server/models/constructor-items/common.d.ts +6 -13
  322. package/server/models/constructor-items/common.js +1 -8
  323. package/server/text-transform/common.d.ts +4 -3
  324. package/server/text-transform/common.js +41 -18
  325. package/server/text-transform/config.d.ts +5 -2
  326. package/server/text-transform/config.js +84 -43
  327. package/server/text-transform/transformers.js +2 -2
  328. package/server/utils/blocks.d.ts +10 -2
  329. package/server/utils/blocks.js +9 -3
  330. package/styles/fonts.scss +1 -0
  331. package/styles/styles.css +0 -1
  332. package/styles/styles.scss +0 -1
  333. package/styles/variables.scss +1 -0
  334. package/widget/2042.index.js +1 -0
  335. package/widget/2723.index.js +1 -0
  336. package/widget/3392.index.js +1 -0
  337. package/widget/6173.index.js +1 -0
  338. package/widget/6328.index.js +1 -0
  339. package/widget/6353.index.js +1 -0
  340. package/widget/6463.index.js +1 -0
  341. package/widget/6887.index.js +1 -0
  342. package/widget/7458.index.js +1 -0
  343. package/widget/7570.index.js +1 -0
  344. package/widget/7627.index.js +1 -0
  345. package/widget/8446.index.js +1 -0
  346. package/widget/9340.index.js +1 -0
  347. package/widget/9979.index.js +1 -0
  348. package/build/cjs/blocks/SliderNew/Arrow/Arrow.d.ts +0 -11
  349. package/build/cjs/blocks/SliderNew/Arrow/Arrow.js +0 -11
  350. package/build/cjs/blocks/SliderNew/Arrow/Arrow.js.map +0 -1
  351. package/build/cjs/blocks/SliderNew/Slider.css +0 -834
  352. package/build/cjs/blocks/SliderNew/Slider.d.ts +0 -13
  353. package/build/cjs/blocks/SliderNew/Slider.js +0 -60
  354. package/build/cjs/blocks/SliderNew/Slider.js.map +0 -1
  355. package/build/cjs/blocks/SliderNew/schema.js.map +0 -1
  356. package/build/cjs/blocks/SliderNew/useSlider.js.map +0 -1
  357. package/build/cjs/blocks/SliderNew/useSliderPagination.js.map +0 -1
  358. package/build/cjs/blocks/SliderNew/utils.d.ts +0 -16
  359. package/build/cjs/blocks/SliderNew/utils.js +0 -48
  360. package/build/cjs/blocks/SliderNew/utils.js.map +0 -1
  361. package/build/cjs/blocks/unstable.d.ts +0 -1
  362. package/build/cjs/blocks/unstable.js +0 -7
  363. package/build/cjs/blocks/unstable.js.map +0 -1
  364. package/build/esm/blocks/SliderNew/Arrow/Arrow.d.ts +0 -12
  365. package/build/esm/blocks/SliderNew/Arrow/Arrow.js +0 -9
  366. package/build/esm/blocks/SliderNew/Arrow/Arrow.js.map +0 -1
  367. package/build/esm/blocks/SliderNew/Slider.css +0 -834
  368. package/build/esm/blocks/SliderNew/Slider.d.ts +0 -14
  369. package/build/esm/blocks/SliderNew/Slider.js +0 -56
  370. package/build/esm/blocks/SliderNew/Slider.js.map +0 -1
  371. package/build/esm/blocks/SliderNew/schema.js.map +0 -1
  372. package/build/esm/blocks/SliderNew/useSlider.js.map +0 -1
  373. package/build/esm/blocks/SliderNew/useSliderPagination.js.map +0 -1
  374. package/build/esm/blocks/SliderNew/utils.d.ts +0 -16
  375. package/build/esm/blocks/SliderNew/utils.js +0 -41
  376. package/build/esm/blocks/SliderNew/utils.js.map +0 -1
  377. package/build/esm/blocks/unstable.d.ts +0 -1
  378. package/build/esm/blocks/unstable.js +0 -2
  379. package/build/esm/blocks/unstable.js.map +0 -1
  380. /package/build/cjs/blocks/{SliderNew → Slider}/useSliderPagination.d.ts +0 -0
  381. /package/build/cjs/blocks/{SliderNew → Slider}/useSliderPagination.js +0 -0
  382. /package/build/cjs/blocks/{Slider → SliderOld}/slick.css +0 -0
  383. /package/build/esm/blocks/{SliderNew → Slider}/useSliderPagination.d.ts +0 -0
  384. /package/build/esm/blocks/{SliderNew → Slider}/useSliderPagination.js +0 -0
  385. /package/build/esm/blocks/{Slider → SliderOld}/slick.css +0 -0
@@ -0,0 +1,18 @@
1
+ import * as React from 'react';
2
+ import { Settings } from 'react-slick';
3
+ import { ClassNameProps, Refable, SliderOldProps as SliderParams } from "../../models/index.js";
4
+ import './SliderOld.css';
5
+ /** @deprecated */
6
+ export interface SliderOldProps extends Omit<SliderParams, 'children'>, Refable<HTMLDivElement>, ClassNameProps, Pick<Settings, 'lazyLoad'> {
7
+ type?: string;
8
+ anchorId?: string;
9
+ onAfterChange?: (index: number) => void;
10
+ onBeforeChange?: (current: number, next: number) => void;
11
+ dotsClassName?: string;
12
+ blockClassName?: string;
13
+ arrowSize?: number;
14
+ initialIndex?: number;
15
+ }
16
+ /** @deprecated */
17
+ export declare const SliderOldBlock: (props: React.PropsWithChildren<SliderOldProps>) => import("react/jsx-runtime").JSX.Element;
18
+ export default SliderOldBlock;
@@ -0,0 +1,289 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import * as React from 'react';
3
+ import { useUniqId } from '@gravity-ui/uikit';
4
+ import debounce from "lodash/debounce.js";
5
+ import get from "lodash/get.js";
6
+ import noop from "lodash/noop.js";
7
+ import SlickSlider from 'react-slick';
8
+ import Anchor from "../../components/Anchor/Anchor.js";
9
+ import AnimateBlock from "../../components/AnimateBlock/AnimateBlock.js";
10
+ import OutsideClick from "../../components/OutsideClick/OutsideClick.js";
11
+ import Title from "../../components/Title/Title.js";
12
+ import { BREAKPOINTS } from "../../constants.js";
13
+ import { MobileContext } from "../../context/mobileContext/index.js";
14
+ import { SSRContext } from "../../context/ssrContext/index.js";
15
+ import { StylesContext } from "../../context/stylesContext/StylesContext.js";
16
+ import useFocus from "../../hooks/useFocus.js";
17
+ import { SliderType, } from "../../models/index.js";
18
+ import { block } from "../../utils/index.js";
19
+ import Arrow from "./Arrow/Arrow.js";
20
+ import { i18n } from "./i18n/index.js";
21
+ import { getSliderResponsiveParams, getSlidesCountByBreakpoint, getSlidesToShowCount, getSlidesToShowWithDefaults, isFocusable, useRovingTabIndex, } from "./utils.js";
22
+ import './SliderOld.css';
23
+ const b = block('SliderOldBlock');
24
+ const slick = block('slick-origin');
25
+ const DOT_WIDTH = 8;
26
+ const DOT_GAP = 16;
27
+ // eslint-disable-next-line valid-jsdoc
28
+ /** @deprecated */
29
+ export const SliderOldBlock = (props) => {
30
+ const { animated, title, description, type, anchorId, arrows = true, adaptive, autoplay: autoplaySpeed, dots = true, dotsClassName, disclaimer, children, className, blockClassName, lazyLoad, arrowSize, onAfterChange: handleAfterChange, onBeforeChange: handleBeforeChange, initialIndex = 0, } = props;
31
+ const { isServer } = React.useContext(SSRContext);
32
+ const isMobile = React.useContext(MobileContext);
33
+ const [breakpoint, setBreakpoint] = React.useState(BREAKPOINTS.xl);
34
+ const sliderId = useUniqId();
35
+ const disclosedChildren = React.useMemo(() => discloseAllNestedChildren(children, sliderId), [children, sliderId]);
36
+ const childrenCount = disclosedChildren.length;
37
+ const isAutoplayEnabled = autoplaySpeed !== undefined && autoplaySpeed > 0;
38
+ const isUserInteractionRef = React.useRef(false);
39
+ const [slidesToShow] = React.useState(getSlidesToShowWithDefaults({
40
+ contentLength: childrenCount,
41
+ breakpoints: props.slidesToShow,
42
+ mobileFullscreen: Boolean(props.type && Object.values(SliderType).includes(props.type)),
43
+ }));
44
+ const slidesToShowCount = getSlidesToShowCount(slidesToShow);
45
+ const slidesCountByBreakpoint = getSlidesCountByBreakpoint(breakpoint, slidesToShow);
46
+ const [currentIndex, setCurrentIndex] = React.useState(initialIndex);
47
+ const [childStyles, setChildStyles] = React.useState({});
48
+ const [slider, setSlider] = React.useState();
49
+ const prevIndexRef = React.useRef(0);
50
+ const autoplayTimeId = React.useRef();
51
+ const { hasFocus, unsetFocus } = useFocus(slider?.innerSlider?.list);
52
+ const asUserInteraction = (fn) => (...args) => {
53
+ isUserInteractionRef.current = true;
54
+ return fn(...args);
55
+ };
56
+ // eslint-disable-next-line react-hooks/exhaustive-deps
57
+ const onResize = React.useCallback(debounce(() => {
58
+ if (!slider) {
59
+ return;
60
+ }
61
+ const newBreakpoint = get(slider, 'state.breakpoint') || BREAKPOINTS.xl;
62
+ if (newBreakpoint !== breakpoint) {
63
+ setBreakpoint(newBreakpoint);
64
+ setCurrentIndex(0);
65
+ slider.slickGoTo(0);
66
+ }
67
+ }, 100), [slider, breakpoint]);
68
+ const scrollLastSlide = React.useCallback((current) => {
69
+ const lastSlide = childrenCount - slidesToShowCount;
70
+ if (isAutoplayEnabled && lastSlide === current) {
71
+ // Slick doesn't support autoplay with no infinity scroll
72
+ autoplayTimeId.current = setTimeout(() => {
73
+ if (slider) {
74
+ slider.slickGoTo(0, false);
75
+ slider.slickPause();
76
+ }
77
+ setTimeout(() => {
78
+ if (slider) {
79
+ slider.slickPlay();
80
+ }
81
+ }, 500);
82
+ }, autoplaySpeed);
83
+ }
84
+ }, [autoplaySpeed, childrenCount, isAutoplayEnabled, slider, slidesToShowCount]);
85
+ React.useEffect(() => {
86
+ if (hasFocus && autoplayTimeId.current) {
87
+ clearTimeout(autoplayTimeId.current);
88
+ }
89
+ else {
90
+ scrollLastSlide(currentIndex);
91
+ }
92
+ }, [currentIndex, hasFocus, scrollLastSlide]);
93
+ React.useEffect(() => {
94
+ onResize();
95
+ window.addEventListener('resize', onResize, { passive: true });
96
+ return () => window.removeEventListener('resize', onResize);
97
+ }, [onResize]);
98
+ const handleArrowClick = (direction) => {
99
+ let nextIndex;
100
+ if (direction === 'right') {
101
+ nextIndex =
102
+ currentIndex === childrenCount - slidesCountByBreakpoint ? 0 : currentIndex + 1;
103
+ }
104
+ else {
105
+ nextIndex =
106
+ currentIndex === 0 ? childrenCount - slidesCountByBreakpoint : currentIndex - 1;
107
+ }
108
+ if (slider) {
109
+ slider.slickGoTo(nextIndex);
110
+ }
111
+ };
112
+ const onBeforeChange = React.useCallback((current, next) => {
113
+ if (handleBeforeChange) {
114
+ handleBeforeChange(current, next);
115
+ }
116
+ prevIndexRef.current = current;
117
+ setCurrentIndex(Math.ceil(next));
118
+ }, [handleBeforeChange]);
119
+ const onAfterChange = React.useCallback((current) => {
120
+ if (handleAfterChange) {
121
+ handleAfterChange(current);
122
+ }
123
+ if (autoplayTimeId.current) {
124
+ clearTimeout(autoplayTimeId.current);
125
+ }
126
+ if (!hasFocus) {
127
+ scrollLastSlide(current);
128
+ }
129
+ if (isUserInteractionRef.current) {
130
+ const focusIndex = prevIndexRef.current >= current
131
+ ? current
132
+ : Math.max(current, prevIndexRef.current + slidesCountByBreakpoint);
133
+ const firstNewSlide = document.getElementById(getSlideId(sliderId, focusIndex));
134
+ if (firstNewSlide) {
135
+ const focusableChild = Array.from(firstNewSlide.querySelectorAll('*')).find(isFocusable);
136
+ focusableChild?.focus();
137
+ }
138
+ }
139
+ isUserInteractionRef.current = false;
140
+ }, [handleAfterChange, hasFocus, scrollLastSlide, sliderId, slidesCountByBreakpoint]);
141
+ const handleDotClick = (index) => {
142
+ const nextIndex = index > currentIndex ? index + 1 - slidesCountByBreakpoint : index;
143
+ if (slider) {
144
+ slider.slickGoTo(nextIndex);
145
+ }
146
+ };
147
+ const barSlidesCount = childrenCount - slidesCountByBreakpoint + 1;
148
+ const barPosition = (DOT_GAP + DOT_WIDTH) * currentIndex;
149
+ const barWidth = DOT_WIDTH + (DOT_GAP + DOT_WIDTH) * (slidesCountByBreakpoint - 1);
150
+ const { getRovingItemProps, rovingListProps } = useRovingTabIndex({
151
+ itemCount: barSlidesCount,
152
+ activeIndex: currentIndex + 1,
153
+ firstIndex: 1,
154
+ uniqId: sliderId,
155
+ });
156
+ const renderBar = () => {
157
+ return (slidesCountByBreakpoint > 1 && (_jsx("li", { className: b('bar'), style: {
158
+ left: barPosition,
159
+ width: barWidth,
160
+ } })));
161
+ };
162
+ // renders additional bar, not visible in the layout but visible for screenreaders
163
+ const renderAccessibleBar = (index) => {
164
+ return (
165
+ // To have this key differ from keys used in renderDot function, added `-accessible-bar` part
166
+ _jsx(React.Fragment, { children: slidesCountByBreakpoint > 0 && (_jsx("li", { className: b('accessible-bar'), role: "menuitemradio", "aria-checked": true, "aria-label": i18n('dot-label', {
167
+ index: currentIndex + 1,
168
+ count: barSlidesCount,
169
+ }), style: {
170
+ left: barPosition,
171
+ width: barWidth,
172
+ }, ...getRovingItemProps(currentIndex + 1) })) }, `${index}-accessible-bar`));
173
+ };
174
+ const getCurrentSlideNumber = (index) => {
175
+ const currentIndexDiff = index - currentIndex;
176
+ let currentSlideNumber;
177
+ if (0 <= currentIndexDiff && currentIndexDiff < slidesCountByBreakpoint) {
178
+ currentSlideNumber = currentIndex + 1;
179
+ }
180
+ else if (currentIndexDiff >= slidesCountByBreakpoint) {
181
+ currentSlideNumber = index - slidesCountByBreakpoint + 2;
182
+ }
183
+ else {
184
+ currentSlideNumber = index + 1;
185
+ }
186
+ return currentSlideNumber;
187
+ };
188
+ const isVisibleSlide = (index) => {
189
+ const currentIndexDiff = index - currentIndex;
190
+ const result = slidesCountByBreakpoint > 0 &&
191
+ 0 <= currentIndexDiff &&
192
+ currentIndexDiff < slidesCountByBreakpoint;
193
+ return result;
194
+ };
195
+ const renderDot = (index) => {
196
+ const isVisible = isVisibleSlide(index);
197
+ const currentSlideNumber = getCurrentSlideNumber(index);
198
+ const rovingItemProps = isVisible ? undefined : getRovingItemProps(currentSlideNumber);
199
+ return (_jsx("li", { className: b('dot', { active: index === currentIndex }), onClick: asUserInteraction(() => handleDotClick(index)), onKeyDown: (e) => {
200
+ const key = e.key.toLowerCase();
201
+ if (key === 'space' || key === 'enter') {
202
+ e.currentTarget.click();
203
+ }
204
+ }, role: "menuitemradio", "aria-checked": false, tabIndex: -1, "aria-hidden": isVisible, "aria-label": i18n('dot-label', {
205
+ index: currentSlideNumber,
206
+ count: barSlidesCount,
207
+ }), ...rovingItemProps }, index));
208
+ };
209
+ const renderNavigation = () => {
210
+ if (childrenCount <= slidesCountByBreakpoint || !dots || childrenCount === 1) {
211
+ return null;
212
+ }
213
+ const dotsList = Array(childrenCount)
214
+ .fill(null)
215
+ .map((_item, index) => renderDot(index));
216
+ dotsList.splice(currentIndex, 0, renderAccessibleBar(currentIndex));
217
+ return (_jsx("div", { className: b('dots', dotsClassName), children: _jsxs("ul", { className: b('dots-list'), role: "menu", "aria-label": i18n('pagination-label'), ...rovingListProps, children: [renderBar(), dotsList] }) }));
218
+ };
219
+ const renderDisclaimer = () => {
220
+ return disclaimer ? (_jsx("div", { className: b('disclaimer', { size: disclaimer.size || 'm' }), children: disclaimer.text })) : null;
221
+ };
222
+ const renderSlider = () => {
223
+ /* Disable adding of width in inline styles when SSR to prevent overriding of default styles */
224
+ /* Calculate appropriate breakpoint for mobile devices with user agent */
225
+ const variableWidth = isServer && isMobile;
226
+ const settings = {
227
+ ref: (slickSlider) => setSlider(slickSlider),
228
+ className: slick(null, className),
229
+ arrows,
230
+ variableWidth,
231
+ infinite: false,
232
+ speed: 1000,
233
+ adaptiveHeight: adaptive,
234
+ autoplay: isAutoplayEnabled,
235
+ autoplaySpeed,
236
+ slidesToShow: slidesToShowCount,
237
+ slidesToScroll: 1,
238
+ responsive: getSliderResponsiveParams(slidesToShow),
239
+ beforeChange: onBeforeChange,
240
+ afterChange: onAfterChange,
241
+ initialSlide: initialIndex,
242
+ nextArrow: (_jsx(Arrow, { type: "right", handleClick: asUserInteraction(handleArrowClick), size: arrowSize })),
243
+ prevArrow: (_jsx(Arrow, { type: "left", handleClick: asUserInteraction(handleArrowClick), size: arrowSize })),
244
+ lazyLoad,
245
+ accessibility: false,
246
+ };
247
+ return (_jsxs(OutsideClick, { onOutsideClick: isMobile ? unsetFocus : noop, children: [_jsx(SlickSlider, { ...settings, children: disclosedChildren }), _jsxs("div", { className: b('footer'), children: [renderDisclaimer(), renderNavigation()] })] }));
248
+ };
249
+ return (_jsx(StylesContext.Provider, { value: { ...childStyles, setStyles: setChildStyles }, children: _jsxs("div", { className: b({
250
+ 'align-left': childrenCount < slidesCountByBreakpoint,
251
+ 'one-slide': childrenCount === 1,
252
+ 'only-arrows': !title?.text && !description && arrows,
253
+ mobile: isMobile,
254
+ type,
255
+ }, blockClassName), children: [anchorId && _jsx(Anchor, { id: anchorId }), _jsx(Title, { title: title, subtitle: description, className: b('header', { 'no-description': !description }) }), _jsx(AnimateBlock, { className: b('animate-slides'), animate: animated, children: renderSlider() })] }) }));
256
+ };
257
+ function getSlideId(sliderId, index) {
258
+ return `slider-${sliderId}-child-${index}`;
259
+ }
260
+ // TODO remove this and rework PriceDetailed CLOUDFRONT-12230
261
+ function discloseAllNestedChildren(children, sliderId) {
262
+ if (!children) {
263
+ return [];
264
+ }
265
+ let childIndex = 0;
266
+ const wrapped = (child) => {
267
+ const id = getSlideId(sliderId, childIndex++);
268
+ return (_jsx("div", { id: id, children: child }, id));
269
+ };
270
+ return React.Children.map(children, (child) => {
271
+ if (child) {
272
+ // TODO: if child has 'items' then 'items' determinate like nested children for Slider.
273
+ const nestedChildren = child.props.data?.items;
274
+ if (nestedChildren) {
275
+ return nestedChildren.map((nestedChild) => {
276
+ return wrapped(React.cloneElement(child, {
277
+ data: {
278
+ ...child.props.data,
279
+ items: [nestedChild],
280
+ },
281
+ }));
282
+ });
283
+ }
284
+ }
285
+ return child && wrapped(child);
286
+ }).filter(Boolean);
287
+ }
288
+ export default SliderOldBlock;
289
+ //# sourceMappingURL=SliderOld.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SliderOld.js","sourceRoot":"../../../../src","sources":["blocks/SliderOld/SliderOld.tsx"],"names":[],"mappings":"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","sourcesContent":["import * as React from 'react';\n\nimport {useUniqId} from '@gravity-ui/uikit';\nimport debounce from 'lodash/debounce';\nimport get from 'lodash/get';\nimport noop from 'lodash/noop';\nimport SlickSlider, {Settings} from 'react-slick';\n\nimport Anchor from '../../components/Anchor/Anchor';\nimport AnimateBlock from '../../components/AnimateBlock/AnimateBlock';\nimport OutsideClick from '../../components/OutsideClick/OutsideClick';\nimport Title from '../../components/Title/Title';\nimport {BREAKPOINTS} from '../../constants';\nimport {MobileContext} from '../../context/mobileContext';\nimport {SSRContext} from '../../context/ssrContext';\nimport {StylesContext} from '../../context/stylesContext/StylesContext';\nimport useFocus from '../../hooks/useFocus';\nimport {\n ClassNameProps,\n Refable,\n SliderOldProps as SliderParams,\n SliderType,\n Timeout,\n} from '../../models';\nimport {block} from '../../utils';\n\nimport Arrow, {ArrowType} from './Arrow/Arrow';\nimport {i18n} from './i18n';\nimport {SliderBreakpointParams} from './models';\nimport {\n getSliderResponsiveParams,\n getSlidesCountByBreakpoint,\n getSlidesToShowCount,\n getSlidesToShowWithDefaults,\n isFocusable,\n useRovingTabIndex,\n} from './utils';\n\nimport './SliderOld.scss';\n\nconst b = block('SliderOldBlock');\nconst slick = block('slick-origin');\n\nconst DOT_WIDTH = 8;\nconst DOT_GAP = 16;\n\n/** @deprecated */\nexport interface SliderOldProps\n extends Omit<SliderParams, 'children'>,\n Refable<HTMLDivElement>,\n ClassNameProps,\n Pick<Settings, 'lazyLoad'> {\n type?: string;\n anchorId?: string;\n onAfterChange?: (index: number) => void;\n onBeforeChange?: (current: number, next: number) => void;\n dotsClassName?: string;\n blockClassName?: string;\n arrowSize?: number;\n initialIndex?: number;\n}\n\n// eslint-disable-next-line valid-jsdoc\n/** @deprecated */\nexport const SliderOldBlock = (props: React.PropsWithChildren<SliderOldProps>) => {\n const {\n animated,\n title,\n description,\n type,\n anchorId,\n arrows = true,\n adaptive,\n autoplay: autoplaySpeed,\n dots = true,\n dotsClassName,\n disclaimer,\n children,\n className,\n blockClassName,\n lazyLoad,\n arrowSize,\n onAfterChange: handleAfterChange,\n onBeforeChange: handleBeforeChange,\n initialIndex = 0,\n } = props;\n\n const {isServer} = React.useContext(SSRContext);\n const isMobile = React.useContext(MobileContext);\n const [breakpoint, setBreakpoint] = React.useState<number>(BREAKPOINTS.xl);\n const sliderId = useUniqId();\n const disclosedChildren = React.useMemo<React.ReactElement[]>(\n () => discloseAllNestedChildren(children as React.ReactElement[], sliderId),\n [children, sliderId],\n );\n const childrenCount = disclosedChildren.length;\n const isAutoplayEnabled = autoplaySpeed !== undefined && autoplaySpeed > 0;\n const isUserInteractionRef = React.useRef(false);\n\n const [slidesToShow] = React.useState<SliderBreakpointParams>(\n getSlidesToShowWithDefaults({\n contentLength: childrenCount,\n breakpoints: props.slidesToShow,\n mobileFullscreen: Boolean(\n props.type && Object.values(SliderType).includes(props.type as SliderType),\n ),\n }),\n );\n\n const slidesToShowCount = getSlidesToShowCount(slidesToShow);\n const slidesCountByBreakpoint = getSlidesCountByBreakpoint(breakpoint, slidesToShow);\n\n const [currentIndex, setCurrentIndex] = React.useState<number>(initialIndex);\n const [childStyles, setChildStyles] = React.useState<Object>({});\n const [slider, setSlider] = React.useState<SlickSlider>();\n const prevIndexRef = React.useRef<number>(0);\n const autoplayTimeId = React.useRef<Timeout>();\n const {hasFocus, unsetFocus} = useFocus(slider?.innerSlider?.list);\n\n const asUserInteraction =\n <T extends unknown[], R>(fn: (...args: T) => R) =>\n (...args: T): R => {\n isUserInteractionRef.current = true;\n return fn(...args);\n };\n\n // eslint-disable-next-line react-hooks/exhaustive-deps\n const onResize = React.useCallback(\n debounce(() => {\n if (!slider) {\n return;\n }\n\n const newBreakpoint = get(slider, 'state.breakpoint') || BREAKPOINTS.xl;\n\n if (newBreakpoint !== breakpoint) {\n setBreakpoint(newBreakpoint);\n setCurrentIndex(0);\n\n slider.slickGoTo(0);\n }\n }, 100),\n [slider, breakpoint],\n );\n\n const scrollLastSlide = React.useCallback(\n (current: number) => {\n const lastSlide = childrenCount - slidesToShowCount;\n\n if (isAutoplayEnabled && lastSlide === current) {\n // Slick doesn't support autoplay with no infinity scroll\n autoplayTimeId.current = setTimeout(() => {\n if (slider) {\n slider.slickGoTo(0, false);\n slider.slickPause();\n }\n setTimeout(() => {\n if (slider) {\n slider.slickPlay();\n }\n }, 500);\n }, autoplaySpeed);\n }\n },\n [autoplaySpeed, childrenCount, isAutoplayEnabled, slider, slidesToShowCount],\n );\n\n React.useEffect(() => {\n if (hasFocus && autoplayTimeId.current) {\n clearTimeout(autoplayTimeId.current);\n } else {\n scrollLastSlide(currentIndex);\n }\n }, [currentIndex, hasFocus, scrollLastSlide]);\n\n React.useEffect(() => {\n onResize();\n\n window.addEventListener('resize', onResize, {passive: true});\n\n return () => window.removeEventListener('resize', onResize);\n }, [onResize]);\n\n const handleArrowClick = (direction: ArrowType) => {\n let nextIndex;\n\n if (direction === 'right') {\n nextIndex =\n currentIndex === childrenCount - slidesCountByBreakpoint ? 0 : currentIndex + 1;\n } else {\n nextIndex =\n currentIndex === 0 ? childrenCount - slidesCountByBreakpoint : currentIndex - 1;\n }\n\n if (slider) {\n slider.slickGoTo(nextIndex);\n }\n };\n\n const onBeforeChange = React.useCallback(\n (current: number, next: number) => {\n if (handleBeforeChange) {\n handleBeforeChange(current, next);\n }\n\n prevIndexRef.current = current;\n\n setCurrentIndex(Math.ceil(next));\n },\n [handleBeforeChange],\n );\n\n const onAfterChange = React.useCallback(\n (current: number) => {\n if (handleAfterChange) {\n handleAfterChange(current);\n }\n\n if (autoplayTimeId.current) {\n clearTimeout(autoplayTimeId.current);\n }\n\n if (!hasFocus) {\n scrollLastSlide(current);\n }\n\n if (isUserInteractionRef.current) {\n const focusIndex =\n prevIndexRef.current >= current\n ? current\n : Math.max(current, prevIndexRef.current + slidesCountByBreakpoint);\n\n const firstNewSlide = document.getElementById(getSlideId(sliderId, focusIndex));\n if (firstNewSlide) {\n const focusableChild = Array.from(firstNewSlide.querySelectorAll('*')).find(\n isFocusable,\n ) as HTMLElement | undefined;\n focusableChild?.focus();\n }\n }\n\n isUserInteractionRef.current = false;\n },\n [handleAfterChange, hasFocus, scrollLastSlide, sliderId, slidesCountByBreakpoint],\n );\n\n const handleDotClick = (index: number) => {\n const nextIndex = index > currentIndex ? index + 1 - slidesCountByBreakpoint : index;\n\n if (slider) {\n slider.slickGoTo(nextIndex);\n }\n };\n\n const barSlidesCount = childrenCount - slidesCountByBreakpoint + 1;\n const barPosition = (DOT_GAP + DOT_WIDTH) * currentIndex;\n const barWidth = DOT_WIDTH + (DOT_GAP + DOT_WIDTH) * (slidesCountByBreakpoint - 1);\n\n const {getRovingItemProps, rovingListProps} = useRovingTabIndex({\n itemCount: barSlidesCount,\n activeIndex: currentIndex + 1,\n firstIndex: 1,\n uniqId: sliderId,\n });\n\n const renderBar = () => {\n return (\n slidesCountByBreakpoint > 1 && (\n <li\n className={b('bar')}\n style={{\n left: barPosition,\n width: barWidth,\n }}\n />\n )\n );\n };\n\n // renders additional bar, not visible in the layout but visible for screenreaders\n const renderAccessibleBar = (index: number) => {\n return (\n // To have this key differ from keys used in renderDot function, added `-accessible-bar` part\n <React.Fragment key={`${index}-accessible-bar`}>\n {slidesCountByBreakpoint > 0 && (\n <li\n className={b('accessible-bar')}\n role=\"menuitemradio\"\n aria-checked\n aria-label={i18n('dot-label', {\n index: currentIndex + 1,\n count: barSlidesCount,\n })}\n style={{\n left: barPosition,\n width: barWidth,\n }}\n {...getRovingItemProps(currentIndex + 1)}\n />\n )}\n </React.Fragment>\n );\n };\n\n const getCurrentSlideNumber = (index: number) => {\n const currentIndexDiff = index - currentIndex;\n\n let currentSlideNumber;\n if (0 <= currentIndexDiff && currentIndexDiff < slidesCountByBreakpoint) {\n currentSlideNumber = currentIndex + 1;\n } else if (currentIndexDiff >= slidesCountByBreakpoint) {\n currentSlideNumber = index - slidesCountByBreakpoint + 2;\n } else {\n currentSlideNumber = index + 1;\n }\n return currentSlideNumber;\n };\n const isVisibleSlide = (index: number) => {\n const currentIndexDiff = index - currentIndex;\n\n const result =\n slidesCountByBreakpoint > 0 &&\n 0 <= currentIndexDiff &&\n currentIndexDiff < slidesCountByBreakpoint;\n return result;\n };\n\n const renderDot = (index: number) => {\n const isVisible = isVisibleSlide(index);\n const currentSlideNumber = getCurrentSlideNumber(index);\n const rovingItemProps = isVisible ? undefined : getRovingItemProps(currentSlideNumber);\n return (\n <li\n key={index}\n className={b('dot', {active: index === currentIndex})}\n onClick={asUserInteraction(() => handleDotClick(index))}\n onKeyDown={(e) => {\n const key = e.key.toLowerCase();\n if (key === 'space' || key === 'enter') {\n e.currentTarget.click();\n }\n }}\n role=\"menuitemradio\"\n aria-checked={false}\n tabIndex={-1}\n aria-hidden={isVisible}\n aria-label={i18n('dot-label', {\n index: currentSlideNumber,\n count: barSlidesCount,\n })}\n {...rovingItemProps}\n />\n );\n };\n\n const renderNavigation = () => {\n if (childrenCount <= slidesCountByBreakpoint || !dots || childrenCount === 1) {\n return null;\n }\n const dotsList = Array(childrenCount)\n .fill(null)\n .map((_item, index) => renderDot(index));\n dotsList.splice(currentIndex, 0, renderAccessibleBar(currentIndex));\n\n return (\n <div className={b('dots', dotsClassName)}>\n <ul\n className={b('dots-list')}\n role=\"menu\"\n aria-label={i18n('pagination-label')}\n {...rovingListProps}\n >\n {renderBar()}\n {dotsList}\n </ul>\n </div>\n );\n };\n\n const renderDisclaimer = () => {\n return disclaimer ? (\n <div className={b('disclaimer', {size: disclaimer.size || 'm'})}>{disclaimer.text}</div>\n ) : null;\n };\n\n const renderSlider = () => {\n /* Disable adding of width in inline styles when SSR to prevent overriding of default styles */\n /* Calculate appropriate breakpoint for mobile devices with user agent */\n const variableWidth = isServer && isMobile;\n\n const settings = {\n ref: (slickSlider: SlickSlider) => setSlider(slickSlider),\n className: slick(null, className),\n arrows,\n variableWidth,\n infinite: false,\n speed: 1000,\n adaptiveHeight: adaptive,\n autoplay: isAutoplayEnabled,\n autoplaySpeed,\n slidesToShow: slidesToShowCount,\n slidesToScroll: 1,\n responsive: getSliderResponsiveParams(slidesToShow),\n beforeChange: onBeforeChange,\n afterChange: onAfterChange,\n initialSlide: initialIndex,\n nextArrow: (\n <Arrow\n type=\"right\"\n handleClick={asUserInteraction(handleArrowClick)}\n size={arrowSize}\n />\n ),\n prevArrow: (\n <Arrow\n type=\"left\"\n handleClick={asUserInteraction(handleArrowClick)}\n size={arrowSize}\n />\n ),\n lazyLoad,\n accessibility: false,\n };\n\n return (\n <OutsideClick onOutsideClick={isMobile ? unsetFocus : noop}>\n <SlickSlider {...settings}>{disclosedChildren}</SlickSlider>\n <div className={b('footer')}>\n {renderDisclaimer()}\n {renderNavigation()}\n </div>\n </OutsideClick>\n );\n };\n\n return (\n <StylesContext.Provider value={{...childStyles, setStyles: setChildStyles}}>\n <div\n className={b(\n {\n 'align-left': childrenCount < slidesCountByBreakpoint,\n 'one-slide': childrenCount === 1,\n 'only-arrows': !title?.text && !description && arrows,\n mobile: isMobile,\n type,\n },\n blockClassName,\n )}\n >\n {anchorId && <Anchor id={anchorId} />}\n <Title\n title={title}\n subtitle={description}\n className={b('header', {'no-description': !description})}\n />\n <AnimateBlock className={b('animate-slides')} animate={animated}>\n {renderSlider()}\n </AnimateBlock>\n </div>\n </StylesContext.Provider>\n );\n};\n\nfunction getSlideId(sliderId: string, index: number) {\n return `slider-${sliderId}-child-${index}`;\n}\n\n// TODO remove this and rework PriceDetailed CLOUDFRONT-12230\nfunction discloseAllNestedChildren(\n children: React.ReactElement[],\n sliderId: string,\n): React.ReactElement[] {\n if (!children) {\n return [];\n }\n\n let childIndex = 0;\n const wrapped = (child: React.ReactElement) => {\n const id = getSlideId(sliderId, childIndex++);\n\n return (\n <div key={id} id={id}>\n {child}\n </div>\n );\n };\n\n return React.Children.map(children, (child) => {\n if (child) {\n // TODO: if child has 'items' then 'items' determinate like nested children for Slider.\n const nestedChildren = child.props.data?.items;\n\n if (nestedChildren) {\n return nestedChildren.map((nestedChild: React.ReactElement) => {\n return wrapped(\n React.cloneElement(child, {\n data: {\n ...child.props.data,\n items: [nestedChild],\n },\n }),\n );\n });\n }\n }\n return child && wrapped(child);\n }).filter(Boolean);\n}\n\nexport default SliderOldBlock;\n"]}
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "arrow-right": "Next",
3
3
  "arrow-left": "Previous",
4
- "dot-label": "Page {{index}}",
4
+ "dot-label": "Page {{index}} of {{count}}",
5
5
  "pagination-label": "Pages"
6
6
  }
@@ -1,5 +1,5 @@
1
1
  export declare const i18n: ((key: "arrow-right" | "arrow-left" | "dot-label" | "pagination-label", params?: import("@gravity-ui/i18n").Params) => string) & {
2
2
  keysetData: {
3
- "pc-SliderNewBlock": Record<"arrow-right" | "arrow-left" | "dot-label" | "pagination-label", import("@gravity-ui/i18n").KeyData>;
3
+ "pc-SliderOldBlock": Record<"arrow-right" | "arrow-left" | "dot-label" | "pagination-label", import("@gravity-ui/i18n").KeyData>;
4
4
  };
5
5
  };
@@ -2,5 +2,5 @@ import { addComponentKeysets } from '@gravity-ui/uikit/i18n';
2
2
  import { NAMESPACE } from "../../../utils/cn.js";
3
3
  import en from "./en.json";
4
4
  import ru from "./ru.json";
5
- export const i18n = addComponentKeysets({ en, ru }, `${NAMESPACE}SliderNewBlock`);
5
+ export const i18n = addComponentKeysets({ en, ru }, `${NAMESPACE}SliderOldBlock`);
6
6
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"../../../../../src","sources":["blocks/SliderNew/i18n/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,mBAAmB,EAAC,MAAM,wBAAwB,CAAC;AAE3D,OAAO,EAAC,SAAS,EAAC,6BAA0B;AAE5C,OAAO,EAAE,kBAAkB;AAC3B,OAAO,EAAE,kBAAkB;AAE3B,MAAM,CAAC,MAAM,IAAI,GAAG,mBAAmB,CAAC,EAAC,EAAE,EAAE,EAAE,EAAC,EAAE,GAAG,SAAS,gBAAgB,CAAC,CAAC","sourcesContent":["import {addComponentKeysets} from '@gravity-ui/uikit/i18n';\n\nimport {NAMESPACE} from '../../../utils/cn';\n\nimport en from './en.json';\nimport ru from './ru.json';\n\nexport const i18n = addComponentKeysets({en, ru}, `${NAMESPACE}SliderNewBlock`);\n"]}
1
+ {"version":3,"file":"index.js","sourceRoot":"../../../../../src","sources":["blocks/SliderOld/i18n/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,mBAAmB,EAAC,MAAM,wBAAwB,CAAC;AAE3D,OAAO,EAAC,SAAS,EAAC,6BAA0B;AAE5C,OAAO,EAAE,kBAAkB;AAC3B,OAAO,EAAE,kBAAkB;AAE3B,MAAM,CAAC,MAAM,IAAI,GAAG,mBAAmB,CAAC,EAAC,EAAE,EAAE,EAAE,EAAC,EAAE,GAAG,SAAS,gBAAgB,CAAC,CAAC","sourcesContent":["import {addComponentKeysets} from '@gravity-ui/uikit/i18n';\n\nimport {NAMESPACE} from '../../../utils/cn';\n\nimport en from './en.json';\nimport ru from './ru.json';\n\nexport const i18n = addComponentKeysets({en, ru}, `${NAMESPACE}SliderOldBlock`);\n"]}
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "arrow-right": "Дальше",
3
3
  "arrow-left": "Назад",
4
- "dot-label": "Страница {{index}}",
4
+ "dot-label": "Страница {{index}} из {{count}}",
5
5
  "pagination-label": "Страницы"
6
6
  }
@@ -1,8 +1,8 @@
1
1
  export declare enum SliderBreakpointNames {
2
- Xs = "xs",
3
2
  Sm = "sm",
4
3
  Md = "md",
5
- Lg = "lg"
4
+ Lg = "lg",
5
+ Xl = "xl"
6
6
  }
7
7
  export type SliderBreakpointParams = Record<SliderBreakpointNames, number>;
8
8
  export type SlidesToShow = Partial<SliderBreakpointParams> | number;
@@ -1,8 +1,8 @@
1
1
  export var SliderBreakpointNames;
2
2
  (function (SliderBreakpointNames) {
3
- SliderBreakpointNames["Xs"] = "xs";
4
3
  SliderBreakpointNames["Sm"] = "sm";
5
4
  SliderBreakpointNames["Md"] = "md";
6
5
  SliderBreakpointNames["Lg"] = "lg";
6
+ SliderBreakpointNames["Xl"] = "xl";
7
7
  })(SliderBreakpointNames || (SliderBreakpointNames = {}));
8
8
  //# sourceMappingURL=models.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"models.js","sourceRoot":"../../../../src","sources":["blocks/SliderNew/models.ts"],"names":[],"mappings":"AAAA,MAAM,CAAN,IAAY,qBAKX;AALD,WAAY,qBAAqB;IAC7B,kCAAS,CAAA;IACT,kCAAS,CAAA;IACT,kCAAS,CAAA;IACT,kCAAS,CAAA;AACb,CAAC,EALW,qBAAqB,KAArB,qBAAqB,QAKhC","sourcesContent":["export enum SliderBreakpointNames {\n Xs = 'xs',\n Sm = 'sm',\n Md = 'md',\n Lg = 'lg',\n}\n\nexport type SliderBreakpointParams = Record<SliderBreakpointNames, number>;\nexport type SlidesToShow = Partial<SliderBreakpointParams> | number;\n"]}
1
+ {"version":3,"file":"models.js","sourceRoot":"../../../../src","sources":["blocks/SliderOld/models.ts"],"names":[],"mappings":"AAAA,MAAM,CAAN,IAAY,qBAKX;AALD,WAAY,qBAAqB;IAC7B,kCAAS,CAAA;IACT,kCAAS,CAAA;IACT,kCAAS,CAAA;IACT,kCAAS,CAAA;AACb,CAAC,EALW,qBAAqB,KAArB,qBAAqB,QAKhC","sourcesContent":["export enum SliderBreakpointNames {\n Sm = 'sm',\n Md = 'md',\n Lg = 'lg',\n Xl = 'xl',\n}\n\nexport type SliderBreakpointParams = Record<SliderBreakpointNames, number>;\nexport type SlidesToShow = Partial<SliderBreakpointParams> | number;\n"]}
@@ -1,4 +1,4 @@
1
- export declare const SliderNewProps: {
1
+ export declare const SliderOldProps: {
2
2
  dots: {
3
3
  type: string;
4
4
  };
@@ -11,15 +11,6 @@ export declare const SliderNewProps: {
11
11
  autoplay: {
12
12
  type: string;
13
13
  };
14
- type: {
15
- type: string;
16
- };
17
- adaptive: {
18
- type: string;
19
- };
20
- arrowSize: {
21
- type: string;
22
- };
23
14
  animated: {
24
15
  animated: {
25
16
  type: string;
@@ -92,8 +83,9 @@ export declare const SliderNewProps: {
92
83
  };
93
84
  };
94
85
  };
95
- export declare const SliderNewBlock: {
96
- 'slider-new-block': {
86
+ /** @deprecated */
87
+ export declare const SliderOldBlock: {
88
+ 'slider-old-block': {
97
89
  additionalProperties: boolean;
98
90
  required: never[];
99
91
  properties: {
@@ -144,15 +136,6 @@ export declare const SliderNewBlock: {
144
136
  autoplay: {
145
137
  type: string;
146
138
  };
147
- type: {
148
- type: string;
149
- };
150
- adaptive: {
151
- type: string;
152
- };
153
- arrowSize: {
154
- type: string;
155
- };
156
139
  animated: {
157
140
  animated: {
158
141
  type: string;
@@ -263,6 +246,7 @@ export declare const SliderNewBlock: {
263
246
  };
264
247
  };
265
248
  };
249
+ type: {};
266
250
  when: {
267
251
  type: string;
268
252
  };
@@ -51,7 +51,7 @@ const DisclaimerProps = {
51
51
  },
52
52
  },
53
53
  };
54
- export const SliderNewProps = {
54
+ export const SliderOldProps = {
55
55
  dots: {
56
56
  type: 'boolean',
57
57
  },
@@ -64,29 +64,21 @@ export const SliderNewProps = {
64
64
  autoplay: {
65
65
  type: 'number',
66
66
  },
67
- type: {
68
- type: 'string',
69
- },
70
- adaptive: {
71
- type: 'boolean',
72
- },
73
- arrowSize: {
74
- type: 'number',
75
- },
76
67
  animated: AnimatableProps,
77
68
  slidesToShow: sliderSizesObject,
78
69
  disclaimer: DisclaimerProps,
79
70
  loadable: LoadableProps,
80
71
  children: ChildrenCardsProps,
81
72
  };
82
- export const SliderNewBlock = {
83
- 'slider-new-block': {
73
+ /** @deprecated */
74
+ export const SliderOldBlock = {
75
+ 'slider-old-block': {
84
76
  additionalProperties: false,
85
77
  required: [],
86
78
  properties: {
87
79
  ...BlockBaseProps,
88
80
  ...AnimatableProps,
89
- ...SliderNewProps,
81
+ ...SliderOldProps,
90
82
  ...BlockHeaderProps,
91
83
  },
92
84
  },
@@ -0,0 +1 @@
1
+ {"version":3,"file":"schema.js","sourceRoot":"../../../../src","sources":["blocks/SliderOld/schema.ts"],"names":[],"mappings":"AAAA,OAAO,EACH,eAAe,EACf,cAAc,EACd,gBAAgB,EAChB,kBAAkB,EAClB,iBAAiB,EACjB,QAAQ,GACX,0CAAuC;AAExC,MAAM,aAAa,GAAG;IAClB,oBAAoB,EAAE,KAAK;IAC3B,QAAQ,EAAE,CAAC,QAAQ,CAAC;IACpB,UAAU,EAAE;QACR,MAAM,EAAE;YACJ,IAAI,EAAE,QAAQ;YACd,0DAA0D;YAC1D,0DAA0D;SAC7D;QACD;;WAEG;QACH,QAAQ,EAAE;YACN,IAAI,EAAE,QAAQ;SACjB;QACD,MAAM,EAAE;YACJ,IAAI,EAAE,QAAQ;YACd,iBAAiB,EAAE;gBACf,IAAI,EAAE;oBACF,KAAK,EAAE;wBACH;4BACI,IAAI,EAAE,CAAC,QAAQ,EAAE,QAAQ,EAAE,SAAS,CAAC;yBACxC;wBACD;4BACI,IAAI,EAAE,QAAQ;4BACd,oBAAoB,EAAE,IAAI;yBAC7B;wBACD;4BACI,IAAI,EAAE,OAAO;yBAChB;qBACJ;iBACJ;aACJ;SACJ;KACJ;IACD,gEAAgE;IAChE,QAAQ,EAAE,IAAI;CACjB,CAAC;AAEF,MAAM,eAAe,GAAG;IACpB,oBAAoB,EAAE,KAAK;IAC3B,QAAQ,EAAE,CAAC,MAAM,CAAC;IAClB,UAAU,EAAE;QACR,IAAI,EAAE;YACF,IAAI,EAAE,QAAQ;YACd,WAAW,EAAE,MAAM;SACtB;QACD,IAAI,EAAE;YACF,IAAI,EAAE,QAAQ;YACd,IAAI,EAAE,QAAQ;SACjB;KACJ;CACJ,CAAC;AAEF,MAAM,CAAC,MAAM,cAAc,GAAG;IAC1B,IAAI,EAAE;QACF,IAAI,EAAE,SAAS;KAClB;IACD,MAAM,EAAE;QACJ,IAAI,EAAE,SAAS;KAClB;IACD,WAAW,EAAE;QACT,IAAI,EAAE,SAAS;KAClB;IACD,QAAQ,EAAE;QACN,IAAI,EAAE,QAAQ;KACjB;IACD,QAAQ,EAAE,eAAe;IACzB,YAAY,EAAE,iBAAiB;IAC/B,UAAU,EAAE,eAAe;IAC3B,QAAQ,EAAE,aAAa;IACvB,QAAQ,EAAE,kBAAkB;CAC/B,CAAC;AAEF,kBAAkB;AAClB,MAAM,CAAC,MAAM,cAAc,GAAG;IAC1B,kBAAkB,EAAE;QAChB,oBAAoB,EAAE,KAAK;QAC3B,QAAQ,EAAE,EAAE;QACZ,UAAU,EAAE;YACR,GAAG,cAAc;YACjB,GAAG,eAAe;YAClB,GAAG,cAAc;YACjB,GAAG,gBAAgB;SACtB;KACJ;CACJ,CAAC","sourcesContent":["import {\n AnimatableProps,\n BlockBaseProps,\n BlockHeaderProps,\n ChildrenCardsProps,\n sliderSizesObject,\n textSize,\n} from '../../schema/validators/common';\n\nconst LoadableProps = {\n additionalProperties: false,\n required: ['source'],\n properties: {\n source: {\n type: 'string',\n // add loadable sources here if you use it in your project\n // enum: ['my-loadable-source-1', 'my-loadable-source-1'],\n },\n /**\n * @deprecated\n */\n minCount: {\n type: 'number',\n },\n params: {\n type: 'object',\n patternProperties: {\n '.*': {\n oneOf: [\n {\n type: ['string', 'number', 'boolean'],\n },\n {\n type: 'object',\n additionalProperties: true,\n },\n {\n type: 'array',\n },\n ],\n },\n },\n },\n },\n // remove it in your custom validator schema if you use loadable\n disabled: true,\n};\n\nconst DisclaimerProps = {\n additionalProperties: false,\n required: ['text'],\n properties: {\n text: {\n type: 'string',\n contentType: 'text',\n },\n size: {\n type: 'string',\n enum: textSize,\n },\n },\n};\n\nexport const SliderOldProps = {\n dots: {\n type: 'boolean',\n },\n arrows: {\n type: 'boolean',\n },\n randomOrder: {\n type: 'boolean',\n },\n autoplay: {\n type: 'number',\n },\n animated: AnimatableProps,\n slidesToShow: sliderSizesObject,\n disclaimer: DisclaimerProps,\n loadable: LoadableProps,\n children: ChildrenCardsProps,\n};\n\n/** @deprecated */\nexport const SliderOldBlock = {\n 'slider-old-block': {\n additionalProperties: false,\n required: [],\n properties: {\n ...BlockBaseProps,\n ...AnimatableProps,\n ...SliderOldProps,\n ...BlockHeaderProps,\n },\n },\n};\n"]}
@@ -0,0 +1,37 @@
1
+ import * as React from 'react';
2
+ import { SliderBreakpointParams, SlidesToShow } from "./models.js";
3
+ export declare const DEFAULT_SLIDE_BREAKPOINTS: {
4
+ xl: number;
5
+ lg: number;
6
+ md: number;
7
+ sm: number;
8
+ };
9
+ export interface GetSlidesToShowParams {
10
+ contentLength: number;
11
+ breakpoints?: SlidesToShow;
12
+ mobileFullscreen?: boolean;
13
+ }
14
+ export declare const isFocusable: (element: Element) => boolean;
15
+ export declare function getSlidesToShowWithDefaults({ contentLength, breakpoints, mobileFullscreen, }: GetSlidesToShowParams): {
16
+ sm: number;
17
+ xl: number;
18
+ lg: number;
19
+ md: number;
20
+ };
21
+ export declare function getSliderResponsiveParams(breakpoints: SliderBreakpointParams): {
22
+ breakpoint: number;
23
+ settings: {
24
+ slidesToShow: number;
25
+ };
26
+ }[];
27
+ export declare function getSlidesCountByBreakpoint(breakpoint: number, breakpoints: SliderBreakpointParams): number;
28
+ export declare function getSlidesToShowCount(breakpoints: SliderBreakpointParams): number;
29
+ export declare function useRovingTabIndex(props: {
30
+ itemCount: number;
31
+ activeIndex: number;
32
+ firstIndex?: number;
33
+ uniqId: string;
34
+ }): {
35
+ getRovingItemProps: (index: number) => Pick<React.HTMLAttributes<HTMLElement>, "id" | "tabIndex" | "onFocus">;
36
+ rovingListProps: React.HTMLAttributes<HTMLElement>;
37
+ };