@gravity-ui/page-constructor 1.9.1 → 1.9.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (77) hide show
  1. package/CHANGELOG.md +15 -0
  2. package/build/cjs/blocks/Tabs/Tabs.css +3 -5
  3. package/build/cjs/components/Image/Image.d.ts +1 -0
  4. package/build/cjs/components/Image/Image.js +2 -4
  5. package/build/cjs/components/VideoBlock/VideoBlock.css +4 -0
  6. package/build/cjs/components/VideoBlock/VideoBlock.js +1 -1
  7. package/build/cjs/components/index.d.ts +0 -2
  8. package/build/cjs/components/index.js +39 -40
  9. package/build/cjs/containers/PageConstructor/PageConstructor.js +1 -1
  10. package/build/cjs/models/navigation.d.ts +7 -7
  11. package/build/cjs/{components/navigation → navigation}/components/Header/Header.css +0 -0
  12. package/build/cjs/{components/navigation → navigation}/components/Header/Header.d.ts +2 -2
  13. package/build/cjs/{components/navigation → navigation}/components/Header/Header.js +5 -5
  14. package/build/cjs/{components/navigation → navigation}/components/Logo/Logo.css +0 -0
  15. package/build/cjs/{components/navigation → navigation}/components/Logo/Logo.d.ts +2 -2
  16. package/build/cjs/{components/navigation → navigation}/components/Logo/Logo.js +5 -5
  17. package/build/cjs/{components/navigation → navigation}/components/MobileNavigation/MobileNavigation.css +0 -0
  18. package/build/cjs/{components/navigation → navigation}/components/MobileNavigation/MobileNavigation.d.ts +1 -1
  19. package/build/cjs/{components/navigation → navigation}/components/MobileNavigation/MobileNavigation.js +4 -4
  20. package/build/cjs/{components/navigation → navigation}/components/Navigation/Navigation.css +0 -0
  21. package/build/cjs/{components/navigation → navigation}/components/Navigation/Navigation.d.ts +1 -1
  22. package/build/cjs/{components/navigation → navigation}/components/Navigation/Navigation.js +4 -4
  23. package/build/cjs/{components/navigation → navigation}/components/NavigationItem/NavigationItem.css +0 -0
  24. package/build/cjs/{components/navigation → navigation}/components/NavigationItem/NavigationItem.d.ts +1 -1
  25. package/build/cjs/{components/navigation → navigation}/components/NavigationItem/NavigationItem.js +11 -11
  26. package/build/cjs/{components/navigation → navigation}/components/NavigationPopup/NavigationPopup.css +0 -0
  27. package/build/cjs/{components/navigation → navigation}/components/NavigationPopup/NavigationPopup.d.ts +1 -1
  28. package/build/cjs/{components/navigation → navigation}/components/NavigationPopup/NavigationPopup.js +3 -3
  29. package/build/cjs/{components/navigation → navigation}/components/SocialIcon/SocialIcon.css +0 -0
  30. package/build/cjs/navigation/components/SocialIcon/SocialIcon.d.ts +7 -0
  31. package/build/cjs/{components/navigation → navigation}/components/SocialIcon/SocialIcon.js +4 -4
  32. package/build/cjs/{components/navigation → navigation}/containers/Layout/Layout.css +0 -0
  33. package/build/cjs/{components/navigation → navigation}/containers/Layout/Layout.d.ts +1 -1
  34. package/build/cjs/{components/navigation → navigation}/containers/Layout/Layout.js +1 -1
  35. package/build/esm/blocks/Tabs/Tabs.css +3 -5
  36. package/build/esm/components/Image/Image.d.ts +1 -1
  37. package/build/esm/components/Image/Image.js +2 -5
  38. package/build/esm/components/VideoBlock/VideoBlock.css +4 -0
  39. package/build/esm/components/VideoBlock/VideoBlock.js +1 -1
  40. package/build/esm/components/index.d.ts +0 -2
  41. package/build/esm/components/index.js +0 -2
  42. package/build/esm/containers/PageConstructor/PageConstructor.js +1 -1
  43. package/build/esm/models/navigation.d.ts +7 -7
  44. package/build/esm/{components/navigation → navigation}/components/Header/Header.css +0 -0
  45. package/build/esm/{components/navigation → navigation}/components/Header/Header.d.ts +2 -2
  46. package/build/esm/{components/navigation → navigation}/components/Header/Header.js +5 -5
  47. package/build/esm/{components/navigation → navigation}/components/Logo/Logo.css +0 -0
  48. package/build/esm/{components/navigation → navigation}/components/Logo/Logo.d.ts +2 -2
  49. package/build/esm/{components/navigation → navigation}/components/Logo/Logo.js +4 -4
  50. package/build/esm/{components/navigation → navigation}/components/MobileNavigation/MobileNavigation.css +0 -0
  51. package/build/esm/{components/navigation → navigation}/components/MobileNavigation/MobileNavigation.d.ts +1 -1
  52. package/build/esm/{components/navigation → navigation}/components/MobileNavigation/MobileNavigation.js +3 -3
  53. package/build/esm/{components/navigation → navigation}/components/Navigation/Navigation.css +0 -0
  54. package/build/esm/{components/navigation → navigation}/components/Navigation/Navigation.d.ts +1 -1
  55. package/build/esm/{components/navigation → navigation}/components/Navigation/Navigation.js +4 -4
  56. package/build/esm/{components/navigation → navigation}/components/NavigationItem/NavigationItem.css +0 -0
  57. package/build/esm/{components/navigation → navigation}/components/NavigationItem/NavigationItem.d.ts +1 -1
  58. package/build/esm/{components/navigation → navigation}/components/NavigationItem/NavigationItem.js +6 -6
  59. package/build/esm/{components/navigation → navigation}/components/NavigationPopup/NavigationPopup.css +0 -0
  60. package/build/esm/{components/navigation → navigation}/components/NavigationPopup/NavigationPopup.d.ts +1 -1
  61. package/build/esm/{components/navigation → navigation}/components/NavigationPopup/NavigationPopup.js +2 -2
  62. package/build/esm/{components/navigation → navigation}/components/SocialIcon/SocialIcon.css +0 -0
  63. package/build/esm/navigation/components/SocialIcon/SocialIcon.d.ts +8 -0
  64. package/build/esm/{components/navigation → navigation}/components/SocialIcon/SocialIcon.js +3 -3
  65. package/build/esm/{components/navigation → navigation}/containers/Layout/Layout.css +0 -0
  66. package/build/esm/{components/navigation → navigation}/containers/Layout/Layout.d.ts +1 -1
  67. package/build/esm/{components/navigation → navigation}/containers/Layout/Layout.js +1 -1
  68. package/package.json +1 -1
  69. package/server/models/navigation.d.ts +7 -7
  70. package/build/cjs/components/Image/Image.css +0 -4
  71. package/build/cjs/components/navigation/components/SocialIcon/SocialIcon.d.ts +0 -7
  72. package/build/cjs/components/navigation/components/index.d.ts +0 -7
  73. package/build/cjs/components/navigation/components/index.js +0 -20
  74. package/build/esm/components/Image/Image.css +0 -4
  75. package/build/esm/components/navigation/components/SocialIcon/SocialIcon.d.ts +0 -8
  76. package/build/esm/components/navigation/components/index.d.ts +0 -7
  77. package/build/esm/components/navigation/components/index.js +0 -7
package/CHANGELOG.md CHANGED
@@ -1,5 +1,20 @@
1
1
  # Changelog
2
2
 
3
+ ## [1.9.3](https://github.com/gravity-ui/page-constructor/compare/v1.9.2...v1.9.3) (2022-12-07)
4
+
5
+
6
+ ### Bug Fixes
7
+
8
+ * **Tabs:** padding and image props ([#77](https://github.com/gravity-ui/page-constructor/issues/77)) ([5809e6b](https://github.com/gravity-ui/page-constructor/commit/5809e6b6364e0b3d01621d15371ef5d0aaa9518b))
9
+
10
+ ## [1.9.2](https://github.com/gravity-ui/page-constructor/compare/v1.9.1...v1.9.2) (2022-12-07)
11
+
12
+
13
+ ### Bug Fixes
14
+
15
+ * navigation import and types ([#76](https://github.com/gravity-ui/page-constructor/issues/76)) ([53ea8d4](https://github.com/gravity-ui/page-constructor/commit/53ea8d4bb12290d3cd3f2cef6dca6a48c5c68d68))
16
+ * release ([#74](https://github.com/gravity-ui/page-constructor/issues/74)) ([13193d4](https://github.com/gravity-ui/page-constructor/commit/13193d420ff2486a94638bd8119e28d69aa713d8))
17
+
3
18
  ## [1.9.1](https://github.com/gravity-ui/page-constructor/compare/v1.9.0...v1.9.1) (2022-12-05)
4
19
 
5
20
 
@@ -8,13 +8,11 @@ unpredictable css rules order in build */
8
8
  margin-bottom: 24px;
9
9
  }
10
10
  .pc-tabs-block__block-title_centered {
11
- display: flex;
12
- justify-content: center;
13
- flex-wrap: wrap;
14
- margin-left: auto;
15
- margin-right: auto;
16
11
  text-align: center;
17
12
  }
13
+ .pc-tabs-block__block-title_centered > * {
14
+ margin: 0 auto;
15
+ }
18
16
  .pc-tabs-block__tabs_centered {
19
17
  display: flex;
20
18
  justify-content: center;
@@ -4,6 +4,7 @@ export interface ImageProps extends Partial<ImageObjectProps>, Partial<ImageDevi
4
4
  style?: CSSProperties;
5
5
  className?: string;
6
6
  onClick?: MouseEventHandler;
7
+ containerClassName?: string;
7
8
  }
8
9
  declare const Image: (props: ImageProps) => JSX.Element | null;
9
10
  export default Image;
@@ -4,14 +4,12 @@ const tslib_1 = require("tslib");
4
4
  const react_1 = (0, tslib_1.__importStar)(require("react"));
5
5
  const projectSettingsContext_1 = require("../../context/projectSettingsContext");
6
6
  const constants_1 = require("../../constants");
7
- const utils_1 = require("../../utils");
8
- const b = (0, utils_1.block)('image');
9
7
  const checkWebP = (src) => {
10
8
  return src.endsWith('.webp') ? src : src + '.webp';
11
9
  };
12
10
  const Image = (props) => {
13
11
  const projectSettings = (0, react_1.useContext)(projectSettingsContext_1.ProjectSettingsContext);
14
- const { src, alt, disableCompress, tablet, desktop, mobile, style, className, onClick } = props;
12
+ const { src, alt, disableCompress, tablet, desktop, mobile, style, className, onClick, containerClassName, } = props;
15
13
  const [imgLoadingError, setImgLoadingError] = (0, react_1.useState)(false);
16
14
  const imageSrc = src || desktop;
17
15
  if (!imageSrc) {
@@ -22,7 +20,7 @@ const Image = (props) => {
22
20
  disableCompress ||
23
21
  imageSrc.endsWith('.svg') ||
24
22
  imgLoadingError;
25
- return (react_1.default.createElement("picture", { className: b() },
23
+ return (react_1.default.createElement("picture", { className: containerClassName },
26
24
  mobile && (react_1.default.createElement(react_1.Fragment, null,
27
25
  !disableWebp && (react_1.default.createElement("source", { srcSet: checkWebP(mobile), type: "image/webp", media: `(max-width: ${constants_1.BREAKPOINTS.sm}px)` })),
28
26
  react_1.default.createElement("source", { srcSet: mobile, media: `(max-width: ${constants_1.BREAKPOINTS.sm}px)` }))),
@@ -19,6 +19,10 @@ unpredictable css rules order in build */
19
19
  object-fit: cover;
20
20
  display: block;
21
21
  }
22
+ .pc-VideoBlock__image-wrapper {
23
+ height: 100%;
24
+ width: 100%;
25
+ }
22
26
  .pc-VideoBlock__button {
23
27
  display: inline-block;
24
28
  margin: 0;
@@ -91,7 +91,7 @@ const VideoBlock = (props) => {
91
91
  return null;
92
92
  }
93
93
  return (react_1.default.createElement("div", { className: b(null, className), ref: ref, style: { height: currentHeight } }, previewImg && !hidePreview && (react_1.default.createElement("div", { className: b('preview'), onClick: onPreviewClick },
94
- react_1.default.createElement(Image_1.default, { src: previewImg, className: b('image') }),
94
+ react_1.default.createElement(Image_1.default, { src: previewImg, className: b('image'), containerClassName: b('image-wrapper') }),
95
95
  playButton || (react_1.default.createElement("button", { className: b('button') },
96
96
  react_1.default.createElement(uikit_1.Icon, { className: b('icon'), data: icons_1.PlayVideo, size: 24 })))))));
97
97
  };
@@ -33,6 +33,4 @@ export { default as OverflowScroller } from './OverflowScroller/OverflowScroller
33
33
  export { default as Author } from './Author/Author';
34
34
  export { default as RouterLink } from './RouterLink/RouterLink';
35
35
  export { default as HTML } from './HTML/HTML';
36
- export { default as Header } from './navigation/components/Header/Header';
37
- export * as Navigation from './navigation/components/index';
38
36
  export type { RouterLinkProps } from './RouterLink/RouterLink';
@@ -1,77 +1,76 @@
1
1
  "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
2
5
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.Navigation = exports.Header = exports.HTML = exports.RouterLink = exports.Author = exports.OverflowScroller = exports.Control = exports.YandexForm = exports.YFMWrapper = exports.VideoBlock = exports.UnpublishedLabel = exports.ToggleArrow = exports.Title = exports.Table = exports.ReactPlayer = exports.OutsideClick = exports.Media = exports.Links = exports.Link = exports.Image = exports.HeightCalculator = exports.HeaderBreadcrumbs = exports.FullWidthBackground = exports.FullscreenImage = exports.Foldable = exports.FileLink = exports.ErrorWrapper = exports.CardBase = exports.Button = exports.BlockHeader = exports.BlockBase = exports.BalancedMasonry = exports.BackLink = exports.BackgroundMedia = exports.BackgroundImage = exports.AnimateBlock = exports.Anchor = void 0;
4
- const tslib_1 = require("tslib");
6
+ exports.HTML = exports.RouterLink = exports.Author = exports.OverflowScroller = exports.Control = exports.YandexForm = exports.YFMWrapper = exports.VideoBlock = exports.UnpublishedLabel = exports.ToggleArrow = exports.Title = exports.Table = exports.ReactPlayer = exports.OutsideClick = exports.Media = exports.Links = exports.Link = exports.Image = exports.HeightCalculator = exports.HeaderBreadcrumbs = exports.FullWidthBackground = exports.FullscreenImage = exports.Foldable = exports.FileLink = exports.ErrorWrapper = exports.CardBase = exports.Button = exports.BlockHeader = exports.BlockBase = exports.BalancedMasonry = exports.BackLink = exports.BackgroundMedia = exports.BackgroundImage = exports.AnimateBlock = exports.Anchor = void 0;
5
7
  var Anchor_1 = require("./Anchor/Anchor");
6
- Object.defineProperty(exports, "Anchor", { enumerable: true, get: function () { return (0, tslib_1.__importDefault)(Anchor_1).default; } });
8
+ Object.defineProperty(exports, "Anchor", { enumerable: true, get: function () { return __importDefault(Anchor_1).default; } });
7
9
  var AnimateBlock_1 = require("./AnimateBlock/AnimateBlock");
8
- Object.defineProperty(exports, "AnimateBlock", { enumerable: true, get: function () { return (0, tslib_1.__importDefault)(AnimateBlock_1).default; } });
10
+ Object.defineProperty(exports, "AnimateBlock", { enumerable: true, get: function () { return __importDefault(AnimateBlock_1).default; } });
9
11
  var BackgroundImage_1 = require("./BackgroundImage/BackgroundImage");
10
- Object.defineProperty(exports, "BackgroundImage", { enumerable: true, get: function () { return (0, tslib_1.__importDefault)(BackgroundImage_1).default; } });
12
+ Object.defineProperty(exports, "BackgroundImage", { enumerable: true, get: function () { return __importDefault(BackgroundImage_1).default; } });
11
13
  var BackgroundMedia_1 = require("./BackgroundMedia/BackgroundMedia");
12
- Object.defineProperty(exports, "BackgroundMedia", { enumerable: true, get: function () { return (0, tslib_1.__importDefault)(BackgroundMedia_1).default; } });
14
+ Object.defineProperty(exports, "BackgroundMedia", { enumerable: true, get: function () { return __importDefault(BackgroundMedia_1).default; } });
13
15
  var BackLink_1 = require("./BackLink/BackLink");
14
- Object.defineProperty(exports, "BackLink", { enumerable: true, get: function () { return (0, tslib_1.__importDefault)(BackLink_1).default; } });
16
+ Object.defineProperty(exports, "BackLink", { enumerable: true, get: function () { return __importDefault(BackLink_1).default; } });
15
17
  var BalancedMasonry_1 = require("./BalancedMasonry/BalancedMasonry");
16
- Object.defineProperty(exports, "BalancedMasonry", { enumerable: true, get: function () { return (0, tslib_1.__importDefault)(BalancedMasonry_1).default; } });
18
+ Object.defineProperty(exports, "BalancedMasonry", { enumerable: true, get: function () { return __importDefault(BalancedMasonry_1).default; } });
17
19
  var BlockBase_1 = require("./BlockBase/BlockBase");
18
- Object.defineProperty(exports, "BlockBase", { enumerable: true, get: function () { return (0, tslib_1.__importDefault)(BlockBase_1).default; } });
20
+ Object.defineProperty(exports, "BlockBase", { enumerable: true, get: function () { return __importDefault(BlockBase_1).default; } });
19
21
  var BlockHeader_1 = require("./BlockHeader/BlockHeader");
20
- Object.defineProperty(exports, "BlockHeader", { enumerable: true, get: function () { return (0, tslib_1.__importDefault)(BlockHeader_1).default; } });
22
+ Object.defineProperty(exports, "BlockHeader", { enumerable: true, get: function () { return __importDefault(BlockHeader_1).default; } });
21
23
  var Button_1 = require("./Button/Button");
22
- Object.defineProperty(exports, "Button", { enumerable: true, get: function () { return (0, tslib_1.__importDefault)(Button_1).default; } });
24
+ Object.defineProperty(exports, "Button", { enumerable: true, get: function () { return __importDefault(Button_1).default; } });
23
25
  var CardBase_1 = require("./CardBase/CardBase");
24
- Object.defineProperty(exports, "CardBase", { enumerable: true, get: function () { return (0, tslib_1.__importDefault)(CardBase_1).default; } });
26
+ Object.defineProperty(exports, "CardBase", { enumerable: true, get: function () { return __importDefault(CardBase_1).default; } });
25
27
  var ErrorWrapper_1 = require("./ErrorWrapper/ErrorWrapper");
26
- Object.defineProperty(exports, "ErrorWrapper", { enumerable: true, get: function () { return (0, tslib_1.__importDefault)(ErrorWrapper_1).default; } });
28
+ Object.defineProperty(exports, "ErrorWrapper", { enumerable: true, get: function () { return __importDefault(ErrorWrapper_1).default; } });
27
29
  var FileLink_1 = require("./FileLink/FileLink");
28
- Object.defineProperty(exports, "FileLink", { enumerable: true, get: function () { return (0, tslib_1.__importDefault)(FileLink_1).default; } });
30
+ Object.defineProperty(exports, "FileLink", { enumerable: true, get: function () { return __importDefault(FileLink_1).default; } });
29
31
  var Foldable_1 = require("./Foldable/Foldable");
30
- Object.defineProperty(exports, "Foldable", { enumerable: true, get: function () { return (0, tslib_1.__importDefault)(Foldable_1).default; } });
32
+ Object.defineProperty(exports, "Foldable", { enumerable: true, get: function () { return __importDefault(Foldable_1).default; } });
31
33
  var FullscreenImage_1 = require("./FullscreenImage/FullscreenImage");
32
- Object.defineProperty(exports, "FullscreenImage", { enumerable: true, get: function () { return (0, tslib_1.__importDefault)(FullscreenImage_1).default; } });
34
+ Object.defineProperty(exports, "FullscreenImage", { enumerable: true, get: function () { return __importDefault(FullscreenImage_1).default; } });
33
35
  var FullWidthBackground_1 = require("./FullWidthBackground/FullWidthBackground");
34
- Object.defineProperty(exports, "FullWidthBackground", { enumerable: true, get: function () { return (0, tslib_1.__importDefault)(FullWidthBackground_1).default; } });
36
+ Object.defineProperty(exports, "FullWidthBackground", { enumerable: true, get: function () { return __importDefault(FullWidthBackground_1).default; } });
35
37
  var HeaderBreadcrumbs_1 = require("./HeaderBreadcrumbs/HeaderBreadcrumbs");
36
- Object.defineProperty(exports, "HeaderBreadcrumbs", { enumerable: true, get: function () { return (0, tslib_1.__importDefault)(HeaderBreadcrumbs_1).default; } });
38
+ Object.defineProperty(exports, "HeaderBreadcrumbs", { enumerable: true, get: function () { return __importDefault(HeaderBreadcrumbs_1).default; } });
37
39
  var HeightCalculator_1 = require("./HeightCalculator/HeightCalculator");
38
- Object.defineProperty(exports, "HeightCalculator", { enumerable: true, get: function () { return (0, tslib_1.__importDefault)(HeightCalculator_1).default; } });
40
+ Object.defineProperty(exports, "HeightCalculator", { enumerable: true, get: function () { return __importDefault(HeightCalculator_1).default; } });
39
41
  var Image_1 = require("./Image/Image");
40
- Object.defineProperty(exports, "Image", { enumerable: true, get: function () { return (0, tslib_1.__importDefault)(Image_1).default; } });
42
+ Object.defineProperty(exports, "Image", { enumerable: true, get: function () { return __importDefault(Image_1).default; } });
41
43
  var Link_1 = require("./Link/Link");
42
- Object.defineProperty(exports, "Link", { enumerable: true, get: function () { return (0, tslib_1.__importDefault)(Link_1).default; } });
44
+ Object.defineProperty(exports, "Link", { enumerable: true, get: function () { return __importDefault(Link_1).default; } });
43
45
  var Links_1 = require("./Link/Links");
44
- Object.defineProperty(exports, "Links", { enumerable: true, get: function () { return (0, tslib_1.__importDefault)(Links_1).default; } });
46
+ Object.defineProperty(exports, "Links", { enumerable: true, get: function () { return __importDefault(Links_1).default; } });
45
47
  var Media_1 = require("./Media/Media");
46
- Object.defineProperty(exports, "Media", { enumerable: true, get: function () { return (0, tslib_1.__importDefault)(Media_1).default; } });
48
+ Object.defineProperty(exports, "Media", { enumerable: true, get: function () { return __importDefault(Media_1).default; } });
47
49
  var OutsideClick_1 = require("./OutsideClick/OutsideClick");
48
- Object.defineProperty(exports, "OutsideClick", { enumerable: true, get: function () { return (0, tslib_1.__importDefault)(OutsideClick_1).default; } });
50
+ Object.defineProperty(exports, "OutsideClick", { enumerable: true, get: function () { return __importDefault(OutsideClick_1).default; } });
49
51
  var ReactPlayer_1 = require("./ReactPlayer/ReactPlayer");
50
- Object.defineProperty(exports, "ReactPlayer", { enumerable: true, get: function () { return (0, tslib_1.__importDefault)(ReactPlayer_1).default; } });
52
+ Object.defineProperty(exports, "ReactPlayer", { enumerable: true, get: function () { return __importDefault(ReactPlayer_1).default; } });
51
53
  var Table_1 = require("./Table/Table");
52
- Object.defineProperty(exports, "Table", { enumerable: true, get: function () { return (0, tslib_1.__importDefault)(Table_1).default; } });
54
+ Object.defineProperty(exports, "Table", { enumerable: true, get: function () { return __importDefault(Table_1).default; } });
53
55
  var Title_1 = require("./Title/Title");
54
- Object.defineProperty(exports, "Title", { enumerable: true, get: function () { return (0, tslib_1.__importDefault)(Title_1).default; } });
56
+ Object.defineProperty(exports, "Title", { enumerable: true, get: function () { return __importDefault(Title_1).default; } });
55
57
  var ToggleArrow_1 = require("./ToggleArrow/ToggleArrow");
56
- Object.defineProperty(exports, "ToggleArrow", { enumerable: true, get: function () { return (0, tslib_1.__importDefault)(ToggleArrow_1).default; } });
58
+ Object.defineProperty(exports, "ToggleArrow", { enumerable: true, get: function () { return __importDefault(ToggleArrow_1).default; } });
57
59
  var UnpublishedLabel_1 = require("./UnpublishedLabel/UnpublishedLabel");
58
- Object.defineProperty(exports, "UnpublishedLabel", { enumerable: true, get: function () { return (0, tslib_1.__importDefault)(UnpublishedLabel_1).default; } });
60
+ Object.defineProperty(exports, "UnpublishedLabel", { enumerable: true, get: function () { return __importDefault(UnpublishedLabel_1).default; } });
59
61
  var VideoBlock_1 = require("./VideoBlock/VideoBlock");
60
- Object.defineProperty(exports, "VideoBlock", { enumerable: true, get: function () { return (0, tslib_1.__importDefault)(VideoBlock_1).default; } });
62
+ Object.defineProperty(exports, "VideoBlock", { enumerable: true, get: function () { return __importDefault(VideoBlock_1).default; } });
61
63
  var YFMWrapper_1 = require("./YFMWrapper/YFMWrapper");
62
- Object.defineProperty(exports, "YFMWrapper", { enumerable: true, get: function () { return (0, tslib_1.__importDefault)(YFMWrapper_1).default; } });
64
+ Object.defineProperty(exports, "YFMWrapper", { enumerable: true, get: function () { return __importDefault(YFMWrapper_1).default; } });
63
65
  var YandexForm_1 = require("./YandexForm/YandexForm");
64
- Object.defineProperty(exports, "YandexForm", { enumerable: true, get: function () { return (0, tslib_1.__importDefault)(YandexForm_1).default; } });
66
+ Object.defineProperty(exports, "YandexForm", { enumerable: true, get: function () { return __importDefault(YandexForm_1).default; } });
65
67
  var Control_1 = require("./Control/Control");
66
- Object.defineProperty(exports, "Control", { enumerable: true, get: function () { return (0, tslib_1.__importDefault)(Control_1).default; } });
68
+ Object.defineProperty(exports, "Control", { enumerable: true, get: function () { return __importDefault(Control_1).default; } });
67
69
  var OverflowScroller_1 = require("./OverflowScroller/OverflowScroller");
68
- Object.defineProperty(exports, "OverflowScroller", { enumerable: true, get: function () { return (0, tslib_1.__importDefault)(OverflowScroller_1).default; } });
70
+ Object.defineProperty(exports, "OverflowScroller", { enumerable: true, get: function () { return __importDefault(OverflowScroller_1).default; } });
69
71
  var Author_1 = require("./Author/Author");
70
- Object.defineProperty(exports, "Author", { enumerable: true, get: function () { return (0, tslib_1.__importDefault)(Author_1).default; } });
72
+ Object.defineProperty(exports, "Author", { enumerable: true, get: function () { return __importDefault(Author_1).default; } });
71
73
  var RouterLink_1 = require("./RouterLink/RouterLink");
72
- Object.defineProperty(exports, "RouterLink", { enumerable: true, get: function () { return (0, tslib_1.__importDefault)(RouterLink_1).default; } });
74
+ Object.defineProperty(exports, "RouterLink", { enumerable: true, get: function () { return __importDefault(RouterLink_1).default; } });
73
75
  var HTML_1 = require("./HTML/HTML");
74
- Object.defineProperty(exports, "HTML", { enumerable: true, get: function () { return (0, tslib_1.__importDefault)(HTML_1).default; } });
75
- var Header_1 = require("./navigation/components/Header/Header");
76
- Object.defineProperty(exports, "Header", { enumerable: true, get: function () { return (0, tslib_1.__importDefault)(Header_1).default; } });
77
- exports.Navigation = (0, tslib_1.__importStar)(require("./navigation/components/index"));
76
+ Object.defineProperty(exports, "HTML", { enumerable: true, get: function () { return __importDefault(HTML_1).default; } });
@@ -16,7 +16,7 @@ const ConstructorRow_1 = require("./components/ConstructorRow");
16
16
  const ConstructorFootnotes_1 = require("./components/ConstructorFootnotes");
17
17
  const ConstructorItem_1 = require("./components/ConstructorItem");
18
18
  const ConstructorBlocks_1 = require("./components/ConstructorBlocks");
19
- const Layout_1 = (0, tslib_1.__importDefault)(require("../../components/navigation/containers/Layout/Layout"));
19
+ const Layout_1 = (0, tslib_1.__importDefault)(require("../../navigation/containers/Layout/Layout"));
20
20
  const b = (0, utils_1.block)('page-constructor');
21
21
  const Constructor = (props) => {
22
22
  const { context, headerBlockTypes } = (0, react_1.useMemo)(() => {
@@ -30,24 +30,24 @@ export interface NavigationSocialItem extends Omit<NavigationItemBase, 'text'> {
30
30
  icon: ImageProps;
31
31
  url: string;
32
32
  }
33
- export declare type NavigationItem = NavigationLinkItem | NavigationButtonItem | NavigationDropdownItem;
33
+ export declare type NavigationItemModel = NavigationLinkItem | NavigationButtonItem | NavigationDropdownItem;
34
34
  export declare type NavigationItemData = NavigationLinkItem | NavigationButtonItem | NavigationSocialItem | DropdownItemData;
35
35
  export declare type DropdownItemData = Omit<NavigationDropdownItem, 'items'>;
36
- export interface NavigationLogo {
36
+ export interface NavigationLogoData {
37
37
  icon: ImageProps;
38
38
  text?: string;
39
39
  url?: string;
40
40
  }
41
41
  export interface HeaderData {
42
- leftItems: NavigationItem[];
43
- rightItems?: NavigationItem[];
42
+ leftItems: NavigationItemModel[];
43
+ rightItems?: NavigationItemModel[];
44
44
  }
45
45
  export interface FooterColumn {
46
46
  title: string;
47
- links: NavigationItem[];
47
+ links: NavigationItemModel[];
48
48
  }
49
49
  export interface FooterUnderline {
50
- links?: NavigationItem[];
50
+ links?: NavigationItemModel[];
51
51
  copyright?: string;
52
52
  }
53
53
  export interface FooterData {
@@ -56,7 +56,7 @@ export interface FooterData {
56
56
  underline?: FooterUnderline;
57
57
  }
58
58
  export interface NavigationData {
59
- logo: NavigationLogo;
59
+ logo: NavigationLogoData;
60
60
  header: HeaderData;
61
61
  footer?: FooterData;
62
62
  }
@@ -1,7 +1,7 @@
1
1
  import React from 'react';
2
- import { HeaderData, NavigationLogo } from '../../../../models';
2
+ import { HeaderData, NavigationLogoData } from '../../../models';
3
3
  export interface HeaderProps {
4
- logo: NavigationLogo;
4
+ logo: NavigationLogoData;
5
5
  data: HeaderData;
6
6
  }
7
7
  export declare const Header: React.FC<HeaderProps>;
@@ -3,15 +3,15 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.Header = void 0;
4
4
  const tslib_1 = require("tslib");
5
5
  const react_1 = (0, tslib_1.__importStar)(require("react"));
6
- const utils_1 = require("../../../../utils");
7
- const grid_1 = require("../../../../grid");
8
- const OutsideClick_1 = (0, tslib_1.__importDefault)(require("../../../OutsideClick/OutsideClick"));
9
- const Control_1 = (0, tslib_1.__importDefault)(require("../../../Control/Control"));
6
+ const utils_1 = require("../../../utils");
7
+ const grid_1 = require("../../../grid");
8
+ const OutsideClick_1 = (0, tslib_1.__importDefault)(require("../../../components/OutsideClick/OutsideClick"));
9
+ const Control_1 = (0, tslib_1.__importDefault)(require("../../../components/Control/Control"));
10
10
  const Navigation_1 = (0, tslib_1.__importDefault)(require("../Navigation/Navigation"));
11
11
  const MobileNavigation_1 = (0, tslib_1.__importDefault)(require("../MobileNavigation/MobileNavigation"));
12
12
  const NavigationItem_1 = (0, tslib_1.__importDefault)(require("../NavigationItem/NavigationItem"));
13
13
  const Logo_1 = (0, tslib_1.__importDefault)(require("../Logo/Logo"));
14
- const icons_1 = require("../../../../icons");
14
+ const icons_1 = require("../../../icons");
15
15
  const b = (0, utils_1.block)('header');
16
16
  const ICON_SIZE = 36;
17
17
  const MobileMenuButton = ({ isSidebarOpened, onSidebarOpenedChange, }) => {
@@ -1,6 +1,6 @@
1
1
  import React from 'react';
2
- import { NavigationLogo } from '../../../../models';
3
- export interface LogoProps extends NavigationLogo {
2
+ import { NavigationLogoData } from '../../../models';
3
+ export interface LogoProps extends NavigationLogoData {
4
4
  className?: string;
5
5
  }
6
6
  declare const Logo: React.FC<LogoProps>;
@@ -2,16 +2,16 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  const tslib_1 = require("tslib");
4
4
  const react_1 = (0, tslib_1.__importDefault)(require("react"));
5
- const utils_1 = require("../../../../utils");
6
- const RouterLink_1 = (0, tslib_1.__importDefault)(require("../../../RouterLink/RouterLink"));
7
- const utils_2 = require("../../../Media/Image/utils");
8
- const index_1 = require("../../../index");
5
+ const utils_1 = require("../../../utils");
6
+ const RouterLink_1 = (0, tslib_1.__importDefault)(require("../../../components/RouterLink/RouterLink"));
7
+ const utils_2 = require("../../../components/Media/Image/utils");
8
+ const components_1 = require("../../../components");
9
9
  const b = (0, utils_1.block)('logo');
10
10
  const Logo = ({ icon, text, className }) => {
11
11
  const imageData = (0, utils_2.getMediaImage)(icon);
12
12
  return (react_1.default.createElement(RouterLink_1.default, { href: "/", passHref: true },
13
13
  react_1.default.createElement("div", { className: b(null, className) },
14
- imageData && react_1.default.createElement(index_1.Image, Object.assign({ className: b('icon') }, imageData)),
14
+ imageData && react_1.default.createElement(components_1.Image, Object.assign({ className: b('icon') }, imageData)),
15
15
  react_1.default.createElement("span", { className: b('text') }, text))));
16
16
  };
17
17
  exports.default = Logo;
@@ -1,5 +1,5 @@
1
1
  import React from 'react';
2
- import { NavigationItem as NavigationItemModel } from '../../../../models/navigation';
2
+ import { NavigationItemModel } from '../../../models';
3
3
  export interface MobileNavigationProps {
4
4
  className?: string;
5
5
  isOpened?: boolean;
@@ -3,9 +3,9 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  const tslib_1 = require("tslib");
4
4
  const react_1 = (0, tslib_1.__importStar)(require("react"));
5
5
  const uikit_1 = require("@gravity-ui/uikit");
6
- const utils_1 = require("../../../../utils");
7
- const Foldable_1 = (0, tslib_1.__importDefault)(require("../../../Foldable/Foldable"));
8
- const navigation_1 = require("../../../../models/navigation");
6
+ const utils_1 = require("../../../utils");
7
+ const Foldable_1 = (0, tslib_1.__importDefault)(require("../../../components/Foldable/Foldable"));
8
+ const models_1 = require("../../../models");
9
9
  const NavigationItem_1 = (0, tslib_1.__importDefault)(require("../NavigationItem/NavigationItem"));
10
10
  const b = (0, utils_1.block)('mobile-navigation');
11
11
  const MobileNavigationDropdown = ({ data, onItemClick, onToggle, isOpened = false, }) => {
@@ -25,7 +25,7 @@ const MobileNavigationItem = ({ link, index, isActive, onActiveItemChange, onClo
25
25
  toggleActive(e);
26
26
  onClose();
27
27
  }, [toggleActive, onClose]);
28
- return (react_1.default.createElement("li", { key: index, className: b('links-item') }, link.type === navigation_1.NavigationItemType.Dropdown ? (react_1.default.createElement(MobileNavigationDropdown, { data: link, onToggle: toggleActive, isOpened: isActive, onItemClick: onItemClick })) : (react_1.default.createElement(NavigationItem_1.default, { data: link, onClick: onItemClick }))));
28
+ return (react_1.default.createElement("li", { key: index, className: b('links-item') }, link.type === models_1.NavigationItemType.Dropdown ? (react_1.default.createElement(MobileNavigationDropdown, { data: link, onToggle: toggleActive, isOpened: isActive, onItemClick: onItemClick })) : (react_1.default.createElement(NavigationItem_1.default, { data: link, onClick: onItemClick }))));
29
29
  };
30
30
  const MobileNavigation = (props) => {
31
31
  if (typeof window === 'undefined') {
@@ -1,5 +1,5 @@
1
1
  import React, { MouseEventHandler } from 'react';
2
- import { NavigationDropdownItem, NavigationItem as NavigationItemModel } from '../../../../models/navigation';
2
+ import { NavigationDropdownItem, NavigationItemModel } from '../../../models/navigation';
3
3
  export interface NavigationProps {
4
4
  links: NavigationItemModel[];
5
5
  activeItemIndex: number;
@@ -3,12 +3,12 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  const tslib_1 = require("tslib");
4
4
  const lodash_1 = (0, tslib_1.__importDefault)(require("lodash"));
5
5
  const react_1 = (0, tslib_1.__importStar)(require("react"));
6
- const utils_1 = require("../../../../utils");
7
- const OverflowScroller_1 = (0, tslib_1.__importDefault)(require("../../../OverflowScroller/OverflowScroller"));
8
- const navigation_1 = require("../../../../models/navigation");
6
+ const utils_1 = require("../../../utils");
7
+ const OverflowScroller_1 = (0, tslib_1.__importDefault)(require("../../../components/OverflowScroller/OverflowScroller"));
8
+ const navigation_1 = require("../../../models/navigation");
9
9
  const NavigationPopup_1 = (0, tslib_1.__importDefault)(require("../NavigationPopup/NavigationPopup"));
10
10
  const NavigationItem_1 = (0, tslib_1.__importDefault)(require("../NavigationItem/NavigationItem"));
11
- const locationContext_1 = require("../../../../context/locationContext");
11
+ const locationContext_1 = require("../../../context/locationContext");
12
12
  const b = (0, utils_1.block)('navigation');
13
13
  const NavigationDropdown = ({ data, isActive, position, hidePopup, onClick, }) => {
14
14
  const { text, items } = data, popupProps = (0, tslib_1.__rest)(data, ["text", "items"]);
@@ -1,5 +1,5 @@
1
1
  import React, { MouseEventHandler } from 'react';
2
- import { NavigationItemData } from '../../../../models';
2
+ import { NavigationItemData } from '../../../models';
3
3
  export interface NavigationItemProps {
4
4
  data: NavigationItemData;
5
5
  className?: string;
@@ -2,23 +2,23 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  const tslib_1 = require("tslib");
4
4
  const react_1 = (0, tslib_1.__importStar)(require("react"));
5
- const utils_1 = require("../../../../utils");
6
- const index_1 = require("../../../index");
7
- const locationContext_1 = require("../../../../context/locationContext");
8
- const models_1 = require("../../../../models");
9
- const icons_1 = require("../../../../icons");
5
+ const utils_1 = require("../../../utils");
6
+ const components_1 = require("../../../components");
7
+ const locationContext_1 = require("../../../context/locationContext");
8
+ const models_1 = require("../../../models");
9
+ const icons_1 = require("../../../icons");
10
10
  const SocialIcon_1 = (0, tslib_1.__importDefault)(require("../SocialIcon/SocialIcon"));
11
- const utils_2 = require("../../../Media/Image/utils");
11
+ const utils_2 = require("../../../components/Media/Image/utils");
12
12
  const b = (0, utils_1.block)('navigation-item');
13
13
  const Content = ({ text, icon }) => (react_1.default.createElement(react_1.Fragment, null,
14
- icon && react_1.default.createElement(index_1.Image, Object.assign({ className: b('icon') }, icon)),
14
+ icon && react_1.default.createElement(components_1.Image, Object.assign({ className: b('icon') }, icon)),
15
15
  react_1.default.createElement("span", { className: b('text') }, text)));
16
16
  const NavigationDropdown = (_a) => {
17
17
  var { text, icon, isOpened } = _a, props = (0, tslib_1.__rest)(_a, ["text", "icon", "isOpened"]);
18
18
  const iconData = icon && (0, utils_2.getMediaImage)(icon);
19
19
  return (react_1.default.createElement("span", Object.assign({}, props),
20
20
  react_1.default.createElement(Content, { text: text, icon: iconData }),
21
- react_1.default.createElement(index_1.ToggleArrow, { className: b('dropdown'), size: 12, type: 'vertical', iconType: "navigation", open: isOpened })));
21
+ react_1.default.createElement(components_1.ToggleArrow, { className: b('dropdown'), size: 12, type: 'vertical', iconType: "navigation", open: isOpened })));
22
22
  };
23
23
  const NavigationLink = (props) => {
24
24
  const { hostname, Link } = (0, react_1.useContext)(locationContext_1.LocationContext);
@@ -32,14 +32,14 @@ const NavigationLink = (props) => {
32
32
  return (react_1.default.createElement("a", Object.assign({ href: url, title: text }, rest, linkExtraProps), content));
33
33
  }
34
34
  else {
35
- return (react_1.default.createElement(index_1.RouterLink, { href: url, passHref: true },
35
+ return (react_1.default.createElement(components_1.RouterLink, { href: url, passHref: true },
36
36
  react_1.default.createElement("a", Object.assign({}, rest), content)));
37
37
  }
38
38
  };
39
39
  const NavigationButton = (props) => {
40
40
  const { url, target } = props;
41
- return target ? (react_1.default.createElement(index_1.Button, Object.assign({}, props, { url: url }))) : (react_1.default.createElement(index_1.RouterLink, { href: url },
42
- react_1.default.createElement(index_1.Button, Object.assign({}, props, { url: url }))));
41
+ return target ? (react_1.default.createElement(components_1.Button, Object.assign({}, props, { url: url }))) : (react_1.default.createElement(components_1.RouterLink, { href: url },
42
+ react_1.default.createElement(components_1.Button, Object.assign({}, props, { url: url }))));
43
43
  };
44
44
  //todo: add types support form component in map
45
45
  // eslint-disable-next-line @typescript-eslint/no-explicit-any
@@ -1,5 +1,5 @@
1
1
  import React from 'react';
2
- import { NavigationLinkItem } from '../../../../models';
2
+ import { NavigationLinkItem } from '../../../models';
3
3
  export interface NavigationPopupProps {
4
4
  items: NavigationLinkItem[];
5
5
  onClose: () => void;
@@ -5,8 +5,8 @@ const tslib_1 = require("tslib");
5
5
  const lodash_1 = (0, tslib_1.__importDefault)(require("lodash"));
6
6
  const react_1 = (0, tslib_1.__importStar)(require("react"));
7
7
  const uikit_1 = require("@gravity-ui/uikit");
8
- const utils_1 = require("../../../../utils");
9
- const index_1 = require("../../../index");
8
+ const utils_1 = require("../../../utils");
9
+ const components_1 = require("../../../components");
10
10
  const NavigationItem_1 = (0, tslib_1.__importDefault)(require("../NavigationItem/NavigationItem"));
11
11
  const b = (0, utils_1.block)('navigation-popup');
12
12
  const NavigationPopup = ({ items, left, onClose }) => {
@@ -39,7 +39,7 @@ const NavigationPopup = ({ items, left, onClose }) => {
39
39
  }
40
40
  return (react_1.default.createElement(uikit_1.Portal, null,
41
41
  react_1.default.createElement("div", { ref: popupRef, className: b(), style: { left: calculatedLeft } },
42
- react_1.default.createElement(index_1.OutsideClick, { onOutsideClick: onClose }, items.map((item) => (react_1.default.createElement(NavigationItem_1.default, { key: item.text, className: b('link'), data: item })))))));
42
+ react_1.default.createElement(components_1.OutsideClick, { onOutsideClick: onClose }, items.map((item) => (react_1.default.createElement(NavigationItem_1.default, { key: item.text, className: b('link'), data: item })))))));
43
43
  };
44
44
  exports.NavigationPopup = NavigationPopup;
45
45
  exports.default = exports.NavigationPopup;
@@ -0,0 +1,7 @@
1
+ import React from 'react';
2
+ import { NavigationSocialItem } from '../../../models';
3
+ export interface NavigationSocialItemOwnProps extends NavigationSocialItem {
4
+ className?: string;
5
+ }
6
+ declare const SocialIcon: React.FC<NavigationSocialItemOwnProps>;
7
+ export default SocialIcon;
@@ -2,13 +2,13 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  const tslib_1 = require("tslib");
4
4
  const react_1 = (0, tslib_1.__importDefault)(require("react"));
5
- const utils_1 = require("../../../../utils");
6
- const index_1 = require("../../../index");
7
- const utils_2 = require("../../../Media/Image/utils");
5
+ const utils_1 = require("../../../utils");
6
+ const components_1 = require("../../../components");
7
+ const utils_2 = require("../../../components/Media/Image/utils");
8
8
  const b = (0, utils_1.block)('social-icon');
9
9
  const SocialIcon = ({ icon, url, className }) => {
10
10
  const iconData = (0, utils_2.getMediaImage)(icon);
11
11
  return (react_1.default.createElement("a", { href: url, target: "_blank", rel: "noopener noreferrer", className: b(null, className) },
12
- react_1.default.createElement(index_1.Image, Object.assign({ className: b('icon') }, iconData))));
12
+ react_1.default.createElement(components_1.Image, Object.assign({ className: b('icon') }, iconData))));
13
13
  };
14
14
  exports.default = SocialIcon;
@@ -1,5 +1,5 @@
1
1
  import React from 'react';
2
- import { NavigationData } from '../../../../models';
2
+ import { NavigationData } from '../../../models';
3
3
  export interface LayoutProps {
4
4
  navigation?: NavigationData;
5
5
  children?: React.ReactNode;
@@ -2,7 +2,7 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  const tslib_1 = require("tslib");
4
4
  const react_1 = (0, tslib_1.__importDefault)(require("react"));
5
- const utils_1 = require("../../../../utils");
5
+ const utils_1 = require("../../../utils");
6
6
  const Header_1 = (0, tslib_1.__importDefault)(require("../../components/Header/Header"));
7
7
  const b = (0, utils_1.block)('layout');
8
8
  const Layout = ({ children, navigation }) => (react_1.default.createElement("div", { className: b() },
@@ -8,13 +8,11 @@ unpredictable css rules order in build */
8
8
  margin-bottom: 24px;
9
9
  }
10
10
  .pc-tabs-block__block-title_centered {
11
- display: flex;
12
- justify-content: center;
13
- flex-wrap: wrap;
14
- margin-left: auto;
15
- margin-right: auto;
16
11
  text-align: center;
17
12
  }
13
+ .pc-tabs-block__block-title_centered > * {
14
+ margin: 0 auto;
15
+ }
18
16
  .pc-tabs-block__tabs_centered {
19
17
  display: flex;
20
18
  justify-content: center;
@@ -1,10 +1,10 @@
1
1
  import { CSSProperties, MouseEventHandler } from 'react';
2
2
  import { ImageDeviceProps, ImageObjectProps } from '../../models';
3
- import './Image.css';
4
3
  export interface ImageProps extends Partial<ImageObjectProps>, Partial<ImageDeviceProps> {
5
4
  style?: CSSProperties;
6
5
  className?: string;
7
6
  onClick?: MouseEventHandler;
7
+ containerClassName?: string;
8
8
  }
9
9
  declare const Image: (props: ImageProps) => JSX.Element | null;
10
10
  export default Image;
@@ -1,15 +1,12 @@
1
1
  import React, { useContext, useState, Fragment } from 'react';
2
2
  import { ProjectSettingsContext } from '../../context/projectSettingsContext';
3
3
  import { BREAKPOINTS } from '../../constants';
4
- import { block } from '../../utils';
5
- import './Image.css';
6
- const b = block('image');
7
4
  const checkWebP = (src) => {
8
5
  return src.endsWith('.webp') ? src : src + '.webp';
9
6
  };
10
7
  const Image = (props) => {
11
8
  const projectSettings = useContext(ProjectSettingsContext);
12
- const { src, alt, disableCompress, tablet, desktop, mobile, style, className, onClick } = props;
9
+ const { src, alt, disableCompress, tablet, desktop, mobile, style, className, onClick, containerClassName, } = props;
13
10
  const [imgLoadingError, setImgLoadingError] = useState(false);
14
11
  const imageSrc = src || desktop;
15
12
  if (!imageSrc) {
@@ -20,7 +17,7 @@ const Image = (props) => {
20
17
  disableCompress ||
21
18
  imageSrc.endsWith('.svg') ||
22
19
  imgLoadingError;
23
- return (React.createElement("picture", { className: b() },
20
+ return (React.createElement("picture", { className: containerClassName },
24
21
  mobile && (React.createElement(Fragment, null,
25
22
  !disableWebp && (React.createElement("source", { srcSet: checkWebP(mobile), type: "image/webp", media: `(max-width: ${BREAKPOINTS.sm}px)` })),
26
23
  React.createElement("source", { srcSet: mobile, media: `(max-width: ${BREAKPOINTS.sm}px)` }))),
@@ -19,6 +19,10 @@ unpredictable css rules order in build */
19
19
  object-fit: cover;
20
20
  display: block;
21
21
  }
22
+ .pc-VideoBlock__image-wrapper {
23
+ height: 100%;
24
+ width: 100%;
25
+ }
22
26
  .pc-VideoBlock__button {
23
27
  display: inline-block;
24
28
  margin: 0;
@@ -87,7 +87,7 @@ const VideoBlock = (props) => {
87
87
  return null;
88
88
  }
89
89
  return (React.createElement("div", { className: b(null, className), ref: ref, style: { height: currentHeight } }, previewImg && !hidePreview && (React.createElement("div", { className: b('preview'), onClick: onPreviewClick },
90
- React.createElement(Image, { src: previewImg, className: b('image') }),
90
+ React.createElement(Image, { src: previewImg, className: b('image'), containerClassName: b('image-wrapper') }),
91
91
  playButton || (React.createElement("button", { className: b('button') },
92
92
  React.createElement(Icon, { className: b('icon'), data: PlayVideo, size: 24 })))))));
93
93
  };
@@ -33,6 +33,4 @@ export { default as OverflowScroller } from './OverflowScroller/OverflowScroller
33
33
  export { default as Author } from './Author/Author';
34
34
  export { default as RouterLink } from './RouterLink/RouterLink';
35
35
  export { default as HTML } from './HTML/HTML';
36
- export { default as Header } from './navigation/components/Header/Header';
37
- export * as Navigation from './navigation/components/index';
38
36
  export type { RouterLinkProps } from './RouterLink/RouterLink';
@@ -33,5 +33,3 @@ export { default as OverflowScroller } from './OverflowScroller/OverflowScroller
33
33
  export { default as Author } from './Author/Author';
34
34
  export { default as RouterLink } from './RouterLink/RouterLink';
35
35
  export { default as HTML } from './HTML/HTML';
36
- export { default as Header } from './navigation/components/Header/Header';
37
- export * as Navigation from './navigation/components/index';
@@ -13,7 +13,7 @@ import { ConstructorRow } from './components/ConstructorRow';
13
13
  import { ConstructorFootnotes } from './components/ConstructorFootnotes';
14
14
  import { ConstructorHeader } from './components/ConstructorItem';
15
15
  import { ConstructorBlocks } from './components/ConstructorBlocks';
16
- import Layout from '../../components/navigation/containers/Layout/Layout';
16
+ import Layout from '../../navigation/containers/Layout/Layout';
17
17
  import './PageConstructor.css';
18
18
  const b = cnBlock('page-constructor');
19
19
  export const Constructor = (props) => {
@@ -30,24 +30,24 @@ export interface NavigationSocialItem extends Omit<NavigationItemBase, 'text'> {
30
30
  icon: ImageProps;
31
31
  url: string;
32
32
  }
33
- export declare type NavigationItem = NavigationLinkItem | NavigationButtonItem | NavigationDropdownItem;
33
+ export declare type NavigationItemModel = NavigationLinkItem | NavigationButtonItem | NavigationDropdownItem;
34
34
  export declare type NavigationItemData = NavigationLinkItem | NavigationButtonItem | NavigationSocialItem | DropdownItemData;
35
35
  export declare type DropdownItemData = Omit<NavigationDropdownItem, 'items'>;
36
- export interface NavigationLogo {
36
+ export interface NavigationLogoData {
37
37
  icon: ImageProps;
38
38
  text?: string;
39
39
  url?: string;
40
40
  }
41
41
  export interface HeaderData {
42
- leftItems: NavigationItem[];
43
- rightItems?: NavigationItem[];
42
+ leftItems: NavigationItemModel[];
43
+ rightItems?: NavigationItemModel[];
44
44
  }
45
45
  export interface FooterColumn {
46
46
  title: string;
47
- links: NavigationItem[];
47
+ links: NavigationItemModel[];
48
48
  }
49
49
  export interface FooterUnderline {
50
- links?: NavigationItem[];
50
+ links?: NavigationItemModel[];
51
51
  copyright?: string;
52
52
  }
53
53
  export interface FooterData {
@@ -56,7 +56,7 @@ export interface FooterData {
56
56
  underline?: FooterUnderline;
57
57
  }
58
58
  export interface NavigationData {
59
- logo: NavigationLogo;
59
+ logo: NavigationLogoData;
60
60
  header: HeaderData;
61
61
  footer?: FooterData;
62
62
  }
@@ -1,8 +1,8 @@
1
1
  import React from 'react';
2
- import { HeaderData, NavigationLogo } from '../../../../models';
2
+ import { HeaderData, NavigationLogoData } from '../../../models';
3
3
  import './Header.css';
4
4
  export interface HeaderProps {
5
- logo: NavigationLogo;
5
+ logo: NavigationLogoData;
6
6
  data: HeaderData;
7
7
  }
8
8
  export declare const Header: React.FC<HeaderProps>;
@@ -1,13 +1,13 @@
1
1
  import React, { useCallback, useState } from 'react';
2
- import { block } from '../../../../utils';
3
- import { Col, Grid, Row } from '../../../../grid';
4
- import OutsideClick from '../../../OutsideClick/OutsideClick';
5
- import Control from '../../../Control/Control';
2
+ import { block } from '../../../utils';
3
+ import { Col, Grid, Row } from '../../../grid';
4
+ import OutsideClick from '../../../components/OutsideClick/OutsideClick';
5
+ import Control from '../../../components/Control/Control';
6
6
  import Navigation from '../Navigation/Navigation';
7
7
  import MobileNavigation from '../MobileNavigation/MobileNavigation';
8
8
  import NavigationItem from '../NavigationItem/NavigationItem';
9
9
  import Logo from '../Logo/Logo';
10
- import { NavigationClose, NavigationOpen } from '../../../../icons';
10
+ import { NavigationClose, NavigationOpen } from '../../../icons';
11
11
  import './Header.css';
12
12
  const b = block('header');
13
13
  const ICON_SIZE = 36;
@@ -1,7 +1,7 @@
1
1
  import React from 'react';
2
- import { NavigationLogo } from '../../../../models';
2
+ import { NavigationLogoData } from '../../../models';
3
3
  import './Logo.css';
4
- export interface LogoProps extends NavigationLogo {
4
+ export interface LogoProps extends NavigationLogoData {
5
5
  className?: string;
6
6
  }
7
7
  declare const Logo: React.FC<LogoProps>;
@@ -1,8 +1,8 @@
1
1
  import React from 'react';
2
- import { block } from '../../../../utils';
3
- import RouterLink from '../../../RouterLink/RouterLink';
4
- import { getMediaImage } from '../../../Media/Image/utils';
5
- import { Image } from '../../../index';
2
+ import { block } from '../../../utils';
3
+ import RouterLink from '../../../components/RouterLink/RouterLink';
4
+ import { getMediaImage } from '../../../components/Media/Image/utils';
5
+ import { Image } from '../../../components';
6
6
  import './Logo.css';
7
7
  const b = block('logo');
8
8
  const Logo = ({ icon, text, className }) => {
@@ -1,5 +1,5 @@
1
1
  import React from 'react';
2
- import { NavigationItem as NavigationItemModel } from '../../../../models/navigation';
2
+ import { NavigationItemModel } from '../../../models';
3
3
  import './MobileNavigation.css';
4
4
  export interface MobileNavigationProps {
5
5
  className?: string;
@@ -1,8 +1,8 @@
1
1
  import React, { useRef, useCallback } from 'react';
2
2
  import { Popup, Portal } from '@gravity-ui/uikit';
3
- import { block } from '../../../../utils';
4
- import Foldable from '../../../Foldable/Foldable';
5
- import { NavigationItemType, } from '../../../../models/navigation';
3
+ import { block } from '../../../utils';
4
+ import Foldable from '../../../components/Foldable/Foldable';
5
+ import { NavigationItemType } from '../../../models';
6
6
  import NavigationItem from '../NavigationItem/NavigationItem';
7
7
  import './MobileNavigation.css';
8
8
  const b = block('mobile-navigation');
@@ -1,5 +1,5 @@
1
1
  import React, { MouseEventHandler } from 'react';
2
- import { NavigationDropdownItem, NavigationItem as NavigationItemModel } from '../../../../models/navigation';
2
+ import { NavigationDropdownItem, NavigationItemModel } from '../../../models/navigation';
3
3
  import './Navigation.css';
4
4
  export interface NavigationProps {
5
5
  links: NavigationItemModel[];
@@ -1,12 +1,12 @@
1
1
  import { __rest } from "tslib";
2
2
  import _ from 'lodash';
3
3
  import React, { Fragment, useState, useEffect, useCallback, useContext, useRef, } from 'react';
4
- import { block } from '../../../../utils';
5
- import OverflowScroller from '../../../OverflowScroller/OverflowScroller';
6
- import { NavigationItemType, } from '../../../../models/navigation';
4
+ import { block } from '../../../utils';
5
+ import OverflowScroller from '../../../components/OverflowScroller/OverflowScroller';
6
+ import { NavigationItemType, } from '../../../models/navigation';
7
7
  import NavigationPopup from '../NavigationPopup/NavigationPopup';
8
8
  import NavigationItem from '../NavigationItem/NavigationItem';
9
- import { LocationContext } from '../../../../context/locationContext';
9
+ import { LocationContext } from '../../../context/locationContext';
10
10
  import './Navigation.css';
11
11
  const b = block('navigation');
12
12
  const NavigationDropdown = ({ data, isActive, position, hidePopup, onClick, }) => {
@@ -1,5 +1,5 @@
1
1
  import React, { MouseEventHandler } from 'react';
2
- import { NavigationItemData } from '../../../../models';
2
+ import { NavigationItemData } from '../../../models';
3
3
  import './NavigationItem.css';
4
4
  export interface NavigationItemProps {
5
5
  data: NavigationItemData;
@@ -1,12 +1,12 @@
1
1
  import { __rest } from "tslib";
2
2
  import React, { Fragment, useContext, useMemo } from 'react';
3
- import { block, getLinkProps } from '../../../../utils';
4
- import { RouterLink, ToggleArrow, Button, Image } from '../../../index';
5
- import { LocationContext } from '../../../../context/locationContext';
6
- import { NavigationItemType, } from '../../../../models';
7
- import { NavigationArrow } from '../../../../icons';
3
+ import { block, getLinkProps } from '../../../utils';
4
+ import { RouterLink, ToggleArrow, Button, Image } from '../../../components';
5
+ import { LocationContext } from '../../../context/locationContext';
6
+ import { NavigationItemType, } from '../../../models';
7
+ import { NavigationArrow } from '../../../icons';
8
8
  import SocialIcon from '../SocialIcon/SocialIcon';
9
- import { getMediaImage } from '../../../Media/Image/utils';
9
+ import { getMediaImage } from '../../../components/Media/Image/utils';
10
10
  import './NavigationItem.css';
11
11
  const b = block('navigation-item');
12
12
  const Content = ({ text, icon }) => (React.createElement(Fragment, null,
@@ -1,5 +1,5 @@
1
1
  import React from 'react';
2
- import { NavigationLinkItem } from '../../../../models';
2
+ import { NavigationLinkItem } from '../../../models';
3
3
  import './NavigationPopup.css';
4
4
  export interface NavigationPopupProps {
5
5
  items: NavigationLinkItem[];
@@ -1,8 +1,8 @@
1
1
  import _ from 'lodash';
2
2
  import React, { useRef, useState, useEffect, useCallback } from 'react';
3
3
  import { Portal } from '@gravity-ui/uikit';
4
- import { block } from '../../../../utils';
5
- import { OutsideClick } from '../../../index';
4
+ import { block } from '../../../utils';
5
+ import { OutsideClick } from '../../../components';
6
6
  import NavigationItem from '../NavigationItem/NavigationItem';
7
7
  import './NavigationPopup.css';
8
8
  const b = block('navigation-popup');
@@ -0,0 +1,8 @@
1
+ import React from 'react';
2
+ import { NavigationSocialItem } from '../../../models';
3
+ import './SocialIcon.css';
4
+ export interface NavigationSocialItemOwnProps extends NavigationSocialItem {
5
+ className?: string;
6
+ }
7
+ declare const SocialIcon: React.FC<NavigationSocialItemOwnProps>;
8
+ export default SocialIcon;
@@ -1,7 +1,7 @@
1
1
  import React from 'react';
2
- import { block } from '../../../../utils';
3
- import { Image } from '../../../index';
4
- import { getMediaImage } from '../../../Media/Image/utils';
2
+ import { block } from '../../../utils';
3
+ import { Image } from '../../../components';
4
+ import { getMediaImage } from '../../../components/Media/Image/utils';
5
5
  import './SocialIcon.css';
6
6
  const b = block('social-icon');
7
7
  const SocialIcon = ({ icon, url, className }) => {
@@ -1,5 +1,5 @@
1
1
  import React from 'react';
2
- import { NavigationData } from '../../../../models';
2
+ import { NavigationData } from '../../../models';
3
3
  import './Layout.css';
4
4
  export interface LayoutProps {
5
5
  navigation?: NavigationData;
@@ -1,5 +1,5 @@
1
1
  import React from 'react';
2
- import { block } from '../../../../utils';
2
+ import { block } from '../../../utils';
3
3
  import Header from '../../components/Header/Header';
4
4
  import './Layout.css';
5
5
  const b = block('layout');
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@gravity-ui/page-constructor",
3
- "version": "1.9.1",
3
+ "version": "1.9.3",
4
4
  "description": "Gravity UI Page Constructor",
5
5
  "license": "MIT",
6
6
  "repository": {
@@ -30,24 +30,24 @@ export interface NavigationSocialItem extends Omit<NavigationItemBase, 'text'> {
30
30
  icon: ImageProps;
31
31
  url: string;
32
32
  }
33
- export declare type NavigationItem = NavigationLinkItem | NavigationButtonItem | NavigationDropdownItem;
33
+ export declare type NavigationItemModel = NavigationLinkItem | NavigationButtonItem | NavigationDropdownItem;
34
34
  export declare type NavigationItemData = NavigationLinkItem | NavigationButtonItem | NavigationSocialItem | DropdownItemData;
35
35
  export declare type DropdownItemData = Omit<NavigationDropdownItem, 'items'>;
36
- export interface NavigationLogo {
36
+ export interface NavigationLogoData {
37
37
  icon: ImageProps;
38
38
  text?: string;
39
39
  url?: string;
40
40
  }
41
41
  export interface HeaderData {
42
- leftItems: NavigationItem[];
43
- rightItems?: NavigationItem[];
42
+ leftItems: NavigationItemModel[];
43
+ rightItems?: NavigationItemModel[];
44
44
  }
45
45
  export interface FooterColumn {
46
46
  title: string;
47
- links: NavigationItem[];
47
+ links: NavigationItemModel[];
48
48
  }
49
49
  export interface FooterUnderline {
50
- links?: NavigationItem[];
50
+ links?: NavigationItemModel[];
51
51
  copyright?: string;
52
52
  }
53
53
  export interface FooterData {
@@ -56,7 +56,7 @@ export interface FooterData {
56
56
  underline?: FooterUnderline;
57
57
  }
58
58
  export interface NavigationData {
59
- logo: NavigationLogo;
59
+ logo: NavigationLogoData;
60
60
  header: HeaderData;
61
61
  footer?: FooterData;
62
62
  }
@@ -1,4 +0,0 @@
1
- .pc-image {
2
- height: 100%;
3
- width: 100%;
4
- }
@@ -1,7 +0,0 @@
1
- import React from 'react';
2
- import { NavigationSocialItem } from '../../../../models';
3
- export interface NavigationSocialItemProps extends NavigationSocialItem {
4
- className?: string;
5
- }
6
- declare const SocialIcon: React.FC<NavigationSocialItemProps>;
7
- export default SocialIcon;
@@ -1,7 +0,0 @@
1
- export { default as Header } from './Header/Header';
2
- export { default as NavigationItem } from './NavigationItem/NavigationItem';
3
- export { default as Logo } from './Logo/Logo';
4
- export { default as MobileNavigation } from './MobileNavigation/MobileNavigation';
5
- export { default as Navigation } from './Navigation/Navigation';
6
- export { default as NavigationPopup } from './NavigationPopup/NavigationPopup';
7
- export { default as SocialIcon } from './SocialIcon/SocialIcon';
@@ -1,20 +0,0 @@
1
- "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.SocialIcon = exports.NavigationPopup = exports.Navigation = exports.MobileNavigation = exports.Logo = exports.NavigationItem = exports.Header = void 0;
7
- var Header_1 = require("./Header/Header");
8
- Object.defineProperty(exports, "Header", { enumerable: true, get: function () { return __importDefault(Header_1).default; } });
9
- var NavigationItem_1 = require("./NavigationItem/NavigationItem");
10
- Object.defineProperty(exports, "NavigationItem", { enumerable: true, get: function () { return __importDefault(NavigationItem_1).default; } });
11
- var Logo_1 = require("./Logo/Logo");
12
- Object.defineProperty(exports, "Logo", { enumerable: true, get: function () { return __importDefault(Logo_1).default; } });
13
- var MobileNavigation_1 = require("./MobileNavigation/MobileNavigation");
14
- Object.defineProperty(exports, "MobileNavigation", { enumerable: true, get: function () { return __importDefault(MobileNavigation_1).default; } });
15
- var Navigation_1 = require("./Navigation/Navigation");
16
- Object.defineProperty(exports, "Navigation", { enumerable: true, get: function () { return __importDefault(Navigation_1).default; } });
17
- var NavigationPopup_1 = require("./NavigationPopup/NavigationPopup");
18
- Object.defineProperty(exports, "NavigationPopup", { enumerable: true, get: function () { return __importDefault(NavigationPopup_1).default; } });
19
- var SocialIcon_1 = require("./SocialIcon/SocialIcon");
20
- Object.defineProperty(exports, "SocialIcon", { enumerable: true, get: function () { return __importDefault(SocialIcon_1).default; } });
@@ -1,4 +0,0 @@
1
- .pc-image {
2
- height: 100%;
3
- width: 100%;
4
- }
@@ -1,8 +0,0 @@
1
- import React from 'react';
2
- import { NavigationSocialItem } from '../../../../models';
3
- import './SocialIcon.css';
4
- export interface NavigationSocialItemProps extends NavigationSocialItem {
5
- className?: string;
6
- }
7
- declare const SocialIcon: React.FC<NavigationSocialItemProps>;
8
- export default SocialIcon;
@@ -1,7 +0,0 @@
1
- export { default as Header } from './Header/Header';
2
- export { default as NavigationItem } from './NavigationItem/NavigationItem';
3
- export { default as Logo } from './Logo/Logo';
4
- export { default as MobileNavigation } from './MobileNavigation/MobileNavigation';
5
- export { default as Navigation } from './Navigation/Navigation';
6
- export { default as NavigationPopup } from './NavigationPopup/NavigationPopup';
7
- export { default as SocialIcon } from './SocialIcon/SocialIcon';
@@ -1,7 +0,0 @@
1
- export { default as Header } from './Header/Header';
2
- export { default as NavigationItem } from './NavigationItem/NavigationItem';
3
- export { default as Logo } from './Logo/Logo';
4
- export { default as MobileNavigation } from './MobileNavigation/MobileNavigation';
5
- export { default as Navigation } from './Navigation/Navigation';
6
- export { default as NavigationPopup } from './NavigationPopup/NavigationPopup';
7
- export { default as SocialIcon } from './SocialIcon/SocialIcon';