@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.
- package/README.md +6 -0
- package/build/cjs/blocks/ExtendedFeatures/ExtendedFeatures.css +11 -6
- package/build/cjs/blocks/ExtendedFeatures/ExtendedFeatures.js +3 -6
- package/build/cjs/blocks/Header/Header.css +15 -10
- package/build/cjs/blocks/Header/Header.js +8 -4
- package/build/cjs/blocks/HeaderSlider/HeaderSlider.css +0 -10
- package/build/cjs/blocks/HeaderSlider/HeaderSlider.js +2 -2
- package/build/cjs/blocks/HeaderSlider/schema.d.ts +9 -1
- package/build/cjs/blocks/Questions/QuestionBlockItem/QuestionBlockItem.css +43 -21
- package/build/cjs/blocks/Questions/QuestionBlockItem/QuestionBlockItem.js +5 -3
- package/build/cjs/blocks/Slider/Arrow/Arrow.css +22 -21
- package/build/cjs/blocks/Slider/Arrow/Arrow.d.ts +5 -2
- package/build/cjs/blocks/Slider/Arrow/Arrow.js +5 -4
- package/build/cjs/blocks/Slider/Slider.css +549 -329
- package/build/cjs/blocks/Slider/Slider.d.ts +6 -6
- package/build/cjs/blocks/Slider/Slider.js +40 -282
- package/build/cjs/blocks/Slider/i18n/en.json +1 -1
- package/build/cjs/blocks/Slider/i18n/ru.json +1 -1
- package/build/cjs/blocks/Slider/models.d.ts +2 -2
- package/build/cjs/blocks/Slider/models.js +1 -1
- package/build/cjs/blocks/Slider/schema.d.ts +18 -1
- package/build/cjs/blocks/Slider/schema.js +9 -0
- package/build/cjs/blocks/{SliderNew → Slider}/useSlider.d.ts +1 -0
- package/build/cjs/blocks/{SliderNew → Slider}/useSlider.js +4 -0
- package/build/cjs/blocks/Slider/utils.d.ts +7 -27
- package/build/cjs/blocks/Slider/utils.js +26 -108
- package/build/cjs/blocks/{SliderNew → SliderOld}/Arrow/Arrow.css +15 -12
- package/build/cjs/blocks/SliderOld/Arrow/Arrow.d.ts +9 -0
- package/build/cjs/blocks/{SliderNew → SliderOld}/Arrow/Arrow.js +3 -3
- package/build/cjs/blocks/SliderOld/SliderOld.css +703 -0
- package/build/cjs/blocks/SliderOld/SliderOld.d.ts +17 -0
- package/build/cjs/blocks/SliderOld/SliderOld.js +301 -0
- package/build/cjs/blocks/{SliderNew → SliderOld}/i18n/en.json +1 -1
- package/build/cjs/blocks/{SliderNew → SliderOld}/i18n/index.js +1 -1
- package/build/cjs/blocks/{SliderNew → SliderOld}/i18n/ru.json +1 -1
- package/build/cjs/blocks/{SliderNew → SliderOld}/models.d.ts +2 -2
- package/build/cjs/blocks/{SliderNew → SliderOld}/models.js +1 -1
- package/build/cjs/blocks/{SliderNew → SliderOld}/schema.d.ts +5 -21
- package/build/cjs/blocks/{SliderNew → SliderOld}/schema.js +6 -14
- package/build/cjs/blocks/SliderOld/utils.d.ts +36 -0
- package/build/cjs/blocks/SliderOld/utils.js +125 -0
- package/build/cjs/blocks/index.d.ts +1 -0
- package/build/cjs/blocks/index.js +3 -1
- package/build/cjs/blocks/validators.d.ts +1 -0
- package/build/cjs/blocks/validators.js +1 -0
- package/build/cjs/components/ContentList/ContentList.css +5 -4
- package/build/cjs/components/ContentList/ContentList.js +1 -1
- package/build/cjs/components/FullscreenImage/FullscreenImage.css +96 -18
- package/build/cjs/components/FullscreenImage/FullscreenImage.d.ts +5 -0
- package/build/cjs/components/FullscreenImage/FullscreenImage.js +19 -5
- package/build/cjs/components/HTML/HTML.d.ts +16 -9
- package/build/cjs/components/HTML/HTML.js +16 -11
- package/build/cjs/components/Media/Image/Image.d.ts +1 -0
- package/build/cjs/components/Media/Image/Image.js +7 -5
- package/build/cjs/components/Media/Media.css +4 -0
- package/build/cjs/components/Media/Media.d.ts +1 -0
- package/build/cjs/components/Media/Media.js +3 -2
- package/build/cjs/components/MetaInfo/MetaInfo.css +1 -1
- package/build/cjs/components/MetaInfo/MetaInfo.js +1 -1
- package/build/cjs/components/Table/Table.css +2 -1
- package/build/cjs/components/Table/Table.js +4 -2
- package/build/cjs/components/Title/TitleItem.css +6 -4
- package/build/cjs/components/Title/TitleItem.js +3 -1
- package/build/cjs/components/YFMWrapper/YFMWrapper.d.ts +4 -2
- package/build/cjs/components/YFMWrapper/YFMWrapper.js +4 -1
- package/build/cjs/constructor-items.d.ts +2 -2
- package/build/cjs/constructor-items.js +2 -4
- package/build/cjs/editor/data/templates/{slider-new-block.json → slider-old-block.json} +2 -2
- package/build/cjs/models/common.d.ts +1 -0
- package/build/cjs/models/constructor-items/blocks.d.ts +17 -15
- package/build/cjs/models/constructor-items/blocks.js +3 -2
- package/build/cjs/schema/constants.d.ts +0 -1
- package/build/cjs/schema/constants.js +3 -1
- package/build/cjs/schema/validators/blocks.d.ts +2 -2
- package/build/cjs/schema/validators/blocks.js +2 -2
- package/build/cjs/sub-blocks/BannerCard/BannerCard.css +10 -8
- package/build/cjs/sub-blocks/BannerCard/BannerCard.js +4 -3
- package/build/cjs/sub-blocks/Content/Content.js +1 -1
- package/build/cjs/sub-blocks/PriceCard/PriceCard.css +2 -1
- package/build/cjs/sub-blocks/PriceCard/PriceCard.js +1 -1
- package/build/cjs/sub-blocks/Quote/Quote.css +8 -4
- package/build/cjs/sub-blocks/Quote/Quote.js +2 -4
- package/build/cjs/text-transform/config.js +1 -1
- package/build/cjs/utils/blocks.d.ts +10 -2
- package/build/cjs/utils/blocks.js +10 -4
- package/build/esm/blocks/ExtendedFeatures/ExtendedFeatures.css +11 -6
- package/build/esm/blocks/ExtendedFeatures/ExtendedFeatures.js +4 -7
- package/build/esm/blocks/Header/Header.css +15 -10
- package/build/esm/blocks/Header/Header.js +9 -5
- package/build/esm/blocks/HeaderSlider/HeaderSlider.css +0 -10
- package/build/esm/blocks/HeaderSlider/HeaderSlider.js +1 -1
- package/build/esm/blocks/HeaderSlider/schema.d.ts +9 -1
- package/build/esm/blocks/Questions/QuestionBlockItem/QuestionBlockItem.css +43 -21
- package/build/esm/blocks/Questions/QuestionBlockItem/QuestionBlockItem.js +6 -4
- package/build/esm/blocks/Slider/Arrow/Arrow.css +22 -21
- package/build/esm/blocks/Slider/Arrow/Arrow.d.ts +5 -2
- package/build/esm/blocks/Slider/Arrow/Arrow.js +5 -4
- package/build/esm/blocks/Slider/Slider.css +549 -329
- package/build/esm/blocks/Slider/Slider.d.ts +6 -6
- package/build/esm/blocks/Slider/Slider.js +42 -284
- package/build/esm/blocks/Slider/i18n/en.json +1 -1
- package/build/esm/blocks/Slider/i18n/ru.json +1 -1
- package/build/esm/blocks/Slider/models.d.ts +2 -2
- package/build/esm/blocks/Slider/models.js +1 -1
- package/build/esm/blocks/Slider/schema.d.ts +18 -1
- package/build/esm/blocks/Slider/schema.js +9 -0
- package/build/esm/blocks/{SliderNew → Slider}/useSlider.d.ts +1 -0
- package/build/esm/blocks/{SliderNew → Slider}/useSlider.js +5 -1
- package/build/esm/blocks/Slider/utils.d.ts +7 -27
- package/build/esm/blocks/Slider/utils.js +24 -103
- package/build/esm/blocks/{SliderNew → SliderOld}/Arrow/Arrow.css +15 -12
- package/build/esm/blocks/SliderOld/Arrow/Arrow.d.ts +10 -0
- package/build/esm/blocks/{SliderNew → SliderOld}/Arrow/Arrow.js +3 -3
- package/build/esm/blocks/SliderOld/SliderOld.css +703 -0
- package/build/esm/blocks/SliderOld/SliderOld.d.ts +18 -0
- package/build/esm/blocks/SliderOld/SliderOld.js +297 -0
- package/build/esm/blocks/{SliderNew → SliderOld}/i18n/en.json +1 -1
- package/build/esm/blocks/{SliderNew → SliderOld}/i18n/index.js +1 -1
- package/build/esm/blocks/{SliderNew → SliderOld}/i18n/ru.json +1 -1
- package/build/esm/blocks/{SliderNew → SliderOld}/models.d.ts +2 -2
- package/build/esm/blocks/{SliderNew → SliderOld}/models.js +1 -1
- package/build/esm/blocks/{SliderNew → SliderOld}/schema.d.ts +5 -21
- package/build/esm/blocks/{SliderNew → SliderOld}/schema.js +5 -13
- package/build/esm/blocks/SliderOld/utils.d.ts +36 -0
- package/build/esm/blocks/SliderOld/utils.js +115 -0
- package/build/esm/blocks/index.d.ts +1 -0
- package/build/esm/blocks/index.js +1 -0
- package/build/esm/blocks/validators.d.ts +1 -0
- package/build/esm/blocks/validators.js +1 -0
- package/build/esm/components/ContentList/ContentList.css +5 -4
- package/build/esm/components/ContentList/ContentList.js +1 -1
- package/build/esm/components/FullscreenImage/FullscreenImage.css +96 -18
- package/build/esm/components/FullscreenImage/FullscreenImage.d.ts +5 -0
- package/build/esm/components/FullscreenImage/FullscreenImage.js +20 -6
- package/build/esm/components/HTML/HTML.d.ts +16 -9
- package/build/esm/components/HTML/HTML.js +18 -12
- package/build/esm/components/Media/Image/Image.d.ts +1 -0
- package/build/esm/components/Media/Image/Image.js +7 -5
- package/build/esm/components/Media/Media.css +4 -0
- package/build/esm/components/Media/Media.d.ts +1 -0
- package/build/esm/components/Media/Media.js +3 -2
- package/build/esm/components/MetaInfo/MetaInfo.css +1 -1
- package/build/esm/components/MetaInfo/MetaInfo.js +1 -1
- package/build/esm/components/Table/Table.css +2 -1
- package/build/esm/components/Table/Table.js +5 -3
- package/build/esm/components/Title/TitleItem.css +6 -4
- package/build/esm/components/Title/TitleItem.js +4 -2
- package/build/esm/components/YFMWrapper/YFMWrapper.d.ts +4 -2
- package/build/esm/components/YFMWrapper/YFMWrapper.js +5 -1
- package/build/esm/constructor-items.d.ts +2 -2
- package/build/esm/constructor-items.js +3 -5
- package/build/esm/editor/data/templates/{slider-new-block.json → slider-old-block.json} +2 -2
- package/build/esm/models/common.d.ts +1 -0
- package/build/esm/models/constructor-items/blocks.d.ts +17 -15
- package/build/esm/models/constructor-items/blocks.js +3 -2
- package/build/esm/schema/constants.d.ts +0 -1
- package/build/esm/schema/constants.js +4 -2
- package/build/esm/schema/validators/blocks.d.ts +2 -2
- package/build/esm/schema/validators/blocks.js +2 -2
- package/build/esm/sub-blocks/BannerCard/BannerCard.css +10 -8
- package/build/esm/sub-blocks/BannerCard/BannerCard.js +5 -4
- package/build/esm/sub-blocks/Content/Content.js +1 -1
- package/build/esm/sub-blocks/PriceCard/PriceCard.css +2 -1
- package/build/esm/sub-blocks/PriceCard/PriceCard.js +2 -2
- package/build/esm/sub-blocks/Quote/Quote.css +8 -4
- package/build/esm/sub-blocks/Quote/Quote.js +3 -5
- package/build/esm/text-transform/config.js +1 -1
- package/build/esm/utils/blocks.d.ts +10 -2
- package/build/esm/utils/blocks.js +8 -2
- package/package.json +2 -2
- package/schema/index.js +1 -1
- package/server/models/common.d.ts +1 -0
- package/server/models/constructor-items/blocks.d.ts +17 -15
- package/server/models/constructor-items/blocks.js +3 -2
- package/server/text-transform/config.js +1 -1
- package/server/utils/blocks.d.ts +10 -2
- package/server/utils/blocks.js +10 -4
- package/styles/fonts.scss +1 -0
- package/styles/styles.css +0 -1
- package/styles/styles.scss +0 -1
- package/styles/variables.scss +1 -0
- package/widget/index.js +1 -1
- package/build/cjs/blocks/SliderNew/Arrow/Arrow.d.ts +0 -11
- package/build/cjs/blocks/SliderNew/Slider.css +0 -834
- package/build/cjs/blocks/SliderNew/Slider.d.ts +0 -13
- package/build/cjs/blocks/SliderNew/Slider.js +0 -56
- package/build/cjs/blocks/SliderNew/utils.d.ts +0 -16
- package/build/cjs/blocks/SliderNew/utils.js +0 -43
- package/build/cjs/blocks/unstable.d.ts +0 -1
- package/build/cjs/blocks/unstable.js +0 -8
- package/build/esm/blocks/SliderNew/Arrow/Arrow.d.ts +0 -12
- package/build/esm/blocks/SliderNew/Slider.css +0 -834
- package/build/esm/blocks/SliderNew/Slider.d.ts +0 -14
- package/build/esm/blocks/SliderNew/Slider.js +0 -52
- package/build/esm/blocks/SliderNew/utils.d.ts +0 -16
- package/build/esm/blocks/SliderNew/utils.js +0 -36
- package/build/esm/blocks/unstable.d.ts +0 -1
- package/build/esm/blocks/unstable.js +0 -1
- /package/build/cjs/blocks/{SliderNew → Slider}/useSliderPagination.d.ts +0 -0
- /package/build/cjs/blocks/{SliderNew → Slider}/useSliderPagination.js +0 -0
- /package/build/cjs/blocks/{SliderNew → SliderOld}/i18n/index.d.ts +0 -0
- /package/build/cjs/blocks/{Slider → SliderOld}/slick.css +0 -0
- /package/build/esm/blocks/{SliderNew → Slider}/useSliderPagination.d.ts +0 -0
- /package/build/esm/blocks/{SliderNew → Slider}/useSliderPagination.js +0 -0
- /package/build/esm/blocks/{SliderNew → SliderOld}/i18n/index.d.ts +0 -0
- /package/build/esm/blocks/{Slider → SliderOld}/slick.css +0 -0
|
@@ -1,115 +1,36 @@
|
|
|
1
|
-
import { useEffect,
|
|
1
|
+
import { useEffect, useState } from 'react';
|
|
2
|
+
import isEqual from 'lodash/isEqual';
|
|
2
3
|
import pickBy from 'lodash/pickBy';
|
|
3
4
|
import { BREAKPOINTS } from '../../constants';
|
|
4
5
|
import { SliderBreakpointNames } from './models';
|
|
5
6
|
export const DEFAULT_SLIDE_BREAKPOINTS = {
|
|
6
|
-
[SliderBreakpointNames.
|
|
7
|
-
[SliderBreakpointNames.Lg]: 2,
|
|
7
|
+
[SliderBreakpointNames.Lg]: 3,
|
|
8
8
|
[SliderBreakpointNames.Md]: 2,
|
|
9
|
-
[SliderBreakpointNames.Sm]:
|
|
9
|
+
[SliderBreakpointNames.Sm]: 2,
|
|
10
|
+
[SliderBreakpointNames.Xs]: 1.15,
|
|
10
11
|
};
|
|
11
|
-
|
|
12
|
-
export const isFocusable = (element) => {
|
|
13
|
-
if (!(element instanceof HTMLElement)) {
|
|
14
|
-
return false;
|
|
15
|
-
}
|
|
16
|
-
const tabIndexAttr = element.getAttribute('tabindex');
|
|
17
|
-
const hasTabIndex = tabIndexAttr !== null;
|
|
18
|
-
const tabIndex = Number(tabIndexAttr);
|
|
19
|
-
if (element.ariaHidden === 'true' || (hasTabIndex && tabIndex < 0)) {
|
|
20
|
-
return false;
|
|
21
|
-
}
|
|
22
|
-
if (hasTabIndex && tabIndex >= 0) {
|
|
23
|
-
return true;
|
|
24
|
-
}
|
|
25
|
-
// without this jest fails here for some reason
|
|
26
|
-
let htmlElement;
|
|
27
|
-
switch (true) {
|
|
28
|
-
case element instanceof HTMLAnchorElement:
|
|
29
|
-
htmlElement = element;
|
|
30
|
-
return Boolean(htmlElement.href);
|
|
31
|
-
case element instanceof HTMLInputElement:
|
|
32
|
-
htmlElement = element;
|
|
33
|
-
return htmlElement.type !== 'hidden' && !htmlElement.disabled;
|
|
34
|
-
case element instanceof HTMLSelectElement:
|
|
35
|
-
case element instanceof HTMLTextAreaElement:
|
|
36
|
-
case element instanceof HTMLButtonElement:
|
|
37
|
-
htmlElement = element;
|
|
38
|
-
return !htmlElement.disabled;
|
|
39
|
-
default:
|
|
40
|
-
return false;
|
|
41
|
-
}
|
|
42
|
-
};
|
|
43
|
-
export function getSlidesToShowWithDefaults({ contentLength, breakpoints, mobileFullscreen, }) {
|
|
12
|
+
export function getSliderResponsiveParams({ contentLength, slidesToShow, mobileFullscreen, }) {
|
|
44
13
|
let result;
|
|
45
|
-
if (typeof
|
|
46
|
-
result = Object.keys(DEFAULT_SLIDE_BREAKPOINTS).reduce((acc, breakpointName) => (Object.assign(Object.assign({}, acc), { [breakpointName]:
|
|
14
|
+
if (typeof slidesToShow === 'number') {
|
|
15
|
+
result = Object.keys(DEFAULT_SLIDE_BREAKPOINTS).reduce((acc, breakpointName) => (Object.assign(Object.assign({}, acc), { [breakpointName]: slidesToShow })), {});
|
|
47
16
|
}
|
|
48
17
|
else {
|
|
49
|
-
result =
|
|
18
|
+
result = slidesToShow || DEFAULT_SLIDE_BREAKPOINTS;
|
|
50
19
|
}
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
settings: { slidesToShow },
|
|
57
|
-
}));
|
|
58
|
-
}
|
|
59
|
-
export function getSlidesCountByBreakpoint(breakpoint, breakpoints) {
|
|
60
|
-
const breakpointName = BREAKPOINT_NAMES_BY_VALUES[breakpoint];
|
|
61
|
-
return Math.floor(breakpoints[breakpointName]);
|
|
62
|
-
}
|
|
63
|
-
export function getSlidesToShowCount(breakpoints) {
|
|
64
|
-
return Math.floor(Math.max(...Object.values(breakpoints)));
|
|
65
|
-
}
|
|
66
|
-
const getRovingListItemId = (uniqId, index) => `${uniqId}-roving-tabindex-item-${index}`;
|
|
67
|
-
export function useRovingTabIndex(props) {
|
|
68
|
-
const { itemCount, activeIndex, firstIndex = 0, uniqId } = props;
|
|
69
|
-
const [currentIndex, setCurrentIndex] = useState(firstIndex);
|
|
70
|
-
const hasFocusRef = useRef(false);
|
|
71
|
-
const lastIndex = itemCount + firstIndex - 1;
|
|
72
|
-
const getRovingItemProps = (index) => {
|
|
73
|
-
return {
|
|
74
|
-
id: getRovingListItemId(uniqId, index),
|
|
75
|
-
tabIndex: index === activeIndex ? 0 : -1,
|
|
76
|
-
onFocus: () => {
|
|
77
|
-
setCurrentIndex(index);
|
|
78
|
-
hasFocusRef.current = true;
|
|
79
|
-
},
|
|
20
|
+
const showCount = Object.assign(Object.assign(Object.assign({}, DEFAULT_SLIDE_BREAKPOINTS), pickBy(result, (value) => !isNaN(value))), { xs: !mobileFullscreen && contentLength > 1 ? DEFAULT_SLIDE_BREAKPOINTS.xs : 1 });
|
|
21
|
+
return Object.entries(showCount).reduce((res, [breakpointName, value]) => {
|
|
22
|
+
// eslint-disable-next-line no-param-reassign
|
|
23
|
+
res[BREAKPOINTS[breakpointName] + 1] = {
|
|
24
|
+
slidesPerView: value,
|
|
80
25
|
};
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
var _a;
|
|
84
|
-
if (!hasFocusRef.current) {
|
|
85
|
-
return;
|
|
86
|
-
}
|
|
87
|
-
(_a = document.getElementById(getRovingListItemId(uniqId, currentIndex))) === null || _a === void 0 ? void 0 : _a.focus();
|
|
88
|
-
}, [activeIndex, currentIndex, uniqId]);
|
|
89
|
-
const setNextIndex = () => setCurrentIndex((prev) => (prev >= lastIndex ? firstIndex : prev + 1));
|
|
90
|
-
const setPrevIndex = () => setCurrentIndex((prev) => (prev <= firstIndex ? lastIndex : prev - 1));
|
|
91
|
-
const onRovingListKeyDown = (e) => {
|
|
92
|
-
const key = e.key.toLowerCase();
|
|
93
|
-
if (key !== 'tab' && key !== 'enter') {
|
|
94
|
-
e.preventDefault();
|
|
95
|
-
}
|
|
96
|
-
switch (key) {
|
|
97
|
-
case 'arrowleft':
|
|
98
|
-
case 'arrowup':
|
|
99
|
-
setPrevIndex();
|
|
100
|
-
return;
|
|
101
|
-
case 'arrowright':
|
|
102
|
-
case 'arrowdown':
|
|
103
|
-
setNextIndex();
|
|
104
|
-
return;
|
|
105
|
-
}
|
|
106
|
-
};
|
|
107
|
-
const onRovingListBlur = () => {
|
|
108
|
-
hasFocusRef.current = false;
|
|
109
|
-
};
|
|
110
|
-
const rovingListProps = {
|
|
111
|
-
onKeyDown: onRovingListKeyDown,
|
|
112
|
-
onBlur: onRovingListBlur,
|
|
113
|
-
};
|
|
114
|
-
return { getRovingItemProps, rovingListProps };
|
|
26
|
+
return res;
|
|
27
|
+
}, {});
|
|
115
28
|
}
|
|
29
|
+
export const useMemoized = (value) => {
|
|
30
|
+
const [memoizedValue, setMemoizedValue] = useState(value);
|
|
31
|
+
useEffect(() => {
|
|
32
|
+
setMemoizedValue((memoized) => value && typeof value === 'object' && isEqual(memoized, value) ? memoized : value);
|
|
33
|
+
}, [value]);
|
|
34
|
+
return memoizedValue;
|
|
35
|
+
};
|
|
36
|
+
export const setElementAtrributes = (element, attributes) => Object.entries(attributes).forEach(([attribute, value]) => element.setAttribute(attribute, String(value)));
|
|
@@ -1,34 +1,37 @@
|
|
|
1
|
-
.pc-slider-
|
|
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-
|
|
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-
|
|
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-
|
|
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-
|
|
24
|
+
.pc-slider-old-block-arrow {
|
|
25
25
|
display: none;
|
|
26
26
|
}
|
|
27
27
|
}
|
|
28
|
-
.pc-slider-
|
|
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-
|
|
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
|
|
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-
|
|
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-
|
|
56
|
+
.pc-slider-old-block-arrow__button:focus:not(:focus-visible) {
|
|
54
57
|
outline: 0;
|
|
55
58
|
}
|
|
56
|
-
.pc-slider-
|
|
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-
|
|
63
|
+
.pc-slider-old-block-arrow__icon {
|
|
61
64
|
position: relative;
|
|
62
65
|
}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { ClassNameProps } from '../../../models';
|
|
2
|
+
import './Arrow.css';
|
|
3
|
+
export type ArrowType = 'left' | 'right';
|
|
4
|
+
export interface ArrowProps {
|
|
5
|
+
type: ArrowType;
|
|
6
|
+
handleClick?: (direction: ArrowType) => void;
|
|
7
|
+
size?: number;
|
|
8
|
+
}
|
|
9
|
+
declare const Arrow: ({ type, handleClick, className, size }: ArrowProps & ClassNameProps) => JSX.Element;
|
|
10
|
+
export default Arrow;
|
|
@@ -3,9 +3,9 @@ import ToggleArrow from '../../../components/ToggleArrow/ToggleArrow';
|
|
|
3
3
|
import { block } from '../../../utils';
|
|
4
4
|
import { i18n } from '../i18n';
|
|
5
5
|
import './Arrow.css';
|
|
6
|
-
const b = block('slider-
|
|
7
|
-
const Arrow = ({ type,
|
|
8
|
-
React.createElement("button",
|
|
6
|
+
const b = block('slider-old-block-arrow');
|
|
7
|
+
const Arrow = ({ type, handleClick, className, size = 16 }) => (React.createElement("div", { className: b({ type }, className) },
|
|
8
|
+
React.createElement("button", { className: b('button'), onClick: handleClick ? () => handleClick(type) : undefined, "aria-label": i18n(`arrow-${type}`) },
|
|
9
9
|
React.createElement("span", { className: b('icon-wrapper') },
|
|
10
10
|
React.createElement(ToggleArrow, { size: size, type: 'horizontal', iconType: "navigation", className: b('icon') })))));
|
|
11
11
|
export default Arrow;
|