@gravity-ui/blog-constructor 5.7.3 → 5.8.0

Sign up to get free protection for your applications and to get access to all the features.
@@ -4,10 +4,12 @@ exports.PostCard = void 0;
4
4
  const tslib_1 = require("tslib");
5
5
  const react_1 = tslib_1.__importStar(require("react"));
6
6
  const page_constructor_1 = require("@gravity-ui/page-constructor");
7
+ const uikit_1 = require("@gravity-ui/uikit");
7
8
  const LikesContext_1 = require("../../contexts/LikesContext");
8
9
  const common_1 = require("../../models/common");
9
10
  const cn_1 = require("../../utils/cn");
10
11
  const SuggestPostInfo_1 = require("../PostInfo/SuggestPostInfo");
12
+ const useAriaAttributes_1 = require("../../hooks/useAriaAttributes");
11
13
  const b = (0, cn_1.block)('post-card');
12
14
  const PostCard = ({ post, metrikaGoals, fullWidth = false, size = common_1.PostCardSize.SMALL, showTag = false, titleHeadingLevel = common_1.PostCardTitleHeadingLevel.H3, }) => {
13
15
  var _a;
@@ -21,19 +23,33 @@ const PostCard = ({ post, metrikaGoals, fullWidth = false, size = common_1.PostC
21
23
  toggleLike,
22
24
  }
23
25
  : undefined, [hasUserLike, likes, toggleLike, hasLikes]);
24
- return (react_1.default.createElement(page_constructor_1.CardBase, { url: url, metrikaGoals: metrikaGoals, className: b('card', { fullWidth }) },
26
+ const titleId = (0, uikit_1.useUniqId)();
27
+ const descriptionId = (0, uikit_1.useUniqId)();
28
+ const dateId = (0, uikit_1.useUniqId)();
29
+ const tagId = (0, uikit_1.useUniqId)();
30
+ const readingTimeId = (0, uikit_1.useUniqId)();
31
+ const isTagVisible = showTag && ((_a = tags === null || tags === void 0 ? void 0 : tags[0]) === null || _a === void 0 ? void 0 : _a.name);
32
+ const ariaAttributes = (0, useAriaAttributes_1.useAriaAttributes)({
33
+ labelIds: [isTagVisible && tagId, title && titleId],
34
+ descriptionIds: [
35
+ description && descriptionId,
36
+ date && dateId,
37
+ readingTime && readingTimeId,
38
+ ],
39
+ });
40
+ return (react_1.default.createElement(page_constructor_1.CardBase, { url: url, metrikaGoals: metrikaGoals, className: b('card', { fullWidth }), extraProps: ariaAttributes },
25
41
  react_1.default.createElement(page_constructor_1.CardBase.Header, { image: image, className: b('header', { fullWidth }) },
26
42
  react_1.default.createElement("div", { className: b('image-container'), "data-qa": "blog-suggest-header" })),
27
43
  react_1.default.createElement(page_constructor_1.CardBase.Content, null,
28
- showTag && ((_a = tags === null || tags === void 0 ? void 0 : tags[0]) === null || _a === void 0 ? void 0 : _a.name) && (react_1.default.createElement("div", { className: b('tag', { size }) }, tags[0].name)),
44
+ isTagVisible && (react_1.default.createElement("div", { id: tagId, className: b('tag', { size }) }, tags[0].name)),
29
45
  title &&
30
46
  react_1.default.createElement(titleHeadingLevel, { className: b('title', { size }) }, react_1.default.createElement("span", null,
31
- react_1.default.createElement(page_constructor_1.HTML, null, title))),
47
+ react_1.default.createElement(page_constructor_1.HTML, { id: titleId }, title))),
32
48
  description && (react_1.default.createElement(page_constructor_1.YFMWrapper, { className: b('description'), content: description, modifiers: {
33
49
  blog: size === 'm',
34
50
  blogCard: true,
35
- } }))),
51
+ }, id: descriptionId }))),
36
52
  react_1.default.createElement(page_constructor_1.CardBase.Footer, null,
37
- react_1.default.createElement(SuggestPostInfo_1.SuggestPostInfo, { postId: blogPostId || id, date: date, readingTime: readingTime, hasUserLike: hasUserLike, likes: likesProps, size: size, qa: "blog-suggest-block" }))));
53
+ react_1.default.createElement(SuggestPostInfo_1.SuggestPostInfo, { postId: blogPostId || id, date: date, readingTime: readingTime, hasUserLike: hasUserLike, likes: likesProps, size: size, qa: "blog-suggest-block", dateId: dateId, readingTimeId: readingTimeId }))));
38
54
  };
39
55
  exports.PostCard = PostCard;
@@ -8,6 +8,8 @@ export interface SuggestPostInfoProps extends Pick<PostData, 'date' | 'readingTi
8
8
  hasUserLike?: boolean;
9
9
  toggleLike?: ToggleLikeCallbackType;
10
10
  };
11
+ dateId?: string;
12
+ readingTimeId?: string;
11
13
  }
12
14
  /**
13
15
  * Suggest blog card info component
@@ -20,7 +22,9 @@ export interface SuggestPostInfoProps extends Pick<PostData, 'date' | 'readingTi
20
22
  * @param qa - test-attr
21
23
  * @param size - text size
22
24
  * @param isModernIcon - flag what we need render 'bookmark' icon
25
+ * @param dateId - id value for element with post date. Useful when providing accessible description
26
+ * @param readingTimeId - id value for element with reading time. Useful when providing accessible description
23
27
  *
24
28
  * @returns jsx
25
29
  */
26
- export declare const SuggestPostInfo: ({ postId, date, readingTime, likes, size, qa, }: SuggestPostInfoProps) => React.JSX.Element;
30
+ export declare const SuggestPostInfo: ({ postId, date, readingTime, likes, size, qa, dateId, readingTimeId, }: SuggestPostInfoProps) => React.JSX.Element;
@@ -21,10 +21,12 @@ const b = (0, cn_1.block)('post-info');
21
21
  * @param qa - test-attr
22
22
  * @param size - text size
23
23
  * @param isModernIcon - flag what we need render 'bookmark' icon
24
+ * @param dateId - id value for element with post date. Useful when providing accessible description
25
+ * @param readingTimeId - id value for element with reading time. Useful when providing accessible description
24
26
  *
25
27
  * @returns jsx
26
28
  */
27
- const SuggestPostInfo = ({ postId, date, readingTime, likes, size = common_1.PostCardSize.SMALL, qa, }) => {
29
+ const SuggestPostInfo = ({ postId, date, readingTime, likes, size = common_1.PostCardSize.SMALL, qa, dateId, readingTimeId, }) => {
28
30
  const { hasUserLike, likesCount, handleLike } = (0, useLikes_1.useLikes)({
29
31
  hasLike: likes === null || likes === void 0 ? void 0 : likes.hasUserLike,
30
32
  count: likes === null || likes === void 0 ? void 0 : likes.likesCount,
@@ -33,8 +35,8 @@ const SuggestPostInfo = ({ postId, date, readingTime, likes, size = common_1.Pos
33
35
  });
34
36
  return (react_1.default.createElement("div", { className: b('container') },
35
37
  react_1.default.createElement("div", { className: b('suggest-container') },
36
- date && react_1.default.createElement(Date_1.Date, { date: date, size: size }),
37
- readingTime && react_1.default.createElement(ReadingTime_1.ReadingTime, { readingTime: readingTime, size: size })),
38
+ date && react_1.default.createElement(Date_1.Date, { date: date, size: size, id: dateId }),
39
+ readingTime && (react_1.default.createElement(ReadingTime_1.ReadingTime, { readingTime: readingTime, size: size, id: readingTimeId }))),
38
40
  likes && postId && (react_1.default.createElement(Save_1.Save, { postId: postId, title: likesCount, hasUserLike: hasUserLike, handleUserLike: handleLike, size: size, qa: qa }))));
39
41
  };
40
42
  exports.SuggestPostInfo = SuggestPostInfo;
@@ -3,6 +3,7 @@ import { PostCardSize } from '../../../models/common';
3
3
  type DateProps = {
4
4
  date: string | number;
5
5
  size?: PostCardSize;
6
+ id?: string;
6
7
  };
7
- export declare const Date: ({ date, size }: DateProps) => React.JSX.Element;
8
+ export declare const Date: ({ date, size, id }: DateProps) => React.JSX.Element;
8
9
  export {};
@@ -8,8 +8,8 @@ const common_1 = require("../../../models/common");
8
8
  const cn_1 = require("../../../utils/cn");
9
9
  const date_1 = require("../../../utils/date");
10
10
  const b = (0, cn_1.block)('post-info');
11
- const Date = ({ date, size = common_1.PostCardSize.SMALL }) => {
11
+ const Date = ({ date, size = common_1.PostCardSize.SMALL, id }) => {
12
12
  const { locale } = (0, react_1.useContext)(LocaleContext_1.LocaleContext);
13
- return react_1.default.createElement("div", { className: b('item', { size }) }, (0, date_1.format)(date, 'longDate', locale === null || locale === void 0 ? void 0 : locale.code));
13
+ return (react_1.default.createElement("div", { className: b('item', { size }), id: id }, (0, date_1.format)(date, 'longDate', locale === null || locale === void 0 ? void 0 : locale.code)));
14
14
  };
15
15
  exports.Date = Date;
@@ -2,6 +2,7 @@ import React from 'react';
2
2
  type ReadingTimeProps = {
3
3
  readingTime: number;
4
4
  size?: 's' | 'm';
5
+ id?: string;
5
6
  };
6
- export declare const ReadingTime: ({ readingTime, size }: ReadingTimeProps) => React.JSX.Element;
7
+ export declare const ReadingTime: ({ readingTime, size, id }: ReadingTimeProps) => React.JSX.Element;
7
8
  export {};
@@ -9,7 +9,7 @@ const Time_1 = require("../../../icons/Time");
9
9
  const cn_1 = require("../../../utils/cn");
10
10
  const b = (0, cn_1.block)('post-info');
11
11
  const ICON_SIZE = 16;
12
- const ReadingTime = ({ readingTime, size = 's' }) => (react_1.default.createElement("div", { className: b('item', { size }) },
12
+ const ReadingTime = ({ readingTime, size = 's', id }) => (react_1.default.createElement("div", { className: b('item', { size }), id: id },
13
13
  react_1.default.createElement("span", { className: b('icon') },
14
14
  react_1.default.createElement(uikit_1.Icon, { data: Time_1.Time, size: ICON_SIZE, className: b('icon-color') })),
15
15
  (0, i18n_1.i18)(i18n_1.Keyset.ContextReadingTime, { count: readingTime })));
@@ -0,0 +1,17 @@
1
+ type Labels = string | number | boolean | undefined;
2
+ type Description = string | number | boolean | undefined;
3
+ interface UseAriaAttributesProps {
4
+ labelIds?: Labels[];
5
+ descriptionIds: Description[];
6
+ }
7
+ /**
8
+ * Returns aria-attributes
9
+ * @param labelIds - labels ids. Falsy values will be ignored
10
+ * @param descriptionIds - descriptions ids. Falsy values will be ignored
11
+ * @returns aria attributes for the element to be labelled
12
+ */
13
+ export declare const useAriaAttributes: ({ labelIds, descriptionIds }: UseAriaAttributesProps) => {
14
+ 'aria-labelledby': string;
15
+ 'aria-describedby': string;
16
+ };
17
+ export {};
@@ -0,0 +1,19 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.useAriaAttributes = void 0;
4
+ const react_1 = require("react");
5
+ /**
6
+ * Returns aria-attributes
7
+ * @param labelIds - labels ids. Falsy values will be ignored
8
+ * @param descriptionIds - descriptions ids. Falsy values will be ignored
9
+ * @returns aria attributes for the element to be labelled
10
+ */
11
+ const useAriaAttributes = ({ labelIds = [], descriptionIds = [] }) => {
12
+ const labelledBy = (0, react_1.useMemo)(() => labelIds.filter(Boolean).join(' '), [labelIds]);
13
+ const describedBy = (0, react_1.useMemo)(() => descriptionIds.filter(Boolean).join(' '), [descriptionIds]);
14
+ return {
15
+ 'aria-labelledby': labelledBy,
16
+ 'aria-describedby': describedBy,
17
+ };
18
+ };
19
+ exports.useAriaAttributes = useAriaAttributes;
@@ -1,4 +1,5 @@
1
1
  import { ReactNode } from 'react';
2
+ import { MarkdownItPluginCb } from '@doc-tools/transform/lib/plugins/typings';
2
3
  import { HeaderBlockProps as PageConstructorHeaderBlockProps } from '@gravity-ui/page-constructor';
3
4
  import { IBrowser, IDevice } from 'ua-parser-js';
4
5
  import { Locale } from '../models/locale';
@@ -176,3 +177,6 @@ export declare enum PostCardTitleHeadingLevel {
176
177
  H2 = "h2",
177
178
  H3 = "h3"
178
179
  }
180
+ export interface TransformPostOptions {
181
+ plugins?: MarkdownItPluginCb[];
182
+ }
@@ -1,9 +1,11 @@
1
1
  import React, { useContext, useMemo } from 'react';
2
2
  import { CardBase, HTML, YFMWrapper } from '@gravity-ui/page-constructor';
3
+ import { useUniqId } from '@gravity-ui/uikit';
3
4
  import { LikesContext } from '../../contexts/LikesContext';
4
5
  import { PostCardSize, PostCardTitleHeadingLevel } from '../../models/common';
5
6
  import { block } from '../../utils/cn';
6
7
  import { SuggestPostInfo } from '../PostInfo/SuggestPostInfo';
8
+ import { useAriaAttributes } from '../../hooks/useAriaAttributes';
7
9
  import './PostCard.css';
8
10
  const b = block('post-card');
9
11
  export const PostCard = ({ post, metrikaGoals, fullWidth = false, size = PostCardSize.SMALL, showTag = false, titleHeadingLevel = PostCardTitleHeadingLevel.H3, }) => {
@@ -18,18 +20,32 @@ export const PostCard = ({ post, metrikaGoals, fullWidth = false, size = PostCar
18
20
  toggleLike,
19
21
  }
20
22
  : undefined, [hasUserLike, likes, toggleLike, hasLikes]);
21
- return (React.createElement(CardBase, { url: url, metrikaGoals: metrikaGoals, className: b('card', { fullWidth }) },
23
+ const titleId = useUniqId();
24
+ const descriptionId = useUniqId();
25
+ const dateId = useUniqId();
26
+ const tagId = useUniqId();
27
+ const readingTimeId = useUniqId();
28
+ const isTagVisible = showTag && ((_a = tags === null || tags === void 0 ? void 0 : tags[0]) === null || _a === void 0 ? void 0 : _a.name);
29
+ const ariaAttributes = useAriaAttributes({
30
+ labelIds: [isTagVisible && tagId, title && titleId],
31
+ descriptionIds: [
32
+ description && descriptionId,
33
+ date && dateId,
34
+ readingTime && readingTimeId,
35
+ ],
36
+ });
37
+ return (React.createElement(CardBase, { url: url, metrikaGoals: metrikaGoals, className: b('card', { fullWidth }), extraProps: ariaAttributes },
22
38
  React.createElement(CardBase.Header, { image: image, className: b('header', { fullWidth }) },
23
39
  React.createElement("div", { className: b('image-container'), "data-qa": "blog-suggest-header" })),
24
40
  React.createElement(CardBase.Content, null,
25
- showTag && ((_a = tags === null || tags === void 0 ? void 0 : tags[0]) === null || _a === void 0 ? void 0 : _a.name) && (React.createElement("div", { className: b('tag', { size }) }, tags[0].name)),
41
+ isTagVisible && (React.createElement("div", { id: tagId, className: b('tag', { size }) }, tags[0].name)),
26
42
  title &&
27
43
  React.createElement(titleHeadingLevel, { className: b('title', { size }) }, React.createElement("span", null,
28
- React.createElement(HTML, null, title))),
44
+ React.createElement(HTML, { id: titleId }, title))),
29
45
  description && (React.createElement(YFMWrapper, { className: b('description'), content: description, modifiers: {
30
46
  blog: size === 'm',
31
47
  blogCard: true,
32
- } }))),
48
+ }, id: descriptionId }))),
33
49
  React.createElement(CardBase.Footer, null,
34
- React.createElement(SuggestPostInfo, { postId: blogPostId || id, date: date, readingTime: readingTime, hasUserLike: hasUserLike, likes: likesProps, size: size, qa: "blog-suggest-block" }))));
50
+ React.createElement(SuggestPostInfo, { postId: blogPostId || id, date: date, readingTime: readingTime, hasUserLike: hasUserLike, likes: likesProps, size: size, qa: "blog-suggest-block", dateId: dateId, readingTimeId: readingTimeId }))));
35
51
  };
@@ -9,6 +9,8 @@ export interface SuggestPostInfoProps extends Pick<PostData, 'date' | 'readingTi
9
9
  hasUserLike?: boolean;
10
10
  toggleLike?: ToggleLikeCallbackType;
11
11
  };
12
+ dateId?: string;
13
+ readingTimeId?: string;
12
14
  }
13
15
  /**
14
16
  * Suggest blog card info component
@@ -21,7 +23,9 @@ export interface SuggestPostInfoProps extends Pick<PostData, 'date' | 'readingTi
21
23
  * @param qa - test-attr
22
24
  * @param size - text size
23
25
  * @param isModernIcon - flag what we need render 'bookmark' icon
26
+ * @param dateId - id value for element with post date. Useful when providing accessible description
27
+ * @param readingTimeId - id value for element with reading time. Useful when providing accessible description
24
28
  *
25
29
  * @returns jsx
26
30
  */
27
- export declare const SuggestPostInfo: ({ postId, date, readingTime, likes, size, qa, }: SuggestPostInfoProps) => React.JSX.Element;
31
+ export declare const SuggestPostInfo: ({ postId, date, readingTime, likes, size, qa, dateId, readingTimeId, }: SuggestPostInfoProps) => React.JSX.Element;
@@ -18,10 +18,12 @@ const b = block('post-info');
18
18
  * @param qa - test-attr
19
19
  * @param size - text size
20
20
  * @param isModernIcon - flag what we need render 'bookmark' icon
21
+ * @param dateId - id value for element with post date. Useful when providing accessible description
22
+ * @param readingTimeId - id value for element with reading time. Useful when providing accessible description
21
23
  *
22
24
  * @returns jsx
23
25
  */
24
- export const SuggestPostInfo = ({ postId, date, readingTime, likes, size = PostCardSize.SMALL, qa, }) => {
26
+ export const SuggestPostInfo = ({ postId, date, readingTime, likes, size = PostCardSize.SMALL, qa, dateId, readingTimeId, }) => {
25
27
  const { hasUserLike, likesCount, handleLike } = useLikes({
26
28
  hasLike: likes === null || likes === void 0 ? void 0 : likes.hasUserLike,
27
29
  count: likes === null || likes === void 0 ? void 0 : likes.likesCount,
@@ -30,7 +32,7 @@ export const SuggestPostInfo = ({ postId, date, readingTime, likes, size = PostC
30
32
  });
31
33
  return (React.createElement("div", { className: b('container') },
32
34
  React.createElement("div", { className: b('suggest-container') },
33
- date && React.createElement(Date, { date: date, size: size }),
34
- readingTime && React.createElement(ReadingTime, { readingTime: readingTime, size: size })),
35
+ date && React.createElement(Date, { date: date, size: size, id: dateId }),
36
+ readingTime && (React.createElement(ReadingTime, { readingTime: readingTime, size: size, id: readingTimeId }))),
35
37
  likes && postId && (React.createElement(Save, { postId: postId, title: likesCount, hasUserLike: hasUserLike, handleUserLike: handleLike, size: size, qa: qa }))));
36
38
  };
@@ -4,6 +4,7 @@ import '../PostInfo.css';
4
4
  type DateProps = {
5
5
  date: string | number;
6
6
  size?: PostCardSize;
7
+ id?: string;
7
8
  };
8
- export declare const Date: ({ date, size }: DateProps) => React.JSX.Element;
9
+ export declare const Date: ({ date, size, id }: DateProps) => React.JSX.Element;
9
10
  export {};
@@ -5,7 +5,7 @@ import { block } from '../../../utils/cn';
5
5
  import { format } from '../../../utils/date';
6
6
  import '../PostInfo.css';
7
7
  const b = block('post-info');
8
- export const Date = ({ date, size = PostCardSize.SMALL }) => {
8
+ export const Date = ({ date, size = PostCardSize.SMALL, id }) => {
9
9
  const { locale } = useContext(LocaleContext);
10
- return React.createElement("div", { className: b('item', { size }) }, format(date, 'longDate', locale === null || locale === void 0 ? void 0 : locale.code));
10
+ return (React.createElement("div", { className: b('item', { size }), id: id }, format(date, 'longDate', locale === null || locale === void 0 ? void 0 : locale.code)));
11
11
  };
@@ -3,6 +3,7 @@ import '../PostInfo.css';
3
3
  type ReadingTimeProps = {
4
4
  readingTime: number;
5
5
  size?: 's' | 'm';
6
+ id?: string;
6
7
  };
7
- export declare const ReadingTime: ({ readingTime, size }: ReadingTimeProps) => React.JSX.Element;
8
+ export declare const ReadingTime: ({ readingTime, size, id }: ReadingTimeProps) => React.JSX.Element;
8
9
  export {};
@@ -6,7 +6,7 @@ import { block } from '../../../utils/cn';
6
6
  import '../PostInfo.css';
7
7
  const b = block('post-info');
8
8
  const ICON_SIZE = 16;
9
- export const ReadingTime = ({ readingTime, size = 's' }) => (React.createElement("div", { className: b('item', { size }) },
9
+ export const ReadingTime = ({ readingTime, size = 's', id }) => (React.createElement("div", { className: b('item', { size }), id: id },
10
10
  React.createElement("span", { className: b('icon') },
11
11
  React.createElement(Icon, { data: Time, size: ICON_SIZE, className: b('icon-color') })),
12
12
  i18(Keyset.ContextReadingTime, { count: readingTime })));
@@ -0,0 +1,17 @@
1
+ type Labels = string | number | boolean | undefined;
2
+ type Description = string | number | boolean | undefined;
3
+ interface UseAriaAttributesProps {
4
+ labelIds?: Labels[];
5
+ descriptionIds: Description[];
6
+ }
7
+ /**
8
+ * Returns aria-attributes
9
+ * @param labelIds - labels ids. Falsy values will be ignored
10
+ * @param descriptionIds - descriptions ids. Falsy values will be ignored
11
+ * @returns aria attributes for the element to be labelled
12
+ */
13
+ export declare const useAriaAttributes: ({ labelIds, descriptionIds }: UseAriaAttributesProps) => {
14
+ 'aria-labelledby': string;
15
+ 'aria-describedby': string;
16
+ };
17
+ export {};
@@ -0,0 +1,15 @@
1
+ import { useMemo } from 'react';
2
+ /**
3
+ * Returns aria-attributes
4
+ * @param labelIds - labels ids. Falsy values will be ignored
5
+ * @param descriptionIds - descriptions ids. Falsy values will be ignored
6
+ * @returns aria attributes for the element to be labelled
7
+ */
8
+ export const useAriaAttributes = ({ labelIds = [], descriptionIds = [] }) => {
9
+ const labelledBy = useMemo(() => labelIds.filter(Boolean).join(' '), [labelIds]);
10
+ const describedBy = useMemo(() => descriptionIds.filter(Boolean).join(' '), [descriptionIds]);
11
+ return {
12
+ 'aria-labelledby': labelledBy,
13
+ 'aria-describedby': describedBy,
14
+ };
15
+ };
@@ -1,4 +1,5 @@
1
1
  import { ReactNode } from 'react';
2
+ import { MarkdownItPluginCb } from '@doc-tools/transform/lib/plugins/typings';
2
3
  import { HeaderBlockProps as PageConstructorHeaderBlockProps } from '@gravity-ui/page-constructor';
3
4
  import { IBrowser, IDevice } from 'ua-parser-js';
4
5
  import { Locale } from '../models/locale';
@@ -176,3 +177,6 @@ export declare enum PostCardTitleHeadingLevel {
176
177
  H2 = "h2",
177
178
  H3 = "h3"
178
179
  }
180
+ export interface TransformPostOptions {
181
+ plugins?: MarkdownItPluginCb[];
182
+ }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@gravity-ui/blog-constructor",
3
- "version": "5.7.3",
3
+ "version": "5.8.0",
4
4
  "description": "Gravity UI Blog Constructor",
5
5
  "license": "MIT",
6
6
  "repository": {
@@ -78,7 +78,7 @@
78
78
  },
79
79
  "peerDependencies": {
80
80
  "@doc-tools/transform": "^3.3.2",
81
- "@gravity-ui/page-constructor": "^4.26.0",
81
+ "@gravity-ui/page-constructor": "^4.31.0",
82
82
  "@gravity-ui/uikit": "^5.12.0",
83
83
  "react": "^16.0.0 || ^17.0.0 || ^18.0.0"
84
84
  },
@@ -1,3 +1,4 @@
1
+ import { MarkdownItPluginCb } from '@doc-tools/transform/lib/plugins/typings';
1
2
  import { Lang } from '../models/locale';
2
3
  type TypographyConfigType = {
3
4
  [x: string]: Record<string, unknown>;
@@ -7,6 +8,7 @@ type TransformPageContentPropsType = {
7
8
  lang: Lang;
8
9
  region?: string;
9
10
  typographyConfig?: TypographyConfigType;
11
+ plugins?: MarkdownItPluginCb[];
10
12
  };
11
13
  /**
12
14
  * Func for transform blog page content
@@ -15,7 +17,8 @@ type TransformPageContentPropsType = {
15
17
  * @param lang - runtime app lang
16
18
  * @param region - runtime app region
17
19
  * @param typographyConfig - page-constructor extend typography config
20
+ * @param plugins - YFM plugins
18
21
  * @returns transformed content
19
22
  */
20
- export declare const transformPageContent: ({ content, lang, region, typographyConfig, }: TransformPageContentPropsType) => any;
23
+ export declare const transformPageContent: ({ content, lang, region, typographyConfig, plugins, }: TransformPageContentPropsType) => any;
21
24
  export {};
@@ -6,13 +6,14 @@ const server_1 = require("@gravity-ui/page-constructor/server");
6
6
  const js_yaml_1 = tslib_1.__importDefault(require("js-yaml"));
7
7
  const config_1 = require("./config");
8
8
  const contentFilter_1 = require("./contentFilter");
9
- const transformer = ({ blocks, lang, typographyConfig }) => (0, server_1.contentTransformer)({
9
+ const transformer = ({ blocks, lang, typographyConfig, plugins }) => (0, server_1.contentTransformer)({
10
10
  content: {
11
11
  blocks: blocks || [],
12
12
  },
13
13
  options: {
14
14
  lang,
15
15
  customConfig: Object.assign(Object.assign({}, typographyConfig), (0, config_1.getExtendTypographyConfig)()),
16
+ plugins,
16
17
  },
17
18
  });
18
19
  /**
@@ -22,9 +23,10 @@ const transformer = ({ blocks, lang, typographyConfig }) => (0, server_1.content
22
23
  * @param lang - runtime app lang
23
24
  * @param region - runtime app region
24
25
  * @param typographyConfig - page-constructor extend typography config
26
+ * @param plugins - YFM plugins
25
27
  * @returns transformed content
26
28
  */
27
- const transformPageContent = ({ content, lang, region, typographyConfig = {}, }) => {
29
+ const transformPageContent = ({ content, lang, region, typographyConfig = {}, plugins, }) => {
28
30
  try {
29
31
  const transformedContent = (0, contentFilter_1.filterContent)(js_yaml_1.default.load(content), { lang, region });
30
32
  if (transformedContent.blocks) {
@@ -32,6 +34,7 @@ const transformPageContent = ({ content, lang, region, typographyConfig = {}, })
32
34
  blocks: transformedContent.blocks,
33
35
  lang,
34
36
  typographyConfig,
37
+ plugins,
35
38
  });
36
39
  transformedContent.blocks = transformedBlocks;
37
40
  }
@@ -1,4 +1,4 @@
1
- import { PostData } from '../models/common';
1
+ import { PostData, TransformPostOptions } from '../models/common';
2
2
  import { Lang } from '../models/locale';
3
3
  /**
4
4
  * Func for transform post data
@@ -6,6 +6,7 @@ import { Lang } from '../models/locale';
6
6
  * @param postData - post data
7
7
  * @param lang - runtime language
8
8
  *
9
+ * @param plugins - YFM plugins list
9
10
  * @returns -prepared post
10
11
  */
11
- export declare const transformPost: (postData: PostData, lang: Lang) => PostData;
12
+ export declare const transformPost: (postData: PostData, lang: Lang, { plugins }?: TransformPostOptions) => PostData;
@@ -9,9 +9,10 @@ const server_1 = require("@gravity-ui/page-constructor/server");
9
9
  * @param postData - post data
10
10
  * @param lang - runtime language
11
11
  *
12
+ * @param plugins - YFM plugins list
12
13
  * @returns -prepared post
13
14
  */
14
- const transformPost = (postData, lang) => {
15
+ const transformPost = (postData, lang, { plugins } = {}) => {
15
16
  if (!postData) {
16
17
  // eslint-disable-next-line no-console
17
18
  console.error('Post not found');
@@ -19,6 +20,6 @@ const transformPost = (postData, lang) => {
19
20
  }
20
21
  const { tags, title, metaTitle, description } = postData, post = tslib_1.__rest(postData, ["tags", "title", "metaTitle", "description"]);
21
22
  return Object.assign(Object.assign({}, post), { title,
22
- tags, textTitle: (0, server_1.typografToText)(title, lang), htmlTitle: (0, server_1.typografToHTML)(title, lang), metaTitle: metaTitle || title, description: (0, server_1.yfmTransformer)(lang, description) });
23
+ tags, textTitle: (0, server_1.typografToText)(title, lang), htmlTitle: (0, server_1.typografToHTML)(title, lang), metaTitle: metaTitle || title, description: (0, server_1.yfmTransformer)(lang, description, { plugins }) });
23
24
  };
24
25
  exports.transformPost = transformPost;
@@ -1,4 +1,5 @@
1
1
  import { ReactNode } from 'react';
2
+ import { MarkdownItPluginCb } from '@doc-tools/transform/lib/plugins/typings';
2
3
  import { HeaderBlockProps as PageConstructorHeaderBlockProps } from '@gravity-ui/page-constructor';
3
4
  import { IBrowser, IDevice } from 'ua-parser-js';
4
5
  import { Locale } from '../models/locale';
@@ -176,3 +177,6 @@ export declare enum PostCardTitleHeadingLevel {
176
177
  H2 = "h2",
177
178
  H3 = "h3"
178
179
  }
180
+ export interface TransformPostOptions {
181
+ plugins?: MarkdownItPluginCb[];
182
+ }