@megafon/ui-core 8.2.0 → 8.3.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 (62) hide show
  1. package/dist/es/components/Pagination/Pagination.css +1 -1
  2. package/dist/es/components/Pagination/Pagination.d.ts +18 -9
  3. package/dist/es/components/Pagination/Pagination.js +91 -19
  4. package/dist/es/components/Pagination/components/PaginationButton/PaginationButton.css +1 -1
  5. package/dist/es/components/Pagination/components/PaginationButton/PaginationButton.d.ts +9 -4
  6. package/dist/es/components/Pagination/components/PaginationButton/PaginationButton.js +13 -3
  7. package/dist/es/components/Pagination/components/PaginationButtons/PaginationButtons.css +1 -1
  8. package/dist/es/components/Pagination/components/PaginationButtons/PaginationButtons.d.ts +12 -6
  9. package/dist/es/components/Pagination/components/PaginationButtons/PaginationButtons.js +42 -25
  10. package/dist/es/components/Pagination/components/PaginationNavigation/PaginationNavigation.css +1 -1
  11. package/dist/es/components/Pagination/components/PaginationNavigation/PaginationNavigation.d.ts +13 -4
  12. package/dist/es/components/Pagination/components/PaginationNavigation/PaginationNavigation.js +105 -11
  13. package/dist/es/components/Pagination/helpers.d.ts +8 -2
  14. package/dist/es/components/Pagination/helpers.js +28 -2
  15. package/dist/es/components/Pagination/types.d.ts +25 -0
  16. package/dist/es/components/Pagination/types.js +4 -0
  17. package/dist/es/components/Pagination/usePagination.d.ts +10 -5
  18. package/dist/es/components/Pagination/usePagination.js +86 -54
  19. package/dist/es/components/Tooltip/Tooltip.css +1 -1
  20. package/dist/es/components/Tooltip/Tooltip.js +21 -2
  21. package/dist/es/components/UploadForm/UploadField/UploadField.d.ts +2 -0
  22. package/dist/es/components/UploadForm/UploadField/UploadField.js +2 -0
  23. package/dist/es/components/UploadForm/UploadField/components/_UploadFieldDropArea/UploadFieldDropArea.css +1 -1
  24. package/dist/es/components/UploadForm/UploadFileItem/UploadFileItem.css +1 -1
  25. package/dist/es/components/UploadForm/UploadFileItem/UploadFileItem.d.ts +11 -0
  26. package/dist/es/components/UploadForm/UploadFileItem/UploadFileItem.js +29 -5
  27. package/dist/es/components/ValueField/ValueField.d.ts +3 -0
  28. package/dist/es/components/ValueField/ValueField.js +5 -3
  29. package/dist/es/hooks/useResolution.d.ts +1 -0
  30. package/dist/es/hooks/useResolution.js +24 -7
  31. package/dist/lib/components/Pagination/Pagination.css +1 -1
  32. package/dist/lib/components/Pagination/Pagination.d.ts +18 -9
  33. package/dist/lib/components/Pagination/Pagination.js +90 -18
  34. package/dist/lib/components/Pagination/components/PaginationButton/PaginationButton.css +1 -1
  35. package/dist/lib/components/Pagination/components/PaginationButton/PaginationButton.d.ts +9 -4
  36. package/dist/lib/components/Pagination/components/PaginationButton/PaginationButton.js +13 -3
  37. package/dist/lib/components/Pagination/components/PaginationButtons/PaginationButtons.css +1 -1
  38. package/dist/lib/components/Pagination/components/PaginationButtons/PaginationButtons.d.ts +12 -6
  39. package/dist/lib/components/Pagination/components/PaginationButtons/PaginationButtons.js +45 -25
  40. package/dist/lib/components/Pagination/components/PaginationNavigation/PaginationNavigation.css +1 -1
  41. package/dist/lib/components/Pagination/components/PaginationNavigation/PaginationNavigation.d.ts +13 -4
  42. package/dist/lib/components/Pagination/components/PaginationNavigation/PaginationNavigation.js +105 -11
  43. package/dist/lib/components/Pagination/helpers.d.ts +8 -2
  44. package/dist/lib/components/Pagination/helpers.js +29 -3
  45. package/dist/lib/components/Pagination/types.d.ts +25 -0
  46. package/dist/lib/components/Pagination/types.js +10 -0
  47. package/dist/lib/components/Pagination/usePagination.d.ts +10 -5
  48. package/dist/lib/components/Pagination/usePagination.js +87 -55
  49. package/dist/lib/components/Tooltip/Tooltip.css +1 -1
  50. package/dist/lib/components/Tooltip/Tooltip.js +21 -2
  51. package/dist/lib/components/UploadForm/UploadField/UploadField.d.ts +2 -0
  52. package/dist/lib/components/UploadForm/UploadField/UploadField.js +2 -0
  53. package/dist/lib/components/UploadForm/UploadField/components/_UploadFieldDropArea/UploadFieldDropArea.css +1 -1
  54. package/dist/lib/components/UploadForm/UploadFileItem/UploadFileItem.css +1 -1
  55. package/dist/lib/components/UploadForm/UploadFileItem/UploadFileItem.d.ts +11 -0
  56. package/dist/lib/components/UploadForm/UploadFileItem/UploadFileItem.js +29 -5
  57. package/dist/lib/components/ValueField/ValueField.d.ts +3 -0
  58. package/dist/lib/components/ValueField/ValueField.js +5 -3
  59. package/dist/lib/hooks/useResolution.d.ts +1 -0
  60. package/dist/lib/hooks/useResolution.js +24 -7
  61. package/package.json +3 -3
  62. package/styles/colors.css +5 -6
@@ -1,8 +1,13 @@
1
- export declare const Button: {
2
- HIDDEN: string;
1
+ import { PaginationTypesType, ValueType } from './types';
2
+ export declare const BUTTONS: {
3
+ SKIP_PREV: string;
4
+ SKIP_NEXT: string;
3
5
  FIRST: number;
4
6
  };
5
- export declare const MOBILE_RESOLUTION = 360;
6
- type PaginationItem = string | number;
7
- declare const usePagination: (totalPages: number, activePage: number) => PaginationItem[];
7
+ type usePaginationReturnType = {
8
+ paginationItems: ValueType[];
9
+ skipPrevPage: number;
10
+ skipNextPage: number;
11
+ };
12
+ declare const usePagination: (type: PaginationTypesType, totalPages: number, activePage: number) => usePaginationReturnType;
8
13
  export default usePagination;
@@ -1,75 +1,107 @@
1
1
  import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
2
2
  import _toConsumableArray from "@babel/runtime/helpers/toConsumableArray";
3
+ import _defineProperty from "@babel/runtime/helpers/defineProperty";
3
4
  import "core-js/modules/es.array.concat.js";
4
5
  import React from 'react';
5
- import throttle from 'lodash.throttle';
6
- import throttleTime from "../../constants/throttleTime";
7
- import getRange from "./helpers";
8
- export var Button = {
9
- HIDDEN: 'HIDDEN',
6
+ import useResolution from "../../hooks/useResolution";
7
+ import { getRange } from "./helpers";
8
+ import { PaginationTypes } from "./types";
9
+ export var BUTTONS = {
10
+ SKIP_PREV: 'SKIP_PREV',
11
+ SKIP_NEXT: 'SKIP_NEXT',
10
12
  FIRST: 1
11
13
  };
12
- var NeighbourCount = {
13
- MOBILE: 0,
14
- MAIN: 1
15
- };
16
- var BUTTON_RATIO = 5;
17
- export var MOBILE_RESOLUTION = 360;
14
+ var PAGINATION_SETTINGS = _defineProperty(_defineProperty({}, PaginationTypes.CLASSIC, {
15
+ neighbourCount: {
16
+ main: 1,
17
+ mobile: 1,
18
+ mobileXS: 0
19
+ },
20
+ visibleNumbers: {
21
+ main: 7,
22
+ mobile: 7,
23
+ mobileXS: 5
24
+ },
25
+ skipStep: 0
26
+ }), PaginationTypes.MODERN, {
27
+ neighbourCount: {
28
+ main: 3,
29
+ mobile: 2,
30
+ mobileXS: 1
31
+ },
32
+ visibleNumbers: {
33
+ main: 6,
34
+ mobile: 5,
35
+ mobileXS: 4
36
+ },
37
+ skipStep: 4
38
+ });
18
39
  var getItems = function getItems(_ref) {
19
- var totalPages = _ref.totalPages,
40
+ var type = _ref.type,
41
+ totalPages = _ref.totalPages,
20
42
  activePage = _ref.activePage,
21
- maxButtonsCount = _ref.maxButtonsCount,
43
+ buttonsCount = _ref.buttonsCount,
22
44
  neighbourCount = _ref.neighbourCount;
23
- var isMoreThenMaxBtnsCount = totalPages > maxButtonsCount;
45
+ var isClassicType = type === PaginationTypes.CLASSIC;
46
+ var isMoreThenButtonsCount = totalPages > buttonsCount;
24
47
  var lastPage = totalPages;
25
- if (!isMoreThenMaxBtnsCount) {
26
- return getRange(Button.FIRST, lastPage);
48
+ if (!isMoreThenButtonsCount) {
49
+ return getRange(BUTTONS.FIRST, lastPage);
50
+ }
51
+ var hasLeftHiddenButtons = activePage > Math.ceil(buttonsCount / 2);
52
+ var hasRightHiddenButtons = isClassicType ? lastPage > activePage + neighbourCount + 2 : lastPage > activePage + neighbourCount;
53
+ if (!hasLeftHiddenButtons && hasRightHiddenButtons) {
54
+ var _range = getRange(BUTTONS.FIRST, buttonsCount - 2);
55
+ return [].concat(_toConsumableArray(_range), [BUTTONS.SKIP_NEXT, lastPage]);
27
56
  }
28
- var hasLeftHiddenBtns = activePage > Math.ceil(maxButtonsCount / 2);
29
- var hasRightHiddenBtns = lastPage > activePage + neighbourCount + 2;
30
- switch (true) {
31
- case !hasLeftHiddenBtns && hasRightHiddenBtns:
32
- {
33
- var range = getRange(Button.FIRST, maxButtonsCount - 2);
34
- return [].concat(_toConsumableArray(range), [Button.HIDDEN, lastPage]);
35
- }
36
- case hasLeftHiddenBtns && !hasRightHiddenBtns:
37
- {
38
- var _range = getRange(totalPages - (2 + 2 * neighbourCount), totalPages);
39
- return [Button.FIRST, Button.HIDDEN].concat(_toConsumableArray(_range));
40
- }
41
- default:
42
- {
43
- var _range2 = getRange(activePage - neighbourCount, activePage + neighbourCount);
44
- return [Button.FIRST, Button.HIDDEN].concat(_toConsumableArray(_range2), [Button.HIDDEN, lastPage]);
45
- }
57
+ if (hasLeftHiddenButtons && !hasRightHiddenButtons) {
58
+ var _range2 = isClassicType ? getRange(totalPages - (2 + 2 * neighbourCount), totalPages) : getRange(totalPages - neighbourCount, totalPages);
59
+ return [BUTTONS.FIRST, BUTTONS.SKIP_PREV].concat(_toConsumableArray(_range2));
46
60
  }
61
+ var range = isClassicType ? getRange(activePage - neighbourCount, activePage + neighbourCount) : getRange(activePage, activePage + neighbourCount);
62
+ return [BUTTONS.FIRST, BUTTONS.SKIP_PREV].concat(_toConsumableArray(range), [BUTTONS.SKIP_NEXT, lastPage]);
47
63
  };
48
- var usePagination = function usePagination(totalPages, activePage) {
49
- var _React$useState = React.useState(NeighbourCount.MAIN),
64
+ var usePagination = function usePagination(type, totalPages, activePage) {
65
+ var _PAGINATION_SETTINGS$ = PAGINATION_SETTINGS[type],
66
+ neighbourCount = _PAGINATION_SETTINGS$.neighbourCount,
67
+ visibleNumbers = _PAGINATION_SETTINGS$.visibleNumbers,
68
+ skipStep = _PAGINATION_SETTINGS$.skipStep;
69
+ var _useResolution = useResolution(),
70
+ isMobileExtraSmall = _useResolution.isMobileExtraSmall,
71
+ isMobile = _useResolution.isMobile;
72
+ var _React$useState = React.useState({
73
+ neighbourCount: neighbourCount.main,
74
+ buttonsCount: visibleNumbers.main
75
+ }),
50
76
  _React$useState2 = _slicedToArray(_React$useState, 2),
51
- neighbourCount = _React$useState2[0],
52
- setNeighbourCount = _React$useState2[1];
53
- var maxButtonsCount = 2 * neighbourCount + BUTTON_RATIO;
77
+ config = _React$useState2[0],
78
+ setConfig = _React$useState2[1];
54
79
  var paginationItems = getItems({
80
+ type: type,
55
81
  totalPages: totalPages,
56
82
  activePage: activePage,
57
- maxButtonsCount: maxButtonsCount,
58
- neighbourCount: neighbourCount
83
+ neighbourCount: config.neighbourCount,
84
+ buttonsCount: config.buttonsCount
59
85
  });
86
+ var skipPrevPage = Math.max(1, activePage - skipStep);
87
+ var skipNextPage = Math.min(totalPages, activePage + skipStep);
60
88
  React.useEffect(function () {
61
- var handleResize = function handleResize() {
62
- var isMobile = window.innerWidth <= MOBILE_RESOLUTION;
63
- var value = isMobile ? NeighbourCount.MOBILE : NeighbourCount.MAIN;
64
- setNeighbourCount(value);
65
- };
66
- handleResize();
67
- var handleResizeThrottled = throttle(handleResize, throttleTime.resize);
68
- window.addEventListener('resize', handleResizeThrottled);
69
- return function () {
70
- window.removeEventListener('resize', handleResizeThrottled);
71
- };
72
- }, []);
73
- return paginationItems;
89
+ if (isMobileExtraSmall) {
90
+ setConfig({
91
+ neighbourCount: neighbourCount.mobileXS,
92
+ buttonsCount: visibleNumbers.mobileXS
93
+ });
94
+ return;
95
+ }
96
+ setConfig({
97
+ neighbourCount: isMobile ? neighbourCount.mobile : neighbourCount.main,
98
+ buttonsCount: isMobile ? visibleNumbers.mobile : visibleNumbers.main
99
+ });
100
+ }, [isMobile, isMobileExtraSmall, visibleNumbers, neighbourCount]);
101
+ return {
102
+ paginationItems: paginationItems,
103
+ skipPrevPage: skipPrevPage,
104
+ skipNextPage: skipNextPage
105
+ };
74
106
  };
75
107
  export default usePagination;
@@ -1 +1 @@
1
- h1,h2,h3,h4,h5{margin:0}.mfui-tooltip{opacity:0;pointer-events:none;-webkit-transition-duration:.3s;transition-duration:.3s;-webkit-transition-property:opacity,visibility;transition-property:opacity,visibility;visibility:hidden;z-index:100}.mfui-tooltip_open{opacity:1;pointer-events:all;visibility:visible}.mfui-tooltip_paddings_small .mfui-tooltip__content{padding:16px}.mfui-tooltip_paddings_medium .mfui-tooltip__content{padding:24px}.mfui-tooltip__content{overflow:hidden;position:relative;z-index:1}.mfui-tooltip__content-shadow{bottom:0;left:0;position:absolute;right:0;top:0;z-index:-1}.mfui-tooltip__arrow-container{position:absolute}.mfui-tooltip__arrow,.mfui-tooltip__arrow-wrap{height:13px;width:33px}.mfui-tooltip__arrow{display:-webkit-box;display:-ms-flexbox;display:flex;position:absolute;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center}.mfui-tooltip__arrow svg{position:absolute}.mfui-tooltip__arrow-inner{-webkit-filter:drop-shadow(0 2px 9px rgba(0,0,0,.15));filter:drop-shadow(0 2px 9px rgba(0,0,0,.15));fill:var(--base)}.mfui-tooltip__text{font-size:15px;line-height:24px}@media screen and (max-width:767px){.mfui-tooltip__text{font-size:12px;line-height:18px}}.mfui-tooltip__text_margin{margin-top:8px}.mfui-tooltip__button,.mfui-tooltip__close-button{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;border:none;-webkit-box-sizing:border-box;box-sizing:border-box;cursor:pointer;padding:0}.mfui-tooltip__button{background-color:transparent;color:var(--brandGreen);font-family:inherit;font-size:15px;font-weight:500;line-height:18px;-webkit-transition:.3s;transition:.3s}@media screen and (max-width:767px){.mfui-tooltip__button{font-size:12px;line-height:14px}}.mfui-tooltip__button_margin{margin-top:8px}.mfui-tooltip__button:hover{color:var(--buttonHoverGreen)}.mfui-tooltip__button:hover .mfui-tooltip__button-arrow{fill:var(--buttonHoverGreen)}.mfui-tooltip__button:active{color:var(--buttonDown)}.mfui-tooltip__button:active .mfui-tooltip__button-arrow{fill:var(--buttonDown)}.mfui-tooltip__close-button{position:relative;right:-6px;top:-6px;-webkit-box-pack:center;-ms-flex-pack:center;background-color:var(--spbSky0);border-radius:12px;float:right;height:24px;justify-content:center;-webkit-transition:.3s;transition:.3s;width:24px}.mfui-tooltip__close-button:hover{background-color:var(--spbSky1)}.mfui-tooltip__close-button:active{background-color:var(--spbSky2)}.mfui-tooltip__close-icon{display:block;height:20px;opacity:.5;width:20px;fill:var(--content)}.mfui-tooltip__button-arrow{height:20px;margin-bottom:-2px;min-width:20px;-webkit-transition:.3s;transition:.3s;width:20px;fill:var(--brandGreen)}.mfui-tooltip__addititonal-content_margin{margin-top:16px}@media screen and (max-width:767px){.mfui-tooltip__addititonal-content_margin{margin-top:12px}}.mfui-tooltip_small .mfui-tooltip__content{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:horizontal;-webkit-box-direction:reverse;-ms-flex-direction:row-reverse;flex-direction:row-reverse;gap:18px;-webkit-box-align:center;-ms-flex-align:center;align-items:center}.mfui-tooltip_small .mfui-tooltip__text{font-weight:500}.mfui-tooltip_small .mfui-tooltip__close-button{top:auto}.mfui-tooltip_theme_white .mfui-tooltip__content{border:1px solid var(--stcWhite10)}.mfui-tooltip_theme_blue .mfui-tooltip__arrow:before,.mfui-tooltip_theme_blue .mfui-tooltip__button,.mfui-tooltip_theme_blue .mfui-tooltip__content,.mfui-tooltip_theme_blue .mfui-tooltip__title,.mfui-tooltip_theme_red .mfui-tooltip__arrow:before,.mfui-tooltip_theme_red .mfui-tooltip__button,.mfui-tooltip_theme_red .mfui-tooltip__content,.mfui-tooltip_theme_red .mfui-tooltip__title{color:var(--stcWhite)}.mfui-tooltip_theme_blue .mfui-tooltip__button-arrow,.mfui-tooltip_theme_red .mfui-tooltip__button-arrow{fill:var(--stcWhite)}.mfui-tooltip_theme_blue .mfui-tooltip__button:hover,.mfui-tooltip_theme_red .mfui-tooltip__button:hover{color:var(--buttonHoverGrey)}.mfui-tooltip_theme_blue .mfui-tooltip__button:hover .mfui-tooltip__button-arrow,.mfui-tooltip_theme_red .mfui-tooltip__button:hover .mfui-tooltip__button-arrow{fill:var(--buttonHoverGrey)}.mfui-tooltip_theme_blue .mfui-tooltip__button:active,.mfui-tooltip_theme_red .mfui-tooltip__button:active{color:var(--buttonDown)}.mfui-tooltip_theme_blue .mfui-tooltip__button:active .mfui-tooltip__button-arrow,.mfui-tooltip_theme_red .mfui-tooltip__button:active .mfui-tooltip__button-arrow{fill:var(--buttonDown)}.mfui-tooltip_theme_blue .mfui-tooltip__close-button,.mfui-tooltip_theme_red .mfui-tooltip__close-button{background-color:var(--stcWhite10)}.mfui-tooltip_theme_blue .mfui-tooltip__close-button:hover,.mfui-tooltip_theme_red .mfui-tooltip__close-button:hover{background-color:var(--stcWhite20)}.mfui-tooltip_theme_blue .mfui-tooltip__close-button:active,.mfui-tooltip_theme_red .mfui-tooltip__close-button:active{background-color:var(--stcWhite50)}.mfui-tooltip_theme_blue .mfui-tooltip__close-icon,.mfui-tooltip_theme_red .mfui-tooltip__close-icon{opacity:1;fill:var(--stcWhite)}.mfui-tooltip_theme_red .mfui-tooltip__arrow:before,.mfui-tooltip_theme_red .mfui-tooltip__content,.mfui-tooltip_theme_red .mfui-tooltip__content-shadow{background-color:var(--fury80)}.mfui-tooltip_theme_red .mfui-tooltip__arrow-inner{fill:var(--fury80)}.mfui-tooltip_theme_blue .mfui-tooltip__arrow:before,.mfui-tooltip_theme_blue .mfui-tooltip__content,.mfui-tooltip_theme_blue .mfui-tooltip__content-shadow{background-color:var(--night)}.mfui-tooltip_theme_blue .mfui-tooltip__arrow-inner{fill:var(--night)}.mfui-tooltip[data-popper-placement=right-end] .mfui-tooltip__content,.mfui-tooltip[data-popper-placement=right-end] .mfui-tooltip__content-shadow,.mfui-tooltip[data-popper-placement=right-start] .mfui-tooltip__content,.mfui-tooltip[data-popper-placement=right-start] .mfui-tooltip__content-shadow,.mfui-tooltip[data-popper-placement=right] .mfui-tooltip__content,.mfui-tooltip[data-popper-placement=right] .mfui-tooltip__content-shadow{-webkit-transform:translateX(24px);transform:translateX(24px)}.mfui-tooltip[data-popper-placement=right-end] .mfui-tooltip__arrow-wrap,.mfui-tooltip[data-popper-placement=right-start] .mfui-tooltip__arrow-wrap,.mfui-tooltip[data-popper-placement=right] .mfui-tooltip__arrow-wrap{left:3px}.mfui-tooltip[data-popper-placement=right-end] .mfui-tooltip__arrow,.mfui-tooltip[data-popper-placement=right-end] .mfui-tooltip__arrow-shadow,.mfui-tooltip[data-popper-placement=right-start] .mfui-tooltip__arrow,.mfui-tooltip[data-popper-placement=right-start] .mfui-tooltip__arrow-shadow,.mfui-tooltip[data-popper-placement=right] .mfui-tooltip__arrow,.mfui-tooltip[data-popper-placement=right] .mfui-tooltip__arrow-shadow{-webkit-transform:rotate(-90deg);transform:rotate(-90deg)}.mfui-tooltip_offset_small[data-popper-placement=right-end] .mfui-tooltip__content,.mfui-tooltip_offset_small[data-popper-placement=right-end] .mfui-tooltip__content-shadow,.mfui-tooltip_offset_small[data-popper-placement=right-start] .mfui-tooltip__content,.mfui-tooltip_offset_small[data-popper-placement=right-start] .mfui-tooltip__content-shadow,.mfui-tooltip_offset_small[data-popper-placement=right] .mfui-tooltip__content,.mfui-tooltip_offset_small[data-popper-placement=right] .mfui-tooltip__content-shadow{-webkit-transform:translateX(15px);transform:translateX(15px)}.mfui-tooltip_offset_small[data-popper-placement=right-end] .mfui-tooltip__arrow-wrap,.mfui-tooltip_offset_small[data-popper-placement=right-start] .mfui-tooltip__arrow-wrap,.mfui-tooltip_offset_small[data-popper-placement=right] .mfui-tooltip__arrow-wrap{left:-6px}.mfui-tooltip[data-popper-placement=left-end] .mfui-tooltip__content,.mfui-tooltip[data-popper-placement=left-end] .mfui-tooltip__content-shadow,.mfui-tooltip[data-popper-placement=left-start] .mfui-tooltip__content,.mfui-tooltip[data-popper-placement=left-start] .mfui-tooltip__content-shadow,.mfui-tooltip[data-popper-placement=left] .mfui-tooltip__content,.mfui-tooltip[data-popper-placement=left] .mfui-tooltip__content-shadow{-webkit-transform:translateX(-24px);transform:translateX(-24px)}.mfui-tooltip[data-popper-placement=left-end] .mfui-tooltip__arrow-wrap,.mfui-tooltip[data-popper-placement=left-start] .mfui-tooltip__arrow-wrap,.mfui-tooltip[data-popper-placement=left] .mfui-tooltip__arrow-wrap{right:3px}.mfui-tooltip[data-popper-placement=left-end] .mfui-tooltip__arrow,.mfui-tooltip[data-popper-placement=left-end] .mfui-tooltip__arrow-shadow,.mfui-tooltip[data-popper-placement=left-start] .mfui-tooltip__arrow,.mfui-tooltip[data-popper-placement=left-start] .mfui-tooltip__arrow-shadow,.mfui-tooltip[data-popper-placement=left] .mfui-tooltip__arrow,.mfui-tooltip[data-popper-placement=left] .mfui-tooltip__arrow-shadow{-webkit-transform:rotate(90deg);transform:rotate(90deg)}.mfui-tooltip_offset_small[data-popper-placement=left-end] .mfui-tooltip__content,.mfui-tooltip_offset_small[data-popper-placement=left-end] .mfui-tooltip__content-shadow,.mfui-tooltip_offset_small[data-popper-placement=left-start] .mfui-tooltip__content,.mfui-tooltip_offset_small[data-popper-placement=left-start] .mfui-tooltip__content-shadow,.mfui-tooltip_offset_small[data-popper-placement=left] .mfui-tooltip__content,.mfui-tooltip_offset_small[data-popper-placement=left] .mfui-tooltip__content-shadow{-webkit-transform:translateX(-15px);transform:translateX(-15px)}.mfui-tooltip_offset_small[data-popper-placement=left-end] .mfui-tooltip__arrow-wrap,.mfui-tooltip_offset_small[data-popper-placement=left-start] .mfui-tooltip__arrow-wrap,.mfui-tooltip_offset_small[data-popper-placement=left] .mfui-tooltip__arrow-wrap{right:-6px}.mfui-tooltip[data-popper-placement=top-end] .mfui-tooltip__content,.mfui-tooltip[data-popper-placement=top-end] .mfui-tooltip__content-shadow,.mfui-tooltip[data-popper-placement=top-start] .mfui-tooltip__content,.mfui-tooltip[data-popper-placement=top-start] .mfui-tooltip__content-shadow,.mfui-tooltip[data-popper-placement=top] .mfui-tooltip__content,.mfui-tooltip[data-popper-placement=top] .mfui-tooltip__content-shadow{-webkit-transform:translateY(-24px);transform:translateY(-24px)}.mfui-tooltip[data-popper-placement=top-end] .mfui-tooltip__arrow-wrap,.mfui-tooltip[data-popper-placement=top-start] .mfui-tooltip__arrow-wrap,.mfui-tooltip[data-popper-placement=top] .mfui-tooltip__arrow-wrap{bottom:13px}.mfui-tooltip[data-popper-placement=top-end] .mfui-tooltip__arrow,.mfui-tooltip[data-popper-placement=top-end] .mfui-tooltip__arrow-shadow,.mfui-tooltip[data-popper-placement=top-start] .mfui-tooltip__arrow,.mfui-tooltip[data-popper-placement=top-start] .mfui-tooltip__arrow-shadow,.mfui-tooltip[data-popper-placement=top] .mfui-tooltip__arrow,.mfui-tooltip[data-popper-placement=top] .mfui-tooltip__arrow-shadow{-webkit-transform:rotate(180deg);transform:rotate(180deg)}.mfui-tooltip_offset_small[data-popper-placement=top-end] .mfui-tooltip__content,.mfui-tooltip_offset_small[data-popper-placement=top-end] .mfui-tooltip__content-shadow,.mfui-tooltip_offset_small[data-popper-placement=top-start] .mfui-tooltip__content,.mfui-tooltip_offset_small[data-popper-placement=top-start] .mfui-tooltip__content-shadow,.mfui-tooltip_offset_small[data-popper-placement=top] .mfui-tooltip__content,.mfui-tooltip_offset_small[data-popper-placement=top] .mfui-tooltip__content-shadow{-webkit-transform:translateY(-15px);transform:translateY(-15px)}.mfui-tooltip_offset_small[data-popper-placement=top-end] .mfui-tooltip__arrow-wrap,.mfui-tooltip_offset_small[data-popper-placement=top-start] .mfui-tooltip__arrow-wrap,.mfui-tooltip_offset_small[data-popper-placement=top] .mfui-tooltip__arrow-wrap{bottom:4px}.mfui-tooltip[data-popper-placement=bottom-end] .mfui-tooltip__content,.mfui-tooltip[data-popper-placement=bottom-end] .mfui-tooltip__content-shadow,.mfui-tooltip[data-popper-placement=bottom-start] .mfui-tooltip__content,.mfui-tooltip[data-popper-placement=bottom-start] .mfui-tooltip__content-shadow,.mfui-tooltip[data-popper-placement=bottom] .mfui-tooltip__content,.mfui-tooltip[data-popper-placement=bottom] .mfui-tooltip__content-shadow{-webkit-transform:translateY(24px);transform:translateY(24px)}.mfui-tooltip[data-popper-placement=bottom-end] .mfui-tooltip__arrow-wrap,.mfui-tooltip[data-popper-placement=bottom-start] .mfui-tooltip__arrow-wrap,.mfui-tooltip[data-popper-placement=bottom] .mfui-tooltip__arrow-wrap{top:13px}.mfui-tooltip_offset_small[data-popper-placement=bottom-end] .mfui-tooltip__content,.mfui-tooltip_offset_small[data-popper-placement=bottom-end] .mfui-tooltip__content-shadow,.mfui-tooltip_offset_small[data-popper-placement=bottom-start] .mfui-tooltip__content,.mfui-tooltip_offset_small[data-popper-placement=bottom-start] .mfui-tooltip__content-shadow,.mfui-tooltip_offset_small[data-popper-placement=bottom] .mfui-tooltip__content,.mfui-tooltip_offset_small[data-popper-placement=bottom] .mfui-tooltip__content-shadow{-webkit-transform:translateY(15px);transform:translateY(15px)}.mfui-tooltip_offset_small[data-popper-placement=bottom-end] .mfui-tooltip__arrow-wrap,.mfui-tooltip_offset_small[data-popper-placement=bottom-start] .mfui-tooltip__arrow-wrap,.mfui-tooltip_offset_small[data-popper-placement=bottom] .mfui-tooltip__arrow-wrap{top:4px}.mfui-tooltip[data-popper-escaped=true].mfui-tooltip_has-escape{pointer-events:none;visibility:hidden}
1
+ h1,h2,h3,h4,h5{margin:0}.mfui-tooltip{opacity:0;pointer-events:none;-webkit-transition-duration:.3s;transition-duration:.3s;-webkit-transition-property:opacity,visibility;transition-property:opacity,visibility;visibility:hidden;z-index:100}.mfui-tooltip_open{opacity:1;pointer-events:all;visibility:visible}.mfui-tooltip_paddings_small .mfui-tooltip__content{padding:16px}.mfui-tooltip_paddings_medium .mfui-tooltip__content{padding:24px}.mfui-tooltip__content{overflow:hidden;position:relative;z-index:1}.mfui-tooltip__content-shadow{bottom:0;left:0;position:absolute;right:0;top:0;z-index:-1}.mfui-tooltip__arrow-container{position:absolute}.mfui-tooltip__arrow-wrap{height:13px;width:33px}.mfui-tooltip_theme_white .mfui-tooltip__arrow-wrap{z-index:2}.mfui-tooltip__arrow{display:-webkit-box;display:-ms-flexbox;display:flex;height:13px;position:absolute;width:33px;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center}.mfui-tooltip__arrow svg{position:absolute}.mfui-tooltip__arrow-inner{-webkit-filter:drop-shadow(0 2px 9px rgba(0,0,0,.15));filter:drop-shadow(0 2px 9px rgba(0,0,0,.15));fill:var(--base)}.mfui-tooltip_theme_white .mfui-tooltip__arrow-inner{-webkit-filter:drop-shadow(0 -2px 1px rgba(0,0,0,.05));filter:drop-shadow(0 -2px 1px rgba(0,0,0,.05));top:1px}@-moz-document url-prefix(""){.mfui-tooltip_theme_white .mfui-tooltip__arrow-inner_top{filter:drop-shadow(0 2px 1px rgba(0,0,0,.05))}}.mfui-tooltip_theme_white .mfui-tooltip__arrow-inner path:nth-child(2){fill:var(--stcWhite10)}.mfui-tooltip__text{font-size:15px;line-height:24px}@media screen and (max-width:767px){.mfui-tooltip__text{font-size:12px;line-height:18px}}.mfui-tooltip__text_margin{margin-top:8px}.mfui-tooltip__button,.mfui-tooltip__close-button{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;border:none;-webkit-box-sizing:border-box;box-sizing:border-box;cursor:pointer;padding:0}.mfui-tooltip__button{background-color:transparent;color:var(--brandGreen);font-family:inherit;font-size:15px;font-weight:500;line-height:18px;-webkit-transition:.3s;transition:.3s}@media screen and (max-width:767px){.mfui-tooltip__button{font-size:12px;line-height:14px}}.mfui-tooltip__button_margin{margin-top:8px}.mfui-tooltip__button:hover{color:var(--buttonHoverGreen)}.mfui-tooltip__button:hover .mfui-tooltip__button-arrow{fill:var(--buttonHoverGreen)}.mfui-tooltip__button:active{color:var(--buttonDown)}.mfui-tooltip__button:active .mfui-tooltip__button-arrow{fill:var(--buttonDown)}.mfui-tooltip__close-button{position:relative;right:-6px;top:-6px;-webkit-box-pack:center;-ms-flex-pack:center;background-color:var(--spbSky0);border-radius:12px;float:right;height:24px;justify-content:center;-webkit-transition:.3s;transition:.3s;width:24px}.mfui-tooltip__close-button:hover{background-color:var(--spbSky1)}.mfui-tooltip__close-button:active{background-color:var(--spbSky2)}.mfui-tooltip__close-icon{display:block;height:20px;opacity:.5;width:20px;fill:var(--content)}.mfui-tooltip__button-arrow{height:20px;margin-bottom:-2px;min-width:20px;-webkit-transition:.3s;transition:.3s;width:20px;fill:var(--brandGreen)}.mfui-tooltip__addititonal-content_margin{margin-top:16px}@media screen and (max-width:767px){.mfui-tooltip__addititonal-content_margin{margin-top:12px}}.mfui-tooltip_small .mfui-tooltip__content{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:horizontal;-webkit-box-direction:reverse;-ms-flex-direction:row-reverse;flex-direction:row-reverse;gap:18px;-webkit-box-align:center;-ms-flex-align:center;align-items:center}.mfui-tooltip_small .mfui-tooltip__text{font-weight:500}.mfui-tooltip_small .mfui-tooltip__close-button{top:auto}.mfui-tooltip_theme_white .mfui-tooltip__content{border:1px solid var(--stcWhite10)}.mfui-tooltip_theme_blue .mfui-tooltip__arrow:before,.mfui-tooltip_theme_blue .mfui-tooltip__button,.mfui-tooltip_theme_blue .mfui-tooltip__content,.mfui-tooltip_theme_blue .mfui-tooltip__title,.mfui-tooltip_theme_red .mfui-tooltip__arrow:before,.mfui-tooltip_theme_red .mfui-tooltip__button,.mfui-tooltip_theme_red .mfui-tooltip__content,.mfui-tooltip_theme_red .mfui-tooltip__title{color:var(--stcWhite)}.mfui-tooltip_theme_blue .mfui-tooltip__button-arrow,.mfui-tooltip_theme_red .mfui-tooltip__button-arrow{fill:var(--stcWhite)}.mfui-tooltip_theme_blue .mfui-tooltip__button:hover,.mfui-tooltip_theme_red .mfui-tooltip__button:hover{color:var(--buttonHoverGrey)}.mfui-tooltip_theme_blue .mfui-tooltip__button:hover .mfui-tooltip__button-arrow,.mfui-tooltip_theme_red .mfui-tooltip__button:hover .mfui-tooltip__button-arrow{fill:var(--buttonHoverGrey)}.mfui-tooltip_theme_blue .mfui-tooltip__button:active,.mfui-tooltip_theme_red .mfui-tooltip__button:active{color:var(--buttonDown)}.mfui-tooltip_theme_blue .mfui-tooltip__button:active .mfui-tooltip__button-arrow,.mfui-tooltip_theme_red .mfui-tooltip__button:active .mfui-tooltip__button-arrow{fill:var(--buttonDown)}.mfui-tooltip_theme_blue .mfui-tooltip__close-button,.mfui-tooltip_theme_red .mfui-tooltip__close-button{background-color:var(--stcWhite10)}.mfui-tooltip_theme_blue .mfui-tooltip__close-button:hover,.mfui-tooltip_theme_red .mfui-tooltip__close-button:hover{background-color:var(--stcWhite20)}.mfui-tooltip_theme_blue .mfui-tooltip__close-button:active,.mfui-tooltip_theme_red .mfui-tooltip__close-button:active{background-color:var(--stcWhite50)}.mfui-tooltip_theme_blue .mfui-tooltip__close-icon,.mfui-tooltip_theme_red .mfui-tooltip__close-icon{opacity:1;fill:var(--stcWhite)}.mfui-tooltip_theme_red .mfui-tooltip__arrow:before,.mfui-tooltip_theme_red .mfui-tooltip__content,.mfui-tooltip_theme_red .mfui-tooltip__content-shadow{background-color:var(--fury80)}.mfui-tooltip_theme_red .mfui-tooltip__arrow-inner{fill:var(--fury80)}.mfui-tooltip_theme_blue .mfui-tooltip__arrow:before,.mfui-tooltip_theme_blue .mfui-tooltip__content,.mfui-tooltip_theme_blue .mfui-tooltip__content-shadow{background-color:var(--night)}.mfui-tooltip_theme_blue .mfui-tooltip__arrow-inner{fill:var(--night)}.mfui-tooltip[data-popper-placement=right-end] .mfui-tooltip__content,.mfui-tooltip[data-popper-placement=right-end] .mfui-tooltip__content-shadow,.mfui-tooltip[data-popper-placement=right-start] .mfui-tooltip__content,.mfui-tooltip[data-popper-placement=right-start] .mfui-tooltip__content-shadow,.mfui-tooltip[data-popper-placement=right] .mfui-tooltip__content,.mfui-tooltip[data-popper-placement=right] .mfui-tooltip__content-shadow{-webkit-transform:translateX(24px);transform:translateX(24px)}.mfui-tooltip[data-popper-placement=right-end] .mfui-tooltip__arrow-wrap,.mfui-tooltip[data-popper-placement=right-start] .mfui-tooltip__arrow-wrap,.mfui-tooltip[data-popper-placement=right] .mfui-tooltip__arrow-wrap{left:3px}.mfui-tooltip[data-popper-placement=right-end] .mfui-tooltip__arrow,.mfui-tooltip[data-popper-placement=right-end] .mfui-tooltip__arrow-shadow,.mfui-tooltip[data-popper-placement=right-start] .mfui-tooltip__arrow,.mfui-tooltip[data-popper-placement=right-start] .mfui-tooltip__arrow-shadow,.mfui-tooltip[data-popper-placement=right] .mfui-tooltip__arrow,.mfui-tooltip[data-popper-placement=right] .mfui-tooltip__arrow-shadow{-webkit-transform:rotate(-90deg);transform:rotate(-90deg)}.mfui-tooltip_offset_small[data-popper-placement=right-end] .mfui-tooltip__content,.mfui-tooltip_offset_small[data-popper-placement=right-end] .mfui-tooltip__content-shadow,.mfui-tooltip_offset_small[data-popper-placement=right-start] .mfui-tooltip__content,.mfui-tooltip_offset_small[data-popper-placement=right-start] .mfui-tooltip__content-shadow,.mfui-tooltip_offset_small[data-popper-placement=right] .mfui-tooltip__content,.mfui-tooltip_offset_small[data-popper-placement=right] .mfui-tooltip__content-shadow{-webkit-transform:translateX(15px);transform:translateX(15px)}.mfui-tooltip_offset_small[data-popper-placement=right-end] .mfui-tooltip__arrow-wrap,.mfui-tooltip_offset_small[data-popper-placement=right-start] .mfui-tooltip__arrow-wrap,.mfui-tooltip_offset_small[data-popper-placement=right] .mfui-tooltip__arrow-wrap{left:-6px}.mfui-tooltip[data-popper-placement=left-end] .mfui-tooltip__content,.mfui-tooltip[data-popper-placement=left-end] .mfui-tooltip__content-shadow,.mfui-tooltip[data-popper-placement=left-start] .mfui-tooltip__content,.mfui-tooltip[data-popper-placement=left-start] .mfui-tooltip__content-shadow,.mfui-tooltip[data-popper-placement=left] .mfui-tooltip__content,.mfui-tooltip[data-popper-placement=left] .mfui-tooltip__content-shadow{-webkit-transform:translateX(-24px);transform:translateX(-24px)}.mfui-tooltip[data-popper-placement=left-end] .mfui-tooltip__arrow-wrap,.mfui-tooltip[data-popper-placement=left-start] .mfui-tooltip__arrow-wrap,.mfui-tooltip[data-popper-placement=left] .mfui-tooltip__arrow-wrap{right:3px}.mfui-tooltip[data-popper-placement=left-end] .mfui-tooltip__arrow,.mfui-tooltip[data-popper-placement=left-end] .mfui-tooltip__arrow-shadow,.mfui-tooltip[data-popper-placement=left-start] .mfui-tooltip__arrow,.mfui-tooltip[data-popper-placement=left-start] .mfui-tooltip__arrow-shadow,.mfui-tooltip[data-popper-placement=left] .mfui-tooltip__arrow,.mfui-tooltip[data-popper-placement=left] .mfui-tooltip__arrow-shadow{-webkit-transform:rotate(90deg);transform:rotate(90deg)}.mfui-tooltip_offset_small[data-popper-placement=left-end] .mfui-tooltip__content,.mfui-tooltip_offset_small[data-popper-placement=left-end] .mfui-tooltip__content-shadow,.mfui-tooltip_offset_small[data-popper-placement=left-start] .mfui-tooltip__content,.mfui-tooltip_offset_small[data-popper-placement=left-start] .mfui-tooltip__content-shadow,.mfui-tooltip_offset_small[data-popper-placement=left] .mfui-tooltip__content,.mfui-tooltip_offset_small[data-popper-placement=left] .mfui-tooltip__content-shadow{-webkit-transform:translateX(-15px);transform:translateX(-15px)}.mfui-tooltip_offset_small[data-popper-placement=left-end] .mfui-tooltip__arrow-wrap,.mfui-tooltip_offset_small[data-popper-placement=left-start] .mfui-tooltip__arrow-wrap,.mfui-tooltip_offset_small[data-popper-placement=left] .mfui-tooltip__arrow-wrap{right:-6px}.mfui-tooltip[data-popper-placement=top-end] .mfui-tooltip__content,.mfui-tooltip[data-popper-placement=top-end] .mfui-tooltip__content-shadow,.mfui-tooltip[data-popper-placement=top-start] .mfui-tooltip__content,.mfui-tooltip[data-popper-placement=top-start] .mfui-tooltip__content-shadow,.mfui-tooltip[data-popper-placement=top] .mfui-tooltip__content,.mfui-tooltip[data-popper-placement=top] .mfui-tooltip__content-shadow{-webkit-transform:translateY(-24px);transform:translateY(-24px)}.mfui-tooltip[data-popper-placement=top-end] .mfui-tooltip__arrow-wrap,.mfui-tooltip[data-popper-placement=top-start] .mfui-tooltip__arrow-wrap,.mfui-tooltip[data-popper-placement=top] .mfui-tooltip__arrow-wrap{bottom:13px}.mfui-tooltip[data-popper-placement=top-end] .mfui-tooltip__arrow,.mfui-tooltip[data-popper-placement=top-end] .mfui-tooltip__arrow-shadow,.mfui-tooltip[data-popper-placement=top-start] .mfui-tooltip__arrow,.mfui-tooltip[data-popper-placement=top-start] .mfui-tooltip__arrow-shadow,.mfui-tooltip[data-popper-placement=top] .mfui-tooltip__arrow,.mfui-tooltip[data-popper-placement=top] .mfui-tooltip__arrow-shadow{-webkit-transform:rotate(180deg);transform:rotate(180deg)}.mfui-tooltip_offset_small[data-popper-placement=top-end] .mfui-tooltip__content,.mfui-tooltip_offset_small[data-popper-placement=top-end] .mfui-tooltip__content-shadow,.mfui-tooltip_offset_small[data-popper-placement=top-start] .mfui-tooltip__content,.mfui-tooltip_offset_small[data-popper-placement=top-start] .mfui-tooltip__content-shadow,.mfui-tooltip_offset_small[data-popper-placement=top] .mfui-tooltip__content,.mfui-tooltip_offset_small[data-popper-placement=top] .mfui-tooltip__content-shadow{-webkit-transform:translateY(-15px);transform:translateY(-15px)}.mfui-tooltip_offset_small[data-popper-placement=top-end] .mfui-tooltip__arrow-wrap,.mfui-tooltip_offset_small[data-popper-placement=top-start] .mfui-tooltip__arrow-wrap,.mfui-tooltip_offset_small[data-popper-placement=top] .mfui-tooltip__arrow-wrap{bottom:4px}.mfui-tooltip[data-popper-placement=bottom-end] .mfui-tooltip__content,.mfui-tooltip[data-popper-placement=bottom-end] .mfui-tooltip__content-shadow,.mfui-tooltip[data-popper-placement=bottom-start] .mfui-tooltip__content,.mfui-tooltip[data-popper-placement=bottom-start] .mfui-tooltip__content-shadow,.mfui-tooltip[data-popper-placement=bottom] .mfui-tooltip__content,.mfui-tooltip[data-popper-placement=bottom] .mfui-tooltip__content-shadow{-webkit-transform:translateY(24px);transform:translateY(24px)}.mfui-tooltip[data-popper-placement=bottom-end] .mfui-tooltip__arrow-wrap,.mfui-tooltip[data-popper-placement=bottom-start] .mfui-tooltip__arrow-wrap,.mfui-tooltip[data-popper-placement=bottom] .mfui-tooltip__arrow-wrap{top:13px}.mfui-tooltip_offset_small[data-popper-placement=bottom-end] .mfui-tooltip__content,.mfui-tooltip_offset_small[data-popper-placement=bottom-end] .mfui-tooltip__content-shadow,.mfui-tooltip_offset_small[data-popper-placement=bottom-start] .mfui-tooltip__content,.mfui-tooltip_offset_small[data-popper-placement=bottom-start] .mfui-tooltip__content-shadow,.mfui-tooltip_offset_small[data-popper-placement=bottom] .mfui-tooltip__content,.mfui-tooltip_offset_small[data-popper-placement=bottom] .mfui-tooltip__content-shadow{-webkit-transform:translateY(15px);transform:translateY(15px)}.mfui-tooltip_offset_small[data-popper-placement=bottom-end] .mfui-tooltip__arrow-wrap,.mfui-tooltip_offset_small[data-popper-placement=bottom-start] .mfui-tooltip__arrow-wrap,.mfui-tooltip_offset_small[data-popper-placement=bottom] .mfui-tooltip__arrow-wrap{top:4px}.mfui-tooltip[data-popper-escaped=true].mfui-tooltip_has-escape{pointer-events:none;visibility:hidden}
@@ -22,6 +22,20 @@ var CancelIcon = function CancelIcon(props) {
22
22
  d: "M10 8.8L6.2 5 5 6.2 8.8 10 5 13.8 6.2 15l3.8-3.8 3.8 3.8 1.2-1.2-3.8-3.8L15 6.2 13.8 5 10 8.8z"
23
23
  }));
24
24
  };
25
+ var ArrowWithContour = function ArrowWithContour(props) {
26
+ return /*#__PURE__*/React.createElement("svg", _extends({
27
+ width: 32,
28
+ height: 12
29
+ }, props), /*#__PURE__*/React.createElement("path", {
30
+ fillRule: "evenodd",
31
+ clipRule: "evenodd",
32
+ d: "M14.878.894c.852-.955 2.39-.954 3.241.002C21.128 4.278 27.71 11 32.5 11H.5C5.261 11 11.86 4.275 14.878.894z"
33
+ }), /*#__PURE__*/React.createElement("path", {
34
+ fillRule: "evenodd",
35
+ clipRule: "evenodd",
36
+ d: "M18.119.718c2.295 2.58 6.67 7.103 10.742 9.104 1.266.622 2.503 1 3.639 1h-3.858l-1.829-1a28.919 28.919 0 01-2.797-2.004c-2.684-2.154-5.124-4.726-6.644-6.435a1.19 1.19 0 00-1.748-.002C14.1 3.09 11.654 5.662 8.969 7.816a29.088 29.088 0 01-2.8 2.006l-2.045 1H.5c1.129 0 2.361-.378 3.624-1C8.19 7.82 12.576 3.295 14.878.715c.852-.955 2.39-.953 3.241.003z"
37
+ }));
38
+ };
25
39
  var Arrow = function Arrow(props) {
26
40
  return /*#__PURE__*/React.createElement("svg", _extends({
27
41
  width: 42,
@@ -188,7 +202,8 @@ var Tooltip = function Tooltip(_ref) {
188
202
  var _usePopper = usePopper(currentTarget, popperElement, options),
189
203
  styles = _usePopper.styles,
190
204
  attributes = _usePopper.attributes,
191
- update = _usePopper.update;
205
+ update = _usePopper.update,
206
+ state = _usePopper.state;
192
207
  useEffect(function () {
193
208
  return setIsOpen(isOpened);
194
209
  }, [isOpened]);
@@ -332,7 +347,11 @@ var Tooltip = function Tooltip(_ref) {
332
347
  }, /*#__PURE__*/React.createElement("div", {
333
348
  className: cn('arrow', [arrowClassName]),
334
349
  "data-testid": "".concat(testIdPrefix, "-arrow")
335
- }, /*#__PURE__*/React.createElement(Arrow, {
350
+ }, theme === 'white' ? /*#__PURE__*/React.createElement(ArrowWithContour, {
351
+ className: cn('arrow-inner', {
352
+ top: (state === null || state === void 0 ? void 0 : state.placement) === 'top'
353
+ })
354
+ }) : /*#__PURE__*/React.createElement(Arrow, {
336
355
  className: cn('arrow-inner')
337
356
  }))), /*#__PURE__*/React.createElement("div", {
338
357
  className: cn('content-wrap')
@@ -11,6 +11,8 @@ export interface IUploadDropField {
11
11
  onChange: (files: File[]) => void;
12
12
  /** Дополнительная информация */
13
13
  description?: string;
14
+ /** Список допустимых типов файлов для внутреннего input */
15
+ accept?: string;
14
16
  /** Дополнительные data атрибуты к внутренним элементам */
15
17
  dataAttrs?: {
16
18
  root?: Record<string, string>;
@@ -14,6 +14,7 @@ var UploadField = function UploadField(_ref) {
14
14
  required = _ref$required === void 0 ? false : _ref$required,
15
15
  _ref$disabled = _ref.disabled,
16
16
  disabled = _ref$disabled === void 0 ? false : _ref$disabled,
17
+ accept = _ref.accept,
17
18
  onChange = _ref.onChange,
18
19
  description = _ref.description,
19
20
  dataAttrs = _ref.dataAttrs;
@@ -39,6 +40,7 @@ var UploadField = function UploadField(_ref) {
39
40
  }, filterDataAttrs(dataAttrs === null || dataAttrs === void 0 ? void 0 : dataAttrs.input), {
40
41
  multiple: true,
41
42
  type: "file",
43
+ accept: accept,
42
44
  ref: inputRef,
43
45
  onChange: handleInputChange,
44
46
  disabled: disabled
@@ -1 +1 @@
1
- h1,h2,h3,h4,h5{margin:0}.mfui-upload-field-drop-area{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;gap:8px;-webkit-box-align:center;-ms-flex-align:center;align-items:center;border:1px dashed var(--spbSky2);border-radius:12px;padding:12px 32px 20px;width:100%}.mfui-upload-field-drop-area__upload-icon{height:40px;width:40px;fill:var(--spbSky3)}.mfui-upload-field-drop-area__content{text-align:center}.mfui-upload-field-drop-area__select-button{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border:none;border-radius:0;-webkit-box-sizing:border-box;box-sizing:border-box;color:var(--brandGreen);cursor:pointer;display:inline-block;font-family:inherit;font-weight:500;margin-right:4px;outline:none;padding:0;text-align:center;text-decoration:none}.mfui-upload-field-drop-area__description{color:var(--spbSky3);font-size:12px;font-weight:400;line-height:18px;text-align:center}.mfui-upload-field-drop-area__select-button:hover{color:var(--buttonHoverGreen)}.mfui-upload-field-drop-area__mark{color:var(--fury)}.mfui-upload-field-drop-area_dragging{border-color:var(--brandGreen)}.mfui-upload-field-drop-area_dragging *{pointer-events:none}.mfui-upload-field-drop-area_disabled{background-color:var(--spbSky0);color:var(--spbSky3)}.mfui-upload-field-drop-area_disabled .mfui-upload-field-drop-area__select-button{color:var(--spbSky3);cursor:not-allowed}.mfui-upload-field-drop-area_disabled .mfui-upload-field-drop-area__mark{color:var(--spbSky3)}
1
+ h1,h2,h3,h4,h5{margin:0}.mfui-upload-field-drop-area{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;gap:8px;-webkit-box-align:center;-ms-flex-align:center;align-items:center;border:1px dashed var(--spbSky2);border-radius:12px;padding:12px 32px 20px;width:100%}.mfui-upload-field-drop-area__upload-icon{height:40px;width:40px;fill:var(--spbSky3)}.mfui-upload-field-drop-area__content{text-align:center}.mfui-upload-field-drop-area__select-button{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border:none;border-radius:0;-webkit-box-sizing:border-box;box-sizing:border-box;color:var(--brandGreen);cursor:pointer;display:inline-block;font-family:inherit;font-weight:500;margin-right:4px;outline:none;padding:0;text-align:center;text-decoration:none}.mfui-upload-field-drop-area__description{color:var(--spbSky3);font-size:12px;font-weight:400;line-height:18px;text-align:center}.mfui-upload-field-drop-area__select-button:focus,.mfui-upload-field-drop-area__select-button:hover{color:var(--buttonHoverGreen)}.mfui-upload-field-drop-area__mark{color:var(--fury)}.mfui-upload-field-drop-area_dragging{border-color:var(--brandGreen)}.mfui-upload-field-drop-area_dragging *{pointer-events:none}.mfui-upload-field-drop-area_disabled{background-color:var(--spbSky0);color:var(--spbSky3)}.mfui-upload-field-drop-area_disabled .mfui-upload-field-drop-area__select-button{color:var(--spbSky3);cursor:not-allowed}.mfui-upload-field-drop-area_disabled .mfui-upload-field-drop-area__mark{color:var(--spbSky3)}
@@ -1 +1 @@
1
- h1,h2,h3,h4,h5{margin:0}.mfui-upload-file-item{display:-webkit-box;display:-ms-flexbox;display:flex;gap:12px;-webkit-box-align:start;-ms-flex-align:start;align-items:flex-start;border-color:var(--spbSky1);border-radius:12px;border-style:solid;border-width:1px;-webkit-box-sizing:border-box;box-sizing:border-box;max-width:455px;padding:12px;width:100%}.mfui-upload-file-item__cancel-icon-box,.mfui-upload-file-item__file-icon-box{-ms-flex-negative:0;flex-shrink:0;height:32px;margin-top:5px;width:32px}.mfui-upload-file-item__cancel-icon-box{background-color:var(--spbSky0);border:none;border-radius:50%;cursor:pointer;padding:0}.mfui-upload-file-item__cancel-icon-box svg{fill:var(--spbSky3)}.mfui-upload-file-item__cancel-icon-box:hover{background-color:var(--spbSky1)}.mfui-upload-file-item__cancel-icon-box:active{background-color:var(--spbSky2)}.mfui-upload-file-item__icon{height:100%;width:100%}.mfui-upload-file-item__content{-webkit-box-flex:1;-ms-flex-positive:1;flex-grow:1;overflow:hidden}.mfui-upload-file-item__name{font-size:15px;font-weight:500;line-height:24px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:100%}.mfui-upload-file-item__description{color:var(--spbSky3);display:-webkit-box;display:-ms-flexbox;display:flex;font-size:12px;font-weight:400;gap:4px;line-height:18px}.mfui-upload-file-item__progress-bar{background-color:var(--spbSky1);border-radius:2px;height:4px;margin-top:12px;width:100%}.mfui-upload-file-item__progress-bar-fill{background-color:var(--brandGreen);border-radius:2px;height:100%;-webkit-transition:width .3s ease;transition:width .3s ease;width:0}.mfui-upload-file-item__service-message{color:var(--content)}.mfui-upload-file-item__error-message{color:var(--fury);cursor:pointer;-webkit-text-decoration-color:var(--fury);text-decoration-color:var(--fury);-webkit-text-decoration-line:underline;text-decoration-line:underline;-webkit-text-decoration-style:dotted;text-decoration-style:dotted;text-underline-offset:2px}.mfui-upload-file-item__error-tooltip{font-size:15px;font-weight:500;line-height:24px;max-width:260px}.mfui-upload-file-item_error{border-color:var(--fury20)}
1
+ h1,h2,h3,h4,h5{margin:0}.mfui-upload-file-item{display:-webkit-box;display:-ms-flexbox;display:flex;gap:12px;-webkit-box-align:start;-ms-flex-align:start;align-items:flex-start;border-color:var(--spbSky1);border-radius:12px;border-style:solid;border-width:1px;-webkit-box-sizing:border-box;box-sizing:border-box;max-width:455px;padding:12px;width:100%}.mfui-upload-file-item__file-icon-box{-ms-flex-negative:0;flex-shrink:0;height:32px;margin-top:5px;width:32px}.mfui-upload-file-item__cancel-icon-box,.mfui-upload-file-item__download-icon-box{display:block;-ms-flex-negative:0;border:none;border-radius:50%;cursor:pointer;flex-shrink:0;height:32px;margin-top:5px;padding:0;width:32px}.mfui-upload-file-item__cancel-icon-box svg,.mfui-upload-file-item__download-icon-box svg{fill:var(--spbSky3)}.mfui-upload-file-item__cancel-icon-box{background-color:var(--spbSky0)}.mfui-upload-file-item__cancel-icon-box:hover{background-color:var(--spbSky1)}.mfui-upload-file-item__cancel-icon-box:active{background-color:var(--spbSky2)}.mfui-upload-file-item__download-icon-box:hover svg{fill:var(--buttonHoverGreen)}.mfui-upload-file-item__icon{height:100%;width:100%}.mfui-upload-file-item__content{display:grid;-webkit-box-flex:1;-ms-flex-positive:1;flex-grow:1;grid-template-columns:auto -webkit-min-content;grid-template-columns:auto min-content;grid-template-rows:auto auto}.mfui-upload-file-item__name{font-size:15px;font-weight:500;grid-column:1;line-height:24px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:100%}.mfui-upload-file-item__description{color:var(--spbSky3);display:-webkit-box;display:-ms-flexbox;display:flex;font-size:12px;font-weight:400;gap:4px;grid-column:1;grid-row:2;line-height:18px}.mfui-upload-file-item__progress-bar{background-color:var(--spbSky1);border-radius:2px;grid-column:1/span 2;height:4px;margin-top:12px;width:100%}.mfui-upload-file-item__download-icon-box{grid-column:2;grid-row:1/span 2;margin-right:-4px}.mfui-upload-file-item__progress-bar-fill{background-color:var(--brandGreen);border-radius:2px;height:100%;-webkit-transition:width .3s ease;transition:width .3s ease;width:0}.mfui-upload-file-item__service-message{color:var(--content)}.mfui-upload-file-item__error-message{color:var(--fury);cursor:pointer;-webkit-text-decoration-color:var(--fury);text-decoration-color:var(--fury);-webkit-text-decoration-line:underline;text-decoration-line:underline;-webkit-text-decoration-style:dotted;text-decoration-style:dotted;text-underline-offset:2px}.mfui-upload-file-item__error-tooltip{font-size:15px;font-weight:500;line-height:24px;max-width:260px}.mfui-upload-file-item_error{border-color:var(--fury20)}
@@ -9,16 +9,27 @@ export interface IUploadFileItem {
9
9
  fileSize?: string | number;
10
10
  /** Процент загрузки файла */
11
11
  loadingProgress?: number;
12
+ /** Не отображать прогресс загрузки */
13
+ hideProgress?: boolean;
12
14
  /** Сообщение об ошибке */
13
15
  errorText?: string;
14
16
  /** Проверка файла */
15
17
  isChecking?: string;
18
+ /** Ссылка на файл. Если параметр задан, то появляется кнопка скачивания */
19
+ downloadLink?: string;
20
+ /** Рекомендует браузеру скачивать контент по ссылке. Может быть передано рекомендуемое название скачиваемого файла. */
21
+ download?: boolean | string;
22
+ /** Указывает, где открыть скачиваемый документ */
23
+ target?: React.HTMLAttributeAnchorTarget;
24
+ /** Обработчик скачивания файла */
25
+ onDownload?: (e: React.SyntheticEvent<EventTarget>) => void;
16
26
  /** Обработчик удаления файла */
17
27
  onDelete?: (e: React.SyntheticEvent<EventTarget>) => void;
18
28
  /** Дополнительные data атрибуты к внутренним элементам */
19
29
  dataAttrs?: {
20
30
  root?: Record<string, string>;
21
31
  deleteButton?: Record<string, string>;
32
+ downloadButton?: Record<string, string>;
22
33
  };
23
34
  }
24
35
  declare const UploadFileItem: React.FC<IUploadFileItem>;
@@ -6,6 +6,15 @@ import Tooltip from "../../Tooltip/Tooltip";
6
6
  import UploadFileItemIcon from "./components/_UploadFileItemIcon/UploadFileItemIcon";
7
7
  import { getReadableFileSize, splitFileName } from "./helpers";
8
8
  import "./UploadFileItem.css";
9
+ var DownloadIcon = function DownloadIcon(props) {
10
+ return /*#__PURE__*/React.createElement("svg", _extends({
11
+ viewBox: "0 0 32 32"
12
+ }, props), /*#__PURE__*/React.createElement("path", {
13
+ d: "M15.04 5.99L14.97 17l-1.26-1.49-1.42 1.41L15.37 20h1.26l3.08-3.08-1.42-1.41-1.32 1.55.07-11.05-2-.02z"
14
+ }), /*#__PURE__*/React.createElement("path", {
15
+ d: "M8 17H6a10 10 0 0020 0h-2a8 8 0 01-16 0z"
16
+ }));
17
+ };
9
18
  var CancelIcon = function CancelIcon(props) {
10
19
  return /*#__PURE__*/React.createElement("svg", _extends({
11
20
  viewBox: "0 0 32 32"
@@ -23,9 +32,15 @@ var UploadFileItem = function UploadFileItem(_ref) {
23
32
  fileSize = _ref$fileSize === void 0 ? 0 : _ref$fileSize,
24
33
  _ref$loadingProgress = _ref.loadingProgress,
25
34
  loadingProgress = _ref$loadingProgress === void 0 ? 0 : _ref$loadingProgress,
35
+ _ref$hideProgress = _ref.hideProgress,
36
+ hideProgress = _ref$hideProgress === void 0 ? false : _ref$hideProgress,
26
37
  errorText = _ref.errorText,
27
38
  _ref$isChecking = _ref.isChecking,
28
39
  isChecking = _ref$isChecking === void 0 ? false : _ref$isChecking,
40
+ downloadLink = _ref.downloadLink,
41
+ download = _ref.download,
42
+ target = _ref.target,
43
+ onDownload = _ref.onDownload,
29
44
  onDelete = _ref.onDelete,
30
45
  dataAttrs = _ref.dataAttrs;
31
46
  var tooltipTriggerElement = React.useRef(null);
@@ -34,9 +49,6 @@ var UploadFileItem = function UploadFileItem(_ref) {
34
49
  extension = _splitFileName.extension;
35
50
  var readableFileSize = getReadableFileSize(fileSize);
36
51
  var isError = !!errorText;
37
- var handleDelete = function handleDelete(e) {
38
- onDelete === null || onDelete === void 0 ? void 0 : onDelete(e);
39
- };
40
52
  var loadingStatusText = function loadingStatusText() {
41
53
  if (isChecking) {
42
54
  return 'проверка файла…';
@@ -59,6 +71,9 @@ var UploadFileItem = function UploadFileItem(_ref) {
59
71
  offset: "small"
60
72
  }, errorText));
61
73
  }
74
+ if (hideProgress) {
75
+ return null;
76
+ }
62
77
  return /*#__PURE__*/React.createElement("span", {
63
78
  className: cn('service-message')
64
79
  }, loadingStatusText());
@@ -78,7 +93,16 @@ var UploadFileItem = function UploadFileItem(_ref) {
78
93
  className: cn('name')
79
94
  }, name), /*#__PURE__*/React.createElement("div", {
80
95
  className: cn('description')
81
- }, !!extension && /*#__PURE__*/React.createElement("span", null, extension.toUpperCase()), /*#__PURE__*/React.createElement("span", null, readableFileSize), renderExtraContent()), /*#__PURE__*/React.createElement("div", {
96
+ }, !!extension && /*#__PURE__*/React.createElement("span", null, extension.toUpperCase()), /*#__PURE__*/React.createElement("span", null, readableFileSize), renderExtraContent()), !!downloadLink && /*#__PURE__*/React.createElement("a", _extends({
97
+ className: cn('download-icon-box')
98
+ }, filterDataAttrs(dataAttrs === null || dataAttrs === void 0 ? void 0 : dataAttrs.downloadButton), {
99
+ href: downloadLink,
100
+ download: download,
101
+ target: target,
102
+ onClick: onDownload
103
+ }), /*#__PURE__*/React.createElement(DownloadIcon, {
104
+ className: cn('icon')
105
+ })), !hideProgress && /*#__PURE__*/React.createElement("div", {
82
106
  className: cn('progress-bar')
83
107
  }, /*#__PURE__*/React.createElement("div", {
84
108
  className: cn('progress-bar-fill'),
@@ -89,7 +113,7 @@ var UploadFileItem = function UploadFileItem(_ref) {
89
113
  type: "button",
90
114
  className: cn('cancel-icon-box')
91
115
  }, filterDataAttrs(dataAttrs === null || dataAttrs === void 0 ? void 0 : dataAttrs.deleteButton), {
92
- onClick: handleDelete
116
+ onClick: onDelete
93
117
  }), /*#__PURE__*/React.createElement(CancelIcon, {
94
118
  className: cn('icon')
95
119
  })));
@@ -1,4 +1,5 @@
1
1
  import * as React from 'react';
2
+ import { RefObject } from 'react';
2
3
  import './ValueField.scss';
3
4
  export declare const Field: {
4
5
  readonly LINE: "line";
@@ -35,6 +36,8 @@ export interface IValueField {
35
36
  onChange?: (e: React.ChangeEvent<HTMLInputElement>) => void;
36
37
  /** Обработчик потери фокуса */
37
38
  onBlur?: () => void;
39
+ /** Ссылка на input */
40
+ inputRef?: RefObject<HTMLInputElement>;
38
41
  }
39
42
  declare const ValueField: React.FC<IValueField>;
40
43
  export default ValueField;
@@ -35,20 +35,22 @@ var ValueField = function ValueField(_ref) {
35
35
  isControlled = _ref$isControlled === void 0 ? false : _ref$isControlled,
36
36
  dataAttrs = _ref.dataAttrs,
37
37
  onChange = _ref.onChange,
38
- onBlur = _ref.onBlur;
38
+ onBlur = _ref.onBlur,
39
+ externalInputRef = _ref.inputRef;
39
40
  var _a;
40
41
  var _useState = useState(value !== null && value !== void 0 ? value : ''),
41
42
  _useState2 = _slicedToArray(_useState, 2),
42
43
  inputValue = _useState2[0],
43
44
  setInputValue = _useState2[1];
44
45
  var currentValue = isControlled ? value : inputValue;
45
- var inputRef = React.useRef(null);
46
+ var internalInputRef = React.useRef(null);
46
47
  var _React$useState = React.useState(false),
47
48
  _React$useState2 = _slicedToArray(_React$useState, 2),
48
49
  isFocused = _React$useState2[0],
49
50
  setIsFocused = _React$useState2[1];
50
51
  var isFieldInput = fieldType === Field.INPUT;
51
52
  var RootElement = isFieldInput ? 'label' : 'div';
53
+ var inputRef = externalInputRef || internalInputRef;
52
54
  var handleInputBlur = function handleInputBlur() {
53
55
  setIsFocused(false);
54
56
  onBlur === null || onBlur === void 0 ? void 0 : onBlur();
@@ -90,7 +92,7 @@ var ValueField = function ValueField(_ref) {
90
92
  className: cn('input'),
91
93
  type: "number",
92
94
  value: currentValue,
93
- placeholder: placeholder,
95
+ placeholder: isFocused ? placeholder : undefined,
94
96
  onChange: handleInputChange,
95
97
  onBlur: handleInputBlur,
96
98
  onFocus: handleInputFocus,
@@ -1,4 +1,5 @@
1
1
  type UseResolutionReturnType = {
2
+ isMobileExtraSmall: boolean;
2
3
  isMobile: boolean;
3
4
  };
4
5
  declare function useResolution(): UseResolutionReturnType;
@@ -2,33 +2,50 @@ import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
2
2
  import * as React from 'react';
3
3
  var RESOLUTIONS;
4
4
  (function (RESOLUTIONS) {
5
+ RESOLUTIONS[RESOLUTIONS["MOBILE_XS_END"] = 359] = "MOBILE_XS_END";
5
6
  RESOLUTIONS[RESOLUTIONS["MOBILE_END"] = 767] = "MOBILE_END";
6
7
  })(RESOLUTIONS || (RESOLUTIONS = {}));
7
8
  var _RESOLUTIONS = RESOLUTIONS,
8
- MOBILE_END = _RESOLUTIONS.MOBILE_END;
9
+ MOBILE_END = _RESOLUTIONS.MOBILE_END,
10
+ MOBILE_XS_END = _RESOLUTIONS.MOBILE_XS_END;
9
11
  var MEDIA_QUERIES = {
12
+ MAX_WIDTH_MOBILE_XS_END: "(max-width: ".concat(MOBILE_XS_END, "px)"),
10
13
  MAX_WIDTH_MOBILE_END: "(max-width: ".concat(MOBILE_END, "px)")
11
14
  };
12
- var MAX_WIDTH_MOBILE_END = MEDIA_QUERIES.MAX_WIDTH_MOBILE_END;
15
+ var MAX_WIDTH_MOBILE_XS_END = MEDIA_QUERIES.MAX_WIDTH_MOBILE_XS_END,
16
+ MAX_WIDTH_MOBILE_END = MEDIA_QUERIES.MAX_WIDTH_MOBILE_END;
17
+ var isScreenWidthAtMost = function isScreenWidthAtMost(maxWidth) {
18
+ return typeof window !== 'undefined' ? window.innerWidth <= maxWidth : false;
19
+ };
13
20
  function useResolution() {
14
- var _React$useState = React.useState((window === null || window === void 0 ? void 0 : window.innerWidth) <= MOBILE_END || false),
21
+ var _React$useState = React.useState(isScreenWidthAtMost(MOBILE_END)),
15
22
  _React$useState2 = _slicedToArray(_React$useState, 2),
16
23
  isMobile = _React$useState2[0],
17
24
  setIsMobile = _React$useState2[1];
25
+ var _React$useState3 = React.useState(isScreenWidthAtMost(MOBILE_XS_END)),
26
+ _React$useState4 = _slicedToArray(_React$useState3, 2),
27
+ isMobileExtraSmall = _React$useState4[0],
28
+ setIsMobileExtraSmall = _React$useState4[1];
18
29
  var handleMediaChange = function handleMediaChange(updateStateFn) {
19
30
  return function (e) {
20
31
  return updateStateFn(e.matches);
21
32
  };
22
33
  };
23
34
  var handleMaxWidthMobileEnd = handleMediaChange(setIsMobile);
35
+ var handleMaxWidthMobileExtraSmall = handleMediaChange(setIsMobileExtraSmall);
24
36
  React.useEffect(function () {
25
- window.matchMedia(MAX_WIDTH_MOBILE_END).addEventListener('change', handleMaxWidthMobileEnd);
37
+ var mobileExtraSmallQuery = window.matchMedia(MAX_WIDTH_MOBILE_XS_END);
38
+ var mobileQuery = window.matchMedia(MAX_WIDTH_MOBILE_END);
39
+ mobileExtraSmallQuery.addEventListener('change', handleMaxWidthMobileExtraSmall);
40
+ mobileQuery.addEventListener('change', handleMaxWidthMobileEnd);
26
41
  return function () {
27
- window.matchMedia(MAX_WIDTH_MOBILE_END).removeEventListener('change', handleMaxWidthMobileEnd);
42
+ mobileExtraSmallQuery.removeEventListener('change', handleMaxWidthMobileExtraSmall);
43
+ mobileQuery.removeEventListener('change', handleMaxWidthMobileEnd);
28
44
  };
29
- }, [handleMaxWidthMobileEnd]);
45
+ }, [handleMaxWidthMobileEnd, handleMaxWidthMobileExtraSmall]);
30
46
  return {
31
- isMobile: isMobile
47
+ isMobile: isMobile,
48
+ isMobileExtraSmall: isMobileExtraSmall
32
49
  };
33
50
  }
34
51
  export default useResolution;
@@ -1 +1 @@
1
- h1,h2,h3,h4,h5{margin:0}.mfui-pagination{display:-webkit-box;display:-ms-flexbox;display:flex}
1
+ h1,h2,h3,h4,h5{margin:0}.mfui-pagination{display:-webkit-box;display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;gap:12px;-webkit-box-align:center;-ms-flex-align:center;align-items:center}@media screen and (max-width:767px){.mfui-pagination{-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;gap:16px}}.mfui-pagination__input,.mfui-pagination__wrapper{display:-webkit-box;display:-ms-flexbox;display:flex}.mfui-pagination__input{gap:8px;-webkit-box-align:center;-ms-flex-align:center;align-items:center}.mfui-pagination__input-caption{min-width:-webkit-max-content;min-width:-moz-max-content;min-width:max-content}.mfui-pagination__input-field{width:90px}
@@ -1,22 +1,31 @@
1
1
  import * as React from 'react';
2
+ import { PaginationTypesType, ThemeType, ValueType } from './types';
2
3
  import './Pagination.scss';
3
- import { PaginationValueType } from './components/PaginationButton/PaginationButton';
4
4
  interface IPaginationProps {
5
+ /** Общее количество страниц */
6
+ totalPages: number;
7
+ /** Номер текущей страницы */
8
+ activePage: number;
9
+ /** Тип компонента. DEPRECATED: 'classic' */
10
+ type?: PaginationTypesType;
11
+ /** Цветовая тема компонента */
12
+ theme?: ThemeType;
13
+ /** Отобразить поле ввода номера страницы */
14
+ showSelectPage?: boolean;
15
+ /** Обработчик изменения активной страницы */
16
+ onChange: (value: ValueType) => void;
17
+ /** Дополнительный класс корневого элемента */
18
+ className?: string;
5
19
  /** Дополнительные data атрибуты к внутренним элементам */
6
20
  dataAttrs?: {
7
21
  root?: Record<string, string>;
8
22
  prev?: Record<string, string>;
9
23
  next?: Record<string, string>;
10
24
  button?: Record<string, string>;
25
+ skipPrev?: Record<string, string>;
26
+ skipNext?: Record<string, string>;
27
+ input?: Record<string, string>;
11
28
  };
12
- /** Общее количество страниц */
13
- totalPages: number;
14
- /** Номер текущей страницы */
15
- activePage: number;
16
- /** Тема компонента */
17
- theme?: 'default' | 'light';
18
- /** Обработчик изменения активной страницы */
19
- onChange: (value: PaginationValueType) => void;
20
29
  }
21
30
  declare const Pagination: React.FC<IPaginationProps>;
22
31
  export default Pagination;