@gravity-ui/page-constructor 3.0.0-alpha.6 → 4.0.0-beta.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 (99) hide show
  1. package/CHANGELOG.md +21 -0
  2. package/README.md +1 -1
  3. package/build/cjs/blocks/CardLayout/CardLayout.js +1 -1
  4. package/build/cjs/blocks/CardLayout/schema.d.ts +2 -2
  5. package/build/cjs/blocks/CardLayout/schema.js +1 -1
  6. package/build/cjs/blocks/FilterBlock/FilterBlock.js +9 -13
  7. package/build/cjs/blocks/Header/schema.d.ts +9 -0
  8. package/build/cjs/blocks/HeaderSlider/schema.d.ts +3 -0
  9. package/build/cjs/blocks/Media/schema.d.ts +6 -0
  10. package/build/cjs/blocks/PromoFeaturesBlock/schema.d.ts +3 -0
  11. package/build/cjs/blocks/Tabs/schema.d.ts +3 -0
  12. package/build/cjs/components/FullscreenImage/{FullScreenImage.css → FullscreenImage.css} +13 -13
  13. package/build/cjs/components/FullscreenImage/FullscreenImage.d.ts +3 -3
  14. package/build/cjs/components/FullscreenImage/FullscreenImage.js +7 -7
  15. package/build/cjs/components/FullscreenImage/i18n/index.js +1 -1
  16. package/build/cjs/components/FullscreenMedia/FullscreenMedia.d.ts +9 -0
  17. package/build/cjs/components/FullscreenMedia/{FullScreenMedia.js → FullscreenMedia.js} +5 -5
  18. package/build/cjs/components/Media/FullscreenVideo/FullscreenVideo.d.ts +4 -0
  19. package/build/cjs/components/Media/FullscreenVideo/FullscreenVideo.js +10 -0
  20. package/build/cjs/components/Media/Image/Image.d.ts +1 -0
  21. package/build/cjs/components/Media/Image/Image.js +10 -3
  22. package/build/cjs/components/Media/Media.js +25 -5
  23. package/build/cjs/components/Media/Video/Video.d.ts +1 -1
  24. package/build/cjs/components/VideoBlock/VideoBlock.d.ts +1 -1
  25. package/build/cjs/components/VideoBlock/VideoBlock.js +3 -3
  26. package/build/cjs/components/index.d.ts +1 -1
  27. package/build/cjs/components/index.js +3 -3
  28. package/build/cjs/constructor-items.d.ts +1 -1
  29. package/build/cjs/grid/Col/Col.d.ts +1 -1
  30. package/build/cjs/icons/Fullscreen.d.ts +2 -0
  31. package/build/cjs/icons/{FullScreen.js → Fullscreen.js} +3 -3
  32. package/build/cjs/icons/index.d.ts +1 -1
  33. package/build/cjs/icons/index.js +1 -1
  34. package/build/cjs/models/constructor-items/blocks.d.ts +1 -1
  35. package/build/cjs/models/constructor-items/common.d.ts +1 -1
  36. package/build/cjs/models/constructor-items/sub-blocks.d.ts +1 -1
  37. package/build/cjs/schema/validators/common.d.ts +3 -0
  38. package/build/cjs/schema/validators/common.js +3 -0
  39. package/build/cjs/sub-blocks/LayoutItem/LayoutItem.d.ts +1 -1
  40. package/build/cjs/sub-blocks/LayoutItem/LayoutItem.js +4 -4
  41. package/build/cjs/sub-blocks/LayoutItem/schema.d.ts +4 -1
  42. package/build/cjs/sub-blocks/LayoutItem/schema.js +1 -1
  43. package/build/cjs/sub-blocks/LayoutItem/utils.d.ts +2 -2
  44. package/build/cjs/sub-blocks/LayoutItem/utils.js +6 -6
  45. package/build/cjs/sub-blocks/MediaCard/schema.d.ts +3 -0
  46. package/build/esm/blocks/CardLayout/CardLayout.js +1 -1
  47. package/build/esm/blocks/CardLayout/schema.d.ts +2 -2
  48. package/build/esm/blocks/CardLayout/schema.js +1 -1
  49. package/build/esm/blocks/FilterBlock/FilterBlock.js +10 -14
  50. package/build/esm/blocks/Header/schema.d.ts +9 -0
  51. package/build/esm/blocks/HeaderSlider/schema.d.ts +3 -0
  52. package/build/esm/blocks/Media/schema.d.ts +6 -0
  53. package/build/esm/blocks/PromoFeaturesBlock/schema.d.ts +3 -0
  54. package/build/esm/blocks/Tabs/Tabs.js +2 -2
  55. package/build/esm/blocks/Tabs/schema.d.ts +3 -0
  56. package/build/esm/components/FullscreenImage/{FullScreenImage.css → FullscreenImage.css} +13 -13
  57. package/build/esm/components/FullscreenImage/FullscreenImage.d.ts +4 -4
  58. package/build/esm/components/FullscreenImage/FullscreenImage.js +9 -9
  59. package/build/esm/components/FullscreenImage/i18n/index.js +1 -1
  60. package/build/esm/components/FullscreenMedia/FullscreenMedia.d.ts +10 -0
  61. package/build/esm/components/FullscreenMedia/{FullScreenMedia.js → FullscreenMedia.js} +7 -7
  62. package/build/esm/components/Media/FullscreenVideo/FullscreenVideo.d.ts +4 -0
  63. package/build/esm/components/Media/FullscreenVideo/FullscreenVideo.js +7 -0
  64. package/build/esm/components/Media/Image/Image.d.ts +1 -0
  65. package/build/esm/components/Media/Image/Image.js +12 -5
  66. package/build/esm/components/Media/Media.js +25 -5
  67. package/build/esm/components/Media/Video/Video.d.ts +1 -1
  68. package/build/esm/components/VideoBlock/VideoBlock.d.ts +1 -1
  69. package/build/esm/components/VideoBlock/VideoBlock.js +3 -3
  70. package/build/esm/components/index.d.ts +1 -1
  71. package/build/esm/components/index.js +1 -1
  72. package/build/esm/constructor-items.d.ts +1 -1
  73. package/build/esm/grid/Col/Col.d.ts +1 -1
  74. package/build/esm/icons/Fullscreen.d.ts +2 -0
  75. package/build/esm/icons/{FullScreen.js → Fullscreen.js} +1 -1
  76. package/build/esm/icons/index.d.ts +1 -1
  77. package/build/esm/icons/index.js +1 -1
  78. package/build/esm/models/constructor-items/blocks.d.ts +1 -1
  79. package/build/esm/models/constructor-items/common.d.ts +1 -1
  80. package/build/esm/models/constructor-items/sub-blocks.d.ts +1 -1
  81. package/build/esm/schema/validators/common.d.ts +3 -0
  82. package/build/esm/schema/validators/common.js +3 -0
  83. package/build/esm/sub-blocks/LayoutItem/LayoutItem.d.ts +1 -1
  84. package/build/esm/sub-blocks/LayoutItem/LayoutItem.js +6 -6
  85. package/build/esm/sub-blocks/LayoutItem/schema.d.ts +4 -1
  86. package/build/esm/sub-blocks/LayoutItem/schema.js +1 -1
  87. package/build/esm/sub-blocks/LayoutItem/utils.d.ts +2 -2
  88. package/build/esm/sub-blocks/LayoutItem/utils.js +3 -3
  89. package/build/esm/sub-blocks/MediaCard/schema.d.ts +3 -0
  90. package/package.json +1 -4
  91. package/server/models/constructor-items/blocks.d.ts +1 -1
  92. package/server/models/constructor-items/common.d.ts +1 -1
  93. package/server/models/constructor-items/sub-blocks.d.ts +1 -1
  94. package/build/cjs/components/FullscreenMedia/FullScreenMedia.d.ts +0 -9
  95. package/build/cjs/icons/FullScreen.d.ts +0 -2
  96. package/build/esm/components/FullscreenMedia/FullScreenMedia.d.ts +0 -10
  97. package/build/esm/icons/FullScreen.d.ts +0 -2
  98. /package/build/cjs/components/FullscreenMedia/{FullScreenMedia.css → FullscreenMedia.css} +0 -0
  99. /package/build/esm/components/FullscreenMedia/{FullScreenMedia.css → FullscreenMedia.css} +0 -0
package/CHANGELOG.md CHANGED
@@ -1,5 +1,26 @@
1
1
  # Changelog
2
2
 
3
+ ## [4.0.0-beta.0](https://github.com/gravity-ui/page-constructor/compare/v2.22.1...v4.0.0-beta.0) (2023-06-05)
4
+
5
+
6
+ ### Features
7
+
8
+ * page-constructor 3.0.0 beta ([#234](https://github.com/gravity-ui/page-constructor/issues/234)) ([28def58](https://github.com/gravity-ui/page-constructor/commit/28def586f89cc549c6b928eea994d590740fbefe))
9
+
10
+ ## [2.22.1](https://github.com/gravity-ui/page-constructor/compare/v2.22.0...v2.22.1) (2023-06-01)
11
+
12
+
13
+ ### Bug Fixes
14
+
15
+ * filter block nesting ([#364](https://github.com/gravity-ui/page-constructor/issues/364)) ([5b62522](https://github.com/gravity-ui/page-constructor/commit/5b62522e5e34eeacbb2fb9ec6de957bba69cd758))
16
+
17
+ ## [2.22.0](https://github.com/gravity-ui/page-constructor/compare/v2.21.0...v2.22.0) (2023-05-31)
18
+
19
+
20
+ ### Features
21
+
22
+ * **Media:** add fullscreen video ([#345](https://github.com/gravity-ui/page-constructor/issues/345)) ([516a9a8](https://github.com/gravity-ui/page-constructor/commit/516a9a8423d710b6ecad33046121c489fa876e30))
23
+
3
24
  ## [2.21.0](https://github.com/gravity-ui/page-constructor/compare/v2.20.1...v2.21.0) (2023-05-29)
4
25
 
5
26
 
package/README.md CHANGED
@@ -183,7 +183,7 @@ Sub-blocks are components that can be used in the block `children` property. In
183
183
  - Add it to `enum` or `selectCases` in the `schema/index.ts` file.
184
184
 
185
185
  6. In the block directory, add the `README.md` file with a description of input parameters.
186
- 7. In the block directory add storybook demo in `__stories__` folder. (All demo content for story should be placed in `data.json` at story dir)
186
+ 7. In the block directory add storybook demo in `__stories__` folder. All demo content for story should be placed in `data.json` at story dir. The generic `Story` must accept the type of block props, otherwise incorrect block props will be displayed in Storybook.
187
187
 
188
188
  ### Themes
189
189
 
@@ -12,6 +12,6 @@ const DEFAULT_SIZES = {
12
12
  };
13
13
  const b = (0, utils_1.block)('card-layout-block');
14
14
  const CardLayout = ({ title, description, animated, colSizes = DEFAULT_SIZES, children, }) => (react_1.default.createElement(components_1.AnimateBlock, { className: b(), animate: animated },
15
- react_1.default.createElement(components_1.Title, { title: title, subtitle: description }),
15
+ (title || description) && react_1.default.createElement(components_1.Title, { title: title, subtitle: description }),
16
16
  react_1.default.createElement(grid_1.Row, null, react_1.default.Children.map(children, (child, index) => (react_1.default.createElement(grid_1.Col, { key: index, sizes: colSizes, className: b('item') }, child))))));
17
17
  exports.default = CardLayout;
@@ -1,6 +1,6 @@
1
1
  export declare const CardLayoutProps: {
2
2
  additionalProperties: boolean;
3
- required: string[];
3
+ required: never[];
4
4
  properties: {
5
5
  colSizes: {
6
6
  type: string;
@@ -76,7 +76,7 @@ export declare const CardLayoutProps: {
76
76
  export declare const CardLayoutBlock: {
77
77
  'card-layout-block': {
78
78
  additionalProperties: boolean;
79
- required: string[];
79
+ required: never[];
80
80
  properties: {
81
81
  colSizes: {
82
82
  type: string;
@@ -4,7 +4,7 @@ exports.CardLayoutBlock = exports.CardLayoutProps = void 0;
4
4
  const common_1 = require("../../schema/validators/common");
5
5
  exports.CardLayoutProps = {
6
6
  additionalProperties: false,
7
- required: ['title'],
7
+ required: [],
8
8
  properties: Object.assign(Object.assign(Object.assign(Object.assign({}, common_1.BlockBaseProps), common_1.AnimatableProps), common_1.BlockHeaderProps), { colSizes: common_1.containerSizesObject, children: common_1.ChildrenCardsProps }),
9
9
  };
10
10
  exports.CardLayoutBlock = {
@@ -2,11 +2,11 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  const tslib_1 = require("tslib");
4
4
  const react_1 = tslib_1.__importStar(require("react"));
5
+ const __1 = require("..");
5
6
  const components_1 = require("../../components");
6
7
  const ButtonTabs_1 = tslib_1.__importDefault(require("../../components/ButtonTabs/ButtonTabs"));
7
- const ConstructorBlocks_1 = require("../../containers/PageConstructor/components/ConstructorBlocks");
8
+ const ConstructorItem_1 = require("../../containers/PageConstructor/components/ConstructorItem");
8
9
  const grid_1 = require("../../grid");
9
- const models_1 = require("../../models");
10
10
  const utils_1 = require("../../utils");
11
11
  const i18n_1 = tslib_1.__importDefault(require("./i18n"));
12
12
  const b = (0, utils_1.block)('filter-block');
@@ -24,25 +24,21 @@ const FilterBlock = ({ title, description, tags, tagButtonSize, allTag, items, c
24
24
  ? tabButtons[0].id
25
25
  : selectedTag;
26
26
  }, [tabButtons, selectedTag]);
27
- const container = (0, react_1.useMemo)(() => {
27
+ const cards = (0, react_1.useMemo)(() => {
28
28
  const itemsToShow = actualTag
29
29
  ? items.filter((item) => item.tags.includes(actualTag))
30
30
  : items;
31
- return [
32
- {
33
- type: models_1.BlockType.CardLayoutBlock,
34
- title: '',
35
- colSizes: colSizes,
36
- children: itemsToShow.map((item) => item.card),
37
- },
38
- ];
39
- }, [actualTag, items, colSizes]);
31
+ return itemsToShow.map((item) => item.card);
32
+ }, [actualTag, items]);
40
33
  return (react_1.default.createElement(components_1.AnimateBlock, { className: b(), animate: animated },
41
34
  title && (react_1.default.createElement(components_1.Title, { className: b('title', { centered: centered }), title: title, subtitle: description })),
42
35
  tabButtons.length && (react_1.default.createElement(grid_1.Row, null,
43
36
  react_1.default.createElement(grid_1.Col, null,
44
37
  react_1.default.createElement(ButtonTabs_1.default, { className: b('tabs', { centered: centered }), items: tabButtons, activeTab: selectedTag, onSelectTab: setSelectedTag, tabSize: tagButtonSize })))),
45
38
  react_1.default.createElement(grid_1.Row, { className: b('block-container') },
46
- react_1.default.createElement(ConstructorBlocks_1.ConstructorBlocks, { items: container }))));
39
+ react_1.default.createElement(__1.CardLayoutBlock, { title: "", colSizes: colSizes }, cards.map((card, index) => {
40
+ const key = (0, utils_1.getBlockKey)(card, index);
41
+ return react_1.default.createElement(ConstructorItem_1.ConstructorItem, { data: card, blockKey: key, key: key });
42
+ })))));
47
43
  };
48
44
  exports.default = FilterBlock;
@@ -137,6 +137,9 @@ export declare const HeaderBackgroundProps: {
137
137
  type: string;
138
138
  })[];
139
139
  };
140
+ fullscreen: {
141
+ type: string;
142
+ };
140
143
  };
141
144
  };
142
145
  export declare const HeaderProperties: {
@@ -424,6 +427,9 @@ export declare const HeaderProperties: {
424
427
  type: string;
425
428
  })[];
426
429
  };
430
+ fullscreen: {
431
+ type: string;
432
+ };
427
433
  };
428
434
  } | {
429
435
  type: string;
@@ -757,6 +763,9 @@ export declare const HeaderBlock: {
757
763
  type: string;
758
764
  })[];
759
765
  };
766
+ fullscreen: {
767
+ type: string;
768
+ };
760
769
  };
761
770
  } | {
762
771
  type: string;
@@ -294,6 +294,9 @@ export declare const HeaderSliderBlock: {
294
294
  type: string;
295
295
  })[];
296
296
  };
297
+ fullscreen: {
298
+ type: string;
299
+ };
297
300
  };
298
301
  } | {
299
302
  type: string;
@@ -131,6 +131,9 @@ export declare const Media: {
131
131
  type: string;
132
132
  })[];
133
133
  };
134
+ fullscreen: {
135
+ type: string;
136
+ };
134
137
  };
135
138
  };
136
139
  export declare const MediaBlockBaseProps: {
@@ -608,6 +611,9 @@ export declare const MediaBlock: {
608
611
  type: string;
609
612
  })[];
610
613
  };
614
+ fullscreen: {
615
+ type: string;
616
+ };
611
617
  };
612
618
  };
613
619
  description: {
@@ -146,6 +146,9 @@ export declare const PromoFeaturesItem: {
146
146
  type: string;
147
147
  })[];
148
148
  };
149
+ fullscreen: {
150
+ type: string;
151
+ };
149
152
  };
150
153
  };
151
154
  };
@@ -142,6 +142,9 @@ export declare const tabsItem: {
142
142
  type: string;
143
143
  })[];
144
144
  };
145
+ fullscreen: {
146
+ type: string;
147
+ };
145
148
  };
146
149
  } | {
147
150
  type: string;
@@ -1,24 +1,24 @@
1
1
  /* use this for style redefinitions to awoid problems with
2
2
  unpredictable css rules order in build */
3
- .pc-FullScreenImage__image {
3
+ .pc-fullscreen-image__image {
4
4
  cursor: pointer;
5
5
  }
6
- .pc-FullScreenImage__image-wrapper {
6
+ .pc-fullscreen-image__image-wrapper {
7
7
  position: relative;
8
8
  }
9
- .pc-FullScreenImage__modal-content {
9
+ .pc-fullscreen-image__modal-content {
10
10
  position: relative;
11
11
  }
12
- .pc-FullScreenImage__modal-image {
12
+ .pc-fullscreen-image__modal-image {
13
13
  display: block;
14
14
  max-width: 1232px;
15
15
  max-height: 70vh;
16
16
  overflow: hidden;
17
17
  }
18
- .pc-FullScreenImage__modal .yc-modal__content, .pc-FullScreenImage__modal-image {
18
+ .pc-fullscreen-image__modal .yc-modal__content, .pc-fullscreen-image__modal-image {
19
19
  border-radius: var(--pc-border-radius);
20
20
  }
21
- .pc-FullScreenImage__icon-wrapper {
21
+ .pc-fullscreen-image__icon-wrapper {
22
22
  display: flex;
23
23
  align-items: center;
24
24
  justify-content: center;
@@ -33,28 +33,28 @@ unpredictable css rules order in build */
33
33
  opacity: 0;
34
34
  transition: 0.3s;
35
35
  }
36
- .pc-FullScreenImage__icon-wrapper_visible {
36
+ .pc-fullscreen-image__icon-wrapper_visible {
37
37
  opacity: 1;
38
38
  }
39
- .pc-FullScreenImage__icon {
39
+ .pc-fullscreen-image__icon {
40
40
  color: var(--yc-color-text-hint);
41
41
  }
42
- .pc-FullScreenImage__icon_hover:hover {
42
+ .pc-fullscreen-image__icon_hover:hover {
43
43
  color: var(--yc-color-text-secondary);
44
44
  }
45
45
  @media (max-width: 1185px) {
46
- .pc-FullScreenImage__modal-image {
46
+ .pc-fullscreen-image__modal-image {
47
47
  width: 100%;
48
48
  }
49
49
  }
50
50
  @media (max-width: 1081px) {
51
- .pc-FullScreenImage__image {
51
+ .pc-fullscreen-image__image {
52
52
  pointer-events: none;
53
53
  }
54
- .pc-FullScreenImage__icon-wrapper {
54
+ .pc-fullscreen-image__icon-wrapper {
55
55
  display: none;
56
56
  }
57
- .pc-FullScreenImage__modal {
57
+ .pc-fullscreen-image__modal {
58
58
  display: none !important; /* stylelint-disable-line declaration-no-important */
59
59
  }
60
60
  }
@@ -1,9 +1,9 @@
1
1
  import { CSSProperties } from 'react';
2
2
  import { ImageProps } from '../Image/Image';
3
- export interface FullScreenImageProps extends ImageProps {
3
+ export interface FullscreenImageProps extends ImageProps {
4
4
  imageClassName?: string;
5
5
  modalImageClass?: string;
6
6
  imageStyle?: CSSProperties;
7
7
  }
8
- declare const FullScreenImage: (props: FullScreenImageProps) => JSX.Element;
9
- export default FullScreenImage;
8
+ declare const FullscreenImage: (props: FullscreenImageProps) => JSX.Element;
9
+ export default FullscreenImage;
@@ -7,26 +7,26 @@ const icons_1 = require("../../icons");
7
7
  const utils_1 = require("../../utils");
8
8
  const Image_1 = tslib_1.__importDefault(require("../Image/Image"));
9
9
  const i18n_1 = tslib_1.__importDefault(require("./i18n"));
10
- const b = (0, utils_1.block)('FullScreenImage');
10
+ const b = (0, utils_1.block)('fullscreen-image');
11
11
  const FULL_SCREEN_ICON_SIZE = 18;
12
12
  const CLOSE_ICON_SIZE = 30;
13
- const FullScreenImage = (props) => {
13
+ const FullscreenImage = (props) => {
14
14
  const { imageClassName, modalImageClass, imageStyle, alt = (0, i18n_1.default)('img-alt') } = props;
15
15
  const [isOpened, setIsOpened] = (0, react_1.useState)(false);
16
16
  const [isMouseEnter, setIsMouseEnter] = (0, react_1.useState)(false);
17
17
  const openModal = () => setIsOpened(true);
18
18
  const closeModal = () => setIsOpened(false);
19
- const showFullScreenIcon = () => setIsMouseEnter(true);
20
- const hideFullScreenIcon = () => setIsMouseEnter(false);
19
+ const showFullscreenIcon = () => setIsMouseEnter(true);
20
+ const hideFullscreenIcon = () => setIsMouseEnter(false);
21
21
  return (react_1.default.createElement("div", { className: b() },
22
- react_1.default.createElement("div", { className: b('image-wrapper'), onMouseEnter: showFullScreenIcon, onMouseLeave: hideFullScreenIcon },
22
+ react_1.default.createElement("div", { className: b('image-wrapper'), onMouseEnter: showFullscreenIcon, onMouseLeave: hideFullscreenIcon },
23
23
  react_1.default.createElement(Image_1.default, Object.assign({}, props, { alt: alt, className: b('image', imageClassName), onClick: openModal, style: imageStyle })),
24
24
  react_1.default.createElement("div", { className: b('icon-wrapper', { visible: isMouseEnter }), onClick: openModal },
25
- react_1.default.createElement(uikit_1.Icon, { data: icons_1.FullScreen, width: FULL_SCREEN_ICON_SIZE, height: FULL_SCREEN_ICON_SIZE, className: b('icon') }))),
25
+ react_1.default.createElement(uikit_1.Icon, { data: icons_1.Fullscreen, width: FULL_SCREEN_ICON_SIZE, height: FULL_SCREEN_ICON_SIZE, className: b('icon') }))),
26
26
  isOpened && (react_1.default.createElement(uikit_1.Modal, { open: isOpened, onClose: closeModal, className: b('modal') },
27
27
  react_1.default.createElement("div", { className: b('modal-content') },
28
28
  react_1.default.createElement("div", { className: b('icon-wrapper', { visible: true }), onClick: closeModal },
29
29
  react_1.default.createElement(uikit_1.Icon, { data: icons_1.PreviewClose, width: CLOSE_ICON_SIZE, height: CLOSE_ICON_SIZE, className: b('icon', { hover: true }) })),
30
30
  react_1.default.createElement(Image_1.default, Object.assign({}, props, { className: b('modal-image', modalImageClass) })))))));
31
31
  };
32
- exports.default = FullScreenImage;
32
+ exports.default = FullscreenImage;
@@ -4,5 +4,5 @@ const tslib_1 = require("tslib");
4
4
  const registerKeyset_1 = require("../../../utils/registerKeyset");
5
5
  const en_json_1 = tslib_1.__importDefault(require("./en.json"));
6
6
  const ru_json_1 = tslib_1.__importDefault(require("./ru.json"));
7
- const COMPONENT = 'FullScreenImage';
7
+ const COMPONENT = 'FullscreenImage';
8
8
  exports.default = (0, registerKeyset_1.registerKeyset)({ en: en_json_1.default, ru: ru_json_1.default }, COMPONENT);
@@ -0,0 +1,9 @@
1
+ /// <reference types="react" />
2
+ import { MediaAllProps } from '../Media/Media';
3
+ export type ChildMediaRenderProps = Pick<MediaAllProps, 'fullscreen' | 'imageClassName' | 'videoClassName' | 'youtubeClassName' | 'className'>;
4
+ export interface FullscreenMediaProps {
5
+ showFullscreenIcon?: boolean;
6
+ children: (props?: ChildMediaRenderProps) => JSX.Element;
7
+ }
8
+ declare const FullscreenMedia: ({ children, showFullscreenIcon }: FullscreenMediaProps) => JSX.Element;
9
+ export default FullscreenMedia;
@@ -10,7 +10,7 @@ const b = (0, utils_1.block)('full-screen-media');
10
10
  const FULL_SCREEN_ICON_SIZE = 18;
11
11
  const CLOSE_ICON_SIZE = 30;
12
12
  const getMediaClass = (type) => b('modal-media', { type });
13
- const FullScreenMedia = ({ children, showFullScreenIcon = true }) => {
13
+ const FullscreenMedia = ({ children, showFullscreenIcon = true }) => {
14
14
  const [isOpened, setIsOpened] = (0, react_1.useState)(false);
15
15
  const isMobile = (0, react_1.useContext)(mobileContext_1.MobileContext);
16
16
  const openModal = (e) => {
@@ -24,8 +24,8 @@ const FullScreenMedia = ({ children, showFullScreenIcon = true }) => {
24
24
  return (react_1.default.createElement("div", { className: b() },
25
25
  react_1.default.createElement("div", { className: b('media-wrapper'), onClickCapture: openModal },
26
26
  children({ className: b('inline-media') }),
27
- showFullScreenIcon && (react_1.default.createElement("div", { className: b('icon-wrapper'), onClickCapture: openModal },
28
- react_1.default.createElement(uikit_1.Icon, { data: icons_1.FullScreen, width: FULL_SCREEN_ICON_SIZE, height: FULL_SCREEN_ICON_SIZE, className: b('icon') })))),
27
+ showFullscreenIcon && (react_1.default.createElement("div", { className: b('icon-wrapper'), onClickCapture: openModal },
28
+ react_1.default.createElement(uikit_1.Icon, { data: icons_1.Fullscreen, width: FULL_SCREEN_ICON_SIZE, height: FULL_SCREEN_ICON_SIZE, className: b('icon') })))),
29
29
  isOpened && (react_1.default.createElement(uikit_1.Modal, { open: isOpened, onClose: closeModal, className: b('modal') },
30
30
  react_1.default.createElement("div", { className: b('modal-content') },
31
31
  react_1.default.createElement("div", { className: b('icon-wrapper', { visible: true }), onClick: closeModal },
@@ -34,7 +34,7 @@ const FullScreenMedia = ({ children, showFullScreenIcon = true }) => {
34
34
  imageClassName: getMediaClass('image'),
35
35
  videoClassName: getMediaClass('video'),
36
36
  youtubeClassName: getMediaClass('youtube'),
37
- fullScreen: true,
37
+ fullscreen: true,
38
38
  }))))));
39
39
  };
40
- exports.default = FullScreenMedia;
40
+ exports.default = FullscreenMedia;
@@ -0,0 +1,4 @@
1
+ import React from 'react';
2
+ import { VideoAllProps } from '../Video/Video';
3
+ declare const FullscreenVideo: React.FC<VideoAllProps>;
4
+ export default FullscreenVideo;
@@ -0,0 +1,10 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const tslib_1 = require("tslib");
4
+ const react_1 = tslib_1.__importDefault(require("react"));
5
+ const FullscreenMedia_1 = tslib_1.__importDefault(require("../../FullscreenMedia/FullscreenMedia"));
6
+ const Video_1 = tslib_1.__importDefault(require("../Video/Video"));
7
+ const FullscreenVideo = (props) => {
8
+ return (react_1.default.createElement(FullscreenMedia_1.default, null, (classNames) => react_1.default.createElement(Video_1.default, Object.assign({}, props, classNames))));
9
+ };
10
+ exports.default = FullscreenVideo;
@@ -2,6 +2,7 @@ import { MediaComponentImageProps } from '../../../models';
2
2
  export interface ImageAdditionProps {
3
3
  imageClassName?: string;
4
4
  isBackground?: boolean;
5
+ fullscreen?: boolean;
5
6
  }
6
7
  interface InnerImageProps {
7
8
  hasVideoFallback: boolean;
@@ -13,7 +13,7 @@ const Image_1 = tslib_1.__importDefault(require("../../Image/Image"));
13
13
  const utils_2 = require("./utils");
14
14
  const b = (0, utils_1.block)('media-component-image');
15
15
  const Image = (props) => {
16
- const { parallax, image, height, imageClassName, isBackground, hasVideoFallback, video } = props;
16
+ const { parallax, image, height, imageClassName, isBackground, hasVideoFallback, video, fullscreen, } = props;
17
17
  const [scrollY, setScrollY] = (0, react_1.useState)(0);
18
18
  const [{ springScrollY }, springSetScrollY] = (0, react_spring_1.useSpring)(() => ({
19
19
  springScrollY: 0,
@@ -34,10 +34,10 @@ const Image = (props) => {
34
34
  parallaxInterpolate = springScrollY.interpolate((value) => `translateY(-${Number(value) / parallaxLevel}px)`);
35
35
  }
36
36
  const imageClass = b('item', { withVideo: Boolean(video) && !hasVideoFallback }, imageClassName);
37
- const imageSlider = (imageArray) => (react_1.default.createElement(Slider_1.default, { slidesToShow: 1, type: models_1.SliderType.MediaCard }, imageArray.map((item) => {
37
+ const renderFullscreenImage = (item) => {
38
38
  const itemData = (0, utils_2.getMediaImage)(item);
39
39
  return (react_1.default.createElement(FullscreenImage_1.default, Object.assign({ key: itemData.alt }, itemData, { imageClassName: imageClass, imageStyle: { height } })));
40
- })));
40
+ };
41
41
  const imageBackground = (oneImage) => {
42
42
  const imageData = (0, utils_2.getMediaImage)(oneImage);
43
43
  return (react_1.default.createElement(react_spring_1.animated.div, { style: { transform: parallaxInterpolate } },
@@ -47,9 +47,16 @@ const Image = (props) => {
47
47
  const imageData = (0, utils_2.getMediaImage)(oneImage);
48
48
  return react_1.default.createElement(Image_1.default, Object.assign({}, imageData, { className: imageClass, style: { height } }));
49
49
  };
50
+ const imageSlider = (imageArray) => {
51
+ const fullscreenItem = fullscreen === undefined || fullscreen;
52
+ return (react_1.default.createElement(Slider_1.default, { slidesToShow: 1, type: models_1.SliderType.MediaCard }, imageArray.map((item) => fullscreenItem ? renderFullscreenImage(item) : imageOnly(item))));
53
+ };
50
54
  if (Array.isArray(image)) {
51
55
  return imageSlider(image);
52
56
  }
57
+ if (fullscreen) {
58
+ return renderFullscreenImage(image);
59
+ }
53
60
  return isBackground ? imageBackground(image) : imageOnly(image);
54
61
  };
55
62
  exports.default = Image;
@@ -6,23 +6,43 @@ const react_1 = tslib_1.__importStar(require("react"));
6
6
  const utils_1 = require("../../utils");
7
7
  const VideoBlock_1 = tslib_1.__importDefault(require("../VideoBlock/VideoBlock"));
8
8
  const DataLens_1 = tslib_1.__importDefault(require("./DataLens/DataLens"));
9
+ const FullscreenVideo_1 = tslib_1.__importDefault(require("./FullscreenVideo/FullscreenVideo"));
9
10
  const Image_1 = tslib_1.__importDefault(require("./Image/Image"));
10
11
  const Video_1 = tslib_1.__importDefault(require("./Video/Video"));
11
12
  const b = (0, utils_1.block)('Media');
12
13
  const Media = (props) => {
13
- const { image, video, youtube, dataLens, color, height, previewImg, parallax = false, metrika, fullScreen, analyticsEvents, } = props;
14
+ const { image, video, youtube, dataLens, color, height, previewImg, parallax = false, metrika, fullscreen, analyticsEvents, } = props;
14
15
  const { className, imageClassName, videoClassName, youtubeClassName, playVideo = true, isBackground, playButton, customBarControlsClassName, } = props;
15
16
  const [hasVideoFallback, setHasVideoFallback] = (0, react_1.useState)(false);
16
17
  const content = (0, react_1.useMemo)(() => {
17
18
  let result = [];
18
19
  if (image) {
19
- result.push(react_1.default.createElement(Image_1.default, { key: "image", parallax: parallax, image: image, height: height, imageClassName: imageClassName, isBackground: isBackground, video: video, hasVideoFallback: hasVideoFallback }));
20
+ result.push(react_1.default.createElement(Image_1.default, { key: "image", parallax: parallax, image: image, height: height, imageClassName: imageClassName, isBackground: isBackground, video: video, hasVideoFallback: hasVideoFallback, fullscreen: fullscreen }));
20
21
  }
21
22
  if (video) {
22
- result.push(react_1.default.createElement(Video_1.default, { key: "video", video: video, videoClassName: videoClassName, height: height, metrika: metrika, analyticsEvents: analyticsEvents, playVideo: playVideo, previewImg: previewImg, playButton: playButton, customBarControlsClassName: customBarControlsClassName, hasVideoFallback: hasVideoFallback, setHasVideoFallback: setHasVideoFallback }));
23
+ const videoProps = {
24
+ key: 'video',
25
+ video,
26
+ videoClassName,
27
+ height,
28
+ metrika,
29
+ analyticsEvents,
30
+ playVideo,
31
+ previewImg,
32
+ playButton,
33
+ customBarControlsClassName,
34
+ hasVideoFallback,
35
+ setHasVideoFallback,
36
+ };
37
+ if (fullscreen) {
38
+ result.push(react_1.default.createElement(FullscreenVideo_1.default, Object.assign({}, videoProps)));
39
+ }
40
+ else {
41
+ result.push(react_1.default.createElement(Video_1.default, Object.assign({}, videoProps)));
42
+ }
23
43
  }
24
44
  if (youtube) {
25
- result = (react_1.default.createElement(VideoBlock_1.default, { className: b('youtube', youtubeClassName), record: youtube, attributes: { color: 'white', rel: '0' }, previewImg: previewImg, height: height, fullScreen: fullScreen }));
45
+ result = (react_1.default.createElement(VideoBlock_1.default, { className: b('youtube', youtubeClassName), record: youtube, attributes: { color: 'white', rel: '0' }, previewImg: previewImg, height: height, fullscreen: fullscreen }));
26
46
  }
27
47
  if (dataLens) {
28
48
  result = react_1.default.createElement(DataLens_1.default, { dataLens: dataLens });
@@ -46,7 +66,7 @@ const Media = (props) => {
46
66
  playButton,
47
67
  customBarControlsClassName,
48
68
  youtubeClassName,
49
- fullScreen,
69
+ fullscreen,
50
70
  ]);
51
71
  return (react_1.default.createElement("div", { className: b(null, className), style: { backgroundColor: color } }, content));
52
72
  };
@@ -10,6 +10,6 @@ interface InnerVideoProps {
10
10
  setHasVideoFallback: React.Dispatch<boolean>;
11
11
  hasVideoFallback: boolean;
12
12
  }
13
- type VideoAllProps = VideoAdditionProps & MediaComponentVideoProps & InnerVideoProps;
13
+ export type VideoAllProps = VideoAdditionProps & MediaComponentVideoProps & InnerVideoProps;
14
14
  declare const Video: (props: VideoAllProps) => JSX.Element | null;
15
15
  export default Video;
@@ -13,7 +13,7 @@ export interface VideoBlockProps {
13
13
  previewImg?: string;
14
14
  playButton?: React.ReactNode;
15
15
  height?: number;
16
- fullScreen?: boolean;
16
+ fullscreen?: boolean;
17
17
  }
18
18
  declare const VideoBlock: (props: VideoBlockProps) => JSX.Element | null;
19
19
  export default VideoBlock;
@@ -39,7 +39,7 @@ function getHeight(width) {
39
39
  }
40
40
  exports.getHeight = getHeight;
41
41
  const VideoBlock = (props) => {
42
- const { stream, record, attributes, className, id, previewImg, playButton, height, fullScreen } = props;
42
+ const { stream, record, attributes, className, id, previewImg, playButton, height, fullscreen } = props;
43
43
  const src = getVideoSrc(stream, record);
44
44
  const ref = (0, react_1.useRef)(null);
45
45
  const iframeRef = (0, react_1.useRef)();
@@ -82,14 +82,14 @@ const VideoBlock = (props) => {
82
82
  ref.current.appendChild(iframe);
83
83
  iframeRef.current = iframe;
84
84
  }
85
- }, [stream, record, norender, src, fullId, attributes, iframeRef, fullScreen]);
85
+ }, [stream, record, norender, src, fullId, attributes, iframeRef, fullscreen]);
86
86
  (0, react_1.useEffect)(() => {
87
87
  setHidePreview(false);
88
88
  }, [src, setHidePreview]);
89
89
  if (norender) {
90
90
  return null;
91
91
  }
92
- return (react_1.default.createElement("div", { className: b(null, className), ref: ref, style: { height: currentHeight } }, previewImg && !hidePreview && !fullScreen && (react_1.default.createElement("div", { className: b('preview'), onClick: onPreviewClick },
92
+ return (react_1.default.createElement("div", { className: b(null, className), ref: ref, style: { height: currentHeight } }, previewImg && !hidePreview && !fullscreen && (react_1.default.createElement("div", { className: b('preview'), onClick: onPreviewClick },
93
93
  react_1.default.createElement(Image_1.default, { src: previewImg, className: b('image'), containerClassName: b('image-wrapper') }),
94
94
  playButton || (react_1.default.createElement("button", { className: b('button') },
95
95
  react_1.default.createElement(uikit_1.Icon, { className: b('icon'), data: icons_1.PlayVideo, size: 24 })))))));
@@ -33,6 +33,6 @@ export { default as Author } from './Author/Author';
33
33
  export { default as RouterLink } from './RouterLink/RouterLink';
34
34
  export { default as HTML } from './HTML/HTML';
35
35
  export { default as MetaInfo } from './MetaInfo/MetaInfo';
36
- export { default as FullScreenMedia } from './FullscreenMedia/FullScreenMedia';
36
+ export { default as FullscreenMedia } from './FullscreenMedia/FullscreenMedia';
37
37
  export type { RouterLinkProps } from './RouterLink/RouterLink';
38
38
  export type { ImageBaseProps } from './ImageBase/ImageBase';
@@ -3,7 +3,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
3
3
  return (mod && mod.__esModule) ? mod : { "default": mod };
4
4
  };
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.FullScreenMedia = exports.MetaInfo = 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.ImageBase = exports.Image = exports.HeaderBreadcrumbs = exports.FullWidthBackground = exports.FullscreenImage = exports.Foldable = exports.FileLink = exports.ErrorWrapper = exports.CardBase = exports.Button = exports.BlockBase = exports.BalancedMasonry = exports.BackLink = exports.BackgroundMedia = exports.BackgroundImage = exports.AnimateBlock = exports.Anchor = void 0;
6
+ exports.FullscreenMedia = exports.MetaInfo = 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.ImageBase = exports.Image = exports.HeaderBreadcrumbs = exports.FullWidthBackground = exports.FullscreenImage = exports.Foldable = exports.FileLink = exports.ErrorWrapper = exports.CardBase = exports.Button = exports.BlockBase = exports.BalancedMasonry = exports.BackLink = exports.BackgroundMedia = exports.BackgroundImage = exports.AnimateBlock = exports.Anchor = void 0;
7
7
  var Anchor_1 = require("./Anchor/Anchor");
8
8
  Object.defineProperty(exports, "Anchor", { enumerable: true, get: function () { return __importDefault(Anchor_1).default; } });
9
9
  var AnimateBlock_1 = require("./AnimateBlock/AnimateBlock");
@@ -74,5 +74,5 @@ var HTML_1 = require("./HTML/HTML");
74
74
  Object.defineProperty(exports, "HTML", { enumerable: true, get: function () { return __importDefault(HTML_1).default; } });
75
75
  var MetaInfo_1 = require("./MetaInfo/MetaInfo");
76
76
  Object.defineProperty(exports, "MetaInfo", { enumerable: true, get: function () { return __importDefault(MetaInfo_1).default; } });
77
- var FullScreenMedia_1 = require("./FullscreenMedia/FullScreenMedia");
78
- Object.defineProperty(exports, "FullScreenMedia", { enumerable: true, get: function () { return __importDefault(FullScreenMedia_1).default; } });
77
+ var FullscreenMedia_1 = require("./FullscreenMedia/FullscreenMedia");
78
+ Object.defineProperty(exports, "FullscreenMedia", { enumerable: true, get: function () { return __importDefault(FullscreenMedia_1).default; } });
@@ -23,7 +23,7 @@ export declare const subBlockMap: {
23
23
  "price-detailed": (props: import("./models").PriceDetailedProps) => JSX.Element;
24
24
  "media-card": ({ border, ...mediaProps }: import("./models").MediaCardProps) => JSX.Element;
25
25
  "banner-card": (props: import("./models").BannerCardProps) => JSX.Element;
26
- "layout-item": ({ content: { links, ...content }, metaInfo, media, border, fullScreen, className, }: import("./models").LayoutItemProps) => JSX.Element;
26
+ "layout-item": ({ content: { links, ...content }, metaInfo, media, border, fullscreen, className, }: import("./models").LayoutItemProps) => JSX.Element;
27
27
  "background-card": (props: import("./models").BackgroundCardProps) => JSX.Element;
28
28
  "basic-card": (props: import("./models").BasicCardProps) => JSX.Element;
29
29
  content: (props: import("./models").ContentBlockProps & import("./models").ClassNameProps) => JSX.Element;
@@ -7,4 +7,4 @@ export interface GridColumnProps extends GridColumnClassParams, Refable<HTMLDivE
7
7
  dataQa?: string;
8
8
  children?: React.ReactNode;
9
9
  }
10
- export declare const Col: React.ForwardRefExoticComponent<Pick<WithChildren<GridColumnProps>, "style" | "children" | "className" | "reset" | "sizes" | "offsets" | "orders" | "hidden" | "visible" | "alignSelf" | "justifyContent" | "dataQa"> & React.RefAttributes<HTMLDivElement>>;
10
+ export declare const Col: React.ForwardRefExoticComponent<Pick<WithChildren<GridColumnProps>, "style" | "children" | "className" | "reset" | "visible" | "sizes" | "offsets" | "orders" | "hidden" | "alignSelf" | "justifyContent" | "dataQa"> & React.RefAttributes<HTMLDivElement>>;
@@ -0,0 +1,2 @@
1
+ import React from 'react';
2
+ export declare const Fullscreen: React.FC<React.SVGProps<SVGSVGElement>>;
@@ -1,9 +1,9 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.FullScreen = void 0;
3
+ exports.Fullscreen = void 0;
4
4
  const tslib_1 = require("tslib");
5
5
  const react_1 = tslib_1.__importDefault(require("react"));
6
6
  const svg_1 = require("../utils/svg");
7
- const FullScreen = (props) => (react_1.default.createElement("svg", Object.assign({ xmlns: "http://www.w3.org/2000/svg", width: "24", height: "24", viewBox: "0 0 24 24", fill: "currentColor" }, svg_1.a11yHiddenSvgProps, props),
7
+ const Fullscreen = (props) => (react_1.default.createElement("svg", Object.assign({ xmlns: "http://www.w3.org/2000/svg", width: "24", height: "24", viewBox: "0 0 24 24", fill: "currentColor" }, svg_1.a11yHiddenSvgProps, props),
8
8
  react_1.default.createElement("path", { fillRule: "evenodd", clipRule: "evenodd", d: "M18 4.654v.291a10 10 0 0 0-1.763 1.404l-2.944 2.944a1 1 0 0 0 1.414 1.414l2.933-2.932A9.996 9.996 0 0 0 19.05 6h.296l-.09.39A9.993 9.993 0 0 0 19 8.64v.857a1 1 0 0 0 2 0V4.503a1.5 1.5 0 0 0-1.5-1.5L14.5 3a1 1 0 1 0 0 2h.861a10 10 0 0 0 2.249-.256l.39-.09zM4.95 18a10 10 0 0 1 1.41-1.775l2.933-2.932a1 1 0 0 1 1.414 1.414l-2.944 2.944A9.998 9.998 0 0 1 6 19.055v.291l.39-.09A9.993 9.993 0 0 1 8.64 19h.86a1 1 0 0 1 0 2l-5-.003a1.5 1.5 0 0 1-1.5-1.5V14.5a1 1 0 1 1 2 0v.861a10 10 0 0 1-.256 2.249l-.09.39h.296z" })));
9
- exports.FullScreen = FullScreen;
9
+ exports.Fullscreen = Fullscreen;
@@ -1,7 +1,7 @@
1
1
  export * from './ArrowConstructor';
2
2
  export * from './ArrowSidebar';
3
3
  export * from './Chevron';
4
- export * from './FullScreen';
4
+ export * from './Fullscreen';
5
5
  export * from './Github';
6
6
  export * from './NavigationChevron';
7
7
  export * from './PlayVideo';