@gravity-ui/page-constructor 6.0.0 → 7.0.0-beta.1

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 (347) hide show
  1. package/README.md +10 -0
  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.js +5 -1
  16. package/build/cjs/blocks/Share/Share.js.map +1 -1
  17. package/build/cjs/blocks/Slider/Arrow/Arrow.css +22 -21
  18. package/build/cjs/blocks/Slider/Arrow/Arrow.d.ts +4 -2
  19. package/build/cjs/blocks/Slider/Arrow/Arrow.js +1 -1
  20. package/build/cjs/blocks/Slider/Arrow/Arrow.js.map +1 -1
  21. package/build/cjs/blocks/Slider/Slider.css +549 -329
  22. package/build/cjs/blocks/Slider/Slider.d.ts +6 -5
  23. package/build/cjs/blocks/Slider/Slider.js +31 -271
  24. package/build/cjs/blocks/Slider/Slider.js.map +1 -1
  25. package/build/cjs/blocks/Slider/i18n/en.json +1 -1
  26. package/build/cjs/blocks/Slider/i18n/ru.json +1 -1
  27. package/build/cjs/blocks/Slider/models.d.ts +2 -2
  28. package/build/cjs/blocks/Slider/models.js +1 -1
  29. package/build/cjs/blocks/Slider/models.js.map +1 -1
  30. package/build/cjs/blocks/Slider/schema.d.ts +18 -1
  31. package/build/cjs/blocks/Slider/schema.js +9 -0
  32. package/build/cjs/blocks/Slider/schema.js.map +1 -1
  33. package/build/{esm/blocks/SliderNew → cjs/blocks/Slider}/useSlider.d.ts +1 -0
  34. package/build/cjs/blocks/{SliderNew → Slider}/useSlider.js +4 -0
  35. package/build/cjs/blocks/Slider/useSlider.js.map +1 -0
  36. package/build/cjs/blocks/Slider/useSliderPagination.js.map +1 -0
  37. package/build/cjs/blocks/Slider/utils.d.ts +7 -28
  38. package/build/cjs/blocks/Slider/utils.js +27 -109
  39. package/build/cjs/blocks/Slider/utils.js.map +1 -1
  40. package/build/cjs/blocks/{SliderNew → SliderOld}/Arrow/Arrow.css +15 -12
  41. package/build/cjs/blocks/SliderOld/Arrow/Arrow.d.ts +9 -0
  42. package/build/cjs/blocks/SliderOld/Arrow/Arrow.js +11 -0
  43. package/build/cjs/blocks/SliderOld/Arrow/Arrow.js.map +1 -0
  44. package/build/cjs/blocks/SliderOld/SliderOld.css +703 -0
  45. package/build/cjs/blocks/SliderOld/SliderOld.d.ts +17 -0
  46. package/build/cjs/blocks/SliderOld/SliderOld.js +292 -0
  47. package/build/cjs/blocks/SliderOld/SliderOld.js.map +1 -0
  48. package/build/cjs/blocks/{SliderNew → SliderOld}/i18n/en.json +1 -1
  49. package/build/cjs/blocks/{SliderNew → SliderOld}/i18n/index.d.ts +1 -1
  50. package/build/cjs/blocks/{SliderNew → SliderOld}/i18n/index.js +1 -1
  51. package/build/cjs/blocks/{SliderNew → SliderOld}/i18n/index.js.map +1 -1
  52. package/build/cjs/blocks/{SliderNew → SliderOld}/i18n/ru.json +1 -1
  53. package/build/cjs/blocks/{SliderNew → SliderOld}/models.d.ts +2 -2
  54. package/build/cjs/blocks/{SliderNew → SliderOld}/models.js +1 -1
  55. package/build/cjs/blocks/{SliderNew → SliderOld}/models.js.map +1 -1
  56. package/build/{esm/blocks/SliderNew → cjs/blocks/SliderOld}/schema.d.ts +5 -21
  57. package/build/cjs/blocks/{SliderNew → SliderOld}/schema.js +6 -14
  58. package/build/cjs/blocks/SliderOld/schema.js.map +1 -0
  59. package/build/cjs/blocks/SliderOld/utils.d.ts +37 -0
  60. package/build/cjs/blocks/SliderOld/utils.js +126 -0
  61. package/build/cjs/blocks/SliderOld/utils.js.map +1 -0
  62. package/build/cjs/blocks/Table/Table.css +4 -3
  63. package/build/cjs/blocks/Table/Table.js +3 -1
  64. package/build/cjs/blocks/Table/Table.js.map +1 -1
  65. package/build/cjs/blocks/index.d.ts +2 -0
  66. package/build/cjs/blocks/index.js +3 -1
  67. package/build/cjs/blocks/index.js.map +1 -1
  68. package/build/cjs/blocks/validators.d.ts +1 -0
  69. package/build/cjs/blocks/validators.js +1 -0
  70. package/build/cjs/blocks/validators.js.map +1 -1
  71. package/build/cjs/components/ContentList/ContentList.css +16 -12
  72. package/build/cjs/components/ContentList/ContentList.js +1 -1
  73. package/build/cjs/components/ContentList/ContentList.js.map +1 -1
  74. package/build/cjs/components/FileLink/FileLink.js +8 -1
  75. package/build/cjs/components/FileLink/FileLink.js.map +1 -1
  76. package/build/cjs/components/FullscreenImage/FullscreenImage.css +96 -18
  77. package/build/cjs/components/FullscreenImage/FullscreenImage.d.ts +5 -0
  78. package/build/cjs/components/FullscreenImage/FullscreenImage.js +14 -2
  79. package/build/cjs/components/FullscreenImage/FullscreenImage.js.map +1 -1
  80. package/build/cjs/components/HTML/HTML.d.ts +15 -8
  81. package/build/cjs/components/HTML/HTML.js +15 -10
  82. package/build/cjs/components/HTML/HTML.js.map +1 -1
  83. package/build/cjs/components/Link/Link.js +11 -2
  84. package/build/cjs/components/Link/Link.js.map +1 -1
  85. package/build/cjs/components/Media/Image/Image.d.ts +1 -0
  86. package/build/cjs/components/Media/Image/Image.js +7 -5
  87. package/build/cjs/components/Media/Image/Image.js.map +1 -1
  88. package/build/cjs/components/Media/Media.css +4 -0
  89. package/build/cjs/components/Media/Media.d.ts +1 -0
  90. package/build/cjs/components/Media/Media.js +3 -2
  91. package/build/cjs/components/Media/Media.js.map +1 -1
  92. package/build/cjs/components/MetaInfo/MetaInfo.css +1 -1
  93. package/build/cjs/components/MetaInfo/MetaInfo.js +1 -1
  94. package/build/cjs/components/MetaInfo/MetaInfo.js.map +1 -1
  95. package/build/cjs/components/Table/Table.css +2 -1
  96. package/build/cjs/components/Table/Table.js +4 -2
  97. package/build/cjs/components/Table/Table.js.map +1 -1
  98. package/build/cjs/components/Title/TitleItem.css +15 -5
  99. package/build/cjs/components/Title/TitleItem.js +4 -1
  100. package/build/cjs/components/Title/TitleItem.js.map +1 -1
  101. package/build/cjs/components/YFMWrapper/YFMWrapper.d.ts +4 -2
  102. package/build/cjs/components/YFMWrapper/YFMWrapper.js +4 -3
  103. package/build/cjs/components/YFMWrapper/YFMWrapper.js.map +1 -1
  104. package/build/cjs/constructor-items.d.ts +2 -2
  105. package/build/cjs/constructor-items.js +2 -4
  106. package/build/cjs/constructor-items.js.map +1 -1
  107. package/build/cjs/editor/data/templates/{slider-new-block.json → slider-old-block.json} +2 -2
  108. package/build/cjs/models/common.d.ts +1 -0
  109. package/build/cjs/models/common.js.map +1 -1
  110. package/build/cjs/models/constructor-items/blocks.d.ts +17 -15
  111. package/build/cjs/models/constructor-items/blocks.js +3 -2
  112. package/build/cjs/models/constructor-items/blocks.js.map +1 -1
  113. package/build/cjs/models/constructor-items/common.d.ts +2 -2
  114. package/build/cjs/models/constructor-items/common.js.map +1 -1
  115. package/build/cjs/schema/constants.js +3 -1
  116. package/build/cjs/schema/constants.js.map +1 -1
  117. package/build/cjs/schema/validators/blocks.d.ts +2 -2
  118. package/build/cjs/schema/validators/blocks.js +2 -2
  119. package/build/cjs/schema/validators/blocks.js.map +1 -1
  120. package/build/cjs/schema/validators/common.js +1 -1
  121. package/build/cjs/schema/validators/common.js.map +1 -1
  122. package/build/cjs/sub-blocks/BannerCard/BannerCard.css +14 -8
  123. package/build/cjs/sub-blocks/BannerCard/BannerCard.js +3 -1
  124. package/build/cjs/sub-blocks/BannerCard/BannerCard.js.map +1 -1
  125. package/build/cjs/sub-blocks/Content/Content.css +80 -31
  126. package/build/cjs/sub-blocks/Content/Content.js +3 -1
  127. package/build/cjs/sub-blocks/Content/Content.js.map +1 -1
  128. package/build/cjs/sub-blocks/PriceCard/PriceCard.css +2 -1
  129. package/build/cjs/sub-blocks/PriceCard/PriceCard.js +1 -1
  130. package/build/cjs/sub-blocks/PriceCard/PriceCard.js.map +1 -1
  131. package/build/cjs/sub-blocks/PriceDetailed/PriceDescription/PriceDescription.js +1 -0
  132. package/build/cjs/sub-blocks/PriceDetailed/PriceDescription/PriceDescription.js.map +1 -1
  133. package/build/cjs/sub-blocks/Quote/Quote.css +8 -4
  134. package/build/cjs/sub-blocks/Quote/Quote.js +2 -1
  135. package/build/cjs/sub-blocks/Quote/Quote.js.map +1 -1
  136. package/build/cjs/text-transform/common.d.ts +4 -3
  137. package/build/cjs/text-transform/common.js +41 -18
  138. package/build/cjs/text-transform/common.js.map +1 -1
  139. package/build/cjs/text-transform/config.d.ts +5 -2
  140. package/build/cjs/text-transform/config.js +84 -43
  141. package/build/cjs/text-transform/config.js.map +1 -1
  142. package/build/cjs/text-transform/transformers.js +2 -2
  143. package/build/cjs/text-transform/transformers.js.map +1 -1
  144. package/build/cjs/utils/blocks.d.ts +10 -2
  145. package/build/cjs/utils/blocks.js +10 -3
  146. package/build/cjs/utils/blocks.js.map +1 -1
  147. package/build/esm/blocks/ExtendedFeatures/ExtendedFeatures.css +11 -6
  148. package/build/esm/blocks/ExtendedFeatures/ExtendedFeatures.js +4 -6
  149. package/build/esm/blocks/ExtendedFeatures/ExtendedFeatures.js.map +1 -1
  150. package/build/esm/blocks/Header/Header.css +15 -10
  151. package/build/esm/blocks/Header/Header.js +7 -2
  152. package/build/esm/blocks/Header/Header.js.map +1 -1
  153. package/build/esm/blocks/HeaderSlider/HeaderSlider.css +0 -10
  154. package/build/esm/blocks/HeaderSlider/HeaderSlider.js +1 -1
  155. package/build/esm/blocks/HeaderSlider/HeaderSlider.js.map +1 -1
  156. package/build/esm/blocks/HeaderSlider/schema.d.ts +9 -1
  157. package/build/esm/blocks/Questions/QuestionBlockItem/QuestionBlockItem.css +43 -21
  158. package/build/esm/blocks/Questions/QuestionBlockItem/QuestionBlockItem.js +4 -2
  159. package/build/esm/blocks/Questions/QuestionBlockItem/QuestionBlockItem.js.map +1 -1
  160. package/build/esm/blocks/Share/Share.js +5 -1
  161. package/build/esm/blocks/Share/Share.js.map +1 -1
  162. package/build/esm/blocks/Slider/Arrow/Arrow.css +22 -21
  163. package/build/esm/blocks/Slider/Arrow/Arrow.d.ts +4 -2
  164. package/build/esm/blocks/Slider/Arrow/Arrow.js +1 -1
  165. package/build/esm/blocks/Slider/Arrow/Arrow.js.map +1 -1
  166. package/build/esm/blocks/Slider/Slider.css +549 -329
  167. package/build/esm/blocks/Slider/Slider.d.ts +6 -5
  168. package/build/esm/blocks/Slider/Slider.js +32 -272
  169. package/build/esm/blocks/Slider/Slider.js.map +1 -1
  170. package/build/esm/blocks/Slider/i18n/en.json +1 -1
  171. package/build/esm/blocks/Slider/i18n/ru.json +1 -1
  172. package/build/esm/blocks/Slider/models.d.ts +2 -2
  173. package/build/esm/blocks/Slider/models.js +1 -1
  174. package/build/esm/blocks/Slider/models.js.map +1 -1
  175. package/build/esm/blocks/Slider/schema.d.ts +18 -1
  176. package/build/esm/blocks/Slider/schema.js +9 -0
  177. package/build/esm/blocks/Slider/schema.js.map +1 -1
  178. package/build/{cjs/blocks/SliderNew → esm/blocks/Slider}/useSlider.d.ts +1 -0
  179. package/build/esm/blocks/{SliderNew → Slider}/useSlider.js +4 -0
  180. package/build/esm/blocks/Slider/useSlider.js.map +1 -0
  181. package/build/esm/blocks/Slider/useSliderPagination.js.map +1 -0
  182. package/build/esm/blocks/Slider/utils.d.ts +7 -28
  183. package/build/esm/blocks/Slider/utils.js +24 -103
  184. package/build/esm/blocks/Slider/utils.js.map +1 -1
  185. package/build/esm/blocks/{SliderNew → SliderOld}/Arrow/Arrow.css +15 -12
  186. package/build/esm/blocks/SliderOld/Arrow/Arrow.d.ts +10 -0
  187. package/build/esm/blocks/SliderOld/Arrow/Arrow.js +9 -0
  188. package/build/esm/blocks/SliderOld/Arrow/Arrow.js.map +1 -0
  189. package/build/esm/blocks/SliderOld/SliderOld.css +703 -0
  190. package/build/esm/blocks/SliderOld/SliderOld.d.ts +18 -0
  191. package/build/esm/blocks/SliderOld/SliderOld.js +288 -0
  192. package/build/esm/blocks/SliderOld/SliderOld.js.map +1 -0
  193. package/build/esm/blocks/{SliderNew → SliderOld}/i18n/en.json +1 -1
  194. package/build/esm/blocks/{SliderNew → SliderOld}/i18n/index.d.ts +1 -1
  195. package/build/esm/blocks/{SliderNew → SliderOld}/i18n/index.js +1 -1
  196. package/build/esm/blocks/{SliderNew → SliderOld}/i18n/index.js.map +1 -1
  197. package/build/esm/blocks/{SliderNew → SliderOld}/i18n/ru.json +1 -1
  198. package/build/esm/blocks/{SliderNew → SliderOld}/models.d.ts +2 -2
  199. package/build/esm/blocks/{SliderNew → SliderOld}/models.js +1 -1
  200. package/build/esm/blocks/{SliderNew → SliderOld}/models.js.map +1 -1
  201. package/build/{cjs/blocks/SliderNew → esm/blocks/SliderOld}/schema.d.ts +5 -21
  202. package/build/esm/blocks/{SliderNew → SliderOld}/schema.js +5 -13
  203. package/build/esm/blocks/SliderOld/schema.js.map +1 -0
  204. package/build/esm/blocks/SliderOld/utils.d.ts +37 -0
  205. package/build/esm/blocks/SliderOld/utils.js +116 -0
  206. package/build/esm/blocks/SliderOld/utils.js.map +1 -0
  207. package/build/esm/blocks/Table/Table.css +4 -3
  208. package/build/esm/blocks/Table/Table.js +4 -2
  209. package/build/esm/blocks/Table/Table.js.map +1 -1
  210. package/build/esm/blocks/index.d.ts +2 -0
  211. package/build/esm/blocks/index.js +1 -0
  212. package/build/esm/blocks/index.js.map +1 -1
  213. package/build/esm/blocks/validators.d.ts +1 -0
  214. package/build/esm/blocks/validators.js +1 -0
  215. package/build/esm/blocks/validators.js.map +1 -1
  216. package/build/esm/components/ContentList/ContentList.css +16 -12
  217. package/build/esm/components/ContentList/ContentList.js +1 -1
  218. package/build/esm/components/ContentList/ContentList.js.map +1 -1
  219. package/build/esm/components/FileLink/FileLink.js +8 -1
  220. package/build/esm/components/FileLink/FileLink.js.map +1 -1
  221. package/build/esm/components/FullscreenImage/FullscreenImage.css +96 -18
  222. package/build/esm/components/FullscreenImage/FullscreenImage.d.ts +5 -0
  223. package/build/esm/components/FullscreenImage/FullscreenImage.js +14 -2
  224. package/build/esm/components/FullscreenImage/FullscreenImage.js.map +1 -1
  225. package/build/esm/components/HTML/HTML.d.ts +15 -8
  226. package/build/esm/components/HTML/HTML.js +17 -11
  227. package/build/esm/components/HTML/HTML.js.map +1 -1
  228. package/build/esm/components/Link/Link.js +12 -3
  229. package/build/esm/components/Link/Link.js.map +1 -1
  230. package/build/esm/components/Media/Image/Image.d.ts +1 -0
  231. package/build/esm/components/Media/Image/Image.js +7 -5
  232. package/build/esm/components/Media/Image/Image.js.map +1 -1
  233. package/build/esm/components/Media/Media.css +4 -0
  234. package/build/esm/components/Media/Media.d.ts +1 -0
  235. package/build/esm/components/Media/Media.js +3 -2
  236. package/build/esm/components/Media/Media.js.map +1 -1
  237. package/build/esm/components/MetaInfo/MetaInfo.css +1 -1
  238. package/build/esm/components/MetaInfo/MetaInfo.js +1 -1
  239. package/build/esm/components/MetaInfo/MetaInfo.js.map +1 -1
  240. package/build/esm/components/Table/Table.css +2 -1
  241. package/build/esm/components/Table/Table.js +5 -3
  242. package/build/esm/components/Table/Table.js.map +1 -1
  243. package/build/esm/components/Title/TitleItem.css +15 -5
  244. package/build/esm/components/Title/TitleItem.js +5 -2
  245. package/build/esm/components/Title/TitleItem.js.map +1 -1
  246. package/build/esm/components/YFMWrapper/YFMWrapper.d.ts +4 -2
  247. package/build/esm/components/YFMWrapper/YFMWrapper.js +5 -3
  248. package/build/esm/components/YFMWrapper/YFMWrapper.js.map +1 -1
  249. package/build/esm/constructor-items.d.ts +2 -2
  250. package/build/esm/constructor-items.js +3 -5
  251. package/build/esm/constructor-items.js.map +1 -1
  252. package/build/esm/editor/data/templates/{slider-new-block.json → slider-old-block.json} +2 -2
  253. package/build/esm/models/common.d.ts +1 -0
  254. package/build/esm/models/common.js.map +1 -1
  255. package/build/esm/models/constructor-items/blocks.d.ts +17 -15
  256. package/build/esm/models/constructor-items/blocks.js +3 -2
  257. package/build/esm/models/constructor-items/blocks.js.map +1 -1
  258. package/build/esm/models/constructor-items/common.d.ts +2 -2
  259. package/build/esm/models/constructor-items/common.js.map +1 -1
  260. package/build/esm/schema/constants.js +4 -2
  261. package/build/esm/schema/constants.js.map +1 -1
  262. package/build/esm/schema/validators/blocks.d.ts +2 -2
  263. package/build/esm/schema/validators/blocks.js +2 -2
  264. package/build/esm/schema/validators/blocks.js.map +1 -1
  265. package/build/esm/schema/validators/common.js +1 -1
  266. package/build/esm/schema/validators/common.js.map +1 -1
  267. package/build/esm/sub-blocks/BannerCard/BannerCard.css +14 -8
  268. package/build/esm/sub-blocks/BannerCard/BannerCard.js +4 -2
  269. package/build/esm/sub-blocks/BannerCard/BannerCard.js.map +1 -1
  270. package/build/esm/sub-blocks/Content/Content.css +80 -31
  271. package/build/esm/sub-blocks/Content/Content.js +3 -1
  272. package/build/esm/sub-blocks/Content/Content.js.map +1 -1
  273. package/build/esm/sub-blocks/PriceCard/PriceCard.css +2 -1
  274. package/build/esm/sub-blocks/PriceCard/PriceCard.js +2 -2
  275. package/build/esm/sub-blocks/PriceCard/PriceCard.js.map +1 -1
  276. package/build/esm/sub-blocks/PriceDetailed/PriceDescription/PriceDescription.js +1 -0
  277. package/build/esm/sub-blocks/PriceDetailed/PriceDescription/PriceDescription.js.map +1 -1
  278. package/build/esm/sub-blocks/Quote/Quote.css +8 -4
  279. package/build/esm/sub-blocks/Quote/Quote.js +3 -2
  280. package/build/esm/sub-blocks/Quote/Quote.js.map +1 -1
  281. package/build/esm/text-transform/common.d.ts +4 -3
  282. package/build/esm/text-transform/common.js +41 -18
  283. package/build/esm/text-transform/common.js.map +1 -1
  284. package/build/esm/text-transform/config.d.ts +5 -2
  285. package/build/esm/text-transform/config.js +85 -44
  286. package/build/esm/text-transform/config.js.map +1 -1
  287. package/build/esm/text-transform/transformers.js +2 -2
  288. package/build/esm/text-transform/transformers.js.map +1 -1
  289. package/build/esm/utils/blocks.d.ts +10 -2
  290. package/build/esm/utils/blocks.js +9 -2
  291. package/build/esm/utils/blocks.js.map +1 -1
  292. package/package.json +2 -2
  293. package/schema/index.js +1 -1
  294. package/server/models/common.d.ts +1 -0
  295. package/server/models/constructor-items/blocks.d.ts +17 -15
  296. package/server/models/constructor-items/blocks.js +3 -2
  297. package/server/models/constructor-items/common.d.ts +2 -2
  298. package/server/text-transform/common.d.ts +4 -3
  299. package/server/text-transform/common.js +41 -18
  300. package/server/text-transform/config.d.ts +5 -2
  301. package/server/text-transform/config.js +84 -43
  302. package/server/text-transform/transformers.js +2 -2
  303. package/server/utils/blocks.d.ts +10 -2
  304. package/server/utils/blocks.js +10 -3
  305. package/styles/fonts.scss +1 -0
  306. package/styles/styles.css +0 -1
  307. package/styles/styles.scss +0 -1
  308. package/styles/variables.scss +1 -0
  309. package/widget/index.js +1 -1
  310. package/build/cjs/blocks/SliderNew/Arrow/Arrow.d.ts +0 -11
  311. package/build/cjs/blocks/SliderNew/Arrow/Arrow.js +0 -11
  312. package/build/cjs/blocks/SliderNew/Arrow/Arrow.js.map +0 -1
  313. package/build/cjs/blocks/SliderNew/Slider.css +0 -834
  314. package/build/cjs/blocks/SliderNew/Slider.d.ts +0 -13
  315. package/build/cjs/blocks/SliderNew/Slider.js +0 -49
  316. package/build/cjs/blocks/SliderNew/Slider.js.map +0 -1
  317. package/build/cjs/blocks/SliderNew/schema.js.map +0 -1
  318. package/build/cjs/blocks/SliderNew/useSlider.js.map +0 -1
  319. package/build/cjs/blocks/SliderNew/useSliderPagination.js.map +0 -1
  320. package/build/cjs/blocks/SliderNew/utils.d.ts +0 -16
  321. package/build/cjs/blocks/SliderNew/utils.js +0 -44
  322. package/build/cjs/blocks/SliderNew/utils.js.map +0 -1
  323. package/build/cjs/blocks/unstable.d.ts +0 -1
  324. package/build/cjs/blocks/unstable.js +0 -7
  325. package/build/cjs/blocks/unstable.js.map +0 -1
  326. package/build/esm/blocks/SliderNew/Arrow/Arrow.d.ts +0 -12
  327. package/build/esm/blocks/SliderNew/Arrow/Arrow.js +0 -9
  328. package/build/esm/blocks/SliderNew/Arrow/Arrow.js.map +0 -1
  329. package/build/esm/blocks/SliderNew/Slider.css +0 -834
  330. package/build/esm/blocks/SliderNew/Slider.d.ts +0 -14
  331. package/build/esm/blocks/SliderNew/Slider.js +0 -45
  332. package/build/esm/blocks/SliderNew/Slider.js.map +0 -1
  333. package/build/esm/blocks/SliderNew/schema.js.map +0 -1
  334. package/build/esm/blocks/SliderNew/useSlider.js.map +0 -1
  335. package/build/esm/blocks/SliderNew/useSliderPagination.js.map +0 -1
  336. package/build/esm/blocks/SliderNew/utils.d.ts +0 -16
  337. package/build/esm/blocks/SliderNew/utils.js +0 -37
  338. package/build/esm/blocks/SliderNew/utils.js.map +0 -1
  339. package/build/esm/blocks/unstable.d.ts +0 -1
  340. package/build/esm/blocks/unstable.js +0 -2
  341. package/build/esm/blocks/unstable.js.map +0 -1
  342. /package/build/cjs/blocks/{SliderNew → Slider}/useSliderPagination.d.ts +0 -0
  343. /package/build/cjs/blocks/{SliderNew → Slider}/useSliderPagination.js +0 -0
  344. /package/build/cjs/blocks/{Slider → SliderOld}/slick.css +0 -0
  345. /package/build/esm/blocks/{SliderNew → Slider}/useSliderPagination.d.ts +0 -0
  346. /package/build/esm/blocks/{SliderNew → Slider}/useSliderPagination.js +0 -0
  347. /package/build/esm/blocks/{Slider → SliderOld}/slick.css +0 -0
@@ -0,0 +1,116 @@
1
+ import * as React from 'react';
2
+ import pickBy from "lodash/pickBy.js";
3
+ import { BREAKPOINTS } from "../../constants.js";
4
+ import { SliderBreakpointNames } from "./models.js";
5
+ export const DEFAULT_SLIDE_BREAKPOINTS = {
6
+ [SliderBreakpointNames.Xl]: 3,
7
+ [SliderBreakpointNames.Lg]: 2,
8
+ [SliderBreakpointNames.Md]: 2,
9
+ [SliderBreakpointNames.Sm]: 1.15,
10
+ };
11
+ const BREAKPOINT_NAMES_BY_VALUES = Object.entries(BREAKPOINTS).reduce((acc, [key, value]) => (Object.assign(Object.assign({}, acc), { [value]: key })), {});
12
+ export const isFocusable = (element) => {
13
+ if (!(element instanceof HTMLElement)) {
14
+ return false;
15
+ }
16
+ const tabIndexAttr = element.getAttribute('tabindex');
17
+ const hasTabIndex = tabIndexAttr !== null;
18
+ const tabIndex = Number(tabIndexAttr);
19
+ if (element.ariaHidden === 'true' || (hasTabIndex && tabIndex < 0)) {
20
+ return false;
21
+ }
22
+ if (hasTabIndex && tabIndex >= 0) {
23
+ return true;
24
+ }
25
+ // without this jest fails here for some reason
26
+ let htmlElement;
27
+ switch (true) {
28
+ case element instanceof HTMLAnchorElement:
29
+ htmlElement = element;
30
+ return Boolean(htmlElement.href);
31
+ case element instanceof HTMLInputElement:
32
+ htmlElement = element;
33
+ return htmlElement.type !== 'hidden' && !htmlElement.disabled;
34
+ case element instanceof HTMLSelectElement:
35
+ case element instanceof HTMLTextAreaElement:
36
+ case element instanceof HTMLButtonElement:
37
+ htmlElement = element;
38
+ return !htmlElement.disabled;
39
+ default:
40
+ return false;
41
+ }
42
+ };
43
+ export function getSlidesToShowWithDefaults({ contentLength, breakpoints, mobileFullscreen, }) {
44
+ let result;
45
+ if (typeof breakpoints === 'number') {
46
+ result = Object.keys(DEFAULT_SLIDE_BREAKPOINTS).reduce((acc, breakpointName) => (Object.assign(Object.assign({}, acc), { [breakpointName]: breakpoints })), {});
47
+ }
48
+ else {
49
+ result = breakpoints || DEFAULT_SLIDE_BREAKPOINTS;
50
+ }
51
+ return Object.assign(Object.assign(Object.assign({}, DEFAULT_SLIDE_BREAKPOINTS), pickBy(result, (value) => !isNaN(value))), { sm: !mobileFullscreen && contentLength > 1 ? DEFAULT_SLIDE_BREAKPOINTS.sm : 1 });
52
+ }
53
+ export function getSliderResponsiveParams(breakpoints) {
54
+ return Object.entries(breakpoints).map(([breakpointName, slidesToShow]) => ({
55
+ breakpoint: BREAKPOINTS[breakpointName],
56
+ settings: { slidesToShow },
57
+ }));
58
+ }
59
+ export function getSlidesCountByBreakpoint(breakpoint, breakpoints) {
60
+ const breakpointName = BREAKPOINT_NAMES_BY_VALUES[breakpoint];
61
+ return Math.floor(breakpoints[breakpointName]);
62
+ }
63
+ export function getSlidesToShowCount(breakpoints) {
64
+ return Math.floor(Math.max(...Object.values(breakpoints)));
65
+ }
66
+ const getRovingListItemId = (uniqId, index) => `${uniqId}-roving-tabindex-item-${index}`;
67
+ export function useRovingTabIndex(props) {
68
+ const { itemCount, activeIndex, firstIndex = 0, uniqId } = props;
69
+ const [currentIndex, setCurrentIndex] = React.useState(firstIndex);
70
+ const hasFocusRef = React.useRef(false);
71
+ const lastIndex = itemCount + firstIndex - 1;
72
+ const getRovingItemProps = (index) => {
73
+ return {
74
+ id: getRovingListItemId(uniqId, index),
75
+ tabIndex: index === activeIndex ? 0 : -1,
76
+ onFocus: () => {
77
+ setCurrentIndex(index);
78
+ hasFocusRef.current = true;
79
+ },
80
+ };
81
+ };
82
+ React.useEffect(() => {
83
+ var _a;
84
+ if (!hasFocusRef.current) {
85
+ return;
86
+ }
87
+ (_a = document.getElementById(getRovingListItemId(uniqId, currentIndex))) === null || _a === void 0 ? void 0 : _a.focus();
88
+ }, [activeIndex, currentIndex, uniqId]);
89
+ const setNextIndex = () => setCurrentIndex((prev) => (prev >= lastIndex ? firstIndex : prev + 1));
90
+ const setPrevIndex = () => setCurrentIndex((prev) => (prev <= firstIndex ? lastIndex : prev - 1));
91
+ const onRovingListKeyDown = (e) => {
92
+ const key = e.key.toLowerCase();
93
+ if (key !== 'tab' && key !== 'enter') {
94
+ e.preventDefault();
95
+ }
96
+ switch (key) {
97
+ case 'arrowleft':
98
+ case 'arrowup':
99
+ setPrevIndex();
100
+ return;
101
+ case 'arrowright':
102
+ case 'arrowdown':
103
+ setNextIndex();
104
+ return;
105
+ }
106
+ };
107
+ const onRovingListBlur = () => {
108
+ hasFocusRef.current = false;
109
+ };
110
+ const rovingListProps = {
111
+ onKeyDown: onRovingListKeyDown,
112
+ onBlur: onRovingListBlur,
113
+ };
114
+ return { getRovingItemProps, rovingListProps };
115
+ }
116
+ //# 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) => (prev >= lastIndex ? firstIndex : prev + 1));\n const setPrevIndex = () =>\n setCurrentIndex((prev) => (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
  }
@@ -1,12 +1,14 @@
1
1
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
- import { Table } from "../../components/index.js";
2
+ import { Table, YFMWrapper } from "../../components/index.js";
3
3
  import { Col, Grid, GridColumnSize, Row } from "../../grid/index.js";
4
4
  import { block } from "../../utils/index.js";
5
5
  import './Table.css';
6
6
  const b = block('table-block');
7
7
  export const TableBlock = (props) => {
8
8
  const { title, table } = props;
9
- return (_jsx("div", { className: b(), children: _jsx(Grid, { className: b('content'), children: _jsxs(Row, { className: b('row'), children: [_jsx(Col, { sizes: { [GridColumnSize.Md]: 4, [GridColumnSize.All]: 12 }, children: _jsx("h2", { className: b('title'), children: title }) }), _jsx(Col, { sizes: { [GridColumnSize.Md]: 8, [GridColumnSize.All]: 12 }, children: _jsx(Table, Object.assign({ className: b('table') }, table)) })] }) }) }));
9
+ return (_jsx("div", { className: b(), children: _jsx(Grid, { className: b('content'), children: _jsxs(Row, { className: b('row'), children: [_jsx(Col, { sizes: { [GridColumnSize.Md]: 4, [GridColumnSize.All]: 12 }, children: _jsx(YFMWrapper, { tagName: "h2", contentClassName: b('title'), content: title, modifiers: {
10
+ constructor: true,
11
+ } }) }), _jsx(Col, { sizes: { [GridColumnSize.Md]: 8, [GridColumnSize.All]: 12 }, children: _jsx(Table, Object.assign({ className: b('table') }, table)) })] }) }) }));
10
12
  };
11
13
  export default TableBlock;
12
14
  //# sourceMappingURL=Table.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"Table.js","sourceRoot":"../../../../src","sources":["blocks/Table/Table.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAC,KAAK,EAAC,kCAAyB;AACvC,OAAO,EAAC,GAAG,EAAE,IAAI,EAAE,cAAc,EAAE,GAAG,EAAC,4BAAmB;AAE1D,OAAO,EAAC,KAAK,EAAC,6BAAoB;AAElC,OAAO,aAAa,CAAC;AAErB,MAAM,CAAC,GAAG,KAAK,CAAC,aAAa,CAAC,CAAC;AAE/B,MAAM,CAAC,MAAM,UAAU,GAAG,CAAC,KAAsB,EAAE,EAAE;IACjD,MAAM,EAAC,KAAK,EAAE,KAAK,EAAC,GAAG,KAAK,CAAC;IAE7B,OAAO,CACH,cAAK,SAAS,EAAE,CAAC,EAAE,YACf,KAAC,IAAI,IAAC,SAAS,EAAE,CAAC,CAAC,SAAS,CAAC,YACzB,MAAC,GAAG,IAAC,SAAS,EAAE,CAAC,CAAC,KAAK,CAAC,aACpB,KAAC,GAAG,IAAC,KAAK,EAAE,EAAC,CAAC,cAAc,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,cAAc,CAAC,GAAG,CAAC,EAAE,EAAE,EAAC,YAC1D,aAAI,SAAS,EAAE,CAAC,CAAC,OAAO,CAAC,YAAG,KAAK,GAAM,GACrC,EACN,KAAC,GAAG,IAAC,KAAK,EAAE,EAAC,CAAC,cAAc,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,cAAc,CAAC,GAAG,CAAC,EAAE,EAAE,EAAC,YAC1D,KAAC,KAAK,kBAAC,SAAS,EAAE,CAAC,CAAC,OAAO,CAAC,IAAM,KAAK,EAAI,GACzC,IACJ,GACH,GACL,CACT,CAAC;AACN,CAAC,CAAC;AAEF,eAAe,UAAU,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,OAAO,EAAC,KAAK,EAAE,UAAU,EAAC,kCAAyB;AACnD,OAAO,EAAC,GAAG,EAAE,IAAI,EAAE,cAAc,EAAE,GAAG,EAAC,4BAAmB;AAE1D,OAAO,EAAC,KAAK,EAAC,6BAAoB;AAElC,OAAO,aAAa,CAAC;AAErB,MAAM,CAAC,GAAG,KAAK,CAAC,aAAa,CAAC,CAAC;AAE/B,MAAM,CAAC,MAAM,UAAU,GAAG,CAAC,KAAsB,EAAE,EAAE;IACjD,MAAM,EAAC,KAAK,EAAE,KAAK,EAAC,GAAG,KAAK,CAAC;IAE7B,OAAO,CACH,cAAK,SAAS,EAAE,CAAC,EAAE,YACf,KAAC,IAAI,IAAC,SAAS,EAAE,CAAC,CAAC,SAAS,CAAC,YACzB,MAAC,GAAG,IAAC,SAAS,EAAE,CAAC,CAAC,KAAK,CAAC,aACpB,KAAC,GAAG,IAAC,KAAK,EAAE,EAAC,CAAC,cAAc,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,cAAc,CAAC,GAAG,CAAC,EAAE,EAAE,EAAC,YAC1D,KAAC,UAAU,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,KAAC,GAAG,IAAC,KAAK,EAAE,EAAC,CAAC,cAAc,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,cAAc,CAAC,GAAG,CAAC,EAAE,EAAE,EAAC,YAC1D,KAAC,KAAK,kBAAC,SAAS,EAAE,CAAC,CAAC,OAAO,CAAC,IAAM,KAAK,EAAI,GACzC,IACJ,GACH,GACL,CACT,CAAC;AACN,CAAC,CAAC;AAEF,eAAe,UAAU,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";
@@ -3,6 +3,7 @@ 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";
7
8
  export { default as ExtendedFeaturesBlock } from "./ExtendedFeatures/ExtendedFeatures.js";
8
9
  export { default as PromoFeaturesBlock } from "./PromoFeaturesBlock/PromoFeaturesBlock.js";
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"../../../src","sources":["blocks/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,OAAO,IAAI,WAAW,EAAC,2BAAwB;AACvD,OAAO,EAAC,OAAO,IAAI,cAAc,EAAC,iCAA8B;AAChE,OAAO,EAAC,OAAO,IAAI,SAAS,EAAC,uBAAoB;AACjD,OAAO,EAAC,OAAO,IAAI,UAAU,EAAC,yBAAsB;AACpD,OAAO,EAAC,OAAO,IAAI,QAAQ,EAAC,qBAAkB;AAC9C,OAAO,EAAC,OAAO,IAAI,WAAW,EAAC,2BAAwB;AACvD,OAAO,EAAC,OAAO,IAAI,qBAAqB,EAAC,+CAA4C;AACrF,OAAO,EAAC,OAAO,IAAI,kBAAkB,EAAC,mDAAgD;AACtF,OAAO,EAAC,OAAO,IAAI,cAAc,EAAC,iCAA8B;AAChE,OAAO,EAAC,OAAO,IAAI,UAAU,EAAC,yBAAsB;AACpD,OAAO,EAAC,OAAO,IAAI,SAAS,EAAC,uBAAoB;AACjD,OAAO,EAAC,OAAO,IAAI,WAAW,EAAC,2BAAwB;AACvD,OAAO,EAAC,OAAO,IAAI,UAAU,EAAC,yBAAsB;AACpD,OAAO,EAAC,OAAO,IAAI,iBAAiB,EAAC,uCAAoC;AACzE,OAAO,EAAC,OAAO,IAAI,eAAe,EAAC,mCAAgC;AACnE,OAAO,EAAC,OAAO,IAAI,kBAAkB,EAAC,yCAAsC;AAC5E,OAAO,EAAC,OAAO,IAAI,UAAU,EAAC,yBAAsB;AACpD,OAAO,EAAC,OAAO,IAAI,WAAW,EAAC,qCAAkC;AACjE,OAAO,EAAC,OAAO,IAAI,SAAS,EAAC,uBAAoB","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 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,OAAO,EAAC,OAAO,IAAI,WAAW,EAAC,2BAAwB;AACvD,OAAO,EAAC,OAAO,IAAI,cAAc,EAAC,iCAA8B;AAChE,OAAO,EAAC,OAAO,IAAI,SAAS,EAAC,uBAAoB;AACjD,OAAO,EAAC,OAAO,IAAI,UAAU,EAAC,yBAAsB;AACpD,OAAO,EAAC,OAAO,IAAI,QAAQ,EAAC,qBAAkB;AAC9C,OAAO,EAAC,OAAO,IAAI,cAAc,EAAC,iCAA8B;AAChE,OAAO,EAAC,OAAO,IAAI,WAAW,EAAC,2BAAwB;AAEvD,OAAO,EAAC,OAAO,IAAI,qBAAqB,EAAC,+CAA4C;AACrF,OAAO,EAAC,OAAO,IAAI,kBAAkB,EAAC,mDAAgD;AACtF,OAAO,EAAC,OAAO,IAAI,cAAc,EAAC,iCAA8B;AAChE,OAAO,EAAC,OAAO,IAAI,UAAU,EAAC,yBAAsB;AACpD,OAAO,EAAC,OAAO,IAAI,SAAS,EAAC,uBAAoB;AACjD,OAAO,EAAC,OAAO,IAAI,WAAW,EAAC,2BAAwB;AACvD,OAAO,EAAC,OAAO,IAAI,UAAU,EAAC,yBAAsB;AACpD,OAAO,EAAC,OAAO,IAAI,iBAAiB,EAAC,uCAAoC;AACzE,OAAO,EAAC,OAAO,IAAI,eAAe,EAAC,mCAAgC;AACnE,OAAO,EAAC,OAAO,IAAI,kBAAkB,EAAC,yCAAsC;AAC5E,OAAO,EAAC,OAAO,IAAI,UAAU,EAAC,yBAAsB;AACpD,OAAO,EAAC,OAAO,IAAI,WAAW,EAAC,qCAAkC;AACjE,OAAO,EAAC,OAAO,IAAI,SAAS,EAAC,uBAAoB","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 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";
@@ -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";
@@ -1 +1 @@
1
- {"version":3,"file":"validators.js","sourceRoot":"../../../src","sources":["blocks/validators.ts"],"names":[],"mappings":"AAAA,mCAAgC;AAChC,uCAAoC;AACpC,sCAAmC;AACnC,0CAAuC;AACvC,6CAA0C;AAC1C,mCAAgC;AAChC,yCAAsC;AACtC,kCAA+B;AAC/B,iCAA8B;AAC9B,kCAA+B;AAC/B,+CAA4C;AAC5C,sCAAmC;AACnC,mCAAgC;AAChC,kCAA+B;AAC/B,kCAA+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,mCAAgC;AAChC,uCAAoC;AACpC,sCAAmC;AACnC,0CAAuC;AACvC,6CAA0C;AAC1C,mCAAgC;AAChC,yCAAsC;AACtC,kCAA+B;AAC/B,iCAA8B;AAC9B,kCAA+B;AAC/B,+CAA4C;AAC5C,sCAAmC;AACnC,sCAAmC;AACnC,mCAAgC;AAChC,kCAA+B;AAC/B,kCAA+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"]}
@@ -1,34 +1,38 @@
1
1
  /* use this for style redefinitions to awoid problems with
2
2
  unpredictable css rules order in build */
3
- .pc-content-list_size_l {
3
+ .pc-content-list_size_l, .pc-content-list_size_m {
4
4
  max-width: 480px;
5
5
  }
6
- .pc-content-list_size_l .pc-content-list__title {
6
+ .pc-content-list_size_l .pc-content-list__title, .pc-content-list_size_m .pc-content-list__title {
7
7
  font-size: var(--g-text-header-1-font-size);
8
8
  line-height: var(--g-text-header-1-line-height);
9
9
  margin: 0 0 8px;
10
10
  }
11
- .pc-content-list_size_l .pc-content-list__icon {
11
+ .pc-content-list_size_l .pc-content-list__icon, .pc-content-list_size_m .pc-content-list__icon {
12
12
  width: 22px;
13
13
  height: 22px;
14
14
  margin-top: 1px;
15
15
  margin-bottom: 1px;
16
16
  margin-right: 12px;
17
17
  }
18
- .pc-content-list_size_l .pc-content-list__item:not(:last-child) {
18
+ .pc-content-list_size_l .pc-content-list__item:not(:last-child), .pc-content-list_size_m .pc-content-list__item:not(:last-child) {
19
19
  margin-bottom: 16px;
20
20
  }
21
- .pc-content-list_size_l .pc-content-list__item_without-title:not(:last-child) {
21
+ .pc-content-list_size_l .pc-content-list__item_without-title:not(:last-child), .pc-content-list_size_m .pc-content-list__item_without-title:not(:last-child) {
22
22
  margin-bottom: 12px;
23
23
  }
24
- .pc-content-list_size_l .pc-content-list__item_without-title .pc-content-list__icon {
24
+ .pc-content-list_size_l .pc-content-list__item_without-title .pc-content-list__icon, .pc-content-list_size_m .pc-content-list__item_without-title .pc-content-list__icon {
25
25
  width: 20px;
26
26
  height: 20px;
27
27
  margin-top: 2px;
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 {
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
  }
@@ -21,7 +21,7 @@ const ContentList = ({ list, size = 'l', qa, theme }) => {
21
21
  return (_jsx("div", { className: b({ size, theme }), "data-qa": qa, children: list === null || list === void 0 ? void 0 : list.map((item) => {
22
22
  const { icon, title, text } = item;
23
23
  return (_jsxs("div", { className: b('item', { 'without-title': !title }), children: [_jsx(ItemIcon, { icon: icon, className: b('icon'), qa: qaAttributes.image }), _jsxs("div", { children: [title &&
24
- React.createElement(getHeadingLevel(size), { className: b('title'), 'data-qa': qaAttributes.title }, _jsx(YFMWrapper, { content: title, modifiers: { constructor: true } })), text && (_jsx(YFMWrapper, { className: b('text'), content: text, modifiers: { constructor: true }, qa: qaAttributes.text }))] })] }, uuidv4()));
24
+ React.createElement(getHeadingLevel(size), { className: b('title'), 'data-qa': qaAttributes.title }, _jsx(YFMWrapper, { content: title, modifiers: { constructor: true } })), text && (_jsx(YFMWrapper, { contentClassName: b('text', { 'without-title': !title }), content: text, modifiers: { constructor: true }, qa: qaAttributes.text }))] })] }, uuidv4()));
25
25
  }) }));
26
26
  };
27
27
  export default ContentList;
@@ -1 +1 @@
1
- {"version":3,"file":"ContentList.js","sourceRoot":"../../../../src","sources":["components/ContentList/ContentList.tsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAE/B,OAAO,EAAC,EAAE,IAAI,MAAM,EAAC,MAAM,MAAM,CAAC;AAIlC,OAAO,EAAC,KAAK,EAAC,6BAAoB;AAClC,OAAO,EAAC,eAAe,EAAC,8BAA2B;AACnD,OAAO,UAAU,oCAAiC;AAElD,OAAO,QAAQ,iCAA8B;AAE7C,OAAO,mBAAmB,CAAC;AAE3B,MAAM,CAAC,GAAG,KAAK,CAAC,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,eAAe,CAAC,EAAE,EAAE,CAAC,OAAO,EAAE,OAAO,EAAE,MAAM,CAAC,CAAC,CAAC;IAErE,OAAO,CACH,cAAK,SAAS,EAAE,CAAC,CAAC,EAAC,IAAI,EAAE,KAAK,EAAC,CAAC,aAAW,EAAE,YACxC,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE;YAChB,MAAM,EAAC,IAAI,EAAE,KAAK,EAAE,IAAI,EAAC,GAAG,IAAI,CAAC;YACjC,OAAO,CACH,eAAK,SAAS,EAAE,CAAC,CAAC,MAAM,EAAE,EAAC,eAAe,EAAE,CAAC,KAAK,EAAC,CAAC,aAChD,KAAC,QAAQ,IAAC,IAAI,EAAE,IAAI,EAAE,SAAS,EAAE,CAAC,CAAC,MAAM,CAAC,EAAE,EAAE,EAAE,YAAY,CAAC,KAAK,GAAI,EACtE,0BACK,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,KAAC,UAAU,IAAC,OAAO,EAAE,KAAK,EAAE,SAAS,EAAE,EAAC,WAAW,EAAE,IAAI,EAAC,GAAI,CACjE,EACJ,IAAI,IAAI,CACL,KAAC,UAAU,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,MAAM,EAAE,CAkB7D,CACT,CAAC;QACN,CAAC,CAAC,GACA,CACT,CAAC;AACN,CAAC,CAAC;AAEF,eAAe,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,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAE/B,OAAO,EAAC,EAAE,IAAI,MAAM,EAAC,MAAM,MAAM,CAAC;AAIlC,OAAO,EAAC,KAAK,EAAC,6BAAoB;AAClC,OAAO,EAAC,eAAe,EAAC,8BAA2B;AACnD,OAAO,UAAU,oCAAiC;AAElD,OAAO,QAAQ,iCAA8B;AAE7C,OAAO,mBAAmB,CAAC;AAE3B,MAAM,CAAC,GAAG,KAAK,CAAC,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,eAAe,CAAC,EAAE,EAAE,CAAC,OAAO,EAAE,OAAO,EAAE,MAAM,CAAC,CAAC,CAAC;IAErE,OAAO,CACH,cAAK,SAAS,EAAE,CAAC,CAAC,EAAC,IAAI,EAAE,KAAK,EAAC,CAAC,aAAW,EAAE,YACxC,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE;YAChB,MAAM,EAAC,IAAI,EAAE,KAAK,EAAE,IAAI,EAAC,GAAG,IAAI,CAAC;YACjC,OAAO,CACH,eAAK,SAAS,EAAE,CAAC,CAAC,MAAM,EAAE,EAAC,eAAe,EAAE,CAAC,KAAK,EAAC,CAAC,aAChD,KAAC,QAAQ,IAAC,IAAI,EAAE,IAAI,EAAE,SAAS,EAAE,CAAC,CAAC,MAAM,CAAC,EAAE,EAAE,EAAE,YAAY,CAAC,KAAK,GAAI,EACtE,0BACK,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,KAAC,UAAU,IAAC,OAAO,EAAE,KAAK,EAAE,SAAS,EAAE,EAAC,WAAW,EAAE,IAAI,EAAC,GAAI,CACjE,EACJ,IAAI,IAAI,CACL,KAAC,UAAU,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,MAAM,EAAE,CAkB7D,CACT,CAAC;QACN,CAAC,CAAC,GACA,CACT,CAAC;AACN,CAAC,CAAC;AAEF,eAAe,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"]}
@@ -33,16 +33,23 @@ const FileExtensionThemes = {
33
33
  const LabelSizeMap = {
34
34
  l: 's',
35
35
  m: 's',
36
+ sm: 's',
36
37
  s: 'xs',
37
38
  xs: 'xs',
38
39
  };
40
+ function getTextSize(size) {
41
+ if (size === 'sm') {
42
+ return 'm';
43
+ }
44
+ return size;
45
+ }
39
46
  const FileLink = (props) => {
40
47
  const { hostname } = React.useContext(LocationContext);
41
48
  const { href, text, type = 'vertical', textSize = 'm', className, theme = 'default', onClick, tabIndex, urlTitle, extraProps, } = props;
42
49
  const fileExt = getFileExt(href);
43
50
  const labelTheme = (FileExtensionThemes[fileExt] || 'unknown');
44
51
  const labelSize = LabelSizeMap[textSize];
45
- return (_jsxs("div", { className: b({ ext: fileExt, type, size: textSize, theme }, className), children: [_jsx(Label, { className: b('file-label'), size: labelSize, theme: labelTheme, children: fileExt }), _jsx("div", { className: b('link'), children: _jsx("a", Object.assign({ href: href, onClick: onClick, tabIndex: tabIndex, title: urlTitle }, getLinkProps(href, hostname), extraProps, { children: text })) })] }));
52
+ return (_jsxs("div", { className: b({ ext: fileExt, type, size: getTextSize(textSize), theme }, className), children: [_jsx(Label, { className: b('file-label'), size: labelSize, theme: labelTheme, children: fileExt }), _jsx("div", { className: b('link'), children: _jsx("a", Object.assign({ href: href, onClick: onClick, tabIndex: tabIndex, title: urlTitle }, getLinkProps(href, hostname), extraProps, { children: text })) })] }));
46
53
  };
47
54
  export default FileLink;
48
55
  //# sourceMappingURL=FileLink.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"FileLink.js","sourceRoot":"../../../../src","sources":["components/FileLink/FileLink.tsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAE/B,OAAO,EAAC,KAAK,EAAa,MAAM,mBAAmB,CAAC;AAEpD,OAAO,EAAC,eAAe,EAAC,+CAAsC;AAE9D,OAAO,EAAC,KAAK,EAAE,YAAY,EAAC,6BAAoB;AAEhD,OAAO,gBAAgB,CAAC;AAExB,MAAM,CAAC,GAAG,KAAK,CAAC,WAAW,CAAC,CAAC;AAE7B,MAAM,SAAS,GAAG,uBAAuB,CAAC;AAE1C,MAAM,CAAN,IAAY,aAOX;AAPD,WAAY,aAAa;IACrB,4BAAW,CAAA;IACX,4BAAW,CAAA;IACX,4BAAW,CAAA;IACX,4BAAW,CAAA;IACX,4BAAW,CAAA;IACX,4BAAW,CAAA;AACf,CAAC,EAPW,aAAa,KAAb,aAAa,QAOxB;AAED,MAAM,UAAU,UAAU,CAAC,IAAY;IACnC,IAAI,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,QAAQ,CAAC,SAAS,CAAC,EAAE,CAAC;QAC5B,OAAO,aAAa,CAAC,GAAG,CAAC;IAC7B,CAAC;IACD,oEAAoE;IACpE,OAAO,IAAI,IAAI,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,GAAG,EAAG,CAAC,WAAW,EAAE,CAAC;AACxD,CAAC;AAED,MAAM,mBAAmB,GAAG;IACxB,CAAC,aAAa,CAAC,GAAG,CAAC,EAAE,QAAQ;IAC7B,CAAC,aAAa,CAAC,GAAG,CAAC,EAAE,MAAM;IAC3B,CAAC,aAAa,CAAC,GAAG,CAAC,EAAE,SAAS;IAC9B,CAAC,aAAa,CAAC,GAAG,CAAC,EAAE,SAAS;IAC9B,CAAC,aAAa,CAAC,GAAG,CAAC,EAAE,QAAQ;IAC7B,CAAC,aAAa,CAAC,GAAG,CAAC,EAAE,SAAS;CACjC,CAAC;AAEF,MAAM,YAAY,GAAyC;IACvD,CAAC,EAAE,GAAG;IACN,CAAC,EAAE,GAAG;IACN,CAAC,EAAE,IAAI;IACP,EAAE,EAAE,IAAI;CACX,CAAC;AAEF,MAAM,QAAQ,GAAG,CAAC,KAA6C,EAAE,EAAE;IAC/D,MAAM,EAAC,QAAQ,EAAC,GAAG,KAAK,CAAC,UAAU,CAAC,eAAe,CAAC,CAAC;IACrD,MAAM,EACF,IAAI,EACJ,IAAI,EACJ,IAAI,GAAG,UAAU,EACjB,QAAQ,GAAG,GAAG,EACd,SAAS,EACT,KAAK,GAAG,SAAS,EACjB,OAAO,EACP,QAAQ,EACR,QAAQ,EACR,UAAU,GACb,GAAG,KAAK,CAAC;IACV,MAAM,OAAO,GAAG,UAAU,CAAC,IAAI,CAAkB,CAAC;IAClD,MAAM,UAAU,GAAG,CAAC,mBAAmB,CAAC,OAAO,CAAC,IAAI,SAAS,CAAwB,CAAC;IACtF,MAAM,SAAS,GAAG,YAAY,CAAC,QAAQ,CAAC,CAAC;IAEzC,OAAO,CACH,eAAK,SAAS,EAAE,CAAC,CAAC,EAAC,GAAG,EAAE,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,QAAQ,EAAE,KAAK,EAAC,EAAE,SAAS,CAAC,aACrE,KAAC,KAAK,IAAC,SAAS,EAAE,CAAC,CAAC,YAAY,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,KAAK,EAAE,UAAU,YAChE,OAAO,GACJ,EACR,cAAK,SAAS,EAAE,CAAC,CAAC,MAAM,CAAC,YACrB,0BACI,IAAI,EAAE,IAAI,EACV,OAAO,EAAE,OAAO,EAChB,QAAQ,EAAE,QAAQ,EAClB,KAAK,EAAE,QAAQ,IACX,YAAY,CAAC,IAAI,EAAE,QAAQ,CAAC,EAC5B,UAAU,cAEb,IAAI,IACL,GACF,IACJ,CACT,CAAC;AACN,CAAC,CAAC;AAEF,eAAe,QAAQ,CAAC","sourcesContent":["import * as React from 'react';\n\nimport {Label, LabelProps} from '@gravity-ui/uikit';\n\nimport {LocationContext} from '../../context/locationContext';\nimport {FileLinkProps, TextSize} from '../../models';\nimport {block, getLinkProps} from '../../utils';\n\nimport './FileLink.scss';\n\nconst b = block('file-link');\n\nconst FIGMA_URL = 'https://www.figma.com';\n\nexport enum FileExtension {\n PDF = 'pdf',\n DOC = 'doc',\n XLS = 'xls',\n PPT = 'ppt',\n FIG = 'fig',\n ZIP = 'zip',\n}\n\nexport function getFileExt(name: string) {\n if (name?.includes(FIGMA_URL)) {\n return FileExtension.FIG;\n }\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n return name && name.split('.').pop()!.toLowerCase();\n}\n\nconst FileExtensionThemes = {\n [FileExtension.PDF]: 'danger',\n [FileExtension.DOC]: 'info',\n [FileExtension.XLS]: 'success',\n [FileExtension.PPT]: 'warning',\n [FileExtension.FIG]: 'normal',\n [FileExtension.ZIP]: 'unknown',\n};\n\nconst LabelSizeMap: Record<TextSize, LabelProps['size']> = {\n l: 's',\n m: 's',\n s: 'xs',\n xs: 'xs',\n};\n\nconst FileLink = (props: React.PropsWithChildren<FileLinkProps>) => {\n const {hostname} = React.useContext(LocationContext);\n const {\n href,\n text,\n type = 'vertical',\n textSize = 'm',\n className,\n theme = 'default',\n onClick,\n tabIndex,\n urlTitle,\n extraProps,\n } = props;\n const fileExt = getFileExt(href) as FileExtension;\n const labelTheme = (FileExtensionThemes[fileExt] || 'unknown') as LabelProps['theme'];\n const labelSize = LabelSizeMap[textSize];\n\n return (\n <div className={b({ext: fileExt, type, size: textSize, theme}, className)}>\n <Label className={b('file-label')} size={labelSize} theme={labelTheme}>\n {fileExt}\n </Label>\n <div className={b('link')}>\n <a\n href={href}\n onClick={onClick}\n tabIndex={tabIndex}\n title={urlTitle}\n {...getLinkProps(href, hostname)}\n {...extraProps}\n >\n {text}\n </a>\n </div>\n </div>\n );\n};\n\nexport default FileLink;\n"]}
1
+ {"version":3,"file":"FileLink.js","sourceRoot":"../../../../src","sources":["components/FileLink/FileLink.tsx"],"names":[],"mappings":"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","sourcesContent":["import * as React from 'react';\n\nimport {Label, LabelProps} from '@gravity-ui/uikit';\n\nimport {LocationContext} from '../../context/locationContext';\nimport {FileLinkProps, TextSize} from '../../models';\nimport {block, getLinkProps} from '../../utils';\n\nimport './FileLink.scss';\n\nconst b = block('file-link');\n\nconst FIGMA_URL = 'https://www.figma.com';\n\nexport enum FileExtension {\n PDF = 'pdf',\n DOC = 'doc',\n XLS = 'xls',\n PPT = 'ppt',\n FIG = 'fig',\n ZIP = 'zip',\n}\n\nexport function getFileExt(name: string) {\n if (name?.includes(FIGMA_URL)) {\n return FileExtension.FIG;\n }\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n return name && name.split('.').pop()!.toLowerCase();\n}\n\nconst FileExtensionThemes = {\n [FileExtension.PDF]: 'danger',\n [FileExtension.DOC]: 'info',\n [FileExtension.XLS]: 'success',\n [FileExtension.PPT]: 'warning',\n [FileExtension.FIG]: 'normal',\n [FileExtension.ZIP]: 'unknown',\n};\n\nconst LabelSizeMap: Record<TextSize, LabelProps['size']> = {\n l: 's',\n m: 's',\n sm: 's',\n s: 'xs',\n xs: 'xs',\n};\n\nfunction getTextSize(size: TextSize) {\n if (size === 'sm') {\n return 'm';\n }\n\n return size;\n}\n\nconst FileLink = (props: React.PropsWithChildren<FileLinkProps>) => {\n const {hostname} = React.useContext(LocationContext);\n const {\n href,\n text,\n type = 'vertical',\n textSize = 'm',\n className,\n theme = 'default',\n onClick,\n tabIndex,\n urlTitle,\n extraProps,\n } = props;\n const fileExt = getFileExt(href) as FileExtension;\n const labelTheme = (FileExtensionThemes[fileExt] || 'unknown') as LabelProps['theme'];\n const labelSize = LabelSizeMap[textSize];\n\n return (\n <div className={b({ext: fileExt, type, size: getTextSize(textSize), theme}, className)}>\n <Label className={b('file-label')} size={labelSize} theme={labelTheme}>\n {fileExt}\n </Label>\n <div className={b('link')}>\n <a\n href={href}\n onClick={onClick}\n tabIndex={tabIndex}\n title={urlTitle}\n {...getLinkProps(href, hostname)}\n {...extraProps}\n >\n {text}\n </a>\n </div>\n </div>\n );\n};\n\nexport default FileLink;\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,45 @@ 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__close-icon-wrapper {
106
+ display: inline-block;
107
+ margin: 0;
108
+ padding: 0;
109
+ font: inherit;
110
+ border: none;
111
+ outline: none;
112
+ color: inherit;
113
+ background: none;
114
+ cursor: pointer;
115
+ display: flex;
116
+ align-items: center;
117
+ justify-content: center;
41
118
  width: 36px;
42
119
  height: 36px;
43
120
  border-radius: 8px;
@@ -45,36 +122,37 @@ unpredictable css rules order in build */
45
122
  cursor: pointer;
46
123
  opacity: 0;
47
124
  transition: 0.3s;
125
+ z-index: 1001;
126
+ position: absolute;
127
+ right: 24px;
128
+ top: 24px;
48
129
  }
49
- .pc-fullscreen-image__icon-wrapper:focus {
130
+ .pc-fullscreen-image__close-icon-wrapper:focus {
50
131
  outline: 2px solid var(--g-color-line-focus);
51
132
  outline-offset: 0;
52
133
  }
53
- .pc-fullscreen-image__icon-wrapper:focus:not(:focus-visible) {
134
+ .pc-fullscreen-image__close-icon-wrapper:focus:not(:focus-visible) {
54
135
  outline: 0;
55
136
  }
56
- .pc-fullscreen-image__icon-wrapper:focus {
137
+ .pc-fullscreen-image__close-icon-wrapper:focus {
57
138
  opacity: 1;
58
139
  }
140
+ @media (max-width: 769px) {
141
+ .pc-fullscreen-image__close-icon-wrapper {
142
+ opacity: 1;
143
+ }
144
+ }
59
145
  .pc-fullscreen-image__icon {
60
146
  color: var(--g-color-text-hint);
61
147
  }
62
148
  .pc-fullscreen-image__icon_hover:hover {
63
149
  color: var(--g-color-text-secondary);
64
150
  }
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;
151
+ @media (max-width: 769px) {
152
+ .pc-fullscreen-image__modal .g-modal__content-wrapper {
153
+ margin: 8px;
76
154
  }
77
- .pc-fullscreen-image__modal {
78
- display: none !important; /* stylelint-disable-line declaration-no-important */
155
+ .pc-fullscreen-image__modal_with-slider .g-modal__content-wrapper {
156
+ margin: 0;
79
157
  }
80
158
  }
@@ -1,4 +1,5 @@
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
  import './FullscreenImage.css';
4
5
  export interface FullscreenImageProps extends ImageProps {
@@ -6,6 +7,10 @@ export interface FullscreenImageProps extends ImageProps {
6
7
  modalImageClass?: string;
7
8
  imageStyle?: React.CSSProperties;
8
9
  extraProps?: React.HTMLProps<HTMLDivElement>;
10
+ sliderData?: {
11
+ items: ModelImageProps[];
12
+ initialIndex: number;
13
+ };
9
14
  }
10
15
  declare const FullscreenImage: (props: FullscreenImageProps) => import("react/jsx-runtime").JSX.Element;
11
16
  export default FullscreenImage;