@gravity-ui/page-constructor 8.2.2 → 8.4.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (244) hide show
  1. package/README.md +1 -1
  2. package/build/cjs/blocks/ContentLayout/ContentLayout.css +2 -2
  3. package/build/cjs/blocks/ContentLayout/ContentLayout.js +2 -0
  4. package/build/cjs/blocks/ContentLayout/ContentLayout.js.map +1 -1
  5. package/build/cjs/blocks/ContentLayout/schema.d.ts +0 -11
  6. package/build/cjs/blocks/FoldableList/schema.d.ts +0 -11
  7. package/build/cjs/blocks/Form/Form.css +10 -1
  8. package/build/cjs/blocks/Form/Form.js +4 -2
  9. package/build/cjs/blocks/Form/Form.js.map +1 -1
  10. package/build/cjs/blocks/Form/schema.d.ts +0 -11
  11. package/build/cjs/blocks/Header/Header.css +6 -0
  12. package/build/cjs/blocks/Header/schema.js +1 -25
  13. package/build/cjs/blocks/Header/schema.js.map +1 -1
  14. package/build/cjs/blocks/Hero/Hero.css +211 -0
  15. package/build/cjs/blocks/Hero/Hero.d.ts +3 -0
  16. package/build/cjs/blocks/Hero/Hero.js +50 -0
  17. package/build/cjs/blocks/Hero/Hero.js.map +1 -0
  18. package/build/cjs/blocks/Hero/hooks.d.ts +4 -0
  19. package/build/cjs/blocks/Hero/hooks.js +38 -0
  20. package/build/cjs/blocks/Hero/hooks.js.map +1 -0
  21. package/build/cjs/blocks/Hero/schema.d.ts +2076 -0
  22. package/build/cjs/blocks/Hero/schema.js +66 -0
  23. package/build/cjs/blocks/Hero/schema.js.map +1 -0
  24. package/build/cjs/blocks/Info/schema.d.ts +0 -22
  25. package/build/cjs/blocks/Map/schema.d.ts +0 -11
  26. package/build/cjs/blocks/Media/schema.d.ts +0 -22
  27. package/build/cjs/blocks/Questions/schema.d.ts +0 -11
  28. package/build/cjs/blocks/Tabs/schema.d.ts +0 -11
  29. package/build/cjs/blocks/index.d.ts +1 -0
  30. package/build/cjs/blocks/index.js +3 -1
  31. package/build/cjs/blocks/index.js.map +1 -1
  32. package/build/cjs/components/Buttons/Buttons.css +2 -2
  33. package/build/cjs/components/Buttons/Buttons.d.ts +2 -1
  34. package/build/cjs/components/Buttons/Buttons.js +8 -3
  35. package/build/cjs/components/Buttons/Buttons.js.map +1 -1
  36. package/build/cjs/components/ContentList/ContentList.css +8 -8
  37. package/build/cjs/components/ContentList/ContentList.js +2 -0
  38. package/build/cjs/components/ContentList/ContentList.js.map +1 -1
  39. package/build/cjs/components/DefaultVideo/DefaultVideo.d.ts +1 -0
  40. package/build/cjs/components/DefaultVideo/DefaultVideo.js +2 -2
  41. package/build/cjs/components/DefaultVideo/DefaultVideo.js.map +1 -1
  42. package/build/cjs/components/IconWrapper/IconWrapper.css +6 -0
  43. package/build/cjs/components/Image/Image.d.ts +5 -1
  44. package/build/cjs/components/Image/Image.js +4 -2
  45. package/build/cjs/components/Image/Image.js.map +1 -1
  46. package/build/cjs/components/ImageBase/ImageBase.d.ts +2 -2
  47. package/build/cjs/components/ImageBase/ImageBase.js +5 -5
  48. package/build/cjs/components/ImageBase/ImageBase.js.map +1 -1
  49. package/build/cjs/components/Links/Links.css +1 -1
  50. package/build/cjs/components/Links/Links.js +2 -0
  51. package/build/cjs/components/Links/Links.js.map +1 -1
  52. package/build/cjs/components/Media/Image/Image.d.ts +4 -0
  53. package/build/cjs/components/Media/Image/Image.js +3 -3
  54. package/build/cjs/components/Media/Image/Image.js.map +1 -1
  55. package/build/cjs/components/Media/Media.js +8 -4
  56. package/build/cjs/components/Media/Media.js.map +1 -1
  57. package/build/cjs/components/Media/Video/Video.d.ts +5 -0
  58. package/build/cjs/components/Media/Video/Video.js +30 -4
  59. package/build/cjs/components/Media/Video/Video.js.map +1 -1
  60. package/build/cjs/components/ReactPlayer/ReactPlayer.css +5 -0
  61. package/build/cjs/components/ReactPlayer/ReactPlayer.d.ts +5 -0
  62. package/build/cjs/components/ReactPlayer/ReactPlayer.js +12 -4
  63. package/build/cjs/components/ReactPlayer/ReactPlayer.js.map +1 -1
  64. package/build/cjs/components/Title/TitleItem.css +6 -0
  65. package/build/cjs/components/index.d.ts +1 -0
  66. package/build/cjs/components/index.js +3 -1
  67. package/build/cjs/components/index.js.map +1 -1
  68. package/build/cjs/constructor-items.d.ts +1 -0
  69. package/build/cjs/constructor-items.js +1 -0
  70. package/build/cjs/constructor-items.js.map +1 -1
  71. package/build/cjs/context/imageContext/imageContext.d.ts +1 -1
  72. package/build/cjs/context/imageContext/imageContext.js.map +1 -1
  73. package/build/cjs/demo/ComponentsText.stories.js +3 -3
  74. package/build/cjs/demo/ComponentsText.stories.js.map +1 -1
  75. package/build/cjs/hooks/index.d.ts +1 -0
  76. package/build/cjs/hooks/index.js +1 -0
  77. package/build/cjs/hooks/index.js.map +1 -1
  78. package/build/cjs/hooks/useImageSize.d.ts +8 -0
  79. package/build/cjs/hooks/useImageSize.js +52 -0
  80. package/build/cjs/hooks/useImageSize.js.map +1 -0
  81. package/build/cjs/models/constructor-items/blocks.d.ts +31 -22
  82. package/build/cjs/models/constructor-items/blocks.js +6 -1
  83. package/build/cjs/models/constructor-items/blocks.js.map +1 -1
  84. package/build/cjs/models/constructor-items/common.d.ts +1 -1
  85. package/build/cjs/models/constructor-items/common.js.map +1 -1
  86. package/build/cjs/models/constructor-items/sub-blocks.d.ts +6 -6
  87. package/build/cjs/models/constructor-items/sub-blocks.js.map +1 -1
  88. package/build/cjs/schema/constants.d.ts +5 -30
  89. package/build/cjs/schema/constants.js +1 -0
  90. package/build/cjs/schema/constants.js.map +1 -1
  91. package/build/cjs/schema/validators/blocks.d.ts +1 -0
  92. package/build/cjs/schema/validators/blocks.js +1 -0
  93. package/build/cjs/schema/validators/blocks.js.map +1 -1
  94. package/build/cjs/schema/validators/common.d.ts +28 -0
  95. package/build/cjs/schema/validators/common.js +27 -2
  96. package/build/cjs/schema/validators/common.js.map +1 -1
  97. package/build/cjs/sub-blocks/BackgroundCard/schema.d.ts +3 -10
  98. package/build/cjs/sub-blocks/BackgroundCard/schema.js +1 -1
  99. package/build/cjs/sub-blocks/BackgroundCard/schema.js.map +1 -1
  100. package/build/cjs/sub-blocks/BasicCard/schema.d.ts +2 -9
  101. package/build/cjs/sub-blocks/BasicCard/schema.js +1 -1
  102. package/build/cjs/sub-blocks/BasicCard/schema.js.map +1 -1
  103. package/build/cjs/sub-blocks/Content/Content.css +29 -17
  104. package/build/cjs/sub-blocks/Content/Content.js +7 -13
  105. package/build/cjs/sub-blocks/Content/Content.js.map +1 -1
  106. package/build/cjs/sub-blocks/Content/schema.d.ts +0 -100
  107. package/build/cjs/sub-blocks/Content/schema.js +1 -14
  108. package/build/cjs/sub-blocks/Content/schema.js.map +1 -1
  109. package/build/cjs/sub-blocks/ImageCard/schema.d.ts +0 -11
  110. package/build/cjs/sub-blocks/LayoutItem/schema.d.ts +0 -11
  111. package/build/cjs/sub-blocks/LayoutItem/schema.js +1 -1
  112. package/build/cjs/sub-blocks/LayoutItem/schema.js.map +1 -1
  113. package/build/cjs/text-transform/config.js +17 -0
  114. package/build/cjs/text-transform/config.js.map +1 -1
  115. package/build/esm/blocks/ContentLayout/ContentLayout.css +2 -2
  116. package/build/esm/blocks/ContentLayout/ContentLayout.js +2 -0
  117. package/build/esm/blocks/ContentLayout/ContentLayout.js.map +1 -1
  118. package/build/esm/blocks/ContentLayout/schema.d.ts +0 -11
  119. package/build/esm/blocks/FoldableList/schema.d.ts +0 -11
  120. package/build/esm/blocks/Form/Form.css +10 -1
  121. package/build/esm/blocks/Form/Form.js +4 -2
  122. package/build/esm/blocks/Form/Form.js.map +1 -1
  123. package/build/esm/blocks/Form/schema.d.ts +0 -11
  124. package/build/esm/blocks/Header/Header.css +6 -0
  125. package/build/esm/blocks/Header/schema.js +2 -26
  126. package/build/esm/blocks/Header/schema.js.map +1 -1
  127. package/build/esm/blocks/Hero/Hero.css +211 -0
  128. package/build/esm/blocks/Hero/Hero.d.ts +4 -0
  129. package/build/esm/blocks/Hero/Hero.js +48 -0
  130. package/build/esm/blocks/Hero/Hero.js.map +1 -0
  131. package/build/esm/blocks/Hero/hooks.d.ts +4 -0
  132. package/build/esm/blocks/Hero/hooks.js +33 -0
  133. package/build/esm/blocks/Hero/hooks.js.map +1 -0
  134. package/build/esm/blocks/Hero/schema.d.ts +2076 -0
  135. package/build/esm/blocks/Hero/schema.js +62 -0
  136. package/build/esm/blocks/Hero/schema.js.map +1 -0
  137. package/build/esm/blocks/Info/schema.d.ts +0 -22
  138. package/build/esm/blocks/Map/schema.d.ts +0 -11
  139. package/build/esm/blocks/Media/schema.d.ts +0 -22
  140. package/build/esm/blocks/Questions/schema.d.ts +0 -11
  141. package/build/esm/blocks/Tabs/schema.d.ts +0 -11
  142. package/build/esm/blocks/index.d.ts +1 -0
  143. package/build/esm/blocks/index.js +1 -0
  144. package/build/esm/blocks/index.js.map +1 -1
  145. package/build/esm/components/Buttons/Buttons.css +2 -2
  146. package/build/esm/components/Buttons/Buttons.d.ts +2 -1
  147. package/build/esm/components/Buttons/Buttons.js +8 -3
  148. package/build/esm/components/Buttons/Buttons.js.map +1 -1
  149. package/build/esm/components/ContentList/ContentList.css +8 -8
  150. package/build/esm/components/ContentList/ContentList.js +2 -0
  151. package/build/esm/components/ContentList/ContentList.js.map +1 -1
  152. package/build/esm/components/DefaultVideo/DefaultVideo.d.ts +1 -0
  153. package/build/esm/components/DefaultVideo/DefaultVideo.js +2 -2
  154. package/build/esm/components/DefaultVideo/DefaultVideo.js.map +1 -1
  155. package/build/esm/components/IconWrapper/IconWrapper.css +6 -0
  156. package/build/esm/components/Image/Image.d.ts +5 -1
  157. package/build/esm/components/Image/Image.js +4 -2
  158. package/build/esm/components/Image/Image.js.map +1 -1
  159. package/build/esm/components/ImageBase/ImageBase.d.ts +2 -2
  160. package/build/esm/components/ImageBase/ImageBase.js +5 -4
  161. package/build/esm/components/ImageBase/ImageBase.js.map +1 -1
  162. package/build/esm/components/Links/Links.css +1 -1
  163. package/build/esm/components/Links/Links.js +2 -0
  164. package/build/esm/components/Links/Links.js.map +1 -1
  165. package/build/esm/components/Media/Image/Image.d.ts +4 -0
  166. package/build/esm/components/Media/Image/Image.js +3 -3
  167. package/build/esm/components/Media/Image/Image.js.map +1 -1
  168. package/build/esm/components/Media/Media.js +8 -4
  169. package/build/esm/components/Media/Media.js.map +1 -1
  170. package/build/esm/components/Media/Video/Video.d.ts +5 -0
  171. package/build/esm/components/Media/Video/Video.js +30 -4
  172. package/build/esm/components/Media/Video/Video.js.map +1 -1
  173. package/build/esm/components/ReactPlayer/ReactPlayer.css +5 -0
  174. package/build/esm/components/ReactPlayer/ReactPlayer.d.ts +5 -0
  175. package/build/esm/components/ReactPlayer/ReactPlayer.js +13 -5
  176. package/build/esm/components/ReactPlayer/ReactPlayer.js.map +1 -1
  177. package/build/esm/components/Title/TitleItem.css +6 -0
  178. package/build/esm/components/index.d.ts +1 -0
  179. package/build/esm/components/index.js +1 -0
  180. package/build/esm/components/index.js.map +1 -1
  181. package/build/esm/constructor-items.d.ts +1 -0
  182. package/build/esm/constructor-items.js +2 -1
  183. package/build/esm/constructor-items.js.map +1 -1
  184. package/build/esm/context/imageContext/imageContext.d.ts +1 -1
  185. package/build/esm/context/imageContext/imageContext.js.map +1 -1
  186. package/build/esm/demo/ComponentsText.stories.js +3 -3
  187. package/build/esm/demo/ComponentsText.stories.js.map +1 -1
  188. package/build/esm/hooks/index.d.ts +1 -0
  189. package/build/esm/hooks/index.js +1 -0
  190. package/build/esm/hooks/index.js.map +1 -1
  191. package/build/esm/hooks/useImageSize.d.ts +8 -0
  192. package/build/esm/hooks/useImageSize.js +47 -0
  193. package/build/esm/hooks/useImageSize.js.map +1 -0
  194. package/build/esm/models/constructor-items/blocks.d.ts +31 -22
  195. package/build/esm/models/constructor-items/blocks.js +6 -1
  196. package/build/esm/models/constructor-items/blocks.js.map +1 -1
  197. package/build/esm/models/constructor-items/common.d.ts +1 -1
  198. package/build/esm/models/constructor-items/common.js.map +1 -1
  199. package/build/esm/models/constructor-items/sub-blocks.d.ts +6 -6
  200. package/build/esm/models/constructor-items/sub-blocks.js.map +1 -1
  201. package/build/esm/schema/constants.d.ts +5 -30
  202. package/build/esm/schema/constants.js +2 -1
  203. package/build/esm/schema/constants.js.map +1 -1
  204. package/build/esm/schema/validators/blocks.d.ts +1 -0
  205. package/build/esm/schema/validators/blocks.js +1 -0
  206. package/build/esm/schema/validators/blocks.js.map +1 -1
  207. package/build/esm/schema/validators/common.d.ts +28 -0
  208. package/build/esm/schema/validators/common.js +26 -1
  209. package/build/esm/schema/validators/common.js.map +1 -1
  210. package/build/esm/sub-blocks/BackgroundCard/schema.d.ts +3 -10
  211. package/build/esm/sub-blocks/BackgroundCard/schema.js +1 -1
  212. package/build/esm/sub-blocks/BackgroundCard/schema.js.map +1 -1
  213. package/build/esm/sub-blocks/BasicCard/schema.d.ts +2 -9
  214. package/build/esm/sub-blocks/BasicCard/schema.js +1 -1
  215. package/build/esm/sub-blocks/BasicCard/schema.js.map +1 -1
  216. package/build/esm/sub-blocks/Content/Content.css +29 -17
  217. package/build/esm/sub-blocks/Content/Content.js +7 -12
  218. package/build/esm/sub-blocks/Content/Content.js.map +1 -1
  219. package/build/esm/sub-blocks/Content/schema.d.ts +0 -100
  220. package/build/esm/sub-blocks/Content/schema.js +0 -13
  221. package/build/esm/sub-blocks/Content/schema.js.map +1 -1
  222. package/build/esm/sub-blocks/ImageCard/schema.d.ts +0 -11
  223. package/build/esm/sub-blocks/LayoutItem/schema.d.ts +0 -11
  224. package/build/esm/sub-blocks/LayoutItem/schema.js +1 -1
  225. package/build/esm/sub-blocks/LayoutItem/schema.js.map +1 -1
  226. package/build/esm/text-transform/config.js +17 -0
  227. package/build/esm/text-transform/config.js.map +1 -1
  228. package/package.json +1 -1
  229. package/schema/index.js +1 -1
  230. package/server/models/constructor-items/blocks.d.ts +31 -22
  231. package/server/models/constructor-items/blocks.js +6 -1
  232. package/server/models/constructor-items/common.d.ts +1 -1
  233. package/server/models/constructor-items/sub-blocks.d.ts +6 -6
  234. package/server/text-transform/config.js +17 -0
  235. package/styles/mixins.scss +4 -0
  236. package/widget/index.js +1 -1
  237. package/build/cjs/components/ContentLabels/ContentLabels.css +0 -53
  238. package/build/cjs/components/ContentLabels/ContentLabels.d.ts +0 -3
  239. package/build/cjs/components/ContentLabels/ContentLabels.js +0 -16
  240. package/build/cjs/components/ContentLabels/ContentLabels.js.map +0 -1
  241. package/build/esm/components/ContentLabels/ContentLabels.css +0 -53
  242. package/build/esm/components/ContentLabels/ContentLabels.d.ts +0 -4
  243. package/build/esm/components/ContentLabels/ContentLabels.js +0 -14
  244. package/build/esm/components/ContentLabels/ContentLabels.js.map +0 -1
package/README.md CHANGED
@@ -142,7 +142,7 @@ interface PageConstructorProviderProps {
142
142
  location?: Location; //API of the browser or router history, the page URL.
143
143
  analytics?: AnalyticsContextProps; // function to handle analytics event
144
144
 
145
- ssrConfig?: SSR; //A flag indicating that the code is run on the server size.
145
+ ssrConfig?: SSR; //A flag indicating that the code is run on the server side.
146
146
  theme?: 'light' | 'dark'; //Theme to render the page with.
147
147
  mapsContext?: MapsContextType; //Params for map: apikey, type, scriptSrc, nonce
148
148
  }
@@ -1,4 +1,4 @@
1
- .pc-content-layout-block__files_size_l, .pc-content-layout-block__files_size_s {
1
+ .pc-content-layout-block__files_size_l, .pc-content-layout-block__files_size_xl, .pc-content-layout-block__files_size_s {
2
2
  margin: 0;
3
3
  }
4
4
 
@@ -18,7 +18,7 @@ unpredictable css rules order in build */
18
18
  font-size: var(--g-text-body-2-font-size);
19
19
  line-height: var(--g-text-body-2-line-height);
20
20
  }
21
- .pc-content-layout-block__files_size_l {
21
+ .pc-content-layout-block__files_size_l, .pc-content-layout-block__files_size_xl {
22
22
  font-size: var(--g-text-body-3-font-size);
23
23
  line-height: var(--g-text-body-3-line-height);
24
24
  }
@@ -17,7 +17,9 @@ function getFileTextSize(size) {
17
17
  switch (size) {
18
18
  case 's':
19
19
  return 's';
20
+ case 'm':
20
21
  case 'l':
22
+ case 'xl':
21
23
  default:
22
24
  return 'l';
23
25
  }
@@ -1 +1 @@
1
- {"version":3,"file":"ContentLayout.js","sourceRoot":"../../../../src","sources":["blocks/ContentLayout/ContentLayout.tsx"],"names":[],"mappings":";;;;;;AAAA,qDAA+B;AAE/B,0DAA2D;AAC3D,kDAA4C;AAC5C,wDAA6C;AAC7C,kFAAgE;AAChE,8CAA+B;AAE/B,0DAAyC;AACzC,gDAAkD;AAIlD,MAAM,CAAC,GAAG,IAAA,aAAK,EAAC,sBAAsB,CAAC,CAAC;AAExC,SAAS,eAAe,CAAC,IAAiB;IACtC,QAAQ,IAAI,EAAE,CAAC;QACX,KAAK,GAAG;YACJ,OAAO,GAAG,CAAC;QACf,KAAK,GAAG,CAAC;QACT;YACI,OAAO,GAAG,CAAC;IACnB,CAAC;AACL,CAAC;AAED,SAAS,YAAY,CAAC,IAAqB;IACvC,QAAQ,IAAI,EAAE,CAAC;QACX,KAAK,GAAG;YACJ,OAAO,EAAC,GAAG,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,EAAC,CAAC;QAC5B,KAAK,GAAG;YACJ,OAAO,EAAC,GAAG,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAC,CAAC;QAC7B,KAAK,GAAG,CAAC;QACT;YACI,OAAO,EAAC,GAAG,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,EAAC,CAAC;IAChC,CAAC;AACL,CAAC;AAEM,MAAM,kBAAkB,GAAG,CAAC,KAA8B,EAAE,EAAE;IACjE,MAAM,WAAW,GAAG,IAAA,mCAAc,GAAE,CAAC;IACrC,MAAM,QAAQ,GAAG,WAAW,IAAI,uBAAW,CAAC,EAAE,CAAC;IAE/C,MAAM,EACF,WAAW,EACX,WAAW,EACX,IAAI,GAAG,GAAG,EACV,UAAU,EACV,QAAQ,EACR,KAAK,GAAG,SAAS,EACjB,SAAS,GAAG,GAAG,GAClB,GAAG,KAAK,CAAC;IAEV,MAAM,QAAQ,GAAG,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE,CAAC,YAAY,CAAC,SAAS,CAAC,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC;IAC3E,MAAM,WAAW,GAAG,IAAA,gBAAQ,GAAE,CAAC;IAC/B,MAAM,gBAAgB,GAAG,IAAA,sBAAc,EAAC,UAAU,EAAE,WAAW,CAAC,CAAC;IAEjE,OAAO,CACH,iCAAK,SAAS,EAAE,CAAC,CAAC,EAAC,IAAI,EAAE,KAAK,EAAE,UAAU,EAAE,OAAO,CAAC,UAAU,CAAC,EAAC,CAAC,aAC7D,uBAAC,oBAAO,IACJ,SAAS,EAAE,CAAC,CAAC,SAAS,CAAC,KACnB,WAAW,EACf,IAAI,EAAE,IAAI,EACV,QAAQ,EAAE,QAAQ,EAClB,QAAQ,EAAE,QAAQ,EAClB,KAAK,EAAE,KAAK,GACd,EACD,WAAW,IAAI,CACZ,uBAAC,UAAG,IAAC,SAAS,EAAE,CAAC,CAAC,OAAO,EAAE,EAAC,IAAI,EAAE,QAAQ,EAAC,CAAC,EAAE,KAAK,QAAC,KAAK,EAAE,QAAQ,YAC9D,WAAW,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CACvB,2BAAC,qBAAQ,IACL,SAAS,EAAE,CAAC,CAAC,MAAM,CAAC,KAChB,IAAI,EACR,GAAG,EAAE,IAAI,CAAC,IAAI,EACd,IAAI,EAAC,YAAY,EACjB,QAAQ,EAAE,eAAe,CAAC,IAAI,CAAC,EAC/B,KAAK,EAAE,KAAK,GACd,CACL,CAAC,GACA,CACT,EACA,UAAU,IAAI,CACX,gCAAK,SAAS,EAAE,CAAC,CAAC,YAAY,CAAC,YAC3B,uBAAC,4BAAe,IACZ,SAAS,EAAE,CAAC,CAAC,iBAAiB,CAAC,KAC3B,gBAAgB,EACpB,IAAI,EAAE,QAAQ,GAChB,GACA,CACT,IACC,CACT,CAAC;AACN,CAAC,CAAC;AArDW,QAAA,kBAAkB,sBAqD7B;AACF,kBAAe,0BAAkB,CAAC","sourcesContent":["import * as React from 'react';\n\nimport {BackgroundImage, FileLink} from '../../components';\nimport {BREAKPOINTS} from '../../constants';\nimport {useTheme} from '../../context/theme';\nimport {useWindowWidth} from '../../context/windowWidthContext';\nimport {Col} from '../../grid';\nimport {ContentLayoutBlockProps, ContentSize, ContentTextSize} from '../../models';\nimport {Content} from '../../sub-blocks';\nimport {block, getThemedValue} from '../../utils';\n\nimport './ContentLayout.scss';\n\nconst b = block('content-layout-block');\n\nfunction getFileTextSize(size: ContentSize) {\n switch (size) {\n case 's':\n return 's';\n case 'l':\n default:\n return 'l';\n }\n}\n\nfunction getTextWidth(size: ContentTextSize) {\n switch (size) {\n case 's':\n return {all: 12, md: 6};\n case 'l':\n return {all: 12, md: 12};\n case 'm':\n default:\n return {all: 12, md: 8};\n }\n}\n\nexport const ContentLayoutBlock = (props: ContentLayoutBlockProps) => {\n const windowWidth = useWindowWidth();\n const isMobile = windowWidth <= BREAKPOINTS.sm;\n\n const {\n textContent,\n fileContent,\n size = 'l',\n background,\n centered,\n theme = 'default',\n textWidth = 'm',\n } = props;\n\n const colSizes = React.useMemo(() => getTextWidth(textWidth), [textWidth]);\n const globalTheme = useTheme();\n const themedBackground = getThemedValue(background, globalTheme);\n\n return (\n <div className={b({size, theme, background: Boolean(background)})}>\n <Content\n className={b('content')}\n {...textContent}\n size={size}\n centered={centered}\n colSizes={colSizes}\n theme={theme}\n />\n {fileContent && (\n <Col className={b('files', {size, centered})} reset sizes={colSizes}>\n {fileContent.map((file) => (\n <FileLink\n className={b('file')}\n {...file}\n key={file.href}\n type=\"horizontal\"\n textSize={getFileTextSize(size)}\n theme={theme}\n />\n ))}\n </Col>\n )}\n {background && (\n <div className={b('background')}>\n <BackgroundImage\n className={b('background-item')}\n {...themedBackground}\n hide={isMobile}\n />\n </div>\n )}\n </div>\n );\n};\nexport default ContentLayoutBlock;\n"]}
1
+ {"version":3,"file":"ContentLayout.js","sourceRoot":"../../../../src","sources":["blocks/ContentLayout/ContentLayout.tsx"],"names":[],"mappings":"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","sourcesContent":["import * as React from 'react';\n\nimport {BackgroundImage, FileLink} from '../../components';\nimport {BREAKPOINTS} from '../../constants';\nimport {useTheme} from '../../context/theme';\nimport {useWindowWidth} from '../../context/windowWidthContext';\nimport {Col} from '../../grid';\nimport {ContentLayoutBlockProps, ContentSize, ContentTextSize} from '../../models';\nimport {Content} from '../../sub-blocks';\nimport {block, getThemedValue} from '../../utils';\n\nimport './ContentLayout.scss';\n\nconst b = block('content-layout-block');\n\nfunction getFileTextSize(size: ContentSize) {\n switch (size) {\n case 's':\n return 's';\n case 'm':\n case 'l':\n case 'xl':\n default:\n return 'l';\n }\n}\n\nfunction getTextWidth(size: ContentTextSize) {\n switch (size) {\n case 's':\n return {all: 12, md: 6};\n case 'l':\n return {all: 12, md: 12};\n case 'm':\n default:\n return {all: 12, md: 8};\n }\n}\n\nexport const ContentLayoutBlock = (props: ContentLayoutBlockProps) => {\n const windowWidth = useWindowWidth();\n const isMobile = windowWidth <= BREAKPOINTS.sm;\n\n const {\n textContent,\n fileContent,\n size = 'l',\n background,\n centered,\n theme = 'default',\n textWidth = 'm',\n } = props;\n\n const colSizes = React.useMemo(() => getTextWidth(textWidth), [textWidth]);\n const globalTheme = useTheme();\n const themedBackground = getThemedValue(background, globalTheme);\n\n return (\n <div className={b({size, theme, background: Boolean(background)})}>\n <Content\n className={b('content')}\n {...textContent}\n size={size}\n centered={centered}\n colSizes={colSizes}\n theme={theme}\n />\n {fileContent && (\n <Col className={b('files', {size, centered})} reset sizes={colSizes}>\n {fileContent.map((file) => (\n <FileLink\n className={b('file')}\n {...file}\n key={file.href}\n type=\"horizontal\"\n textSize={getFileTextSize(size)}\n theme={theme}\n />\n ))}\n </Col>\n )}\n {background && (\n <div className={b('background')}>\n <BackgroundImage\n className={b('background-item')}\n {...themedBackground}\n hide={isMobile}\n />\n </div>\n )}\n </div>\n );\n};\nexport default ContentLayoutBlock;\n"]}
@@ -303,17 +303,6 @@ export declare const ContentLayoutBlock: {
303
303
  };
304
304
  };
305
305
  };
306
- labels: {
307
- type: string;
308
- items: {
309
- type: string;
310
- properties: {
311
- when: {
312
- type: string;
313
- };
314
- };
315
- };
316
- };
317
306
  controlPosition: {
318
307
  type: string;
319
308
  enum: string[];
@@ -129,17 +129,6 @@ export declare const FoldableListBlock: {
129
129
  contentType: string;
130
130
  inputType: string;
131
131
  };
132
- labels: {
133
- type: string;
134
- items: {
135
- type: string;
136
- properties: {
137
- when: {
138
- type: string;
139
- };
140
- };
141
- };
142
- };
143
132
  additionalInfo: {
144
133
  type: string;
145
134
  contentType: string;
@@ -4,6 +4,15 @@ unpredictable css rules order in build */
4
4
  border-radius: 32px;
5
5
  position: relative;
6
6
  }
7
+ .pc-form-block__additional-content {
8
+ display: flex;
9
+ flex-wrap: wrap;
10
+ width: 100%;
11
+ margin-top: 20px;
12
+ }
13
+ .pc-form-block__additional-content_centered {
14
+ justify-content: center;
15
+ }
7
16
  .pc-form-block__title {
8
17
  margin: 0 0 24px 10px;
9
18
  }
@@ -94,7 +103,7 @@ unpredictable css rules order in build */
94
103
  text-align: center;
95
104
  padding-bottom: 32px;
96
105
  }
97
- .pc-form-block_with-background .pc-form-block__row .pc-form-block__content-wrapper .pc-content-labels, .pc-form-block:not(.pc-form-block_with-background) .pc-form-block__row .pc-form-block__content-wrapper .pc-content-labels {
106
+ .pc-form-block_with-background .pc-form-block__row .pc-form-block__additional-content, .pc-form-block:not(.pc-form-block_with-background) .pc-form-block__row .pc-form-block__additional-content {
98
107
  justify-content: center;
99
108
  }
100
109
  .pc-form-block:not(.pc-form-block_with-background) .pc-form-block__row .pc-form-block__content-wrapper {
@@ -16,7 +16,7 @@ const utils_2 = require("./utils.js");
16
16
  const b = (0, utils_1.block)('form-block');
17
17
  const colSizes = { [grid_1.GridColumnSize.Lg]: 6, [grid_1.GridColumnSize.All]: 12 };
18
18
  const Form = (props) => {
19
- const { formData, title, textContent, direction = models_1.FormBlockDirection.Center, background, customFormNode, } = props;
19
+ const { formData, title, textContent, direction = models_1.FormBlockDirection.Center, background, customFormNode, additionalContentNode, } = props;
20
20
  const [contentLoaded, setContentLoaded] = React.useState(false);
21
21
  const isMobile = React.useContext(mobileContext_1.MobileContext);
22
22
  const theme = (0, theme_1.useTheme)();
@@ -46,7 +46,9 @@ const Form = (props) => {
46
46
  ? grid_1.GridAlignItems.Center
47
47
  : grid_1.GridAlignItems.Start, className: b('row', {
48
48
  direction,
49
- }), children: [(0, jsx_runtime_1.jsx)(grid_1.Col, { sizes: colSizes, className: b('content-col'), children: textContent && ((0, jsx_runtime_1.jsx)("div", { className: b('content-wrapper'), children: (0, jsx_runtime_1.jsx)(sub_blocks_1.Content, { theme: "default", ...textContent, centered: direction === models_1.FormBlockDirection.Center, colSizes: { all: 12 }, className: b('content') }) })) }), (0, jsx_runtime_1.jsx)(grid_1.Col, { sizes: colSizes, className: b('form-col'), children: (0, jsx_runtime_1.jsx)("div", { className: b('form-wrapper'), children: (0, jsx_runtime_1.jsx)("div", { className: b('full-form', {
49
+ }), children: [(0, jsx_runtime_1.jsx)(grid_1.Col, { sizes: colSizes, className: b('content-col'), children: textContent && ((0, jsx_runtime_1.jsxs)("div", { className: b('content-wrapper'), children: [(0, jsx_runtime_1.jsx)(sub_blocks_1.Content, { theme: "default", ...textContent, centered: direction === models_1.FormBlockDirection.Center, colSizes: { all: 12 }, className: b('content') }), additionalContentNode && ((0, jsx_runtime_1.jsx)("div", { className: b('additional-content', {
50
+ centered: direction === models_1.FormBlockDirection.Center,
51
+ }), children: additionalContentNode }))] })) }), (0, jsx_runtime_1.jsx)(grid_1.Col, { sizes: colSizes, className: b('form-col'), children: (0, jsx_runtime_1.jsx)("div", { className: b('form-wrapper'), children: (0, jsx_runtime_1.jsx)("div", { className: b('full-form', {
50
52
  hidden: !contentLoaded,
51
53
  }), children: customFormNode || ((0, jsx_runtime_1.jsxs)(React.Fragment, { children: [title && ((0, jsx_runtime_1.jsx)(components_1.Title, { title: {
52
54
  text: title,
@@ -1 +1 @@
1
- {"version":3,"file":"Form.js","sourceRoot":"../../../../src","sources":["blocks/Form/Form.tsx"],"names":[],"mappings":"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","sourcesContent":["import * as React from 'react';\n\nimport {BackgroundImage, Title} from '../../components';\nimport InnerForm from '../../components/InnerForm/InnerForm';\nimport {MobileContext} from '../../context/mobileContext';\nimport {useTheme} from '../../context/theme';\nimport {Col, Grid, GridAlignItems, GridColumnSize, Row} from '../../grid';\nimport {useDeviceValue} from '../../hooks/useDeviceValue';\nimport type {FormBlockProps} from '../../models';\nimport {\n FormBlockDataTypes,\n FormBlockDirection,\n isHubspotDataForm,\n isYandexDataForm,\n} from '../../models';\nimport {Content} from '../../sub-blocks';\nimport {block, getThemedValue} from '../../utils';\n\nimport {hasBackgroundCSS} from './utils';\n\nimport './Form.scss';\n\nconst b = block('form-block');\n\nconst colSizes = {[GridColumnSize.Lg]: 6, [GridColumnSize.All]: 12};\n\nconst Form = (props: FormBlockProps) => {\n const {\n formData,\n title,\n textContent,\n direction = FormBlockDirection.Center,\n background,\n customFormNode,\n } = props;\n const [contentLoaded, setContentLoaded] = React.useState(false);\n const isMobile = React.useContext(MobileContext);\n const theme = useTheme();\n\n const themedBackground = getThemedValue(background, theme) || undefined;\n const themedBackgroundStyle = useDeviceValue(themedBackground?.style) || undefined;\n\n const withBackground = Boolean(\n themedBackground &&\n (themedBackground.src ||\n themedBackground.desktop ||\n hasBackgroundCSS(themedBackgroundStyle ?? {})),\n );\n\n const onContentLoad = React.useCallback(() => {\n setContentLoaded(true);\n }, []);\n\n if (!formData && !customFormNode) {\n return null;\n }\n\n let formType;\n\n if (isYandexDataForm(formData)) {\n formType = FormBlockDataTypes.YANDEX;\n } else if (isHubspotDataForm(formData)) {\n formType = FormBlockDataTypes.HUBSPOT;\n }\n\n return (\n <div\n className={b({\n 'with-background': withBackground,\n 'form-type': formType,\n })}\n >\n {themedBackground && (\n <BackgroundImage\n {...themedBackground}\n style={themedBackgroundStyle}\n className={b('media')}\n imageClassName={b('image')}\n />\n )}\n <Grid>\n <Row\n alignItems={\n direction === FormBlockDirection.Center\n ? GridAlignItems.Center\n : GridAlignItems.Start\n }\n className={b('row', {\n direction,\n })}\n >\n <Col sizes={colSizes} className={b('content-col')}>\n {textContent && (\n <div className={b('content-wrapper')}>\n <Content\n theme=\"default\"\n {...textContent}\n centered={direction === FormBlockDirection.Center}\n colSizes={{all: 12}}\n className={b('content')}\n />\n </div>\n )}\n </Col>\n <Col sizes={colSizes} className={b('form-col')}>\n <div className={b('form-wrapper')}>\n <div\n className={b('full-form', {\n hidden: !contentLoaded,\n })}\n >\n {customFormNode || (\n <React.Fragment>\n {title && (\n <Title\n title={{\n text: title,\n textSize: 's',\n }}\n className={b('title', {mobile: isMobile})}\n colSizes={{all: 12}}\n />\n )}\n <InnerForm\n className={b('form')}\n formData={formData}\n onContentLoad={onContentLoad}\n />\n </React.Fragment>\n )}\n </div>\n </div>\n </Col>\n </Row>\n </Grid>\n </div>\n );\n};\n\nexport default Form;\n"]}
1
+ {"version":3,"file":"Form.js","sourceRoot":"../../../../src","sources":["blocks/Form/Form.tsx"],"names":[],"mappings":"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","sourcesContent":["import * as React from 'react';\n\nimport {BackgroundImage, Title} from '../../components';\nimport InnerForm from '../../components/InnerForm/InnerForm';\nimport {MobileContext} from '../../context/mobileContext';\nimport {useTheme} from '../../context/theme';\nimport {Col, Grid, GridAlignItems, GridColumnSize, Row} from '../../grid';\nimport {useDeviceValue} from '../../hooks/useDeviceValue';\nimport type {FormBlockProps} from '../../models';\nimport {\n FormBlockDataTypes,\n FormBlockDirection,\n isHubspotDataForm,\n isYandexDataForm,\n} from '../../models';\nimport {Content} from '../../sub-blocks';\nimport {block, getThemedValue} from '../../utils';\n\nimport {hasBackgroundCSS} from './utils';\n\nimport './Form.scss';\n\nconst b = block('form-block');\n\nconst colSizes = {[GridColumnSize.Lg]: 6, [GridColumnSize.All]: 12};\n\nconst Form = (props: FormBlockProps) => {\n const {\n formData,\n title,\n textContent,\n direction = FormBlockDirection.Center,\n background,\n customFormNode,\n additionalContentNode,\n } = props;\n const [contentLoaded, setContentLoaded] = React.useState(false);\n const isMobile = React.useContext(MobileContext);\n const theme = useTheme();\n\n const themedBackground = getThemedValue(background, theme) || undefined;\n const themedBackgroundStyle = useDeviceValue(themedBackground?.style) || undefined;\n\n const withBackground = Boolean(\n themedBackground &&\n (themedBackground.src ||\n themedBackground.desktop ||\n hasBackgroundCSS(themedBackgroundStyle ?? {})),\n );\n\n const onContentLoad = React.useCallback(() => {\n setContentLoaded(true);\n }, []);\n\n if (!formData && !customFormNode) {\n return null;\n }\n\n let formType;\n\n if (isYandexDataForm(formData)) {\n formType = FormBlockDataTypes.YANDEX;\n } else if (isHubspotDataForm(formData)) {\n formType = FormBlockDataTypes.HUBSPOT;\n }\n\n return (\n <div\n className={b({\n 'with-background': withBackground,\n 'form-type': formType,\n })}\n >\n {themedBackground && (\n <BackgroundImage\n {...themedBackground}\n style={themedBackgroundStyle}\n className={b('media')}\n imageClassName={b('image')}\n />\n )}\n <Grid>\n <Row\n alignItems={\n direction === FormBlockDirection.Center\n ? GridAlignItems.Center\n : GridAlignItems.Start\n }\n className={b('row', {\n direction,\n })}\n >\n <Col sizes={colSizes} className={b('content-col')}>\n {textContent && (\n <div className={b('content-wrapper')}>\n <Content\n theme=\"default\"\n {...textContent}\n centered={direction === FormBlockDirection.Center}\n colSizes={{all: 12}}\n className={b('content')}\n />\n {additionalContentNode && (\n <div\n className={b('additional-content', {\n centered: direction === FormBlockDirection.Center,\n })}\n >\n {additionalContentNode}\n </div>\n )}\n </div>\n )}\n </Col>\n <Col sizes={colSizes} className={b('form-col')}>\n <div className={b('form-wrapper')}>\n <div\n className={b('full-form', {\n hidden: !contentLoaded,\n })}\n >\n {customFormNode || (\n <React.Fragment>\n {title && (\n <Title\n title={{\n text: title,\n textSize: 's',\n }}\n className={b('title', {mobile: isMobile})}\n colSizes={{all: 12}}\n />\n )}\n <InnerForm\n className={b('form')}\n formData={formData}\n onContentLoad={onContentLoad}\n />\n </React.Fragment>\n )}\n </div>\n </div>\n </Col>\n </Row>\n </Grid>\n </div>\n );\n};\n\nexport default Form;\n"]}
@@ -242,17 +242,6 @@ export declare const FormBlock: {
242
242
  };
243
243
  };
244
244
  };
245
- labels: {
246
- type: string;
247
- items: {
248
- type: string;
249
- properties: {
250
- when: {
251
- type: string;
252
- };
253
- };
254
- };
255
- };
256
245
  controlPosition: {
257
246
  type: string;
258
247
  enum: string[];
@@ -67,6 +67,12 @@ unpredictable css rules order in build */
67
67
  font-weight: var(--g-text-accent-font-weight);
68
68
  position: relative;
69
69
  }
70
+ @media (max-width: 769px) {
71
+ .pc-header-block__title.pc-header-block__title {
72
+ font-size: var(--g-text-display-3-font-size);
73
+ line-height: var(--g-text-display-3-line-height);
74
+ }
75
+ }
70
76
  @media (max-width: 577px) {
71
77
  .pc-header-block__title.pc-header-block__title {
72
78
  font-size: var(--g-text-display-2-font-size);
@@ -86,31 +86,7 @@ exports.HeaderProperties = {
86
86
  type: 'string',
87
87
  enum: ['default', 'dark'],
88
88
  },
89
- breadcrumbs: {
90
- type: 'object',
91
- additionalProperties: false,
92
- required: ['items'],
93
- properties: {
94
- items: {
95
- type: 'array',
96
- items: {
97
- type: 'object',
98
- additionalProperties: false,
99
- required: ['url', 'text'],
100
- properties: {
101
- url: {
102
- type: 'string',
103
- },
104
- text: {
105
- type: 'string',
106
- contentType: 'text',
107
- },
108
- },
109
- },
110
- },
111
- theme: { type: 'string', enum: ['light', 'dark'] },
112
- },
113
- },
89
+ breadcrumbs: common_1.HeaderBreadcrumbsProps,
114
90
  status: {
115
91
  type: 'string',
116
92
  },
@@ -1 +1 @@
1
- {"version":3,"file":"schema.js","sourceRoot":"../../../../src","sources":["blocks/Header/schema.ts"],"names":[],"mappings":"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","sourcesContent":["import {ImageProps} from '../../components/Image/schema';\nimport {\n BlockBaseProps,\n ButtonBlock,\n MediaProps,\n VideoProps,\n mediaView,\n withTheme,\n} from '../../schema/validators/common';\nimport {filteredArray} from '../../schema/validators/utils';\n\nexport const HeaderVideoIframeProps = {\n type: 'object',\n additionalProperties: false,\n required: ['src'],\n properties: {\n src: {type: 'string'},\n autoplay: {type: 'boolean'},\n previewImg: {type: 'string'},\n height: {type: 'number'},\n },\n};\n\nexport const HeaderBackgroundProps = {\n type: 'object',\n additionalProperties: false,\n required: [],\n properties: {\n ...MediaProps,\n fullWidth: {type: 'boolean'},\n fullWidthMedia: {type: 'boolean'},\n },\n};\n\nexport const HeaderProperties = {\n title: {\n type: 'string',\n contentType: 'text',\n },\n overtitle: {\n type: 'string',\n contentType: 'text',\n },\n description: {\n type: 'string',\n contentType: 'yfm',\n inputType: 'textarea',\n },\n additionalInfo: {\n type: 'string',\n contentType: 'yfm',\n inputType: 'textarea',\n },\n width: {\n type: 'string',\n enum: ['s', 'm', 'l'],\n },\n buttons: filteredArray(ButtonBlock),\n offset: {\n type: 'string',\n enum: ['default', 'large'],\n },\n image: withTheme(ImageProps),\n video: withTheme(VideoProps),\n videoIframe: withTheme(HeaderVideoIframeProps),\n mediaView: {\n type: 'string',\n enum: mediaView,\n },\n backLink: {\n type: 'object',\n required: ['url', 'title'],\n properties: {\n url: {\n type: 'string',\n },\n title: {\n type: 'string',\n contentType: 'text',\n },\n },\n },\n imageSize: {\n type: 'string',\n enum: ['s', 'm'],\n },\n verticalOffset: {\n type: 'string',\n enum: ['0', 's', 'm', 'l', 'xl'],\n },\n background: withTheme(HeaderBackgroundProps),\n theme: {\n type: 'string',\n enum: ['default', 'dark'],\n },\n breadcrumbs: {\n type: 'object',\n additionalProperties: false,\n required: ['items'],\n properties: {\n items: {\n type: 'array',\n items: {\n type: 'object',\n additionalProperties: false,\n required: ['url', 'text'],\n properties: {\n url: {\n type: 'string',\n },\n text: {\n type: 'string',\n contentType: 'text',\n },\n },\n },\n },\n theme: {type: 'string', enum: ['light', 'dark']},\n },\n },\n status: {\n type: 'string',\n },\n centered: {\n type: 'boolean',\n },\n};\n\nexport const HeaderBlock = {\n 'header-block': {\n additionalProperties: false,\n required: ['title'],\n properties: {\n ...BlockBaseProps,\n ...HeaderProperties,\n },\n },\n};\n"]}
1
+ {"version":3,"file":"schema.js","sourceRoot":"../../../../src","sources":["blocks/Header/schema.ts"],"names":[],"mappings":"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","sourcesContent":["import {ImageProps} from '../../components/Image/schema';\nimport {\n BlockBaseProps,\n ButtonBlock,\n HeaderBreadcrumbsProps,\n MediaProps,\n VideoProps,\n mediaView,\n withTheme,\n} from '../../schema/validators/common';\nimport {filteredArray} from '../../schema/validators/utils';\n\nexport const HeaderVideoIframeProps = {\n type: 'object',\n additionalProperties: false,\n required: ['src'],\n properties: {\n src: {type: 'string'},\n autoplay: {type: 'boolean'},\n previewImg: {type: 'string'},\n height: {type: 'number'},\n },\n};\n\nexport const HeaderBackgroundProps = {\n type: 'object',\n additionalProperties: false,\n required: [],\n properties: {\n ...MediaProps,\n fullWidth: {type: 'boolean'},\n fullWidthMedia: {type: 'boolean'},\n },\n};\n\nexport const HeaderProperties = {\n title: {\n type: 'string',\n contentType: 'text',\n },\n overtitle: {\n type: 'string',\n contentType: 'text',\n },\n description: {\n type: 'string',\n contentType: 'yfm',\n inputType: 'textarea',\n },\n additionalInfo: {\n type: 'string',\n contentType: 'yfm',\n inputType: 'textarea',\n },\n width: {\n type: 'string',\n enum: ['s', 'm', 'l'],\n },\n buttons: filteredArray(ButtonBlock),\n offset: {\n type: 'string',\n enum: ['default', 'large'],\n },\n image: withTheme(ImageProps),\n video: withTheme(VideoProps),\n videoIframe: withTheme(HeaderVideoIframeProps),\n mediaView: {\n type: 'string',\n enum: mediaView,\n },\n backLink: {\n type: 'object',\n required: ['url', 'title'],\n properties: {\n url: {\n type: 'string',\n },\n title: {\n type: 'string',\n contentType: 'text',\n },\n },\n },\n imageSize: {\n type: 'string',\n enum: ['s', 'm'],\n },\n verticalOffset: {\n type: 'string',\n enum: ['0', 's', 'm', 'l', 'xl'],\n },\n background: withTheme(HeaderBackgroundProps),\n theme: {\n type: 'string',\n enum: ['default', 'dark'],\n },\n breadcrumbs: HeaderBreadcrumbsProps,\n status: {\n type: 'string',\n },\n centered: {\n type: 'boolean',\n },\n};\n\nexport const HeaderBlock = {\n 'header-block': {\n additionalProperties: false,\n required: ['title'],\n properties: {\n ...BlockBaseProps,\n ...HeaderProperties,\n },\n },\n};\n"]}
@@ -0,0 +1,211 @@
1
+ /* use this for style redefinitions to awoid problems with
2
+ unpredictable css rules order in build */
3
+ .pc-hero-block {
4
+ position: relative;
5
+ }
6
+ .pc-hero-block__background {
7
+ position: absolute;
8
+ top: 0;
9
+ bottom: 0;
10
+ left: 50%;
11
+ width: min(1440px, 100%);
12
+ border-radius: var(--pc-border-radius);
13
+ transform: translateX(-50%);
14
+ }
15
+ .pc-hero-block__background_full-width {
16
+ display: flex;
17
+ justify-content: center;
18
+ width: 100%;
19
+ border-radius: initial;
20
+ }
21
+ .pc-hero-block__background > div {
22
+ width: 100%;
23
+ height: 100%;
24
+ }
25
+ .pc-hero-block__background-image {
26
+ width: 100%;
27
+ height: 100%;
28
+ }
29
+ .pc-hero-block__background-video {
30
+ width: 100%;
31
+ height: 100%;
32
+ }
33
+ .pc-hero-block__background-video > video {
34
+ width: 100%;
35
+ height: 100%;
36
+ object-fit: cover;
37
+ }
38
+ .pc-hero-block__wrapper {
39
+ position: relative;
40
+ display: grid;
41
+ grid-template-columns: repeat(12, 1fr);
42
+ grid-template-rows: 1fr;
43
+ gap: 16px;
44
+ padding-inline: 8px;
45
+ }
46
+ .pc-hero-block__breadcrumbs {
47
+ position: absolute;
48
+ top: 16px;
49
+ left: 8px;
50
+ max-width: 100%;
51
+ }
52
+ .pc-hero-block__content {
53
+ grid-column: span 6;
54
+ padding-inline-end: 48px;
55
+ }
56
+ .pc-hero-block__content_vertical-offset_s {
57
+ padding-block: 48px;
58
+ }
59
+ .pc-hero-block__content_vertical-offset_m {
60
+ padding-block: 96px;
61
+ }
62
+ .pc-hero-block__content_vertical-offset_l {
63
+ padding-block: 128px;
64
+ }
65
+ .pc-hero-block__content_vertical-offset_xl {
66
+ padding-block: 160px;
67
+ }
68
+ .pc-hero-block__content_no-media {
69
+ width: 100%;
70
+ }
71
+ .pc-hero-block__content-overtitle {
72
+ margin-bottom: 8px;
73
+ }
74
+ .pc-hero-block__content-overtitle_theme_light {
75
+ --_--overtitle-color: var(--g-color-text-dark-primary);
76
+ }
77
+ .pc-hero-block__content-overtitle_theme_dark {
78
+ --_--overtitle-color: var(--g-color-text-light-primary);
79
+ }
80
+ .pc-hero-block__content-overtitle,
81
+ .pc-hero-block__content-overtitle .yfm_constructor {
82
+ font-size: var(--g-text-body-3-font-size);
83
+ line-height: var(--g-text-body-3-line-height);
84
+ color: var(--_--overtitle-color);
85
+ }
86
+ .pc-hero-block__media {
87
+ position: relative;
88
+ grid-column: span 6;
89
+ padding-block: 16px;
90
+ }
91
+ .pc-hero-block__media-container {
92
+ position: absolute;
93
+ inset: 16px 0;
94
+ display: flex;
95
+ align-items: center;
96
+ justify-content: center;
97
+ }
98
+ .pc-hero-block__media-container-content,
99
+ .pc-hero-block__media-container-content .pc-media-component-image__item,
100
+ .pc-hero-block__media-container-content .pc-fullscreen-image,
101
+ .pc-hero-block__media-container-content .pc-fullscreen-image__image-wrapper,
102
+ .pc-hero-block__media-container-content .pc-media-component-video__wrap,
103
+ .pc-hero-block__media-container-content .pc-media-component-video__react-player,
104
+ .pc-hero-block__media-container-content .pc-default-video,
105
+ .pc-hero-block__media-container-content .pc-ReactPlayer__preview-img,
106
+ .pc-hero-block__media-container-content .pc-full-screen-media,
107
+ .pc-hero-block__media-container-content .pc-full-screen-media__media-wrapper {
108
+ width: 100%;
109
+ height: auto;
110
+ }
111
+ .pc-hero-block__media-container-content .pc-ReactPlayer__player,
112
+ .pc-hero-block__media-container-content .pc-ReactPlayer__player > video,
113
+ .pc-hero-block__media-container-content .react-player__preview {
114
+ /* stylelint-disable declaration-no-important */
115
+ width: 100% !important;
116
+ height: auto !important;
117
+ /* stylelint-enable declaration-no-important */
118
+ }
119
+ .pc-hero-block__media-container-content_vertical,
120
+ .pc-hero-block__media-container-content_vertical .pc-media-component-image__item,
121
+ .pc-hero-block__media-container-content_vertical .pc-fullscreen-image,
122
+ .pc-hero-block__media-container-content_vertical .pc-fullscreen-image__image-wrapper,
123
+ .pc-hero-block__media-container-content_vertical .pc-media-component-video__wrap,
124
+ .pc-hero-block__media-container-content_vertical .pc-media-component-video__react-player,
125
+ .pc-hero-block__media-container-content_vertical .pc-default-video,
126
+ .pc-hero-block__media-container-content_vertical .pc-ReactPlayer__preview-img,
127
+ .pc-hero-block__media-container-content_vertical .pc-full-screen-media,
128
+ .pc-hero-block__media-container-content_vertical .pc-full-screen-media__media-wrapper {
129
+ width: auto;
130
+ height: 100%;
131
+ }
132
+ .pc-hero-block__media-container-content_vertical .pc-ReactPlayer__player,
133
+ .pc-hero-block__media-container-content_vertical .pc-ReactPlayer__player > video,
134
+ .pc-hero-block__media-container-content_vertical .react-player__preview {
135
+ /* stylelint-disable declaration-no-important */
136
+ width: auto !important;
137
+ height: 100% !important;
138
+ /* stylelint-enable declaration-no-important */
139
+ }
140
+ .pc-hero-block__media-container-content_round-corners {
141
+ border-radius: var(--pc-border-radius);
142
+ }
143
+ .pc-hero-block__media-container-content .pc-ReactPlayer__player {
144
+ display: flex;
145
+ }
146
+ .pc-hero-block__media-container-content .pc-Media__youtube {
147
+ border-radius: initial;
148
+ }
149
+ .pc-hero-block__media-container-content .pc-media-component-data-lens__wrap,
150
+ .pc-hero-block__media-container-content .pc-media-component-iframe {
151
+ margin: 0;
152
+ }
153
+ @media (max-width: 993px) {
154
+ .pc-hero-block__content {
155
+ grid-column: span 7;
156
+ }
157
+ .pc-hero-block__content_no-media {
158
+ grid-column: span 12;
159
+ }
160
+ .pc-hero-block__media {
161
+ grid-column: span 5;
162
+ }
163
+ }
164
+ @media (max-width: 769px) {
165
+ .pc-hero-block__wrapper {
166
+ padding-block: 20px 24px;
167
+ }
168
+ .pc-hero-block__breadcrumbs {
169
+ grid-column: span 12;
170
+ order: 1;
171
+ position: initial;
172
+ }
173
+ .pc-hero-block__content {
174
+ grid-column: span 12;
175
+ order: 3;
176
+ width: 100%;
177
+ padding-block: 0 16px;
178
+ padding-inline: 0;
179
+ }
180
+ .pc-hero-block__media {
181
+ grid-column: span 12;
182
+ order: 2;
183
+ width: 100%;
184
+ padding-block: 0;
185
+ }
186
+ .pc-hero-block__media-container {
187
+ position: initial;
188
+ inset: 0;
189
+ }
190
+ .pc-hero-block__media-container-content_vertical,
191
+ .pc-hero-block__media-container-content_vertical .pc-media-component-image__item,
192
+ .pc-hero-block__media-container-content_vertical .pc-fullscreen-image,
193
+ .pc-hero-block__media-container-content_vertical .pc-fullscreen-image__image-wrapper,
194
+ .pc-hero-block__media-container-content_vertical .pc-media-component-video__wrap,
195
+ .pc-hero-block__media-container-content_vertical .pc-media-component-video__react-player,
196
+ .pc-hero-block__media-container-content_vertical .pc-default-video,
197
+ .pc-hero-block__media-container-content_vertical .pc-ReactPlayer__preview-img,
198
+ .pc-hero-block__media-container-content_vertical .pc-full-screen-media,
199
+ .pc-hero-block__media-container-content_vertical .pc-full-screen-media__media-wrapper {
200
+ width: 100%;
201
+ height: auto;
202
+ }
203
+ .pc-hero-block__media-container-content_vertical .pc-ReactPlayer__player,
204
+ .pc-hero-block__media-container-content_vertical .pc-ReactPlayer__player > video,
205
+ .pc-hero-block__media-container-content_vertical .react-player__preview {
206
+ /* stylelint-disable declaration-no-important */
207
+ width: 100% !important;
208
+ height: auto !important;
209
+ /* stylelint-enable declaration-no-important */
210
+ }
211
+ }
@@ -0,0 +1,3 @@
1
+ import { HeroBlockProps } from "../../models/index.js";
2
+ declare const Hero: (props: HeroBlockProps) => import("react/jsx-runtime").JSX.Element;
3
+ export default Hero;
@@ -0,0 +1,50 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const tslib_1 = require("tslib");
4
+ const jsx_runtime_1 = require("react/jsx-runtime");
5
+ const React = tslib_1.__importStar(require("react"));
6
+ const components_1 = require("../../components/index.js");
7
+ const constants_1 = require("../../constants.js");
8
+ const theme_1 = require("../../context/theme/index.js");
9
+ const windowWidthContext_1 = require("../../context/windowWidthContext/index.js");
10
+ const grid_1 = require("../../grid/index.js");
11
+ const sub_blocks_1 = require("../../sub-blocks/index.js");
12
+ const utils_1 = require("../../utils/index.js");
13
+ const hooks_1 = require("./hooks.js");
14
+ const b = (0, utils_1.block)('hero-block');
15
+ const Hero = (props) => {
16
+ const { breadcrumbs, overtitle, buttons, media: themedMedia, fullWidth, verticalOffset = 'm', theme: contentTheme = 'default', background: themedBackground, ...contentProps } = props;
17
+ const [mediaAspectRatio, setMediaAspectRatio] = React.useState(Infinity);
18
+ const { aspectRatio: mediaContainerAspectRatio, ref: mediaContainerRef } = (0, hooks_1.useContainerAspectRatio)();
19
+ const isDesktop = (0, windowWidthContext_1.useWindowWidth)() > constants_1.BREAKPOINTS.md;
20
+ const isMediaVertical = mediaAspectRatio < mediaContainerAspectRatio;
21
+ const contextTheme = (0, theme_1.useTheme)();
22
+ const theme = contentTheme === 'default' ? contextTheme : contentTheme;
23
+ const background = (0, utils_1.getThemedValue)(themedBackground, theme);
24
+ const media = (0, utils_1.getThemedValue)(themedMedia, theme);
25
+ const buttonProps = React.useMemo(() => buttons?.map((buttonThemed) => {
26
+ if (React.isValidElement(buttonThemed)) {
27
+ return buttonThemed;
28
+ }
29
+ const button = (0, utils_1.getThemedValue)(buttonThemed, theme);
30
+ return {
31
+ size: 'xl',
32
+ ...button,
33
+ };
34
+ }), [buttons, theme]);
35
+ const onMediaIntrinsicSizeChange = React.useCallback(({ width, height }) => setMediaAspectRatio(width / height), []);
36
+ return ((0, jsx_runtime_1.jsxs)("header", { className: b(), children: [background && ((0, jsx_runtime_1.jsx)(components_1.Media, { className: b('background', {
37
+ ['full-width']: fullWidth,
38
+ }), imageClassName: b('background-image'), videoClassName: b('background-video'), ...background, isBackground: true })), (0, jsx_runtime_1.jsx)(grid_1.Grid, { children: (0, jsx_runtime_1.jsxs)("div", { className: b('wrapper'), children: [breadcrumbs && ((0, jsx_runtime_1.jsx)(components_1.HeaderBreadcrumbs, { className: b('breadcrumbs'), ...breadcrumbs, theme: theme })), (0, jsx_runtime_1.jsxs)("div", { className: b('content', {
39
+ ['vertical-offset']: verticalOffset,
40
+ ['no-media']: !media,
41
+ }), children: [overtitle && ((0, jsx_runtime_1.jsx)("div", { className: b('content-overtitle', { theme }), children: typeof overtitle === 'string' ? ((0, jsx_runtime_1.jsx)(components_1.YFMWrapper, { tagName: "span", content: overtitle, modifiers: {
42
+ constructor: true,
43
+ constructorTheme: theme,
44
+ } })) : (overtitle) })), (0, jsx_runtime_1.jsx)(sub_blocks_1.Content, { size: "xl", colSizes: { all: 12 }, ...contentProps, buttons: buttonProps, theme: contentTheme })] }), media && ((0, jsx_runtime_1.jsx)("div", { className: b('media'), children: (0, jsx_runtime_1.jsx)("div", { className: b('media-container'), ref: mediaContainerRef, children: (0, jsx_runtime_1.jsx)(components_1.Media, { className: b('media-container-content', {
45
+ ['round-corners']: media.roundCorners ?? true,
46
+ vertical: isDesktop && isMediaVertical,
47
+ }), ...media, disablePlayerAutoSizing: true, onIntrinsicSizeChange: onMediaIntrinsicSizeChange }) }) }))] }) })] }));
48
+ };
49
+ exports.default = Hero;
50
+ //# sourceMappingURL=Hero.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Hero.js","sourceRoot":"../../../../src","sources":["blocks/Hero/Hero.tsx"],"names":[],"mappings":"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","sourcesContent":["import * as React from 'react';\n\nimport {HeaderBreadcrumbs, Media, YFMWrapper} from '../../components';\nimport {BREAKPOINTS} from '../../constants';\nimport {useTheme} from '../../context/theme';\nimport {useWindowWidth} from '../../context/windowWidthContext';\nimport {Grid} from '../../grid';\nimport {ButtonProps, HeroBlockProps, Theme} from '../../models';\nimport {Content} from '../../sub-blocks';\nimport {block, getThemedValue} from '../../utils';\n\nimport {useContainerAspectRatio} from './hooks';\n\nimport './Hero.scss';\n\nconst b = block('hero-block');\n\nconst Hero = (props: HeroBlockProps) => {\n const {\n breadcrumbs,\n overtitle,\n buttons,\n media: themedMedia,\n fullWidth,\n verticalOffset = 'm',\n theme: contentTheme = 'default',\n background: themedBackground,\n ...contentProps\n } = props;\n\n const [mediaAspectRatio, setMediaAspectRatio] = React.useState<number>(Infinity);\n\n const {aspectRatio: mediaContainerAspectRatio, ref: mediaContainerRef} =\n useContainerAspectRatio();\n\n const isDesktop = useWindowWidth() > BREAKPOINTS.md;\n const isMediaVertical = mediaAspectRatio < mediaContainerAspectRatio;\n\n const contextTheme = useTheme();\n const theme = contentTheme === 'default' ? contextTheme : (contentTheme as Theme);\n\n const background = getThemedValue(themedBackground, theme);\n const media = getThemedValue(themedMedia, theme);\n\n const buttonProps = React.useMemo<(ButtonProps | React.ReactNode)[] | undefined>(\n () =>\n buttons?.map((buttonThemed) => {\n if (React.isValidElement(buttonThemed)) {\n return buttonThemed;\n }\n\n const button = getThemedValue(buttonThemed, theme) as ButtonProps;\n\n return {\n size: 'xl',\n ...button,\n };\n }),\n [buttons, theme],\n );\n\n const onMediaIntrinsicSizeChange = React.useCallback(\n ({width, height}: {width: number; height: number}) => setMediaAspectRatio(width / height),\n [],\n );\n\n return (\n <header className={b()}>\n {background && (\n <Media\n className={b('background', {\n ['full-width']: fullWidth,\n })}\n imageClassName={b('background-image')}\n videoClassName={b('background-video')}\n {...background}\n isBackground\n />\n )}\n <Grid>\n <div className={b('wrapper')}>\n {breadcrumbs && (\n <HeaderBreadcrumbs\n className={b('breadcrumbs')}\n {...breadcrumbs}\n theme={theme}\n />\n )}\n <div\n className={b('content', {\n ['vertical-offset']: verticalOffset,\n ['no-media']: !media,\n })}\n >\n {overtitle && (\n <div className={b('content-overtitle', {theme})}>\n {typeof overtitle === 'string' ? (\n <YFMWrapper\n tagName=\"span\"\n content={overtitle}\n modifiers={{\n constructor: true,\n constructorTheme: theme,\n }}\n />\n ) : (\n overtitle\n )}\n </div>\n )}\n <Content\n size=\"xl\"\n colSizes={{all: 12}}\n {...contentProps}\n buttons={buttonProps}\n theme={contentTheme}\n />\n </div>\n {media && (\n <div className={b('media')}>\n <div className={b('media-container')} ref={mediaContainerRef}>\n <Media\n className={b('media-container-content', {\n ['round-corners']: media.roundCorners ?? true,\n vertical: isDesktop && isMediaVertical,\n })}\n {...media}\n disablePlayerAutoSizing\n onIntrinsicSizeChange={onMediaIntrinsicSizeChange}\n />\n </div>\n </div>\n )}\n </div>\n </Grid>\n </header>\n );\n};\n\nexport default Hero;\n"]}
@@ -0,0 +1,4 @@
1
+ export declare const useContainerAspectRatio: () => {
2
+ aspectRatio: number;
3
+ ref: (mediaContainer: HTMLDivElement | null) => void;
4
+ };
@@ -0,0 +1,38 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.useContainerAspectRatio = void 0;
4
+ const tslib_1 = require("tslib");
5
+ const React = tslib_1.__importStar(require("react"));
6
+ const throttle_1 = tslib_1.__importDefault(require("lodash/throttle.js"));
7
+ const SIZE_UPDATE_FREQUENCY_MS = 100;
8
+ const useContainerAspectRatio = () => {
9
+ const containerRef = React.useRef(null);
10
+ const [containerAspectRatio, setContainerAspectRatio] = React.useState(1);
11
+ const updateAspectRatio = React.useCallback(() => {
12
+ const container = containerRef.current;
13
+ if (container) {
14
+ setContainerAspectRatio(container.clientWidth / container.clientHeight);
15
+ }
16
+ }, []);
17
+ React.useEffect(() => {
18
+ const container = containerRef.current;
19
+ const isResizeEventsSupported = 'ResizeObserver' in window;
20
+ if (!container || !isResizeEventsSupported) {
21
+ return () => { };
22
+ }
23
+ const observer = new ResizeObserver((0, throttle_1.default)(updateAspectRatio, SIZE_UPDATE_FREQUENCY_MS, { leading: true }));
24
+ observer.observe(container);
25
+ return () => observer.disconnect();
26
+ }, [updateAspectRatio]);
27
+ return {
28
+ aspectRatio: containerAspectRatio,
29
+ ref: (mediaContainer) => {
30
+ if (mediaContainer) {
31
+ containerRef.current = mediaContainer;
32
+ updateAspectRatio();
33
+ }
34
+ },
35
+ };
36
+ };
37
+ exports.useContainerAspectRatio = useContainerAspectRatio;
38
+ //# sourceMappingURL=hooks.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hooks.js","sourceRoot":"../../../../src","sources":["blocks/Hero/hooks.ts"],"names":[],"mappings":";;;;AAAA,qDAA+B;AAE/B,0EAAuC;AAEvC,MAAM,wBAAwB,GAAG,GAAG,CAAC;AAE9B,MAAM,uBAAuB,GAAG,GAAG,EAAE;IACxC,MAAM,YAAY,GAAG,KAAK,CAAC,MAAM,CAAwB,IAAI,CAAC,CAAC;IAC/D,MAAM,CAAC,oBAAoB,EAAE,uBAAuB,CAAC,GAAG,KAAK,CAAC,QAAQ,CAAS,CAAC,CAAC,CAAC;IAElF,MAAM,iBAAiB,GAAG,KAAK,CAAC,WAAW,CAAC,GAAG,EAAE;QAC7C,MAAM,SAAS,GAAG,YAAY,CAAC,OAAO,CAAC;QAEvC,IAAI,SAAS,EAAE,CAAC;YACZ,uBAAuB,CAAC,SAAS,CAAC,WAAW,GAAG,SAAS,CAAC,YAAY,CAAC,CAAC;QAC5E,CAAC;IACL,CAAC,EAAE,EAAE,CAAC,CAAC;IAEP,KAAK,CAAC,SAAS,CAAC,GAAG,EAAE;QACjB,MAAM,SAAS,GAAG,YAAY,CAAC,OAAO,CAAC;QACvC,MAAM,uBAAuB,GAAG,gBAAgB,IAAI,MAAM,CAAC;QAE3D,IAAI,CAAC,SAAS,IAAI,CAAC,uBAAuB,EAAE,CAAC;YACzC,OAAO,GAAG,EAAE,GAAE,CAAC,CAAC;QACpB,CAAC;QAED,MAAM,QAAQ,GAAG,IAAI,cAAc,CAC/B,IAAA,kBAAQ,EAAC,iBAAiB,EAAE,wBAAwB,EAAE,EAAC,OAAO,EAAE,IAAI,EAAC,CAAC,CACzE,CAAC;QAEF,QAAQ,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;QAE5B,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,UAAU,EAAE,CAAC;IACvC,CAAC,EAAE,CAAC,iBAAiB,CAAC,CAAC,CAAC;IAExB,OAAO;QACH,WAAW,EAAE,oBAAoB;QACjC,GAAG,EAAE,CAAC,cAAqC,EAAE,EAAE;YAC3C,IAAI,cAAc,EAAE,CAAC;gBACjB,YAAY,CAAC,OAAO,GAAG,cAAc,CAAC;gBACtC,iBAAiB,EAAE,CAAC;YACxB,CAAC;QACL,CAAC;KACJ,CAAC;AACN,CAAC,CAAC;AAtCW,QAAA,uBAAuB,2BAsClC","sourcesContent":["import * as React from 'react';\n\nimport throttle from 'lodash/throttle';\n\nconst SIZE_UPDATE_FREQUENCY_MS = 100;\n\nexport const useContainerAspectRatio = () => {\n const containerRef = React.useRef<HTMLDivElement | null>(null);\n const [containerAspectRatio, setContainerAspectRatio] = React.useState<number>(1);\n\n const updateAspectRatio = React.useCallback(() => {\n const container = containerRef.current;\n\n if (container) {\n setContainerAspectRatio(container.clientWidth / container.clientHeight);\n }\n }, []);\n\n React.useEffect(() => {\n const container = containerRef.current;\n const isResizeEventsSupported = 'ResizeObserver' in window;\n\n if (!container || !isResizeEventsSupported) {\n return () => {};\n }\n\n const observer = new ResizeObserver(\n throttle(updateAspectRatio, SIZE_UPDATE_FREQUENCY_MS, {leading: true}),\n );\n\n observer.observe(container);\n\n return () => observer.disconnect();\n }, [updateAspectRatio]);\n\n return {\n aspectRatio: containerAspectRatio,\n ref: (mediaContainer: HTMLDivElement | null) => {\n if (mediaContainer) {\n containerRef.current = mediaContainer;\n updateAspectRatio();\n }\n },\n };\n};\n"]}