@gravity-ui/page-constructor 4.37.3 → 4.38.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 (52) hide show
  1. package/build/cjs/{sub-blocks/Content → components}/ContentList/ContentList.css +13 -0
  2. package/build/cjs/components/ContentList/ContentList.d.ts +4 -0
  3. package/build/cjs/{sub-blocks/Content → components}/ContentList/ContentList.js +8 -13
  4. package/build/cjs/components/ContentList/ContentListItemIcon.d.ts +7 -0
  5. package/build/cjs/components/ContentList/ContentListItemIcon.js +23 -0
  6. package/build/cjs/components/FileLink/FileLink.js +1 -1
  7. package/build/cjs/components/index.d.ts +1 -0
  8. package/build/cjs/components/index.js +3 -1
  9. package/build/cjs/models/constructor-items/blocks.d.ts +7 -2
  10. package/build/cjs/models/constructor-items/sub-blocks.d.ts +14 -2
  11. package/build/cjs/models/constructor-items/sub-blocks.js +1 -0
  12. package/build/cjs/schema/validators/sub-blocks.d.ts +1 -0
  13. package/build/cjs/schema/validators/sub-blocks.js +1 -0
  14. package/build/cjs/sub-blocks/Content/Content.js +2 -4
  15. package/build/cjs/sub-blocks/PriceCard/PriceCard.css +80 -0
  16. package/build/cjs/sub-blocks/PriceCard/PriceCard.d.ts +3 -0
  17. package/build/cjs/sub-blocks/PriceCard/PriceCard.js +33 -0
  18. package/build/cjs/sub-blocks/PriceCard/schema.d.ts +648 -0
  19. package/build/cjs/sub-blocks/PriceCard/schema.js +34 -0
  20. package/build/cjs/sub-blocks/index.d.ts +1 -0
  21. package/build/cjs/sub-blocks/index.js +3 -1
  22. package/build/cjs/text-transform/config.js +12 -0
  23. package/build/esm/{sub-blocks/Content → components}/ContentList/ContentList.css +13 -0
  24. package/build/esm/components/ContentList/ContentList.d.ts +5 -0
  25. package/build/esm/{sub-blocks/Content → components}/ContentList/ContentList.js +6 -11
  26. package/build/esm/components/ContentList/ContentListItemIcon.d.ts +7 -0
  27. package/build/esm/components/ContentList/ContentListItemIcon.js +20 -0
  28. package/build/esm/components/FileLink/FileLink.js +1 -1
  29. package/build/esm/components/index.d.ts +1 -0
  30. package/build/esm/components/index.js +1 -0
  31. package/build/esm/models/constructor-items/blocks.d.ts +7 -2
  32. package/build/esm/models/constructor-items/sub-blocks.d.ts +14 -2
  33. package/build/esm/models/constructor-items/sub-blocks.js +1 -0
  34. package/build/esm/schema/validators/sub-blocks.d.ts +1 -0
  35. package/build/esm/schema/validators/sub-blocks.js +1 -0
  36. package/build/esm/sub-blocks/Content/Content.js +1 -3
  37. package/build/esm/sub-blocks/PriceCard/PriceCard.css +80 -0
  38. package/build/esm/sub-blocks/PriceCard/PriceCard.d.ts +4 -0
  39. package/build/esm/sub-blocks/PriceCard/PriceCard.js +31 -0
  40. package/build/esm/sub-blocks/PriceCard/schema.d.ts +648 -0
  41. package/build/esm/sub-blocks/PriceCard/schema.js +31 -0
  42. package/build/esm/sub-blocks/index.d.ts +1 -0
  43. package/build/esm/sub-blocks/index.js +1 -0
  44. package/build/esm/text-transform/config.js +12 -0
  45. package/package.json +1 -1
  46. package/server/models/constructor-items/blocks.d.ts +7 -2
  47. package/server/models/constructor-items/sub-blocks.d.ts +14 -2
  48. package/server/models/constructor-items/sub-blocks.js +1 -0
  49. package/server/text-transform/config.js +12 -0
  50. package/widget/index.js +1 -1
  51. package/build/cjs/sub-blocks/Content/ContentList/ContentList.d.ts +0 -8
  52. package/build/esm/sub-blocks/Content/ContentList/ContentList.d.ts +0 -9
@@ -15,6 +15,13 @@ unpredictable css rules order in build */
15
15
  margin-bottom: 1px;
16
16
  margin-right: 12px;
17
17
  }
18
+ .pc-content-list_size_l .pc-content-list__icon_without_title {
19
+ width: 20px;
20
+ height: 20px;
21
+ margin-top: 0;
22
+ margin-bottom: 0;
23
+ margin-right: 8px;
24
+ }
18
25
  .pc-content-list_size_l .pc-content-list__item:not(:last-child) {
19
26
  margin-bottom: 16px;
20
27
  }
@@ -33,6 +40,12 @@ unpredictable css rules order in build */
33
40
  margin-bottom: 2px;
34
41
  margin-right: 8px;
35
42
  }
43
+ .pc-content-list_size_s .pc-content-list__icon_without_title {
44
+ width: 18px;
45
+ height: 18px;
46
+ margin-top: 0;
47
+ margin-bottom: 0;
48
+ }
36
49
  .pc-content-list_size_s .pc-content-list__text {
37
50
  font-size: var(--g-text-body-1-font-size);
38
51
  line-height: var(--g-text-body-1-line-height);
@@ -0,0 +1,4 @@
1
+ import { ContentListProps } from '../../models';
2
+ import { QAProps } from '../../models/common';
3
+ declare const ContentList: ({ list, size, qa }: ContentListProps & QAProps) => JSX.Element;
4
+ export default ContentList;
@@ -3,13 +3,11 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  const tslib_1 = require("tslib");
4
4
  const react_1 = tslib_1.__importDefault(require("react"));
5
5
  const uuid_1 = require("uuid");
6
- const components_1 = require("../../../components");
7
- const Image_1 = tslib_1.__importDefault(require("../../../components/Image/Image"));
8
- const utils_1 = require("../../../components/Media/Image/utils");
9
- const theme_1 = require("../../../context/theme");
10
- const utils_2 = require("../../../utils");
11
- const blocks_1 = require("../../../utils/blocks");
12
- const b = (0, utils_2.block)('content-list');
6
+ const utils_1 = require("../../utils");
7
+ const blocks_1 = require("../../utils/blocks");
8
+ const YFMWrapper_1 = tslib_1.__importDefault(require("../YFMWrapper/YFMWrapper"));
9
+ const ContentListItemIcon_1 = tslib_1.__importDefault(require("./ContentListItemIcon"));
10
+ const b = (0, utils_1.block)('content-list');
13
11
  function getHeadingLevel(size) {
14
12
  switch (size) {
15
13
  case 's':
@@ -19,19 +17,16 @@ function getHeadingLevel(size) {
19
17
  return 'h3';
20
18
  }
21
19
  }
22
- const ContentList = ({ list, size, qa }) => {
23
- const theme = (0, theme_1.useTheme)();
20
+ const ContentList = ({ list, size = 'l', qa }) => {
24
21
  const qaAttributes = (0, blocks_1.getQaAttrubutes)(qa, ['image', 'title', 'text']);
25
22
  return (react_1.default.createElement("div", { className: b({ size }), "data-qa": qa }, list === null || list === void 0 ? void 0 : list.map((item) => {
26
23
  const { icon, title, text } = item;
27
- const iconThemed = (0, utils_2.getThemedValue)(icon, theme);
28
- const iconData = (0, utils_1.getMediaImage)(iconThemed);
29
24
  return (react_1.default.createElement("div", { className: b('item'), key: (0, uuid_1.v4)() },
30
- react_1.default.createElement(Image_1.default, Object.assign({}, iconData, { className: b('icon'), qa: qaAttributes.image })),
25
+ react_1.default.createElement(ContentListItemIcon_1.default, { icon: icon, className: b('icon', { without_title: !title }), qa: qaAttributes.image }),
31
26
  react_1.default.createElement("div", null,
32
27
  title &&
33
28
  react_1.default.createElement(getHeadingLevel(size), { className: b('title'), 'data-qa': qaAttributes.title }, title),
34
- text && (react_1.default.createElement(components_1.YFMWrapper, { className: b('text'), content: text, modifiers: { constructor: true }, qa: qaAttributes.text })))));
29
+ text && (react_1.default.createElement(YFMWrapper_1.default, { className: b('text'), content: text, modifiers: { constructor: true }, qa: qaAttributes.text })))));
35
30
  })));
36
31
  };
37
32
  exports.default = ContentList;
@@ -0,0 +1,7 @@
1
+ import { ClassNameProps, ImageProps, QAProps, SVGIcon } from '../../models';
2
+ import { ThemeSupporting } from '../../utils';
3
+ interface ListItemProps extends QAProps, ClassNameProps {
4
+ icon: ThemeSupporting<ImageProps | SVGIcon>;
5
+ }
6
+ declare const ContentListItemIcon: ({ icon, className, qa }: ListItemProps) => JSX.Element;
7
+ export default ContentListItemIcon;
@@ -0,0 +1,23 @@
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 theme_1 = require("../../context/theme");
6
+ const utils_1 = require("../../utils");
7
+ const Image_1 = tslib_1.__importDefault(require("../Image/Image"));
8
+ const utils_2 = require("../Media/Image/utils");
9
+ function isIconSvg(icon) {
10
+ return typeof icon === 'function';
11
+ }
12
+ const ContentListItemIcon = ({ icon, className, qa }) => {
13
+ const theme = (0, theme_1.useTheme)();
14
+ const iconThemed = (0, utils_1.getThemedValue)(icon, theme);
15
+ if (isIconSvg(iconThemed)) {
16
+ const Icon = iconThemed;
17
+ return (react_1.default.createElement("div", null,
18
+ react_1.default.createElement(Icon, { className: className })));
19
+ }
20
+ const iconData = (0, utils_2.getMediaImage)(iconThemed);
21
+ return react_1.default.createElement(Image_1.default, Object.assign({}, iconData, { className: className, qa: qa }));
22
+ };
23
+ exports.default = ContentListItemIcon;
@@ -18,7 +18,7 @@ var FileExtension;
18
18
  FileExtension["ZIP"] = "zip";
19
19
  })(FileExtension = exports.FileExtension || (exports.FileExtension = {}));
20
20
  function getFileExt(name) {
21
- if (name.includes(FIGMA_URL)) {
21
+ if (name === null || name === void 0 ? void 0 : name.includes(FIGMA_URL)) {
22
22
  return FileExtension.FIG;
23
23
  }
24
24
  // eslint-disable-next-line @typescript-eslint/no-non-null-assertion
@@ -34,5 +34,6 @@ 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
36
  export { default as FullscreenMedia } from './FullscreenMedia/FullscreenMedia';
37
+ export { default as ContentList } from './ContentList/ContentList';
37
38
  export type { RouterLinkProps } from './RouterLink/RouterLink';
38
39
  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.ContentList = 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");
@@ -76,3 +76,5 @@ var MetaInfo_1 = require("./MetaInfo/MetaInfo");
76
76
  Object.defineProperty(exports, "MetaInfo", { enumerable: true, get: function () { return __importDefault(MetaInfo_1).default; } });
77
77
  var FullscreenMedia_1 = require("./FullscreenMedia/FullscreenMedia");
78
78
  Object.defineProperty(exports, "FullscreenMedia", { enumerable: true, get: function () { return __importDefault(FullscreenMedia_1).default; } });
79
+ var ContentList_1 = require("./ContentList/ContentList");
80
+ Object.defineProperty(exports, "ContentList", { enumerable: true, get: function () { return __importDefault(ContentList_1).default; } });
@@ -3,7 +3,7 @@ import { ButtonSize } from '@gravity-ui/uikit';
3
3
  import { GridColumnSize, GridColumnSizesType } from '../../grid/types';
4
4
  import { ThemeSupporting } from '../../utils';
5
5
  import { AnalyticsEventsBase } from '../common';
6
- import { AnchorProps, Animatable, BackgroundImageProps, ButtonProps, ContentSize, ContentTextSize, ContentTheme, FileLinkProps, HeaderBreadCrumbsProps, HeaderImageSize, HeaderOffset, HeaderWidth, ImageDeviceProps, Justify, LegendTableMarkerType, LinkProps, MapProps, MediaDirection, MediaProps, TextSize, TextTheme, ThemedImage, ThemedMediaProps, ThemedMediaVideoProps, TitleItemBaseProps, TitleItemProps, YandexFormProps } from './common';
6
+ import { AnchorProps, Animatable, BackgroundImageProps, ButtonProps, ContentSize, ContentTextSize, ContentTheme, FileLinkProps, HeaderBreadCrumbsProps, HeaderImageSize, HeaderOffset, HeaderWidth, ImageDeviceProps, ImageProps, Justify, LegendTableMarkerType, LinkProps, MapProps, MediaDirection, MediaProps, TextSize, TextTheme, ThemedImage, ThemedMediaProps, ThemedMediaVideoProps, TitleItemBaseProps, TitleItemProps, YandexFormProps } from './common';
7
7
  import { BannerCardProps, HubspotFormProps, SubBlock, SubBlockModels } from './sub-blocks';
8
8
  export declare enum BlockType {
9
9
  PromoFeaturesBlock = "promo-features-block",
@@ -270,10 +270,15 @@ export interface ContentLayoutBlockProps extends ContentLayoutBlockParams {
270
270
  textContent: ContentBlockProps;
271
271
  fileContent?: FileLinkProps[];
272
272
  }
273
+ export type SVGIcon = React.FC<React.SVGProps<SVGSVGElement>>;
273
274
  export interface ContentItemProps {
274
275
  title?: string;
275
276
  text?: string;
276
- icon: ThemedImage;
277
+ icon: ThemeSupporting<ImageProps | SVGIcon>;
278
+ }
279
+ export interface ContentListProps {
280
+ list: ContentItemProps[];
281
+ size: ContentSize;
277
282
  }
278
283
  export interface ContentBlockProps {
279
284
  title?: TitleItemBaseProps | string;
@@ -3,7 +3,7 @@ import { ThemeSupporting } from '../../utils';
3
3
  import { HubspotEventData, HubspotEventHandlers } from '../../utils/hubspot';
4
4
  import { AnalyticsEventsBase, PixelEvent } from '../common';
5
5
  import { ContentBlockProps } from './blocks';
6
- import { AuthorItem, ButtonPixel, ButtonProps, CardBaseProps, ContentTheme, DividerSize, ImageObjectProps, ImageProps, MediaProps, PriceDetailedProps, TextTheme, Themable, ThemedImage } from './common';
6
+ import { AuthorItem, ButtonPixel, ButtonProps, CardBaseProps, ContentTheme, DividerSize, ImageObjectProps, ImageProps, LinkProps, MediaProps, PriceDetailedProps, TextTheme, Themable, ThemedImage } from './common';
7
7
  export declare enum SubBlockType {
8
8
  Divider = "divider",
9
9
  Quote = "quote",
@@ -21,7 +21,8 @@ export declare enum SubBlockType {
21
21
  /**
22
22
  * @deprecated Will be removed, use BasicCard instead
23
23
  */
24
- Card = "card"
24
+ Card = "card",
25
+ PriceCard = "price-card"
25
26
  }
26
27
  export declare enum IconPosition {
27
28
  Top = "top",
@@ -98,6 +99,17 @@ export interface BannerCardProps {
98
99
  }
99
100
  export interface MediaCardProps extends MediaProps, AnalyticsEventsBase, CardBaseProps {
100
101
  }
102
+ export interface PriceCardProps extends CardBaseProps, Pick<ContentBlockProps, 'theme'> {
103
+ title: string;
104
+ price: string;
105
+ pricePeriod?: string;
106
+ priceDetails?: string;
107
+ description?: string;
108
+ buttons?: ButtonProps[];
109
+ links?: LinkProps[];
110
+ backgroundColor?: string;
111
+ list?: string[];
112
+ }
101
113
  export interface LayoutItemProps extends ClassNameProps, AnalyticsEventsBase {
102
114
  content: Omit<ContentBlockProps, 'colSizes' | 'centered' | 'size'>;
103
115
  media: MediaProps;
@@ -20,6 +20,7 @@ var SubBlockType;
20
20
  * @deprecated Will be removed, use BasicCard instead
21
21
  */
22
22
  SubBlockType["Card"] = "card";
23
+ SubBlockType["PriceCard"] = "price-card";
23
24
  })(SubBlockType = exports.SubBlockType || (exports.SubBlockType = {}));
24
25
  var IconPosition;
25
26
  (function (IconPosition) {
@@ -6,3 +6,4 @@ export * from '../../sub-blocks/LayoutItem/schema';
6
6
  export * from '../../sub-blocks/Quote/schema';
7
7
  export * from '../../sub-blocks/Divider/schema';
8
8
  export * from '../../sub-blocks/BasicCard/schema';
9
+ export * from '../../sub-blocks/PriceCard/schema';
@@ -9,3 +9,4 @@ tslib_1.__exportStar(require("../../sub-blocks/LayoutItem/schema"), exports);
9
9
  tslib_1.__exportStar(require("../../sub-blocks/Quote/schema"), exports);
10
10
  tslib_1.__exportStar(require("../../sub-blocks/Divider/schema"), exports);
11
11
  tslib_1.__exportStar(require("../../sub-blocks/BasicCard/schema"), exports);
12
+ tslib_1.__exportStar(require("../../sub-blocks/PriceCard/schema"), exports);
@@ -4,11 +4,9 @@ const tslib_1 = require("tslib");
4
4
  const react_1 = tslib_1.__importDefault(require("react"));
5
5
  const uikit_1 = require("@gravity-ui/uikit");
6
6
  const components_1 = require("../../components");
7
- const Link_1 = tslib_1.__importDefault(require("../../components/Link/Link"));
8
7
  const grid_1 = require("../../grid");
9
8
  const utils_1 = require("../../utils");
10
9
  const blocks_1 = require("../../utils/blocks");
11
- const ContentList_1 = tslib_1.__importDefault(require("./ContentList/ContentList"));
12
10
  const b = (0, utils_1.block)('content');
13
11
  function getTextSize(size) {
14
12
  switch (size) {
@@ -50,14 +48,14 @@ const Content = (props) => {
50
48
  title && (react_1.default.createElement(components_1.Title, { className: b('title'), title: titleProps, colSizes: { all: 12 }, id: titleId })),
51
49
  text && (react_1.default.createElement("div", { className: b('text', { ['without-title']: !hasTitle }) },
52
50
  react_1.default.createElement(components_1.YFMWrapper, { content: text, modifiers: { constructor: true, [`constructor-size-${size}`]: true }, id: textId }))),
53
- (list === null || list === void 0 ? void 0 : list.length) ? react_1.default.createElement(ContentList_1.default, { list: list, size: size, qa: qaAttributes.list }) : null,
51
+ (list === null || list === void 0 ? void 0 : list.length) ? react_1.default.createElement(components_1.ContentList, { list: list, size: size, qa: qaAttributes.list }) : null,
54
52
  additionalInfo && (react_1.default.createElement("div", { className: b('notice') },
55
53
  react_1.default.createElement(components_1.YFMWrapper, { content: additionalInfo, modifiers: {
56
54
  constructor: true,
57
55
  'constructor-notice': true,
58
56
  [`constructor-size-${size}`]: true,
59
57
  } }))),
60
- links && (react_1.default.createElement("div", { className: b('links'), "data-qa": qaAttributes.links }, links.map((link) => (react_1.default.createElement(Link_1.default, Object.assign({ className: b('link') }, link, { textSize: getLinkSize(size), key: link.url, qa: qaAttributes.link, extraProps: Object.assign({ 'aria-describedby': link.urlTitle ? undefined : titleId }, link.extraProps) })))))),
58
+ links && (react_1.default.createElement("div", { className: b('links'), "data-qa": qaAttributes.links }, links.map((link) => (react_1.default.createElement(components_1.Link, Object.assign({ className: b('link') }, link, { textSize: getLinkSize(size), key: link.url, qa: qaAttributes.link, extraProps: Object.assign({ 'aria-describedby': link.urlTitle ? undefined : titleId }, link.extraProps) })))))),
61
59
  buttons && (react_1.default.createElement("div", { className: b('buttons'), "data-qa": qaAttributes.buttons }, buttons.map((item) => (react_1.default.createElement(components_1.Button, Object.assign({ className: b('button') }, item, { key: item.url, size: getButtonSize(size), qa: qaAttributes.button, extraProps: Object.assign({ 'aria-describedby': item.urlTitle ? undefined : titleId }, item.extraProps) }))))))));
62
60
  };
63
61
  exports.default = Content;
@@ -0,0 +1,80 @@
1
+ /* use this for style redefinitions to awoid problems with
2
+ unpredictable css rules order in build */
3
+ .pc-price-card {
4
+ position: relative;
5
+ }
6
+ .pc-price-card__background {
7
+ position: absolute;
8
+ top: 0;
9
+ left: 0;
10
+ width: 100%;
11
+ height: 100%;
12
+ }
13
+ .pc-price-card__content {
14
+ height: 100%;
15
+ display: flex;
16
+ flex-direction: column;
17
+ position: relative;
18
+ }
19
+ .pc-price-card__content_theme_dark {
20
+ color: var(--g-color-text-light-primary);
21
+ --g-color-line-focus: var(--pc-color-line-focus-dark);
22
+ }
23
+ .pc-price-card__content_theme_dark .pc-price-card__info .yfm,
24
+ .pc-price-card__content_theme_dark .pc-price-card__info .yfm * {
25
+ color: var(--g-color-text-light-primary);
26
+ }
27
+ .pc-price-card__content_theme_dark .pc-price-card__info a {
28
+ text-decoration: underline;
29
+ }
30
+ .pc-price-card__content_theme_dark .pc-price-card__info a:hover {
31
+ color: var(--g-color-text-light-secondary);
32
+ }
33
+ .pc-price-card__content_theme_light {
34
+ color: var(--g-color-text-dark-primary);
35
+ }
36
+ .pc-price-card__content_theme_light .pc-price-card__info .yfm,
37
+ .pc-price-card__content_theme_light .pc-price-card__info .yfm * {
38
+ color: var(--g-color-text-dark-primary);
39
+ }
40
+ .pc-price-card__content_theme_light .pc-price-card__info a {
41
+ text-decoration: underline;
42
+ }
43
+ .pc-price-card__content_theme_light .pc-price-card__info a:hover {
44
+ color: var(--g-color-text-dark-secondary);
45
+ }
46
+ .pc-price-card__title {
47
+ font-size: var(--g-text-subheader-3-font-size);
48
+ line-height: var(--g-text-subheader-3-line-height);
49
+ margin-bottom: 24px;
50
+ }
51
+ .pc-price-card__price {
52
+ margin-bottom: 24px;
53
+ }
54
+ .pc-price-card__price-value {
55
+ font-size: var(--g-text-display-1-font-size);
56
+ line-height: var(--g-text-display-1-line-height);
57
+ }
58
+ .pc-price-card__price-period {
59
+ margin-left: 4px;
60
+ }
61
+ .pc-price-card__price-details {
62
+ margin-bottom: 12px;
63
+ }
64
+ .pc-price-card__main {
65
+ flex: 1;
66
+ min-height: 0;
67
+ display: flex;
68
+ flex-direction: column;
69
+ position: relative;
70
+ }
71
+ .pc-price-card__info {
72
+ margin-bottom: 24px;
73
+ flex: 1;
74
+ min-height: 0;
75
+ display: flex;
76
+ flex-direction: column;
77
+ }
78
+ .pc-price-card__links > *:not(:last-child), .pc-price-card__buttons > *:not(:last-child) {
79
+ margin-right: 16px;
80
+ }
@@ -0,0 +1,3 @@
1
+ import { PriceCardProps } from '../../models';
2
+ declare const PriceCard: (props: PriceCardProps) => JSX.Element;
3
+ export default PriceCard;
@@ -0,0 +1,33 @@
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 Check_1 = tslib_1.__importDefault(require("@gravity-ui/icons/Check"));
6
+ const components_1 = require("../../components");
7
+ const utils_1 = require("../../utils");
8
+ const b = (0, utils_1.block)('price-card');
9
+ const PriceCard = (props) => {
10
+ const { border, title, price, pricePeriod, priceDetails, theme, description, list, buttons, links, backgroundColor, } = props;
11
+ return (react_1.default.createElement(components_1.CardBase, { className: b({ theme }), border: border },
12
+ react_1.default.createElement(components_1.CardBase.Content, null,
13
+ react_1.default.createElement(components_1.BackgroundImage, { className: b('background'), style: { backgroundColor } }),
14
+ react_1.default.createElement("div", { className: b('content', { theme }) },
15
+ react_1.default.createElement("div", { className: b('info') },
16
+ react_1.default.createElement("div", { className: b('title') }, title),
17
+ react_1.default.createElement("div", { className: b('price') },
18
+ react_1.default.createElement("div", null,
19
+ react_1.default.createElement("span", { className: b('price-value') }, price),
20
+ pricePeriod && (react_1.default.createElement("span", { className: b('price-period') },
21
+ "/ ",
22
+ pricePeriod))),
23
+ priceDetails && (react_1.default.createElement("div", { className: b('price-details') }, priceDetails))),
24
+ react_1.default.createElement("div", null, description),
25
+ (list === null || list === void 0 ? void 0 : list.length) ? (react_1.default.createElement("div", { className: b('list') },
26
+ react_1.default.createElement(components_1.ContentList, { list: list.map((item) => ({
27
+ icon: Check_1.default,
28
+ text: item,
29
+ })), size: "s" }))) : null),
30
+ buttons && (react_1.default.createElement("div", { className: b('buttons') }, buttons.map((button) => (react_1.default.createElement(components_1.Button, Object.assign({ key: button.url }, button)))))),
31
+ links && (react_1.default.createElement("div", { className: b('links') }, links.map((link) => (react_1.default.createElement(components_1.Link, Object.assign({ key: link.url, textSize: "m" }, link))))))))));
32
+ };
33
+ exports.default = PriceCard;