@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,129 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.isFocusable = exports.DEFAULT_SLIDE_BREAKPOINTS = void 0;
4
+ exports.getSlidesToShowWithDefaults = getSlidesToShowWithDefaults;
5
+ exports.getSliderResponsiveParams = getSliderResponsiveParams;
6
+ exports.getSlidesCountByBreakpoint = getSlidesCountByBreakpoint;
7
+ exports.getSlidesToShowCount = getSlidesToShowCount;
8
+ exports.useRovingTabIndex = useRovingTabIndex;
9
+ const tslib_1 = require("tslib");
10
+ const React = tslib_1.__importStar(require("react"));
11
+ const pickBy_1 = tslib_1.__importDefault(require("lodash/pickBy.js"));
12
+ const constants_1 = require("../../constants.js");
13
+ const models_1 = require("./models.js");
14
+ exports.DEFAULT_SLIDE_BREAKPOINTS = {
15
+ [models_1.SliderBreakpointNames.Xl]: 3,
16
+ [models_1.SliderBreakpointNames.Lg]: 2,
17
+ [models_1.SliderBreakpointNames.Md]: 2,
18
+ [models_1.SliderBreakpointNames.Sm]: 1.15,
19
+ };
20
+ const BREAKPOINT_NAMES_BY_VALUES = Object.entries(constants_1.BREAKPOINTS).reduce((acc, [key, value]) => ({ ...acc, [value]: key }), {});
21
+ const isFocusable = (element) => {
22
+ if (!(element instanceof HTMLElement)) {
23
+ return false;
24
+ }
25
+ const tabIndexAttr = element.getAttribute('tabindex');
26
+ const hasTabIndex = tabIndexAttr !== null;
27
+ const tabIndex = Number(tabIndexAttr);
28
+ if (element.ariaHidden === 'true' || (hasTabIndex && tabIndex < 0)) {
29
+ return false;
30
+ }
31
+ if (hasTabIndex && tabIndex >= 0) {
32
+ return true;
33
+ }
34
+ // without this jest fails here for some reason
35
+ let htmlElement;
36
+ switch (true) {
37
+ case element instanceof HTMLAnchorElement:
38
+ htmlElement = element;
39
+ return Boolean(htmlElement.href);
40
+ case element instanceof HTMLInputElement:
41
+ htmlElement = element;
42
+ return htmlElement.type !== 'hidden' && !htmlElement.disabled;
43
+ case element instanceof HTMLSelectElement:
44
+ case element instanceof HTMLTextAreaElement:
45
+ case element instanceof HTMLButtonElement:
46
+ htmlElement = element;
47
+ return !htmlElement.disabled;
48
+ default:
49
+ return false;
50
+ }
51
+ };
52
+ exports.isFocusable = isFocusable;
53
+ function getSlidesToShowWithDefaults({ contentLength, breakpoints, mobileFullscreen, }) {
54
+ let result;
55
+ if (typeof breakpoints === 'number') {
56
+ result = Object.keys(exports.DEFAULT_SLIDE_BREAKPOINTS).reduce((acc, breakpointName) => ({ ...acc, [breakpointName]: breakpoints }), {});
57
+ }
58
+ else {
59
+ result = breakpoints || exports.DEFAULT_SLIDE_BREAKPOINTS;
60
+ }
61
+ return {
62
+ ...exports.DEFAULT_SLIDE_BREAKPOINTS,
63
+ ...(0, pickBy_1.default)(result, (value) => !isNaN(value)),
64
+ sm: !mobileFullscreen && contentLength > 1 ? exports.DEFAULT_SLIDE_BREAKPOINTS.sm : 1,
65
+ };
66
+ }
67
+ function getSliderResponsiveParams(breakpoints) {
68
+ return Object.entries(breakpoints).map(([breakpointName, slidesToShow]) => ({
69
+ breakpoint: constants_1.BREAKPOINTS[breakpointName],
70
+ settings: { slidesToShow },
71
+ }));
72
+ }
73
+ function getSlidesCountByBreakpoint(breakpoint, breakpoints) {
74
+ const breakpointName = BREAKPOINT_NAMES_BY_VALUES[breakpoint];
75
+ return Math.floor(breakpoints[breakpointName]);
76
+ }
77
+ function getSlidesToShowCount(breakpoints) {
78
+ return Math.floor(Math.max(...Object.values(breakpoints)));
79
+ }
80
+ const getRovingListItemId = (uniqId, index) => `${uniqId}-roving-tabindex-item-${index}`;
81
+ function useRovingTabIndex(props) {
82
+ const { itemCount, activeIndex, firstIndex = 0, uniqId } = props;
83
+ const [currentIndex, setCurrentIndex] = React.useState(firstIndex);
84
+ const hasFocusRef = React.useRef(false);
85
+ const lastIndex = itemCount + firstIndex - 1;
86
+ const getRovingItemProps = (index) => {
87
+ return {
88
+ id: getRovingListItemId(uniqId, index),
89
+ tabIndex: index === activeIndex ? 0 : -1,
90
+ onFocus: () => {
91
+ setCurrentIndex(index);
92
+ hasFocusRef.current = true;
93
+ },
94
+ };
95
+ };
96
+ React.useEffect(() => {
97
+ if (!hasFocusRef.current) {
98
+ return;
99
+ }
100
+ document.getElementById(getRovingListItemId(uniqId, currentIndex))?.focus();
101
+ }, [activeIndex, currentIndex, uniqId]);
102
+ const setNextIndex = () => setCurrentIndex((prev) => (prev >= lastIndex ? firstIndex : prev + 1));
103
+ const setPrevIndex = () => setCurrentIndex((prev) => (prev <= firstIndex ? lastIndex : prev - 1));
104
+ const onRovingListKeyDown = (e) => {
105
+ const key = e.key.toLowerCase();
106
+ if (key !== 'tab' && key !== 'enter') {
107
+ e.preventDefault();
108
+ }
109
+ switch (key) {
110
+ case 'arrowleft':
111
+ case 'arrowup':
112
+ setPrevIndex();
113
+ return;
114
+ case 'arrowright':
115
+ case 'arrowdown':
116
+ setNextIndex();
117
+ return;
118
+ }
119
+ };
120
+ const onRovingListBlur = () => {
121
+ hasFocusRef.current = false;
122
+ };
123
+ const rovingListProps = {
124
+ onKeyDown: onRovingListKeyDown,
125
+ onBlur: onRovingListBlur,
126
+ };
127
+ return { getRovingItemProps, rovingListProps };
128
+ }
129
+ //# sourceMappingURL=utils.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"utils.js","sourceRoot":"../../../../src","sources":["blocks/SliderOld/utils.ts"],"names":[],"mappings":"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","sourcesContent":["import * as React from 'react';\n\nimport pickBy from 'lodash/pickBy';\n\nimport {BREAKPOINTS} from '../../constants';\n\nimport {SliderBreakpointNames, SliderBreakpointParams, SlidesToShow} from './models';\n\nexport const DEFAULT_SLIDE_BREAKPOINTS = {\n [SliderBreakpointNames.Xl]: 3,\n [SliderBreakpointNames.Lg]: 2,\n [SliderBreakpointNames.Md]: 2,\n [SliderBreakpointNames.Sm]: 1.15,\n};\n\nconst BREAKPOINT_NAMES_BY_VALUES = Object.entries(BREAKPOINTS).reduce<\n Record<number, SliderBreakpointNames>\n>((acc, [key, value]) => ({...acc, [value]: key as SliderBreakpointNames}), {});\n\nexport interface GetSlidesToShowParams {\n contentLength: number;\n breakpoints?: SlidesToShow;\n mobileFullscreen?: boolean;\n}\n\nexport const isFocusable = (element: Element): boolean => {\n if (!(element instanceof HTMLElement)) {\n return false;\n }\n const tabIndexAttr = element.getAttribute('tabindex');\n const hasTabIndex = tabIndexAttr !== null;\n const tabIndex = Number(tabIndexAttr);\n if (element.ariaHidden === 'true' || (hasTabIndex && tabIndex < 0)) {\n return false;\n }\n if (hasTabIndex && tabIndex >= 0) {\n return true;\n }\n\n // without this jest fails here for some reason\n let htmlElement:\n | HTMLAnchorElement\n | HTMLInputElement\n | HTMLSelectElement\n | HTMLTextAreaElement\n | HTMLButtonElement;\n switch (true) {\n case element instanceof HTMLAnchorElement:\n htmlElement = element as HTMLAnchorElement;\n return Boolean(htmlElement.href);\n case element instanceof HTMLInputElement:\n htmlElement = element as HTMLInputElement;\n return htmlElement.type !== 'hidden' && !htmlElement.disabled;\n case element instanceof HTMLSelectElement:\n case element instanceof HTMLTextAreaElement:\n case element instanceof HTMLButtonElement:\n htmlElement = element as HTMLSelectElement | HTMLTextAreaElement | HTMLButtonElement;\n return !htmlElement.disabled;\n default:\n return false;\n }\n};\n\nexport function getSlidesToShowWithDefaults({\n contentLength,\n breakpoints,\n mobileFullscreen,\n}: GetSlidesToShowParams) {\n let result;\n\n if (typeof breakpoints === 'number') {\n result = Object.keys(DEFAULT_SLIDE_BREAKPOINTS).reduce(\n (acc, breakpointName) => ({...acc, [breakpointName]: breakpoints}),\n {} as SliderBreakpointParams,\n );\n } else {\n result = breakpoints || DEFAULT_SLIDE_BREAKPOINTS;\n }\n\n return {\n ...DEFAULT_SLIDE_BREAKPOINTS,\n ...pickBy(result, (value) => !isNaN(value)),\n sm: !mobileFullscreen && contentLength > 1 ? DEFAULT_SLIDE_BREAKPOINTS.sm : 1,\n };\n}\n\nexport function getSliderResponsiveParams(breakpoints: SliderBreakpointParams) {\n return Object.entries(breakpoints).map(([breakpointName, slidesToShow]) => ({\n breakpoint: BREAKPOINTS[breakpointName as SliderBreakpointNames],\n settings: {slidesToShow},\n }));\n}\n\nexport function getSlidesCountByBreakpoint(\n breakpoint: number,\n breakpoints: SliderBreakpointParams,\n) {\n const breakpointName = BREAKPOINT_NAMES_BY_VALUES[breakpoint];\n\n return Math.floor(breakpoints[breakpointName]);\n}\n\nexport function getSlidesToShowCount(breakpoints: SliderBreakpointParams) {\n return Math.floor(Math.max(...Object.values(breakpoints)));\n}\n\nconst getRovingListItemId = (uniqId: string, index: number) =>\n `${uniqId}-roving-tabindex-item-${index}`;\nexport function useRovingTabIndex(props: {\n itemCount: number;\n activeIndex: number;\n firstIndex?: number;\n uniqId: string;\n}) {\n const {itemCount, activeIndex, firstIndex = 0, uniqId} = props;\n const [currentIndex, setCurrentIndex] = React.useState(firstIndex);\n const hasFocusRef = React.useRef(false);\n const lastIndex = itemCount + firstIndex - 1;\n\n const getRovingItemProps = (\n index: number,\n ): Pick<React.HTMLAttributes<HTMLElement>, 'id' | 'tabIndex' | 'onFocus'> => {\n return {\n id: getRovingListItemId(uniqId, index),\n tabIndex: index === activeIndex ? 0 : -1,\n onFocus: () => {\n setCurrentIndex(index);\n hasFocusRef.current = true;\n },\n };\n };\n\n React.useEffect(() => {\n if (!hasFocusRef.current) {\n return;\n }\n document.getElementById(getRovingListItemId(uniqId, currentIndex))?.focus();\n }, [activeIndex, currentIndex, uniqId]);\n\n const setNextIndex = () =>\n setCurrentIndex((prev: number) => (prev >= lastIndex ? firstIndex : prev + 1));\n const setPrevIndex = () =>\n setCurrentIndex((prev: number) => (prev <= firstIndex ? lastIndex : prev - 1));\n\n const onRovingListKeyDown: React.KeyboardEventHandler<HTMLElement> = (e) => {\n const key = e.key.toLowerCase();\n\n if (key !== 'tab' && key !== 'enter') {\n e.preventDefault();\n }\n\n switch (key) {\n case 'arrowleft':\n case 'arrowup':\n setPrevIndex();\n return;\n case 'arrowright':\n case 'arrowdown':\n setNextIndex();\n return;\n }\n };\n\n const onRovingListBlur: React.FocusEventHandler<HTMLElement> = () => {\n hasFocusRef.current = false;\n };\n\n const rovingListProps: React.HTMLAttributes<HTMLElement> = {\n onKeyDown: onRovingListKeyDown,\n onBlur: onRovingListBlur,\n };\n\n return {getRovingItemProps, rovingListProps};\n}\n"]}
@@ -1,10 +1,10 @@
1
- .pc-table-block__title {
1
+ .pc-table-block__title.pc-table-block__title {
2
2
  margin: 0;
3
3
  }
4
4
 
5
5
  /* use this for style redefinitions to awoid problems with
6
6
  unpredictable css rules order in build */
7
- .pc-table-block__title {
7
+ .pc-table-block__title.pc-table-block__title {
8
8
  font-size: var(--g-text-display-2-font-size);
9
9
  line-height: var(--g-text-display-2-line-height);
10
10
  color: var(--pc-text-header-color);
@@ -14,11 +14,12 @@ unpredictable css rules order in build */
14
14
  margin-right: 32px;
15
15
  }
16
16
  @media (max-width: 576px) {
17
- .pc-table-block__title {
17
+ .pc-table-block__title.pc-table-block__title {
18
18
  font-size: var(--g-text-display-1-font-size);
19
19
  line-height: var(--g-text-display-1-line-height);
20
20
  }
21
21
  }
22
+
22
23
  .pc-table-block__table {
23
24
  margin-top: 0;
24
25
  }
@@ -8,7 +8,9 @@ const utils_1 = require("../../utils/index.js");
8
8
  const b = (0, utils_1.block)('table-block');
9
9
  const TableBlock = (props) => {
10
10
  const { title, table } = props;
11
- return ((0, jsx_runtime_1.jsx)("div", { className: b(), children: (0, jsx_runtime_1.jsx)(grid_1.Grid, { className: b('content'), children: (0, jsx_runtime_1.jsxs)(grid_1.Row, { className: b('row'), children: [(0, jsx_runtime_1.jsx)(grid_1.Col, { sizes: { [grid_1.GridColumnSize.Md]: 4, [grid_1.GridColumnSize.All]: 12 }, children: (0, jsx_runtime_1.jsx)("h2", { className: b('title'), children: title }) }), (0, jsx_runtime_1.jsx)(grid_1.Col, { sizes: { [grid_1.GridColumnSize.Md]: 8, [grid_1.GridColumnSize.All]: 12 }, children: (0, jsx_runtime_1.jsx)(components_1.Table, { className: b('table'), ...table }) })] }) }) }));
11
+ return ((0, jsx_runtime_1.jsx)("div", { className: b(), children: (0, jsx_runtime_1.jsx)(grid_1.Grid, { className: b('content'), children: (0, jsx_runtime_1.jsxs)(grid_1.Row, { className: b('row'), children: [(0, jsx_runtime_1.jsx)(grid_1.Col, { sizes: { [grid_1.GridColumnSize.Md]: 4, [grid_1.GridColumnSize.All]: 12 }, children: (0, jsx_runtime_1.jsx)(components_1.YFMWrapper, { tagName: "h2", contentClassName: b('title'), content: title, modifiers: {
12
+ constructor: true,
13
+ } }) }), (0, jsx_runtime_1.jsx)(grid_1.Col, { sizes: { [grid_1.GridColumnSize.Md]: 8, [grid_1.GridColumnSize.All]: 12 }, children: (0, jsx_runtime_1.jsx)(components_1.Table, { className: b('table'), ...table }) })] }) }) }));
12
14
  };
13
15
  exports.TableBlock = TableBlock;
14
16
  exports.default = exports.TableBlock;
@@ -1 +1 @@
1
- {"version":3,"file":"Table.js","sourceRoot":"../../../../src","sources":["blocks/Table/Table.tsx"],"names":[],"mappings":";;;;AAAA,0DAAuC;AACvC,8CAA0D;AAE1D,gDAAkC;AAIlC,MAAM,CAAC,GAAG,IAAA,aAAK,EAAC,aAAa,CAAC,CAAC;AAExB,MAAM,UAAU,GAAG,CAAC,KAAsB,EAAE,EAAE;IACjD,MAAM,EAAC,KAAK,EAAE,KAAK,EAAC,GAAG,KAAK,CAAC;IAE7B,OAAO,CACH,gCAAK,SAAS,EAAE,CAAC,EAAE,YACf,uBAAC,WAAI,IAAC,SAAS,EAAE,CAAC,CAAC,SAAS,CAAC,YACzB,wBAAC,UAAG,IAAC,SAAS,EAAE,CAAC,CAAC,KAAK,CAAC,aACpB,uBAAC,UAAG,IAAC,KAAK,EAAE,EAAC,CAAC,qBAAc,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,qBAAc,CAAC,GAAG,CAAC,EAAE,EAAE,EAAC,YAC1D,+BAAI,SAAS,EAAE,CAAC,CAAC,OAAO,CAAC,YAAG,KAAK,GAAM,GACrC,EACN,uBAAC,UAAG,IAAC,KAAK,EAAE,EAAC,CAAC,qBAAc,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,qBAAc,CAAC,GAAG,CAAC,EAAE,EAAE,EAAC,YAC1D,uBAAC,kBAAK,IAAC,SAAS,EAAE,CAAC,CAAC,OAAO,CAAC,KAAM,KAAK,GAAI,GACzC,IACJ,GACH,GACL,CACT,CAAC;AACN,CAAC,CAAC;AAjBW,QAAA,UAAU,cAiBrB;AAEF,kBAAe,kBAAU,CAAC","sourcesContent":["import {Table} from '../../components';\nimport {Col, Grid, GridColumnSize, Row} from '../../grid';\nimport {TableBlockProps} from '../../models';\nimport {block} from '../../utils';\n\nimport './Table.scss';\n\nconst b = block('table-block');\n\nexport const TableBlock = (props: TableBlockProps) => {\n const {title, table} = props;\n\n return (\n <div className={b()}>\n <Grid className={b('content')}>\n <Row className={b('row')}>\n <Col sizes={{[GridColumnSize.Md]: 4, [GridColumnSize.All]: 12}}>\n <h2 className={b('title')}>{title}</h2>\n </Col>\n <Col sizes={{[GridColumnSize.Md]: 8, [GridColumnSize.All]: 12}}>\n <Table className={b('table')} {...table} />\n </Col>\n </Row>\n </Grid>\n </div>\n );\n};\n\nexport default TableBlock;\n"]}
1
+ {"version":3,"file":"Table.js","sourceRoot":"../../../../src","sources":["blocks/Table/Table.tsx"],"names":[],"mappings":";;;;AAAA,0DAAmD;AACnD,8CAA0D;AAE1D,gDAAkC;AAIlC,MAAM,CAAC,GAAG,IAAA,aAAK,EAAC,aAAa,CAAC,CAAC;AAExB,MAAM,UAAU,GAAG,CAAC,KAAsB,EAAE,EAAE;IACjD,MAAM,EAAC,KAAK,EAAE,KAAK,EAAC,GAAG,KAAK,CAAC;IAE7B,OAAO,CACH,gCAAK,SAAS,EAAE,CAAC,EAAE,YACf,uBAAC,WAAI,IAAC,SAAS,EAAE,CAAC,CAAC,SAAS,CAAC,YACzB,wBAAC,UAAG,IAAC,SAAS,EAAE,CAAC,CAAC,KAAK,CAAC,aACpB,uBAAC,UAAG,IAAC,KAAK,EAAE,EAAC,CAAC,qBAAc,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,qBAAc,CAAC,GAAG,CAAC,EAAE,EAAE,EAAC,YAC1D,uBAAC,uBAAU,IACP,OAAO,EAAC,IAAI,EACZ,gBAAgB,EAAE,CAAC,CAAC,OAAO,CAAC,EAC5B,OAAO,EAAE,KAAK,EACd,SAAS,EAAE;gCACP,WAAW,EAAE,IAAI;6BACpB,GACH,GACA,EACN,uBAAC,UAAG,IAAC,KAAK,EAAE,EAAC,CAAC,qBAAc,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,qBAAc,CAAC,GAAG,CAAC,EAAE,EAAE,EAAC,YAC1D,uBAAC,kBAAK,IAAC,SAAS,EAAE,CAAC,CAAC,OAAO,CAAC,KAAM,KAAK,GAAI,GACzC,IACJ,GACH,GACL,CACT,CAAC;AACN,CAAC,CAAC;AAxBW,QAAA,UAAU,cAwBrB;AAEF,kBAAe,kBAAU,CAAC","sourcesContent":["import {Table, YFMWrapper} from '../../components';\nimport {Col, Grid, GridColumnSize, Row} from '../../grid';\nimport {TableBlockProps} from '../../models';\nimport {block} from '../../utils';\n\nimport './Table.scss';\n\nconst b = block('table-block');\n\nexport const TableBlock = (props: TableBlockProps) => {\n const {title, table} = props;\n\n return (\n <div className={b()}>\n <Grid className={b('content')}>\n <Row className={b('row')}>\n <Col sizes={{[GridColumnSize.Md]: 4, [GridColumnSize.All]: 12}}>\n <YFMWrapper\n tagName=\"h2\"\n contentClassName={b('title')}\n content={title}\n modifiers={{\n constructor: true,\n }}\n />\n </Col>\n <Col sizes={{[GridColumnSize.Md]: 8, [GridColumnSize.All]: 12}}>\n <Table className={b('table')} {...table} />\n </Col>\n </Row>\n </Grid>\n </div>\n );\n};\n\nexport default TableBlock;\n"]}
@@ -3,7 +3,9 @@ export { default as CompaniesBlock } from "./Companies/Companies.js";
3
3
  export { default as InfoBlock } from "./Info/Info.js";
4
4
  export { default as MediaBlock } from "./Media/Media.js";
5
5
  export { default as MapBlock } from "./Map/Map.js";
6
+ export { default as SliderOldBlock } from "./SliderOld/SliderOld.js";
6
7
  export { default as SliderBlock } from "./Slider/Slider.js";
8
+ export type { Swiper, SwiperOptions } from "./Slider/Slider.js";
7
9
  export { default as ExtendedFeaturesBlock } from "./ExtendedFeatures/ExtendedFeatures.js";
8
10
  export { default as PromoFeaturesBlock } from "./PromoFeaturesBlock/PromoFeaturesBlock.js";
9
11
  export { default as QuestionsBlock } from "./Questions/Questions.js";
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.FormBlock = exports.FilterBlock = exports.ShareBlock = exports.ContentLayoutBlock = exports.CardLayoutBlock = exports.HeaderSliderBlock = exports.IconsBlock = exports.HeaderBlock = exports.TabsBlock = exports.TableBlock = exports.FoldableListBlock = exports.QuestionsBlock = exports.PromoFeaturesBlock = exports.ExtendedFeaturesBlock = exports.SliderBlock = exports.MapBlock = exports.MediaBlock = exports.InfoBlock = exports.CompaniesBlock = exports.BannerBlock = void 0;
3
+ exports.FormBlock = exports.FilterBlock = exports.ShareBlock = exports.ContentLayoutBlock = exports.CardLayoutBlock = exports.HeaderSliderBlock = exports.IconsBlock = exports.HeaderBlock = exports.TabsBlock = exports.TableBlock = exports.FoldableListBlock = exports.QuestionsBlock = exports.PromoFeaturesBlock = exports.ExtendedFeaturesBlock = exports.SliderBlock = exports.SliderOldBlock = exports.MapBlock = exports.MediaBlock = exports.InfoBlock = exports.CompaniesBlock = exports.BannerBlock = void 0;
4
4
  const tslib_1 = require("tslib");
5
5
  var Banner_1 = require("./Banner/Banner.js");
6
6
  Object.defineProperty(exports, "BannerBlock", { enumerable: true, get: function () { return tslib_1.__importDefault(Banner_1).default; } });
@@ -12,6 +12,8 @@ var Media_1 = require("./Media/Media.js");
12
12
  Object.defineProperty(exports, "MediaBlock", { enumerable: true, get: function () { return tslib_1.__importDefault(Media_1).default; } });
13
13
  var Map_1 = require("./Map/Map.js");
14
14
  Object.defineProperty(exports, "MapBlock", { enumerable: true, get: function () { return tslib_1.__importDefault(Map_1).default; } });
15
+ var SliderOld_1 = require("./SliderOld/SliderOld.js");
16
+ Object.defineProperty(exports, "SliderOldBlock", { enumerable: true, get: function () { return tslib_1.__importDefault(SliderOld_1).default; } });
15
17
  var Slider_1 = require("./Slider/Slider.js");
16
18
  Object.defineProperty(exports, "SliderBlock", { enumerable: true, get: function () { return tslib_1.__importDefault(Slider_1).default; } });
17
19
  var ExtendedFeatures_1 = require("./ExtendedFeatures/ExtendedFeatures.js");
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"../../../src","sources":["blocks/index.ts"],"names":[],"mappings":";;;;AAAA,6CAAuD;AAA/C,8HAAA,OAAO,OAAe;AAC9B,sDAAgE;AAAxD,oIAAA,OAAO,OAAkB;AACjC,uCAAiD;AAAzC,0HAAA,OAAO,OAAa;AAC5B,0CAAoD;AAA5C,4HAAA,OAAO,OAAc;AAC7B,oCAA8C;AAAtC,wHAAA,OAAO,OAAY;AAC3B,6CAAuD;AAA/C,8HAAA,OAAO,OAAe;AAC9B,2EAAqF;AAA7E,kJAAA,OAAO,OAAyB;AACxC,iFAAsF;AAA9E,iJAAA,OAAO,OAAsB;AACrC,sDAAgE;AAAxD,oIAAA,OAAO,OAAkB;AACjC,+DAAyE;AAAjE,0IAAA,OAAO,OAAqB;AACpC,0CAAoD;AAA5C,4HAAA,OAAO,OAAc;AAC7B,uCAAiD;AAAzC,0HAAA,OAAO,OAAa;AAC5B,6CAAuD;AAA/C,8HAAA,OAAO,OAAe;AAC9B,0CAAoD;AAA5C,4HAAA,OAAO,OAAc;AAC7B,+DAAyE;AAAjE,0IAAA,OAAO,OAAqB;AACpC,yDAAmE;AAA3D,sIAAA,OAAO,OAAmB;AAClC,kEAA4E;AAApE,4IAAA,OAAO,OAAsB;AACrC,0CAAoD;AAA5C,4HAAA,OAAO,OAAc;AAC7B,4DAAiE;AAAzD,mIAAA,OAAO,OAAe;AAC9B,uCAAiD;AAAzC,0HAAA,OAAO,OAAa","sourcesContent":["export {default as BannerBlock} from './Banner/Banner';\nexport {default as CompaniesBlock} from './Companies/Companies';\nexport {default as InfoBlock} from './Info/Info';\nexport {default as MediaBlock} from './Media/Media';\nexport {default as MapBlock} from './Map/Map';\nexport {default as SliderBlock} from './Slider/Slider';\nexport {default as ExtendedFeaturesBlock} from './ExtendedFeatures/ExtendedFeatures';\nexport {default as PromoFeaturesBlock} from './PromoFeaturesBlock/PromoFeaturesBlock';\nexport {default as QuestionsBlock} from './Questions/Questions';\nexport {default as FoldableListBlock} from './FoldableList/FoldableList';\nexport {default as TableBlock} from './Table/Table';\nexport {default as TabsBlock} from './Tabs/Tabs';\nexport {default as HeaderBlock} from './Header/Header';\nexport {default as IconsBlock} from './Icons/Icons';\nexport {default as HeaderSliderBlock} from './HeaderSlider/HeaderSlider';\nexport {default as CardLayoutBlock} from './CardLayout/CardLayout';\nexport {default as ContentLayoutBlock} from './ContentLayout/ContentLayout';\nexport {default as ShareBlock} from './Share/Share';\nexport {default as FilterBlock} from './FilterBlock/FilterBlock';\nexport {default as FormBlock} from './Form/Form';\n"]}
1
+ {"version":3,"file":"index.js","sourceRoot":"../../../src","sources":["blocks/index.ts"],"names":[],"mappings":";;;;AAAA,6CAAuD;AAA/C,8HAAA,OAAO,OAAe;AAC9B,sDAAgE;AAAxD,oIAAA,OAAO,OAAkB;AACjC,uCAAiD;AAAzC,0HAAA,OAAO,OAAa;AAC5B,0CAAoD;AAA5C,4HAAA,OAAO,OAAc;AAC7B,oCAA8C;AAAtC,wHAAA,OAAO,OAAY;AAC3B,sDAAgE;AAAxD,oIAAA,OAAO,OAAkB;AACjC,6CAAuD;AAA/C,8HAAA,OAAO,OAAe;AAE9B,2EAAqF;AAA7E,kJAAA,OAAO,OAAyB;AACxC,iFAAsF;AAA9E,iJAAA,OAAO,OAAsB;AACrC,sDAAgE;AAAxD,oIAAA,OAAO,OAAkB;AACjC,+DAAyE;AAAjE,0IAAA,OAAO,OAAqB;AACpC,0CAAoD;AAA5C,4HAAA,OAAO,OAAc;AAC7B,uCAAiD;AAAzC,0HAAA,OAAO,OAAa;AAC5B,6CAAuD;AAA/C,8HAAA,OAAO,OAAe;AAC9B,0CAAoD;AAA5C,4HAAA,OAAO,OAAc;AAC7B,+DAAyE;AAAjE,0IAAA,OAAO,OAAqB;AACpC,yDAAmE;AAA3D,sIAAA,OAAO,OAAmB;AAClC,kEAA4E;AAApE,4IAAA,OAAO,OAAsB;AACrC,0CAAoD;AAA5C,4HAAA,OAAO,OAAc;AAC7B,4DAAiE;AAAzD,mIAAA,OAAO,OAAe;AAC9B,uCAAiD;AAAzC,0HAAA,OAAO,OAAa","sourcesContent":["export {default as BannerBlock} from './Banner/Banner';\nexport {default as CompaniesBlock} from './Companies/Companies';\nexport {default as InfoBlock} from './Info/Info';\nexport {default as MediaBlock} from './Media/Media';\nexport {default as MapBlock} from './Map/Map';\nexport {default as SliderOldBlock} from './SliderOld/SliderOld';\nexport {default as SliderBlock} from './Slider/Slider';\nexport type {Swiper, SwiperOptions} from './Slider/Slider';\nexport {default as ExtendedFeaturesBlock} from './ExtendedFeatures/ExtendedFeatures';\nexport {default as PromoFeaturesBlock} from './PromoFeaturesBlock/PromoFeaturesBlock';\nexport {default as QuestionsBlock} from './Questions/Questions';\nexport {default as FoldableListBlock} from './FoldableList/FoldableList';\nexport {default as TableBlock} from './Table/Table';\nexport {default as TabsBlock} from './Tabs/Tabs';\nexport {default as HeaderBlock} from './Header/Header';\nexport {default as IconsBlock} from './Icons/Icons';\nexport {default as HeaderSliderBlock} from './HeaderSlider/HeaderSlider';\nexport {default as CardLayoutBlock} from './CardLayout/CardLayout';\nexport {default as ContentLayoutBlock} from './ContentLayout/ContentLayout';\nexport {default as ShareBlock} from './Share/Share';\nexport {default as FilterBlock} from './FilterBlock/FilterBlock';\nexport {default as FormBlock} from './Form/Form';\n"]}
@@ -10,6 +10,7 @@ export * from "./Info/schema.js";
10
10
  export * from "./Media/schema.js";
11
11
  export * from "./PromoFeaturesBlock/schema.js";
12
12
  export * from "./Questions/schema.js";
13
+ export * from "./SliderOld/schema.js";
13
14
  export * from "./Slider/schema.js";
14
15
  export * from "./Table/schema.js";
15
16
  export * from "./Share/schema.js";
@@ -13,6 +13,7 @@ tslib_1.__exportStar(require("./Info/schema.js"), exports);
13
13
  tslib_1.__exportStar(require("./Media/schema.js"), exports);
14
14
  tslib_1.__exportStar(require("./PromoFeaturesBlock/schema.js"), exports);
15
15
  tslib_1.__exportStar(require("./Questions/schema.js"), exports);
16
+ tslib_1.__exportStar(require("./SliderOld/schema.js"), exports);
16
17
  tslib_1.__exportStar(require("./Slider/schema.js"), exports);
17
18
  tslib_1.__exportStar(require("./Table/schema.js"), exports);
18
19
  tslib_1.__exportStar(require("./Share/schema.js"), exports);
@@ -1 +1 @@
1
- {"version":3,"file":"validators.js","sourceRoot":"../../../src","sources":["blocks/validators.ts"],"names":[],"mappings":";;;AAAA,6DAAgC;AAChC,iEAAoC;AACpC,gEAAmC;AACnC,oEAAuC;AACvC,uEAA0C;AAC1C,6DAAgC;AAChC,mEAAsC;AACtC,4DAA+B;AAC/B,2DAA8B;AAC9B,4DAA+B;AAC/B,yEAA4C;AAC5C,gEAAmC;AACnC,6DAAgC;AAChC,4DAA+B;AAC/B,4DAA+B","sourcesContent":["export * from './Banner/schema';\nexport * from './CardLayout/schema';\nexport * from './Companies/schema';\nexport * from './ContentLayout/schema';\nexport * from './ExtendedFeatures/schema';\nexport * from './Header/schema';\nexport * from './HeaderSlider/schema';\nexport * from './Icons/schema';\nexport * from './Info/schema';\nexport * from './Media/schema';\nexport * from './PromoFeaturesBlock/schema';\nexport * from './Questions/schema';\nexport * from './Slider/schema';\nexport * from './Table/schema';\nexport * from './Share/schema';\n"]}
1
+ {"version":3,"file":"validators.js","sourceRoot":"../../../src","sources":["blocks/validators.ts"],"names":[],"mappings":";;;AAAA,6DAAgC;AAChC,iEAAoC;AACpC,gEAAmC;AACnC,oEAAuC;AACvC,uEAA0C;AAC1C,6DAAgC;AAChC,mEAAsC;AACtC,4DAA+B;AAC/B,2DAA8B;AAC9B,4DAA+B;AAC/B,yEAA4C;AAC5C,gEAAmC;AACnC,gEAAmC;AACnC,6DAAgC;AAChC,4DAA+B;AAC/B,4DAA+B","sourcesContent":["export * from './Banner/schema';\nexport * from './CardLayout/schema';\nexport * from './Companies/schema';\nexport * from './ContentLayout/schema';\nexport * from './ExtendedFeatures/schema';\nexport * from './Header/schema';\nexport * from './HeaderSlider/schema';\nexport * from './Icons/schema';\nexport * from './Info/schema';\nexport * from './Media/schema';\nexport * from './PromoFeaturesBlock/schema';\nexport * from './Questions/schema';\nexport * from './SliderOld/schema';\nexport * from './Slider/schema';\nexport * from './Table/schema';\nexport * from './Share/schema';\n"]}
@@ -8,9 +8,9 @@ const Image_1 = tslib_1.__importDefault(require("../Image/Image.js"));
8
8
  exports.qaIdByDefault = 'background-image';
9
9
  const b = (0, utils_1.block)('storage-background-image');
10
10
  const BackgroundImage = (props) => {
11
- const { children, src, desktop, className, imageClassName, style, qa } = props;
11
+ const { children, src, desktop, className, imageClassName, style, hide, qa } = props;
12
12
  const qaAttributes = (0, utils_1.getQaAttrubutes)(qa || exports.qaIdByDefault);
13
- return ((0, jsx_runtime_1.jsxs)("div", { className: b(null, className), style: style, "data-qa": qa || exports.qaIdByDefault, children: [(src || desktop) && ((0, jsx_runtime_1.jsx)(Image_1.default, { ...props, className: b('img', imageClassName), qa: qaAttributes.image })), children && (0, jsx_runtime_1.jsx)("div", { className: b('container'), children: children })] }));
13
+ return ((0, jsx_runtime_1.jsxs)("div", { className: b(null, className), style: style, "data-qa": qa || exports.qaIdByDefault, children: [(src || desktop) && !hide && ((0, jsx_runtime_1.jsx)(Image_1.default, { ...props, className: b('img', imageClassName), qa: qaAttributes.image })), children && (0, jsx_runtime_1.jsx)("div", { className: b('container'), children: children })] }));
14
14
  };
15
15
  exports.default = BackgroundImage;
16
16
  //# sourceMappingURL=BackgroundImage.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"BackgroundImage.js","sourceRoot":"../../../../src","sources":["components/BackgroundImage/BackgroundImage.tsx"],"names":[],"mappings":";;;;;AAGA,gDAAmD;AACnD,sEAAmC;AAItB,QAAA,aAAa,GAAG,kBAAkB,CAAC;AAEhD,MAAM,CAAC,GAAG,IAAA,aAAK,EAAC,0BAA0B,CAAC,CAAC;AAE5C,MAAM,eAAe,GAAG,CAAC,KAAoD,EAAE,EAAE;IAC7E,MAAM,EAAC,QAAQ,EAAE,GAAG,EAAE,OAAO,EAAE,SAAS,EAAE,cAAc,EAAE,KAAK,EAAE,EAAE,EAAC,GAAG,KAAK,CAAC;IAC7E,MAAM,YAAY,GAAG,IAAA,uBAAe,EAAC,EAAE,IAAI,qBAAa,CAAC,CAAC;IAE1D,OAAO,CACH,iCAAK,SAAS,EAAE,CAAC,CAAC,IAAI,EAAE,SAAS,CAAC,EAAE,KAAK,EAAE,KAAK,aAAW,EAAE,IAAI,qBAAa,aACzE,CAAC,GAAG,IAAI,OAAO,CAAC,IAAI,CACjB,uBAAC,eAAK,OAAK,KAAK,EAAE,SAAS,EAAE,CAAC,CAAC,KAAK,EAAE,cAAc,CAAC,EAAE,EAAE,EAAE,YAAY,CAAC,KAAK,GAAI,CACpF,EACA,QAAQ,IAAI,gCAAK,SAAS,EAAE,CAAC,CAAC,WAAW,CAAC,YAAG,QAAQ,GAAO,IAC3D,CACT,CAAC;AACN,CAAC,CAAC;AAEF,kBAAe,eAAe,CAAC","sourcesContent":["import * as React from 'react';\n\nimport {BackgroundImageProps} from '../../models';\nimport {block, getQaAttrubutes} from '../../utils';\nimport Image from '../Image/Image';\n\nimport './BackgroundImage.scss';\n\nexport const qaIdByDefault = 'background-image';\n\nconst b = block('storage-background-image');\n\nconst BackgroundImage = (props: React.PropsWithChildren<BackgroundImageProps>) => {\n const {children, src, desktop, className, imageClassName, style, qa} = props;\n const qaAttributes = getQaAttrubutes(qa || qaIdByDefault);\n\n return (\n <div className={b(null, className)} style={style} data-qa={qa || qaIdByDefault}>\n {(src || desktop) && (\n <Image {...props} className={b('img', imageClassName)} qa={qaAttributes.image} />\n )}\n {children && <div className={b('container')}>{children}</div>}\n </div>\n );\n};\n\nexport default BackgroundImage;\n"]}
1
+ {"version":3,"file":"BackgroundImage.js","sourceRoot":"../../../../src","sources":["components/BackgroundImage/BackgroundImage.tsx"],"names":[],"mappings":";;;;;AAGA,gDAAmD;AACnD,sEAAmC;AAItB,QAAA,aAAa,GAAG,kBAAkB,CAAC;AAEhD,MAAM,CAAC,GAAG,IAAA,aAAK,EAAC,0BAA0B,CAAC,CAAC;AAE5C,MAAM,eAAe,GAAG,CAAC,KAAoD,EAAE,EAAE;IAC7E,MAAM,EAAC,QAAQ,EAAE,GAAG,EAAE,OAAO,EAAE,SAAS,EAAE,cAAc,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE,EAAC,GAAG,KAAK,CAAC;IACnF,MAAM,YAAY,GAAG,IAAA,uBAAe,EAAC,EAAE,IAAI,qBAAa,CAAC,CAAC;IAE1D,OAAO,CACH,iCAAK,SAAS,EAAE,CAAC,CAAC,IAAI,EAAE,SAAS,CAAC,EAAE,KAAK,EAAE,KAAK,aAAW,EAAE,IAAI,qBAAa,aACzE,CAAC,GAAG,IAAI,OAAO,CAAC,IAAI,CAAC,IAAI,IAAI,CAC1B,uBAAC,eAAK,OAAK,KAAK,EAAE,SAAS,EAAE,CAAC,CAAC,KAAK,EAAE,cAAc,CAAC,EAAE,EAAE,EAAE,YAAY,CAAC,KAAK,GAAI,CACpF,EACA,QAAQ,IAAI,gCAAK,SAAS,EAAE,CAAC,CAAC,WAAW,CAAC,YAAG,QAAQ,GAAO,IAC3D,CACT,CAAC;AACN,CAAC,CAAC;AAEF,kBAAe,eAAe,CAAC","sourcesContent":["import * as React from 'react';\n\nimport {BackgroundImageProps} from '../../models';\nimport {block, getQaAttrubutes} from '../../utils';\nimport Image from '../Image/Image';\n\nimport './BackgroundImage.scss';\n\nexport const qaIdByDefault = 'background-image';\n\nconst b = block('storage-background-image');\n\nconst BackgroundImage = (props: React.PropsWithChildren<BackgroundImageProps>) => {\n const {children, src, desktop, className, imageClassName, style, hide, qa} = props;\n const qaAttributes = getQaAttrubutes(qa || qaIdByDefault);\n\n return (\n <div className={b(null, className)} style={style} data-qa={qa || qaIdByDefault}>\n {(src || desktop) && !hide && (\n <Image {...props} className={b('img', imageClassName)} qa={qaAttributes.image} />\n )}\n {children && <div className={b('container')}>{children}</div>}\n </div>\n );\n};\n\nexport default BackgroundImage;\n"]}
@@ -28,7 +28,11 @@ unpredictable css rules order in build */
28
28
  margin-bottom: 2px;
29
29
  margin-right: 8px;
30
30
  }
31
- .pc-content-list_size_l .pc-content-list__item_without-title .pc-content-list__text, .pc-content-list_size_m .pc-content-list__item_without-title .pc-content-list__text {
31
+ .pc-content-list_size_l .pc-content-list__text, .pc-content-list_size_m .pc-content-list__text {
32
+ font-size: var(--g-text-subheader-2-font-size);
33
+ line-height: var(--g-text-subheader-2-line-height);
34
+ }
35
+ .pc-content-list_size_l .pc-content-list__text_without-title, .pc-content-list_size_m .pc-content-list__text_without-title {
32
36
  font-size: var(--g-text-subheader-3-font-size);
33
37
  line-height: var(--g-text-subheader-3-line-height);
34
38
  }
@@ -47,10 +51,6 @@ unpredictable css rules order in build */
47
51
  margin-bottom: 2px;
48
52
  margin-right: 8px;
49
53
  }
50
- .pc-content-list_size_s .pc-content-list__text {
51
- font-size: var(--g-text-body-1-font-size);
52
- line-height: var(--g-text-body-1-line-height);
53
- }
54
54
  .pc-content-list_size_s .pc-content-list__item:not(:last-child) {
55
55
  margin-bottom: 12px;
56
56
  }
@@ -63,7 +63,11 @@ unpredictable css rules order in build */
63
63
  margin-top: 1px;
64
64
  margin-bottom: 1px;
65
65
  }
66
- .pc-content-list_size_s .pc-content-list__item_without-title .pc-content-list__text {
66
+ .pc-content-list_size_s .pc-content-list__text {
67
+ font-size: var(--g-text-body-1-font-size);
68
+ line-height: var(--g-text-body-1-line-height);
69
+ }
70
+ .pc-content-list_size_s .pc-content-list__text_without-title {
67
71
  font-size: var(--g-text-subheader-2-font-size);
68
72
  line-height: var(--g-text-subheader-2-line-height);
69
73
  }
@@ -23,7 +23,7 @@ const ContentList = ({ list, size = 'l', qa, theme }) => {
23
23
  return ((0, jsx_runtime_1.jsx)("div", { className: b({ size, theme }), "data-qa": qa, children: list?.map((item) => {
24
24
  const { icon, title, text } = item;
25
25
  return ((0, jsx_runtime_1.jsxs)("div", { className: b('item', { 'without-title': !title }), children: [(0, jsx_runtime_1.jsx)(ContentListItemIcon_1.default, { icon: icon, className: b('icon'), qa: qaAttributes.image }), (0, jsx_runtime_1.jsxs)("div", { children: [title &&
26
- React.createElement(getHeadingLevel(size), { className: b('title'), 'data-qa': qaAttributes.title }, (0, jsx_runtime_1.jsx)(YFMWrapper_1.default, { content: title, modifiers: { constructor: true } })), text && ((0, jsx_runtime_1.jsx)(YFMWrapper_1.default, { className: b('text'), content: text, modifiers: { constructor: true }, qa: qaAttributes.text }))] })] }, (0, uuid_1.v4)()));
26
+ React.createElement(getHeadingLevel(size), { className: b('title'), 'data-qa': qaAttributes.title }, (0, jsx_runtime_1.jsx)(YFMWrapper_1.default, { content: title, modifiers: { constructor: true } })), text && ((0, jsx_runtime_1.jsx)(YFMWrapper_1.default, { contentClassName: b('text', { 'without-title': !title }), content: text, modifiers: { constructor: true }, qa: qaAttributes.text }))] })] }, (0, uuid_1.v4)()));
27
27
  }) }));
28
28
  };
29
29
  exports.default = ContentList;
@@ -1 +1 @@
1
- {"version":3,"file":"ContentList.js","sourceRoot":"../../../../src","sources":["components/ContentList/ContentList.tsx"],"names":[],"mappings":";;;;AAAA,qDAA+B;AAE/B,+BAAkC;AAIlC,gDAAkC;AAClC,kDAAmD;AACnD,qFAAkD;AAElD,2FAA6C;AAI7C,MAAM,CAAC,GAAG,IAAA,aAAK,EAAC,cAAc,CAAC,CAAC;AAEhC,SAAS,eAAe,CAAC,IAAiB;IACtC,QAAQ,IAAI,EAAE,CAAC;QACX,KAAK,GAAG;YACJ,OAAO,IAAI,CAAC;QAChB,KAAK,GAAG,CAAC;QACT;YACI,OAAO,IAAI,CAAC;IACpB,CAAC;AACL,CAAC;AAED,MAAM,WAAW,GAAG,CAAC,EAAC,IAAI,EAAE,IAAI,GAAG,GAAG,EAAE,EAAE,EAAE,KAAK,EAA6B,EAAE,EAAE;IAC9E,MAAM,YAAY,GAAG,IAAA,wBAAe,EAAC,EAAE,EAAE,CAAC,OAAO,EAAE,OAAO,EAAE,MAAM,CAAC,CAAC,CAAC;IAErE,OAAO,CACH,gCAAK,SAAS,EAAE,CAAC,CAAC,EAAC,IAAI,EAAE,KAAK,EAAC,CAAC,aAAW,EAAE,YACxC,IAAI,EAAE,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE;YAChB,MAAM,EAAC,IAAI,EAAE,KAAK,EAAE,IAAI,EAAC,GAAG,IAAI,CAAC;YACjC,OAAO,CACH,iCAAK,SAAS,EAAE,CAAC,CAAC,MAAM,EAAE,EAAC,eAAe,EAAE,CAAC,KAAK,EAAC,CAAC,aAChD,uBAAC,6BAAQ,IAAC,IAAI,EAAE,IAAI,EAAE,SAAS,EAAE,CAAC,CAAC,MAAM,CAAC,EAAE,EAAE,EAAE,YAAY,CAAC,KAAK,GAAI,EACtE,4CACK,KAAK;gCACF,KAAK,CAAC,aAAa,CACf,eAAe,CAAC,IAAI,CAAC,EACrB,EAAC,SAAS,EAAE,CAAC,CAAC,OAAO,CAAC,EAAE,SAAS,EAAE,YAAY,CAAC,KAAK,EAAC,EACtD,uBAAC,oBAAU,IAAC,OAAO,EAAE,KAAK,EAAE,SAAS,EAAE,EAAC,WAAW,EAAE,IAAI,EAAC,GAAI,CACjE,EACJ,IAAI,IAAI,CACL,uBAAC,oBAAU,IACP,SAAS,EAAE,CAAC,CAAC,MAAM,CAAC,EACpB,OAAO,EAAE,IAAI,EACb,SAAS,EAAE,EAAC,WAAW,EAAE,IAAI,EAAC,EAC9B,EAAE,EAAE,YAAY,CAAC,IAAI,GACvB,CACL,IACC,KAjBiD,IAAA,SAAM,GAAE,CAkB7D,CACT,CAAC;QACN,CAAC,CAAC,GACA,CACT,CAAC;AACN,CAAC,CAAC;AAEF,kBAAe,WAAW,CAAC","sourcesContent":["import * as React from 'react';\n\nimport {v4 as uuidv4} from 'uuid';\n\nimport {ContentListProps, ContentSize} from '../../models';\nimport {QAProps} from '../../models/common';\nimport {block} from '../../utils';\nimport {getQaAttrubutes} from '../../utils/blocks';\nimport YFMWrapper from '../YFMWrapper/YFMWrapper';\n\nimport ItemIcon from './ContentListItemIcon';\n\nimport './ContentList.scss';\n\nconst b = block('content-list');\n\nfunction getHeadingLevel(size: ContentSize) {\n switch (size) {\n case 's':\n return 'h4';\n case 'l':\n default:\n return 'h3';\n }\n}\n\nconst ContentList = ({list, size = 'l', qa, theme}: ContentListProps & QAProps) => {\n const qaAttributes = getQaAttrubutes(qa, ['image', 'title', 'text']);\n\n return (\n <div className={b({size, theme})} data-qa={qa}>\n {list?.map((item) => {\n const {icon, title, text} = item;\n return (\n <div className={b('item', {'without-title': !title})} key={uuidv4()}>\n <ItemIcon icon={icon} className={b('icon')} qa={qaAttributes.image} />\n <div>\n {title &&\n React.createElement(\n getHeadingLevel(size),\n {className: b('title'), 'data-qa': qaAttributes.title},\n <YFMWrapper content={title} modifiers={{constructor: true}} />,\n )}\n {text && (\n <YFMWrapper\n className={b('text')}\n content={text}\n modifiers={{constructor: true}}\n qa={qaAttributes.text}\n />\n )}\n </div>\n </div>\n );\n })}\n </div>\n );\n};\n\nexport default ContentList;\n"]}
1
+ {"version":3,"file":"ContentList.js","sourceRoot":"../../../../src","sources":["components/ContentList/ContentList.tsx"],"names":[],"mappings":";;;;AAAA,qDAA+B;AAE/B,+BAAkC;AAIlC,gDAAkC;AAClC,kDAAmD;AACnD,qFAAkD;AAElD,2FAA6C;AAI7C,MAAM,CAAC,GAAG,IAAA,aAAK,EAAC,cAAc,CAAC,CAAC;AAEhC,SAAS,eAAe,CAAC,IAAiB;IACtC,QAAQ,IAAI,EAAE,CAAC;QACX,KAAK,GAAG;YACJ,OAAO,IAAI,CAAC;QAChB,KAAK,GAAG,CAAC;QACT;YACI,OAAO,IAAI,CAAC;IACpB,CAAC;AACL,CAAC;AAED,MAAM,WAAW,GAAG,CAAC,EAAC,IAAI,EAAE,IAAI,GAAG,GAAG,EAAE,EAAE,EAAE,KAAK,EAA6B,EAAE,EAAE;IAC9E,MAAM,YAAY,GAAG,IAAA,wBAAe,EAAC,EAAE,EAAE,CAAC,OAAO,EAAE,OAAO,EAAE,MAAM,CAAC,CAAC,CAAC;IAErE,OAAO,CACH,gCAAK,SAAS,EAAE,CAAC,CAAC,EAAC,IAAI,EAAE,KAAK,EAAC,CAAC,aAAW,EAAE,YACxC,IAAI,EAAE,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE;YAChB,MAAM,EAAC,IAAI,EAAE,KAAK,EAAE,IAAI,EAAC,GAAG,IAAI,CAAC;YACjC,OAAO,CACH,iCAAK,SAAS,EAAE,CAAC,CAAC,MAAM,EAAE,EAAC,eAAe,EAAE,CAAC,KAAK,EAAC,CAAC,aAChD,uBAAC,6BAAQ,IAAC,IAAI,EAAE,IAAI,EAAE,SAAS,EAAE,CAAC,CAAC,MAAM,CAAC,EAAE,EAAE,EAAE,YAAY,CAAC,KAAK,GAAI,EACtE,4CACK,KAAK;gCACF,KAAK,CAAC,aAAa,CACf,eAAe,CAAC,IAAI,CAAC,EACrB,EAAC,SAAS,EAAE,CAAC,CAAC,OAAO,CAAC,EAAE,SAAS,EAAE,YAAY,CAAC,KAAK,EAAC,EACtD,uBAAC,oBAAU,IAAC,OAAO,EAAE,KAAK,EAAE,SAAS,EAAE,EAAC,WAAW,EAAE,IAAI,EAAC,GAAI,CACjE,EACJ,IAAI,IAAI,CACL,uBAAC,oBAAU,IACP,gBAAgB,EAAE,CAAC,CAAC,MAAM,EAAE,EAAC,eAAe,EAAE,CAAC,KAAK,EAAC,CAAC,EACtD,OAAO,EAAE,IAAI,EACb,SAAS,EAAE,EAAC,WAAW,EAAE,IAAI,EAAC,EAC9B,EAAE,EAAE,YAAY,CAAC,IAAI,GACvB,CACL,IACC,KAjBiD,IAAA,SAAM,GAAE,CAkB7D,CACT,CAAC;QACN,CAAC,CAAC,GACA,CACT,CAAC;AACN,CAAC,CAAC;AAEF,kBAAe,WAAW,CAAC","sourcesContent":["import * as React from 'react';\n\nimport {v4 as uuidv4} from 'uuid';\n\nimport {ContentListProps, ContentSize} from '../../models';\nimport {QAProps} from '../../models/common';\nimport {block} from '../../utils';\nimport {getQaAttrubutes} from '../../utils/blocks';\nimport YFMWrapper from '../YFMWrapper/YFMWrapper';\n\nimport ItemIcon from './ContentListItemIcon';\n\nimport './ContentList.scss';\n\nconst b = block('content-list');\n\nfunction getHeadingLevel(size: ContentSize) {\n switch (size) {\n case 's':\n return 'h4';\n case 'l':\n default:\n return 'h3';\n }\n}\n\nconst ContentList = ({list, size = 'l', qa, theme}: ContentListProps & QAProps) => {\n const qaAttributes = getQaAttrubutes(qa, ['image', 'title', 'text']);\n\n return (\n <div className={b({size, theme})} data-qa={qa}>\n {list?.map((item) => {\n const {icon, title, text} = item;\n return (\n <div className={b('item', {'without-title': !title})} key={uuidv4()}>\n <ItemIcon icon={icon} className={b('icon')} qa={qaAttributes.image} />\n <div>\n {title &&\n React.createElement(\n getHeadingLevel(size),\n {className: b('title'), 'data-qa': qaAttributes.title},\n <YFMWrapper content={title} modifiers={{constructor: true}} />,\n )}\n {text && (\n <YFMWrapper\n contentClassName={b('text', {'without-title': !title})}\n content={text}\n modifiers={{constructor: true}}\n qa={qaAttributes.text}\n />\n )}\n </div>\n </div>\n );\n })}\n </div>\n );\n};\n\nexport default ContentList;\n"]}
@@ -6,12 +6,31 @@ unpredictable css rules order in build */
6
6
  .pc-fullscreen-image__image-wrapper {
7
7
  position: relative;
8
8
  }
9
- .pc-fullscreen-image__image-wrapper:hover .pc-fullscreen-image__icon-wrapper {
9
+ .pc-fullscreen-image__image-wrapper:hover .pc-fullscreen-image__expand-icon-wrapper {
10
10
  opacity: 1;
11
11
  }
12
12
  .pc-fullscreen-image__modal-content {
13
13
  position: relative;
14
14
  border-radius: var(--pc-border-radius);
15
+ width: 100%;
16
+ }
17
+ .pc-fullscreen-image__modal-content-wrapper {
18
+ width: 100%;
19
+ }
20
+ .pc-fullscreen-image__modal-content_loaded {
21
+ max-width: fit-content;
22
+ }
23
+ .pc-fullscreen-image__modal_with-slider .g-modal__content-wrapper {
24
+ width: 100%;
25
+ height: 100vh;
26
+ margin: 0;
27
+ justify-content: center;
28
+ }
29
+ .pc-fullscreen-image__modal_with-slider .pc-fullscreen-image__modal-content {
30
+ background-color: transparent;
31
+ }
32
+ .pc-fullscreen-image__modal_with-slider .pc-fullscreen-image__modal-content:hover .pc-fullscreen-image__expand-icon-wrapper, .pc-fullscreen-image__modal_with-slider .pc-fullscreen-image__modal-content:hover .pc-fullscreen-image__close-icon-wrapper {
33
+ opacity: 1;
15
34
  }
16
35
  .pc-fullscreen-image__modal-image {
17
36
  display: block;
@@ -19,10 +38,32 @@ unpredictable css rules order in build */
19
38
  max-height: 70vh;
20
39
  overflow: hidden;
21
40
  }
41
+ .pc-fullscreen-image__modal-slider {
42
+ max-width: 100vw;
43
+ width: 100%;
44
+ height: 100vh;
45
+ }
46
+ .pc-fullscreen-image__modal-slider_item {
47
+ height: 100%;
48
+ display: flex;
49
+ justify-content: center;
50
+ align-items: center;
51
+ }
52
+ .pc-fullscreen-image__modal-slider_item-image {
53
+ display: block;
54
+ margin: auto;
55
+ border-radius: var(--pc-border-radius);
56
+ overflow: hidden;
57
+ margin-top: 40px;
58
+ max-height: calc(100vh - 120px);
59
+ max-width: 100%;
60
+ object-fit: contain;
61
+ object-position: center;
62
+ }
22
63
  .pc-fullscreen-image__modal .g-modal__content, .pc-fullscreen-image__modal-image {
23
64
  border-radius: var(--pc-border-radius);
24
65
  }
25
- .pc-fullscreen-image__icon-wrapper {
66
+ .pc-fullscreen-image__expand-icon-wrapper {
26
67
  display: inline-block;
27
68
  margin: 0;
28
69
  padding: 0;
@@ -35,9 +76,48 @@ unpredictable css rules order in build */
35
76
  display: flex;
36
77
  align-items: center;
37
78
  justify-content: center;
79
+ width: 36px;
80
+ height: 36px;
81
+ border-radius: 8px;
82
+ background-color: var(--g-color-base-simple-hover-solid);
83
+ cursor: pointer;
84
+ opacity: 0;
85
+ transition: 0.3s;
38
86
  position: absolute;
39
87
  right: 16px;
40
88
  top: 16px;
89
+ }
90
+ .pc-fullscreen-image__expand-icon-wrapper:focus {
91
+ outline: 2px solid var(--g-color-line-focus);
92
+ outline-offset: 0;
93
+ }
94
+ .pc-fullscreen-image__expand-icon-wrapper:focus:not(:focus-visible) {
95
+ outline: 0;
96
+ }
97
+ .pc-fullscreen-image__expand-icon-wrapper:focus {
98
+ opacity: 1;
99
+ }
100
+ @media (max-width: 769px) {
101
+ .pc-fullscreen-image__expand-icon-wrapper {
102
+ opacity: 1;
103
+ }
104
+ }
105
+ .pc-fullscreen-image__expand-icon-wrapper_visible {
106
+ opacity: 1;
107
+ }
108
+ .pc-fullscreen-image__close-icon-wrapper {
109
+ display: inline-block;
110
+ margin: 0;
111
+ padding: 0;
112
+ font: inherit;
113
+ border: none;
114
+ outline: none;
115
+ color: inherit;
116
+ background: none;
117
+ cursor: pointer;
118
+ display: flex;
119
+ align-items: center;
120
+ justify-content: center;
41
121
  width: 36px;
42
122
  height: 36px;
43
123
  border-radius: 8px;
@@ -45,36 +125,37 @@ unpredictable css rules order in build */
45
125
  cursor: pointer;
46
126
  opacity: 0;
47
127
  transition: 0.3s;
128
+ z-index: 1001;
129
+ position: absolute;
130
+ right: 24px;
131
+ top: 24px;
48
132
  }
49
- .pc-fullscreen-image__icon-wrapper:focus {
133
+ .pc-fullscreen-image__close-icon-wrapper:focus {
50
134
  outline: 2px solid var(--g-color-line-focus);
51
135
  outline-offset: 0;
52
136
  }
53
- .pc-fullscreen-image__icon-wrapper:focus:not(:focus-visible) {
137
+ .pc-fullscreen-image__close-icon-wrapper:focus:not(:focus-visible) {
54
138
  outline: 0;
55
139
  }
56
- .pc-fullscreen-image__icon-wrapper_visible {
140
+ .pc-fullscreen-image__close-icon-wrapper:focus {
57
141
  opacity: 1;
58
142
  }
143
+ @media (max-width: 769px) {
144
+ .pc-fullscreen-image__close-icon-wrapper {
145
+ opacity: 1;
146
+ }
147
+ }
59
148
  .pc-fullscreen-image__icon {
60
149
  color: var(--g-color-text-hint);
61
150
  }
62
151
  .pc-fullscreen-image__icon_hover:hover {
63
152
  color: var(--g-color-text-secondary);
64
153
  }
65
- @media (max-width: 1185px) {
66
- .pc-fullscreen-image__modal-image {
67
- width: 100%;
68
- }
69
- }
70
- @media (max-width: 1081px) {
71
- .pc-fullscreen-image__image {
72
- pointer-events: none;
73
- }
74
- .pc-fullscreen-image__icon-wrapper {
75
- display: none;
154
+ @media (max-width: 769px) {
155
+ .pc-fullscreen-image__modal .g-modal__content-wrapper {
156
+ margin: 8px;
76
157
  }
77
- .pc-fullscreen-image__modal {
78
- display: none !important; /* stylelint-disable-line declaration-no-important */
158
+ .pc-fullscreen-image__modal_with-slider .g-modal__content-wrapper {
159
+ margin: 0;
79
160
  }
80
161
  }
@@ -1,10 +1,15 @@
1
1
  import * as React from 'react';
2
+ import { ImageProps as ModelImageProps } from "../../models/index.js";
2
3
  import { ImageProps } from "../Image/Image.js";
3
4
  export interface FullscreenImageProps extends ImageProps {
4
5
  imageClassName?: string;
5
6
  modalImageClass?: string;
6
7
  imageStyle?: React.CSSProperties;
7
8
  extraProps?: React.HTMLProps<HTMLDivElement>;
9
+ sliderData?: {
10
+ items: ModelImageProps[];
11
+ initialIndex: number;
12
+ };
8
13
  }
9
14
  declare const FullscreenImage: (props: FullscreenImageProps) => import("react/jsx-runtime").JSX.Element;
10
15
  export default FullscreenImage;
@@ -5,18 +5,30 @@ const jsx_runtime_1 = require("react/jsx-runtime");
5
5
  const React = tslib_1.__importStar(require("react"));
6
6
  const icons_1 = require("@gravity-ui/icons");
7
7
  const uikit_1 = require("@gravity-ui/uikit");
8
+ const blocks_1 = require("../../blocks/index.js");
9
+ const models_1 = require("../../models/index.js");
8
10
  const utils_1 = require("../../utils/index.js");
9
11
  const Image_1 = tslib_1.__importDefault(require("../Image/Image.js"));
12
+ const utils_2 = require("../Media/Image/utils.js");
10
13
  const i18n_1 = require("./i18n/index.js");
11
14
  const b = (0, utils_1.block)('fullscreen-image');
12
15
  const FULL_SCREEN_ICON_SIZE = 18;
13
16
  const CLOSE_ICON_SIZE = 24;
14
17
  const FullscreenImage = (props) => {
15
- const { imageClassName, modalImageClass, imageStyle, alt = (0, i18n_1.i18n)('img-alt'), extraProps } = props;
18
+ const { imageClassName, sliderData, modalImageClass, imageStyle, alt = (0, i18n_1.i18n)('img-alt'), extraProps, } = props;
16
19
  const [isOpened, setIsOpened] = React.useState(false);
20
+ const [sliderLoaded, setSliderLoaded] = React.useState(false);
17
21
  const openModal = () => setIsOpened(true);
18
22
  const closeModal = () => setIsOpened(false);
19
- return ((0, jsx_runtime_1.jsxs)("div", { className: b(), ...extraProps, children: [(0, jsx_runtime_1.jsxs)("div", { className: b('image-wrapper'), children: [(0, jsx_runtime_1.jsx)(Image_1.default, { ...props, alt: alt, className: b('image', imageClassName), onClick: openModal, style: imageStyle }), (0, jsx_runtime_1.jsx)("button", { className: b('icon-wrapper'), onClick: openModal, children: (0, jsx_runtime_1.jsx)(uikit_1.Icon, { data: icons_1.ChevronsExpandUpRight, width: FULL_SCREEN_ICON_SIZE, height: FULL_SCREEN_ICON_SIZE, className: b('icon') }) })] }), isOpened && ((0, jsx_runtime_1.jsxs)(uikit_1.Modal, { open: isOpened, onClose: closeModal, className: b('modal'), contentClassName: b('modal-content'), children: [(0, jsx_runtime_1.jsx)("button", { className: b('icon-wrapper', { visible: true }), onClick: closeModal, "aria-label": (0, i18n_1.i18n)('close'), children: (0, jsx_runtime_1.jsx)(uikit_1.Icon, { data: icons_1.Xmark, width: CLOSE_ICON_SIZE, height: CLOSE_ICON_SIZE, className: b('icon', { hover: true }) }) }), (0, jsx_runtime_1.jsx)(Image_1.default, { ...props, className: b('modal-image', modalImageClass) })] }))] }));
23
+ React.useEffect(() => {
24
+ if (sliderData && !isOpened) {
25
+ setSliderLoaded(false);
26
+ }
27
+ }, [isOpened, sliderData]);
28
+ const handleSliderImageLoad = () => {
29
+ setSliderLoaded(true);
30
+ };
31
+ return ((0, jsx_runtime_1.jsxs)("div", { className: b(), ...extraProps, children: [(0, jsx_runtime_1.jsxs)("div", { className: b('image-wrapper'), children: [(0, jsx_runtime_1.jsx)(Image_1.default, { ...props, alt: alt, className: b('image', imageClassName), onClick: openModal, style: imageStyle }), (0, jsx_runtime_1.jsx)("button", { className: b('expand-icon-wrapper'), onClick: openModal, children: (0, jsx_runtime_1.jsx)(uikit_1.Icon, { data: icons_1.ChevronsExpandUpRight, width: FULL_SCREEN_ICON_SIZE, height: FULL_SCREEN_ICON_SIZE, className: b('icon') }) })] }), isOpened && ((0, jsx_runtime_1.jsxs)(uikit_1.Modal, { open: isOpened, onClose: closeModal, className: b('modal', { 'with-slider': Boolean(sliderData) }), contentClassName: b('modal-content', { loaded: sliderLoaded }), children: [(0, jsx_runtime_1.jsx)("button", { className: b('close-icon-wrapper', { visible: true }), onClick: closeModal, "aria-label": (0, i18n_1.i18n)('close'), children: (0, jsx_runtime_1.jsx)(uikit_1.Icon, { data: icons_1.Xmark, width: CLOSE_ICON_SIZE, height: CLOSE_ICON_SIZE, className: b('icon', { hover: true }) }) }), sliderData ? ((0, jsx_runtime_1.jsx)("div", { className: b('modal-slider'), children: (0, jsx_runtime_1.jsx)(blocks_1.SliderBlock, { initialSlide: sliderData.initialIndex, slidesToShow: 1, type: models_1.SliderType.FullscreenCard, children: sliderData.items.map((item, index) => ((0, jsx_runtime_1.jsx)("div", { className: b('modal-slider_item'), children: (0, jsx_runtime_1.jsx)(Image_1.default, { onLoad: handleSliderImageLoad, className: b('modal-slider_item-image', modalImageClass), containerClassName: b('modal-slider_item-image-wrapper'), ...(0, utils_2.getMediaImage)(item) }) }, index))) }) })) : ((0, jsx_runtime_1.jsx)(Image_1.default, { ...props, className: b('modal-image', modalImageClass) }))] }))] }));
20
32
  };
21
33
  exports.default = FullscreenImage;
22
34
  //# sourceMappingURL=FullscreenImage.js.map