@gravity-ui/page-constructor 5.31.2 → 6.0.0-alpha.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 (206) hide show
  1. package/README.md +6 -0
  2. package/build/cjs/blocks/ExtendedFeatures/ExtendedFeatures.css +11 -6
  3. package/build/cjs/blocks/ExtendedFeatures/ExtendedFeatures.js +3 -6
  4. package/build/cjs/blocks/Header/Header.css +15 -10
  5. package/build/cjs/blocks/Header/Header.js +8 -4
  6. package/build/cjs/blocks/HeaderSlider/HeaderSlider.css +0 -10
  7. package/build/cjs/blocks/HeaderSlider/HeaderSlider.js +2 -2
  8. package/build/cjs/blocks/HeaderSlider/schema.d.ts +9 -1
  9. package/build/cjs/blocks/Questions/QuestionBlockItem/QuestionBlockItem.css +43 -21
  10. package/build/cjs/blocks/Questions/QuestionBlockItem/QuestionBlockItem.js +5 -3
  11. package/build/cjs/blocks/Slider/Arrow/Arrow.css +22 -21
  12. package/build/cjs/blocks/Slider/Arrow/Arrow.d.ts +5 -2
  13. package/build/cjs/blocks/Slider/Arrow/Arrow.js +5 -4
  14. package/build/cjs/blocks/Slider/Slider.css +549 -329
  15. package/build/cjs/blocks/Slider/Slider.d.ts +6 -6
  16. package/build/cjs/blocks/Slider/Slider.js +40 -282
  17. package/build/cjs/blocks/Slider/i18n/en.json +1 -1
  18. package/build/cjs/blocks/Slider/i18n/ru.json +1 -1
  19. package/build/cjs/blocks/Slider/models.d.ts +2 -2
  20. package/build/cjs/blocks/Slider/models.js +1 -1
  21. package/build/cjs/blocks/Slider/schema.d.ts +18 -1
  22. package/build/cjs/blocks/Slider/schema.js +9 -0
  23. package/build/cjs/blocks/{SliderNew → Slider}/useSlider.d.ts +1 -0
  24. package/build/cjs/blocks/{SliderNew → Slider}/useSlider.js +4 -0
  25. package/build/cjs/blocks/Slider/utils.d.ts +7 -27
  26. package/build/cjs/blocks/Slider/utils.js +26 -108
  27. package/build/cjs/blocks/{SliderNew → SliderOld}/Arrow/Arrow.css +15 -12
  28. package/build/cjs/blocks/SliderOld/Arrow/Arrow.d.ts +9 -0
  29. package/build/cjs/blocks/{SliderNew → SliderOld}/Arrow/Arrow.js +3 -3
  30. package/build/cjs/blocks/SliderOld/SliderOld.css +703 -0
  31. package/build/cjs/blocks/SliderOld/SliderOld.d.ts +17 -0
  32. package/build/cjs/blocks/SliderOld/SliderOld.js +301 -0
  33. package/build/cjs/blocks/{SliderNew → SliderOld}/i18n/en.json +1 -1
  34. package/build/cjs/blocks/{SliderNew → SliderOld}/i18n/index.js +1 -1
  35. package/build/cjs/blocks/{SliderNew → SliderOld}/i18n/ru.json +1 -1
  36. package/build/cjs/blocks/{SliderNew → SliderOld}/models.d.ts +2 -2
  37. package/build/cjs/blocks/{SliderNew → SliderOld}/models.js +1 -1
  38. package/build/cjs/blocks/{SliderNew → SliderOld}/schema.d.ts +5 -21
  39. package/build/cjs/blocks/{SliderNew → SliderOld}/schema.js +6 -14
  40. package/build/cjs/blocks/SliderOld/utils.d.ts +36 -0
  41. package/build/cjs/blocks/SliderOld/utils.js +125 -0
  42. package/build/cjs/blocks/index.d.ts +1 -0
  43. package/build/cjs/blocks/index.js +3 -1
  44. package/build/cjs/blocks/validators.d.ts +1 -0
  45. package/build/cjs/blocks/validators.js +1 -0
  46. package/build/cjs/components/ContentList/ContentList.css +5 -4
  47. package/build/cjs/components/ContentList/ContentList.js +1 -1
  48. package/build/cjs/components/FullscreenImage/FullscreenImage.css +96 -18
  49. package/build/cjs/components/FullscreenImage/FullscreenImage.d.ts +5 -0
  50. package/build/cjs/components/FullscreenImage/FullscreenImage.js +19 -5
  51. package/build/cjs/components/HTML/HTML.d.ts +16 -9
  52. package/build/cjs/components/HTML/HTML.js +16 -11
  53. package/build/cjs/components/Media/Image/Image.d.ts +1 -0
  54. package/build/cjs/components/Media/Image/Image.js +7 -5
  55. package/build/cjs/components/Media/Media.css +4 -0
  56. package/build/cjs/components/Media/Media.d.ts +1 -0
  57. package/build/cjs/components/Media/Media.js +3 -2
  58. package/build/cjs/components/MetaInfo/MetaInfo.css +1 -1
  59. package/build/cjs/components/MetaInfo/MetaInfo.js +1 -1
  60. package/build/cjs/components/Table/Table.css +2 -1
  61. package/build/cjs/components/Table/Table.js +4 -2
  62. package/build/cjs/components/Title/TitleItem.css +6 -4
  63. package/build/cjs/components/Title/TitleItem.js +3 -1
  64. package/build/cjs/components/YFMWrapper/YFMWrapper.d.ts +4 -2
  65. package/build/cjs/components/YFMWrapper/YFMWrapper.js +4 -1
  66. package/build/cjs/constructor-items.d.ts +2 -2
  67. package/build/cjs/constructor-items.js +2 -4
  68. package/build/cjs/editor/data/templates/{slider-new-block.json → slider-old-block.json} +2 -2
  69. package/build/cjs/models/common.d.ts +1 -0
  70. package/build/cjs/models/constructor-items/blocks.d.ts +17 -15
  71. package/build/cjs/models/constructor-items/blocks.js +3 -2
  72. package/build/cjs/schema/constants.d.ts +0 -1
  73. package/build/cjs/schema/constants.js +3 -1
  74. package/build/cjs/schema/validators/blocks.d.ts +2 -2
  75. package/build/cjs/schema/validators/blocks.js +2 -2
  76. package/build/cjs/sub-blocks/BannerCard/BannerCard.css +10 -8
  77. package/build/cjs/sub-blocks/BannerCard/BannerCard.js +4 -3
  78. package/build/cjs/sub-blocks/Content/Content.js +1 -1
  79. package/build/cjs/sub-blocks/PriceCard/PriceCard.css +2 -1
  80. package/build/cjs/sub-blocks/PriceCard/PriceCard.js +1 -1
  81. package/build/cjs/sub-blocks/Quote/Quote.css +8 -4
  82. package/build/cjs/sub-blocks/Quote/Quote.js +2 -4
  83. package/build/cjs/text-transform/config.js +1 -1
  84. package/build/cjs/utils/blocks.d.ts +10 -2
  85. package/build/cjs/utils/blocks.js +10 -4
  86. package/build/esm/blocks/ExtendedFeatures/ExtendedFeatures.css +11 -6
  87. package/build/esm/blocks/ExtendedFeatures/ExtendedFeatures.js +4 -7
  88. package/build/esm/blocks/Header/Header.css +15 -10
  89. package/build/esm/blocks/Header/Header.js +9 -5
  90. package/build/esm/blocks/HeaderSlider/HeaderSlider.css +0 -10
  91. package/build/esm/blocks/HeaderSlider/HeaderSlider.js +1 -1
  92. package/build/esm/blocks/HeaderSlider/schema.d.ts +9 -1
  93. package/build/esm/blocks/Questions/QuestionBlockItem/QuestionBlockItem.css +43 -21
  94. package/build/esm/blocks/Questions/QuestionBlockItem/QuestionBlockItem.js +6 -4
  95. package/build/esm/blocks/Slider/Arrow/Arrow.css +22 -21
  96. package/build/esm/blocks/Slider/Arrow/Arrow.d.ts +5 -2
  97. package/build/esm/blocks/Slider/Arrow/Arrow.js +5 -4
  98. package/build/esm/blocks/Slider/Slider.css +549 -329
  99. package/build/esm/blocks/Slider/Slider.d.ts +6 -6
  100. package/build/esm/blocks/Slider/Slider.js +42 -284
  101. package/build/esm/blocks/Slider/i18n/en.json +1 -1
  102. package/build/esm/blocks/Slider/i18n/ru.json +1 -1
  103. package/build/esm/blocks/Slider/models.d.ts +2 -2
  104. package/build/esm/blocks/Slider/models.js +1 -1
  105. package/build/esm/blocks/Slider/schema.d.ts +18 -1
  106. package/build/esm/blocks/Slider/schema.js +9 -0
  107. package/build/esm/blocks/{SliderNew → Slider}/useSlider.d.ts +1 -0
  108. package/build/esm/blocks/{SliderNew → Slider}/useSlider.js +5 -1
  109. package/build/esm/blocks/Slider/utils.d.ts +7 -27
  110. package/build/esm/blocks/Slider/utils.js +24 -103
  111. package/build/esm/blocks/{SliderNew → SliderOld}/Arrow/Arrow.css +15 -12
  112. package/build/esm/blocks/SliderOld/Arrow/Arrow.d.ts +10 -0
  113. package/build/esm/blocks/{SliderNew → SliderOld}/Arrow/Arrow.js +3 -3
  114. package/build/esm/blocks/SliderOld/SliderOld.css +703 -0
  115. package/build/esm/blocks/SliderOld/SliderOld.d.ts +18 -0
  116. package/build/esm/blocks/SliderOld/SliderOld.js +297 -0
  117. package/build/esm/blocks/{SliderNew → SliderOld}/i18n/en.json +1 -1
  118. package/build/esm/blocks/{SliderNew → SliderOld}/i18n/index.js +1 -1
  119. package/build/esm/blocks/{SliderNew → SliderOld}/i18n/ru.json +1 -1
  120. package/build/esm/blocks/{SliderNew → SliderOld}/models.d.ts +2 -2
  121. package/build/esm/blocks/{SliderNew → SliderOld}/models.js +1 -1
  122. package/build/esm/blocks/{SliderNew → SliderOld}/schema.d.ts +5 -21
  123. package/build/esm/blocks/{SliderNew → SliderOld}/schema.js +5 -13
  124. package/build/esm/blocks/SliderOld/utils.d.ts +36 -0
  125. package/build/esm/blocks/SliderOld/utils.js +115 -0
  126. package/build/esm/blocks/index.d.ts +1 -0
  127. package/build/esm/blocks/index.js +1 -0
  128. package/build/esm/blocks/validators.d.ts +1 -0
  129. package/build/esm/blocks/validators.js +1 -0
  130. package/build/esm/components/ContentList/ContentList.css +5 -4
  131. package/build/esm/components/ContentList/ContentList.js +1 -1
  132. package/build/esm/components/FullscreenImage/FullscreenImage.css +96 -18
  133. package/build/esm/components/FullscreenImage/FullscreenImage.d.ts +5 -0
  134. package/build/esm/components/FullscreenImage/FullscreenImage.js +20 -6
  135. package/build/esm/components/HTML/HTML.d.ts +16 -9
  136. package/build/esm/components/HTML/HTML.js +18 -12
  137. package/build/esm/components/Media/Image/Image.d.ts +1 -0
  138. package/build/esm/components/Media/Image/Image.js +7 -5
  139. package/build/esm/components/Media/Media.css +4 -0
  140. package/build/esm/components/Media/Media.d.ts +1 -0
  141. package/build/esm/components/Media/Media.js +3 -2
  142. package/build/esm/components/MetaInfo/MetaInfo.css +1 -1
  143. package/build/esm/components/MetaInfo/MetaInfo.js +1 -1
  144. package/build/esm/components/Table/Table.css +2 -1
  145. package/build/esm/components/Table/Table.js +5 -3
  146. package/build/esm/components/Title/TitleItem.css +6 -4
  147. package/build/esm/components/Title/TitleItem.js +4 -2
  148. package/build/esm/components/YFMWrapper/YFMWrapper.d.ts +4 -2
  149. package/build/esm/components/YFMWrapper/YFMWrapper.js +5 -1
  150. package/build/esm/constructor-items.d.ts +2 -2
  151. package/build/esm/constructor-items.js +3 -5
  152. package/build/esm/editor/data/templates/{slider-new-block.json → slider-old-block.json} +2 -2
  153. package/build/esm/models/common.d.ts +1 -0
  154. package/build/esm/models/constructor-items/blocks.d.ts +17 -15
  155. package/build/esm/models/constructor-items/blocks.js +3 -2
  156. package/build/esm/schema/constants.d.ts +0 -1
  157. package/build/esm/schema/constants.js +4 -2
  158. package/build/esm/schema/validators/blocks.d.ts +2 -2
  159. package/build/esm/schema/validators/blocks.js +2 -2
  160. package/build/esm/sub-blocks/BannerCard/BannerCard.css +10 -8
  161. package/build/esm/sub-blocks/BannerCard/BannerCard.js +5 -4
  162. package/build/esm/sub-blocks/Content/Content.js +1 -1
  163. package/build/esm/sub-blocks/PriceCard/PriceCard.css +2 -1
  164. package/build/esm/sub-blocks/PriceCard/PriceCard.js +2 -2
  165. package/build/esm/sub-blocks/Quote/Quote.css +8 -4
  166. package/build/esm/sub-blocks/Quote/Quote.js +3 -5
  167. package/build/esm/text-transform/config.js +1 -1
  168. package/build/esm/utils/blocks.d.ts +10 -2
  169. package/build/esm/utils/blocks.js +8 -2
  170. package/package.json +2 -2
  171. package/schema/index.js +1 -1
  172. package/server/models/common.d.ts +1 -0
  173. package/server/models/constructor-items/blocks.d.ts +17 -15
  174. package/server/models/constructor-items/blocks.js +3 -2
  175. package/server/text-transform/config.js +1 -1
  176. package/server/utils/blocks.d.ts +10 -2
  177. package/server/utils/blocks.js +10 -4
  178. package/styles/fonts.scss +1 -0
  179. package/styles/styles.css +0 -1
  180. package/styles/styles.scss +0 -1
  181. package/styles/variables.scss +1 -0
  182. package/widget/index.js +1 -1
  183. package/build/cjs/blocks/SliderNew/Arrow/Arrow.d.ts +0 -11
  184. package/build/cjs/blocks/SliderNew/Slider.css +0 -834
  185. package/build/cjs/blocks/SliderNew/Slider.d.ts +0 -13
  186. package/build/cjs/blocks/SliderNew/Slider.js +0 -56
  187. package/build/cjs/blocks/SliderNew/utils.d.ts +0 -16
  188. package/build/cjs/blocks/SliderNew/utils.js +0 -43
  189. package/build/cjs/blocks/unstable.d.ts +0 -1
  190. package/build/cjs/blocks/unstable.js +0 -8
  191. package/build/esm/blocks/SliderNew/Arrow/Arrow.d.ts +0 -12
  192. package/build/esm/blocks/SliderNew/Slider.css +0 -834
  193. package/build/esm/blocks/SliderNew/Slider.d.ts +0 -14
  194. package/build/esm/blocks/SliderNew/Slider.js +0 -52
  195. package/build/esm/blocks/SliderNew/utils.d.ts +0 -16
  196. package/build/esm/blocks/SliderNew/utils.js +0 -36
  197. package/build/esm/blocks/unstable.d.ts +0 -1
  198. package/build/esm/blocks/unstable.js +0 -1
  199. /package/build/cjs/blocks/{SliderNew → Slider}/useSliderPagination.d.ts +0 -0
  200. /package/build/cjs/blocks/{SliderNew → Slider}/useSliderPagination.js +0 -0
  201. /package/build/cjs/blocks/{SliderNew → SliderOld}/i18n/index.d.ts +0 -0
  202. /package/build/cjs/blocks/{Slider → SliderOld}/slick.css +0 -0
  203. /package/build/esm/blocks/{SliderNew → Slider}/useSliderPagination.d.ts +0 -0
  204. /package/build/esm/blocks/{SliderNew → Slider}/useSliderPagination.js +0 -0
  205. /package/build/esm/blocks/{SliderNew → SliderOld}/i18n/index.d.ts +0 -0
  206. /package/build/esm/blocks/{Slider → SliderOld}/slick.css +0 -0
@@ -1,125 +1,43 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.useRovingTabIndex = exports.getSlidesToShowCount = exports.getSlidesCountByBreakpoint = exports.getSliderResponsiveParams = exports.getSlidesToShowWithDefaults = exports.isFocusable = exports.DEFAULT_SLIDE_BREAKPOINTS = void 0;
3
+ exports.setElementAtrributes = exports.useMemoized = exports.getSliderResponsiveParams = exports.DEFAULT_SLIDE_BREAKPOINTS = void 0;
4
4
  const tslib_1 = require("tslib");
5
5
  const react_1 = require("react");
6
+ const isEqual_1 = tslib_1.__importDefault(require("lodash/isEqual"));
6
7
  const pickBy_1 = tslib_1.__importDefault(require("lodash/pickBy"));
7
8
  const constants_1 = require("../../constants");
8
9
  const models_1 = require("./models");
9
10
  exports.DEFAULT_SLIDE_BREAKPOINTS = {
10
- [models_1.SliderBreakpointNames.Xl]: 3,
11
- [models_1.SliderBreakpointNames.Lg]: 2,
11
+ [models_1.SliderBreakpointNames.Lg]: 3,
12
12
  [models_1.SliderBreakpointNames.Md]: 2,
13
- [models_1.SliderBreakpointNames.Sm]: 1.15,
13
+ [models_1.SliderBreakpointNames.Sm]: 2,
14
+ [models_1.SliderBreakpointNames.Xs]: 1.15,
14
15
  };
15
- const BREAKPOINT_NAMES_BY_VALUES = Object.entries(constants_1.BREAKPOINTS).reduce((acc, [key, value]) => (Object.assign(Object.assign({}, acc), { [value]: key })), {});
16
- const isFocusable = (element) => {
17
- if (!(element instanceof HTMLElement)) {
18
- return false;
19
- }
20
- const tabIndexAttr = element.getAttribute('tabindex');
21
- const hasTabIndex = tabIndexAttr !== null;
22
- const tabIndex = Number(tabIndexAttr);
23
- if (element.ariaHidden === 'true' || (hasTabIndex && tabIndex < 0)) {
24
- return false;
25
- }
26
- if (hasTabIndex && tabIndex >= 0) {
27
- return true;
28
- }
29
- // without this jest fails here for some reason
30
- let htmlElement;
31
- switch (true) {
32
- case element instanceof HTMLAnchorElement:
33
- htmlElement = element;
34
- return Boolean(htmlElement.href);
35
- case element instanceof HTMLInputElement:
36
- htmlElement = element;
37
- return htmlElement.type !== 'hidden' && !htmlElement.disabled;
38
- case element instanceof HTMLSelectElement:
39
- case element instanceof HTMLTextAreaElement:
40
- case element instanceof HTMLButtonElement:
41
- htmlElement = element;
42
- return !htmlElement.disabled;
43
- default:
44
- return false;
45
- }
46
- };
47
- exports.isFocusable = isFocusable;
48
- function getSlidesToShowWithDefaults({ contentLength, breakpoints, mobileFullscreen, }) {
16
+ function getSliderResponsiveParams({ contentLength, slidesToShow, mobileFullscreen, }) {
49
17
  let result;
50
- if (typeof breakpoints === 'number') {
51
- result = Object.keys(exports.DEFAULT_SLIDE_BREAKPOINTS).reduce((acc, breakpointName) => (Object.assign(Object.assign({}, acc), { [breakpointName]: breakpoints })), {});
18
+ if (typeof slidesToShow === 'number') {
19
+ result = Object.keys(exports.DEFAULT_SLIDE_BREAKPOINTS).reduce((acc, breakpointName) => (Object.assign(Object.assign({}, acc), { [breakpointName]: slidesToShow })), {});
52
20
  }
53
21
  else {
54
- result = breakpoints || exports.DEFAULT_SLIDE_BREAKPOINTS;
22
+ result = slidesToShow || exports.DEFAULT_SLIDE_BREAKPOINTS;
55
23
  }
56
- return Object.assign(Object.assign(Object.assign({}, exports.DEFAULT_SLIDE_BREAKPOINTS), (0, pickBy_1.default)(result, (value) => !isNaN(value))), { sm: !mobileFullscreen && contentLength > 1 ? exports.DEFAULT_SLIDE_BREAKPOINTS.sm : 1 });
57
- }
58
- exports.getSlidesToShowWithDefaults = getSlidesToShowWithDefaults;
59
- function getSliderResponsiveParams(breakpoints) {
60
- return Object.entries(breakpoints).map(([breakpointName, slidesToShow]) => ({
61
- breakpoint: constants_1.BREAKPOINTS[breakpointName],
62
- settings: { slidesToShow },
63
- }));
24
+ const showCount = Object.assign(Object.assign(Object.assign({}, exports.DEFAULT_SLIDE_BREAKPOINTS), (0, pickBy_1.default)(result, (value) => !isNaN(value))), { xs: !mobileFullscreen && contentLength > 1 ? exports.DEFAULT_SLIDE_BREAKPOINTS.xs : 1 });
25
+ return Object.entries(showCount).reduce((res, [breakpointName, value]) => {
26
+ // eslint-disable-next-line no-param-reassign
27
+ res[constants_1.BREAKPOINTS[breakpointName] + 1] = {
28
+ slidesPerView: value,
29
+ };
30
+ return res;
31
+ }, {});
64
32
  }
65
33
  exports.getSliderResponsiveParams = getSliderResponsiveParams;
66
- function getSlidesCountByBreakpoint(breakpoint, breakpoints) {
67
- const breakpointName = BREAKPOINT_NAMES_BY_VALUES[breakpoint];
68
- return Math.floor(breakpoints[breakpointName]);
69
- }
70
- exports.getSlidesCountByBreakpoint = getSlidesCountByBreakpoint;
71
- function getSlidesToShowCount(breakpoints) {
72
- return Math.floor(Math.max(...Object.values(breakpoints)));
73
- }
74
- exports.getSlidesToShowCount = getSlidesToShowCount;
75
- const getRovingListItemId = (uniqId, index) => `${uniqId}-roving-tabindex-item-${index}`;
76
- function useRovingTabIndex(props) {
77
- const { itemCount, activeIndex, firstIndex = 0, uniqId } = props;
78
- const [currentIndex, setCurrentIndex] = (0, react_1.useState)(firstIndex);
79
- const hasFocusRef = (0, react_1.useRef)(false);
80
- const lastIndex = itemCount + firstIndex - 1;
81
- const getRovingItemProps = (index) => {
82
- return {
83
- id: getRovingListItemId(uniqId, index),
84
- tabIndex: index === activeIndex ? 0 : -1,
85
- onFocus: () => {
86
- setCurrentIndex(index);
87
- hasFocusRef.current = true;
88
- },
89
- };
90
- };
34
+ const useMemoized = (value) => {
35
+ const [memoizedValue, setMemoizedValue] = (0, react_1.useState)(value);
91
36
  (0, react_1.useEffect)(() => {
92
- var _a;
93
- if (!hasFocusRef.current) {
94
- return;
95
- }
96
- (_a = document.getElementById(getRovingListItemId(uniqId, currentIndex))) === null || _a === void 0 ? void 0 : _a.focus();
97
- }, [activeIndex, currentIndex, uniqId]);
98
- const setNextIndex = () => setCurrentIndex((prev) => (prev >= lastIndex ? firstIndex : prev + 1));
99
- const setPrevIndex = () => setCurrentIndex((prev) => (prev <= firstIndex ? lastIndex : prev - 1));
100
- const onRovingListKeyDown = (e) => {
101
- const key = e.key.toLowerCase();
102
- if (key !== 'tab' && key !== 'enter') {
103
- e.preventDefault();
104
- }
105
- switch (key) {
106
- case 'arrowleft':
107
- case 'arrowup':
108
- setPrevIndex();
109
- return;
110
- case 'arrowright':
111
- case 'arrowdown':
112
- setNextIndex();
113
- return;
114
- }
115
- };
116
- const onRovingListBlur = () => {
117
- hasFocusRef.current = false;
118
- };
119
- const rovingListProps = {
120
- onKeyDown: onRovingListKeyDown,
121
- onBlur: onRovingListBlur,
122
- };
123
- return { getRovingItemProps, rovingListProps };
124
- }
125
- exports.useRovingTabIndex = useRovingTabIndex;
37
+ setMemoizedValue((memoized) => value && typeof value === 'object' && (0, isEqual_1.default)(memoized, value) ? memoized : value);
38
+ }, [value]);
39
+ return memoizedValue;
40
+ };
41
+ exports.useMemoized = useMemoized;
42
+ const setElementAtrributes = (element, attributes) => Object.entries(attributes).forEach(([attribute, value]) => element.setAttribute(attribute, String(value)));
43
+ exports.setElementAtrributes = setElementAtrributes;
@@ -1,34 +1,37 @@
1
- .pc-slider-new-block-arrow__button {
1
+ .pc-slider-old-block-arrow__button {
2
2
  box-shadow: 0px 4px 24px var(--pc-color-sfx-shadow), 0px 2px 8px var(--pc-color-sfx-shadow);
3
3
  }
4
4
 
5
- .pc-slider-new-block-arrow__button:hover {
5
+ .pc-slider-old-block-arrow__button:hover {
6
6
  box-shadow: 0px 4px 24px var(--g-color-sfx-shadow), 0px 2px 8px var(--g-color-sfx-shadow);
7
7
  cursor: pointer;
8
8
  }
9
9
 
10
10
  /* use this for style redefinitions to awoid problems with
11
11
  unpredictable css rules order in build */
12
- .pc-slider-new-block-arrow__icon-wrapper, .pc-slider-new-block-arrow__button, .pc-slider-new-block-arrow {
12
+ .pc-slider-old-block-arrow__icon-wrapper, .pc-slider-old-block-arrow__button, .pc-slider-old-block-arrow {
13
13
  display: flex;
14
14
  align-items: center;
15
15
  justify-content: center;
16
16
  }
17
17
 
18
- .pc-slider-new-block-arrow {
18
+ .pc-slider-old-block-arrow {
19
19
  width: 42px;
20
20
  height: 42px;
21
21
  cursor: pointer;
22
22
  }
23
23
  @media (max-width: 576px) {
24
- .pc-slider-new-block-arrow {
24
+ .pc-slider-old-block-arrow {
25
25
  display: none;
26
26
  }
27
27
  }
28
- .pc-slider-new-block-arrow_type_left .pc-slider-new-block-arrow__icon-wrapper {
28
+ .pc-slider-old-block-arrow_type_left {
29
+ margin-right: 16px;
30
+ }
31
+ .pc-slider-old-block-arrow_type_left .pc-slider-old-block-arrow__icon-wrapper {
29
32
  transform: rotate(180deg);
30
33
  }
31
- .pc-slider-new-block-arrow__button {
34
+ .pc-slider-old-block-arrow__button {
32
35
  display: inline-block;
33
36
  margin: 0;
34
37
  padding: 0;
@@ -44,19 +47,19 @@ unpredictable css rules order in build */
44
47
  border-radius: 100%;
45
48
  background-color: var(--g-color-base-background);
46
49
  box-shadow: 0 4px 24px var(--pc-color-sfx-shadow), 0 2px 8px var(--pc-color-sfx-shadow);
47
- transition: box-shadow 0.3s cubic-bezier(0.22, 0.61, 0.36, 1), color 0.3s cubic-bezier(0.22, 0.61, 0.36, 1);
50
+ transition: box-shadow 0.3s cubic-bezier(0.22, 0.61, 0.36, 1), color 1s cubic-bezier(0.22, 0.61, 0.36, 1);
48
51
  }
49
- .pc-slider-new-block-arrow__button:focus {
52
+ .pc-slider-old-block-arrow__button:focus {
50
53
  outline: 2px solid var(--g-color-line-focus);
51
54
  outline-offset: 0;
52
55
  }
53
- .pc-slider-new-block-arrow__button:focus:not(:focus-visible) {
56
+ .pc-slider-old-block-arrow__button:focus:not(:focus-visible) {
54
57
  outline: 0;
55
58
  }
56
- .pc-slider-new-block-arrow:hover .pc-slider-new-block-arrow__button {
59
+ .pc-slider-old-block-arrow:hover .pc-slider-old-block-arrow__button {
57
60
  color: var(--g-color-text-primary);
58
61
  box-shadow: 0 2px 12px var(--pc-color-sfx-shadow), 0 4px 24px var(--pc-color-sfx-shadow);
59
62
  }
60
- .pc-slider-new-block-arrow__icon {
63
+ .pc-slider-old-block-arrow__icon {
61
64
  position: relative;
62
65
  }
@@ -0,0 +1,9 @@
1
+ import { ClassNameProps } from '../../../models';
2
+ export type ArrowType = 'left' | 'right';
3
+ export interface ArrowProps {
4
+ type: ArrowType;
5
+ handleClick?: (direction: ArrowType) => void;
6
+ size?: number;
7
+ }
8
+ declare const Arrow: ({ type, handleClick, className, size }: ArrowProps & ClassNameProps) => JSX.Element;
9
+ export default Arrow;
@@ -5,9 +5,9 @@ const react_1 = tslib_1.__importDefault(require("react"));
5
5
  const ToggleArrow_1 = tslib_1.__importDefault(require("../../../components/ToggleArrow/ToggleArrow"));
6
6
  const utils_1 = require("../../../utils");
7
7
  const i18n_1 = require("../i18n");
8
- const b = (0, utils_1.block)('slider-new-block-arrow');
9
- const Arrow = ({ type, onClick, className, size = 16, extraProps }) => (react_1.default.createElement("div", { className: b({ type }, className) },
10
- react_1.default.createElement("button", Object.assign({ className: b('button'), onClick: onClick, "aria-label": (0, i18n_1.i18n)(`arrow-${type}`) }, extraProps),
8
+ const b = (0, utils_1.block)('slider-old-block-arrow');
9
+ const Arrow = ({ type, handleClick, className, size = 16 }) => (react_1.default.createElement("div", { className: b({ type }, className) },
10
+ react_1.default.createElement("button", { className: b('button'), onClick: handleClick ? () => handleClick(type) : undefined, "aria-label": (0, i18n_1.i18n)(`arrow-${type}`) },
11
11
  react_1.default.createElement("span", { className: b('icon-wrapper') },
12
12
  react_1.default.createElement(ToggleArrow_1.default, { size: size, type: 'horizontal', iconType: "navigation", className: b('icon') })))));
13
13
  exports.default = Arrow;