@salutejs/plasma-core 1.226.1-next-sbcom.0 → 1.227.0-dev.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 (247) hide show
  1. package/__helpers/IconPlaceholder.js +6 -9
  2. package/__helpers/index.js +1 -1
  3. package/collectPackageInfo.js +4 -4
  4. package/components/Badge/Badge.js +30 -103
  5. package/components/Badge/index.js +1 -1
  6. package/components/Basebox/Basebox.js +33 -42
  7. package/components/Basebox/index.js +1 -1
  8. package/components/Button/Button.js +28 -67
  9. package/components/Button/Button.mixins.js +22 -76
  10. package/components/Button/Button.props.js +5 -5
  11. package/components/Button/createButton.js +14 -145
  12. package/components/Button/index.js +4 -4
  13. package/components/Card/Card.js +34 -162
  14. package/components/Card/CardBody.js +4 -4
  15. package/components/Card/CardContent.js +14 -23
  16. package/components/Card/CardMedia.js +20 -91
  17. package/components/Card/CardPrice.js +18 -60
  18. package/components/Card/CardTypography.js +43 -52
  19. package/components/Card/index.js +5 -5
  20. package/components/Carousel/Carousel.js +46 -64
  21. package/components/Carousel/CarouselItem.js +21 -93
  22. package/components/Carousel/hooks.js +62 -121
  23. package/components/Carousel/index.js +3 -3
  24. package/components/Carousel/utils.js +59 -73
  25. package/components/Fade/Fade.js +6 -9
  26. package/components/Fade/index.js +1 -1
  27. package/components/Field/Field.js +48 -63
  28. package/components/Field/Field.statuses.js +3 -3
  29. package/components/Field/index.js +2 -2
  30. package/components/Image/Image.js +34 -115
  31. package/components/Image/index.js +1 -1
  32. package/components/Input/Input.js +7 -7
  33. package/components/Input/Input.mixins.js +9 -12
  34. package/components/Input/index.js +1 -1
  35. package/components/ModalBase/ModalBase.js +22 -100
  36. package/components/ModalBase/ModalBaseContext.js +6 -9
  37. package/components/ModalBase/ModalOverlay.js +28 -111
  38. package/components/ModalBase/hooks.js +15 -43
  39. package/components/ModalBase/index.js +2 -2
  40. package/components/PaginationDots/PaginationDot.js +11 -17
  41. package/components/PaginationDots/PaginationDots.js +4 -7
  42. package/components/PaginationDots/index.js +3 -3
  43. package/components/PaginationDots/usePaginationDots.js +10 -11
  44. package/components/Popup/Popup.js +52 -205
  45. package/components/Popup/index.js +1 -1
  46. package/components/PopupBase/PopupBase.js +35 -169
  47. package/components/PopupBase/PopupBaseContext.js +26 -86
  48. package/components/PopupBase/PopupBaseRoot.js +31 -169
  49. package/components/PopupBase/hooks.js +23 -97
  50. package/components/PopupBase/index.js +3 -3
  51. package/components/PopupBase/utils.js +32 -78
  52. package/components/Price/Price.js +15 -90
  53. package/components/Price/index.js +1 -1
  54. package/components/RadioGroup/RadioGroup.js +6 -127
  55. package/components/RadioGroup/index.js +1 -1
  56. package/components/SSRProvider/SSRProvider.js +4 -5
  57. package/components/SSRProvider/index.js +1 -1
  58. package/components/Skeleton/LineSkeleton.js +23 -95
  59. package/components/Skeleton/RectSkeleton.js +20 -93
  60. package/components/Skeleton/Skeleton.js +2 -2
  61. package/components/Skeleton/TextSkeleton.js +11 -55
  62. package/components/Skeleton/index.js +3 -3
  63. package/components/Slider/Double.js +52 -203
  64. package/components/Slider/Handle.js +28 -158
  65. package/components/Slider/Single.js +29 -177
  66. package/components/Slider/Slider.js +5 -7
  67. package/components/Slider/SliderBase.js +39 -48
  68. package/components/Slider/ThumbBase.js +19 -95
  69. package/components/Slider/index.js +3 -3
  70. package/components/Slider/utils.js +2 -2
  71. package/components/Spinner/Spinner.js +28 -100
  72. package/components/Spinner/SpinnerSvg.js +9 -78
  73. package/components/Spinner/index.js +1 -1
  74. package/components/Switch/Switch.js +49 -220
  75. package/components/Switch/index.js +1 -1
  76. package/components/Tabs/TabItem.js +33 -168
  77. package/components/Tabs/Tabs.js +32 -170
  78. package/components/Tabs/TabsContext.js +12 -42
  79. package/components/Tabs/createTabsController.js +33 -168
  80. package/components/Tabs/index.js +4 -4
  81. package/components/TextArea/TextArea.js +20 -30
  82. package/components/TextArea/index.js +1 -1
  83. package/components/TextField/index.js +3 -3
  84. package/components/Toast/Toast.js +15 -16
  85. package/components/Toast/ToastContext.js +4 -8
  86. package/components/Toast/ToastController.js +44 -101
  87. package/components/Toast/ToastProvider.js +37 -142
  88. package/components/Toast/index.js +3 -3
  89. package/components/Toast/useToast.js +6 -6
  90. package/components/Typography/Body.js +18 -18
  91. package/components/Typography/Button.js +13 -13
  92. package/components/Typography/Caption.js +8 -8
  93. package/components/Typography/Display.js +18 -18
  94. package/components/Typography/Footnote.js +13 -13
  95. package/components/Typography/Headline.js +43 -43
  96. package/components/Typography/Paragraph.js +24 -24
  97. package/components/Typography/Underline.js +8 -8
  98. package/es/__helpers/IconPlaceholder.js +5 -8
  99. package/es/collectPackageInfo.js +3 -3
  100. package/es/components/Badge/Badge.js +27 -100
  101. package/es/components/Basebox/Basebox.js +28 -37
  102. package/es/components/Button/Button.js +24 -63
  103. package/es/components/Button/Button.mixins.js +19 -73
  104. package/es/components/Button/Button.props.js +3 -3
  105. package/es/components/Button/createButton.js +12 -143
  106. package/es/components/Card/Card.js +29 -157
  107. package/es/components/Card/CardBody.js +2 -2
  108. package/es/components/Card/CardContent.js +12 -21
  109. package/es/components/Card/CardMedia.js +17 -88
  110. package/es/components/Card/CardPrice.js +13 -55
  111. package/es/components/Card/CardTypography.js +43 -52
  112. package/es/components/Carousel/Carousel.js +45 -63
  113. package/es/components/Carousel/CarouselItem.js +18 -90
  114. package/es/components/Carousel/hooks.js +58 -117
  115. package/es/components/Carousel/utils.js +58 -72
  116. package/es/components/Fade/Fade.js +5 -8
  117. package/es/components/Field/Field.js +44 -59
  118. package/es/components/Field/Field.statuses.js +4 -4
  119. package/es/components/Image/Image.js +31 -112
  120. package/es/components/Input/Input.js +4 -4
  121. package/es/components/Input/Input.mixins.js +6 -9
  122. package/es/components/ModalBase/ModalBase.js +16 -94
  123. package/es/components/ModalBase/ModalBaseContext.js +6 -9
  124. package/es/components/ModalBase/ModalOverlay.js +23 -106
  125. package/es/components/ModalBase/hooks.js +12 -40
  126. package/es/components/PaginationDots/PaginationDot.js +9 -15
  127. package/es/components/PaginationDots/PaginationDots.js +3 -6
  128. package/es/components/PaginationDots/usePaginationDots.js +9 -10
  129. package/es/components/Popup/Popup.js +48 -201
  130. package/es/components/PopupBase/PopupBase.js +27 -161
  131. package/es/components/PopupBase/PopupBaseContext.js +25 -85
  132. package/es/components/PopupBase/PopupBaseRoot.js +26 -164
  133. package/es/components/PopupBase/hooks.js +21 -95
  134. package/es/components/PopupBase/utils.js +31 -77
  135. package/es/components/Price/Price.js +12 -87
  136. package/es/components/RadioGroup/RadioGroup.js +5 -126
  137. package/es/components/SSRProvider/SSRProvider.js +3 -4
  138. package/es/components/Skeleton/LineSkeleton.js +18 -90
  139. package/es/components/Skeleton/RectSkeleton.js +16 -89
  140. package/es/components/Skeleton/Skeleton.js +2 -2
  141. package/es/components/Skeleton/TextSkeleton.js +7 -51
  142. package/es/components/Slider/Double.js +49 -200
  143. package/es/components/Slider/Handle.js +23 -153
  144. package/es/components/Slider/Single.js +26 -174
  145. package/es/components/Slider/Slider.js +2 -4
  146. package/es/components/Slider/SliderBase.js +36 -45
  147. package/es/components/Slider/ThumbBase.js +16 -92
  148. package/es/components/Slider/index.js +1 -1
  149. package/es/components/Slider/utils.js +2 -2
  150. package/es/components/Spinner/Spinner.js +23 -95
  151. package/es/components/Spinner/SpinnerSvg.js +8 -77
  152. package/es/components/Switch/Switch.js +45 -216
  153. package/es/components/Tabs/TabItem.js +28 -163
  154. package/es/components/Tabs/Tabs.js +28 -166
  155. package/es/components/Tabs/TabsContext.js +11 -41
  156. package/es/components/Tabs/createTabsController.js +28 -163
  157. package/es/components/TextArea/TextArea.js +18 -28
  158. package/es/components/Toast/Toast.js +10 -11
  159. package/es/components/Toast/ToastContext.js +3 -7
  160. package/es/components/Toast/ToastController.js +38 -95
  161. package/es/components/Toast/ToastProvider.js +34 -139
  162. package/es/components/Toast/useToast.js +4 -4
  163. package/es/components/Typography/Body.js +15 -15
  164. package/es/components/Typography/Button.js +10 -10
  165. package/es/components/Typography/Caption.js +5 -5
  166. package/es/components/Typography/Display.js +15 -15
  167. package/es/components/Typography/Footnote.js +10 -10
  168. package/es/components/Typography/Headline.js +40 -40
  169. package/es/components/Typography/Paragraph.js +21 -21
  170. package/es/components/Typography/Underline.js +5 -5
  171. package/es/hocs/withAutoFocus.js +8 -78
  172. package/es/hocs/withSkeleton.js +5 -10
  173. package/es/hooks/useDebouncedFunction.js +4 -36
  174. package/es/hooks/useFocusTrap.js +18 -21
  175. package/es/hooks/useForkRef.js +3 -3
  176. package/es/hooks/useIsomorphicLayoutEffect.js +1 -1
  177. package/es/hooks/useResizeObserver.js +8 -8
  178. package/es/hooks/useUniqId.js +6 -52
  179. package/es/mixins/addFocus.js +17 -22
  180. package/es/mixins/applyDisabled.js +6 -9
  181. package/es/mixins/applyEllipsis.js +2 -4
  182. package/es/mixins/applyMaxLines.js +3 -6
  183. package/es/mixins/applyNoSelect.js +2 -4
  184. package/es/mixins/applyOutline.js +2 -4
  185. package/es/mixins/applyRoundness.js +4 -7
  186. package/es/mixins/applyScrollSnap.js +4 -7
  187. package/es/mixins/applySkeletonGradient.js +6 -9
  188. package/es/mixins/applyView.js +2 -5
  189. package/es/mixins/blur.js +2 -5
  190. package/es/mixins/shadows.js +1 -1
  191. package/es/tokens/colors.js +48 -48
  192. package/es/tokens/typography.js +18 -18
  193. package/es/utils/__tests__/formatters.test.js +2 -2
  194. package/es/utils/animatedScrollTo.js +24 -34
  195. package/es/utils/canUseDOM.js +1 -1
  196. package/es/utils/extractTextFrom.js +3 -7
  197. package/es/utils/focusManager.js +40 -47
  198. package/es/utils/formatCurrency.js +4 -4
  199. package/es/utils/formatters.js +6 -14
  200. package/es/utils/react.js +4 -4
  201. package/es/utils/roundness.js +2 -4
  202. package/es/utils/scopeTab.js +5 -5
  203. package/es/utils/setRef.js +1 -1
  204. package/es/utils/tabbable.js +16 -25
  205. package/es/utils/toCssSize.js +1 -3
  206. package/es/utils/transformStyles.js +5 -60
  207. package/hocs/index.js +2 -2
  208. package/hocs/withAutoFocus.js +9 -79
  209. package/hocs/withSkeleton.js +8 -13
  210. package/hooks/index.js +6 -6
  211. package/hooks/useDebouncedFunction.js +5 -37
  212. package/hooks/useFocusTrap.js +22 -25
  213. package/hooks/useForkRef.js +5 -5
  214. package/hooks/useIsomorphicLayoutEffect.js +3 -3
  215. package/hooks/useResizeObserver.js +9 -9
  216. package/hooks/useUniqId.js +8 -54
  217. package/mixins/addFocus.js +19 -24
  218. package/mixins/applyDisabled.js +7 -10
  219. package/mixins/applyEllipsis.js +3 -5
  220. package/mixins/applyMaxLines.js +4 -7
  221. package/mixins/applyNoSelect.js +3 -5
  222. package/mixins/applyOutline.js +3 -5
  223. package/mixins/applyRoundness.js +5 -8
  224. package/mixins/applyScrollSnap.js +5 -8
  225. package/mixins/applySkeletonGradient.js +8 -11
  226. package/mixins/applyView.js +3 -6
  227. package/mixins/blur.js +2 -5
  228. package/mixins/index.js +11 -11
  229. package/mixins/shadows.js +1 -1
  230. package/package.json +13 -18
  231. package/tokens/colors.js +48 -48
  232. package/tokens/typography.js +18 -18
  233. package/utils/__tests__/formatters.test.js +3 -3
  234. package/utils/animatedScrollTo.js +24 -34
  235. package/utils/canUseDOM.js +1 -1
  236. package/utils/extractTextFrom.js +4 -8
  237. package/utils/focusManager.js +41 -48
  238. package/utils/formatCurrency.js +4 -4
  239. package/utils/formatters.js +6 -14
  240. package/utils/index.js +10 -10
  241. package/utils/react.js +7 -7
  242. package/utils/roundness.js +2 -4
  243. package/utils/scopeTab.js +6 -6
  244. package/utils/setRef.js +1 -1
  245. package/utils/tabbable.js +16 -25
  246. package/utils/toCssSize.js +1 -3
  247. package/utils/transformStyles.js +5 -60
@@ -1,75 +1,75 @@
1
1
  import styled from 'styled-components';
2
2
  import { headline1, headline2, headline3, headline4 } from '../../tokens';
3
3
  import { applyHyphens, applySpacing } from '../../mixins';
4
- export var Headline1 = styled.div.withConfig({
4
+ export const Headline1 = styled.div.withConfig({
5
5
  displayName: "Headline__Headline1",
6
6
  componentId: "sc-ae2aff6b-0"
7
7
  })([
8
- "",
9
- " ",
10
- " ",
11
- ""
8
+ ``,
9
+ ` `,
10
+ ` `,
11
+ ``
12
12
  ], applyHyphens, applySpacing, headline1);
13
- export var Headline2 = styled.div.withConfig({
13
+ export const Headline2 = styled.div.withConfig({
14
14
  displayName: "Headline__Headline2",
15
15
  componentId: "sc-ae2aff6b-1"
16
16
  })([
17
- "",
18
- " ",
19
- " ",
20
- ""
17
+ ``,
18
+ ` `,
19
+ ` `,
20
+ ``
21
21
  ], applyHyphens, applySpacing, headline2);
22
- export var Headline3 = styled.div.withConfig({
22
+ export const Headline3 = styled.div.withConfig({
23
23
  displayName: "Headline__Headline3",
24
24
  componentId: "sc-ae2aff6b-2"
25
25
  })([
26
- "",
27
- " ",
28
- " ",
29
- ""
26
+ ``,
27
+ ` `,
28
+ ` `,
29
+ ``
30
30
  ], applyHyphens, applySpacing, headline3);
31
- export var Headline4 = styled.div.withConfig({
31
+ export const Headline4 = styled.div.withConfig({
32
32
  displayName: "Headline__Headline4",
33
33
  componentId: "sc-ae2aff6b-3"
34
34
  })([
35
- "",
36
- " ",
37
- " ",
38
- ""
35
+ ``,
36
+ ` `,
37
+ ` `,
38
+ ``
39
39
  ], applyHyphens, applySpacing, headline4);
40
- export var H1 = styled.h1.withConfig({
40
+ export const H1 = styled.h1.withConfig({
41
41
  displayName: "Headline__H1",
42
42
  componentId: "sc-ae2aff6b-4"
43
43
  })([
44
- "margin:0;",
45
- " ",
46
- " ",
47
- ""
44
+ `margin:0;`,
45
+ ` `,
46
+ ` `,
47
+ ``
48
48
  ], applyHyphens, applySpacing, headline1);
49
- export var H2 = styled.h2.withConfig({
49
+ export const H2 = styled.h2.withConfig({
50
50
  displayName: "Headline__H2",
51
51
  componentId: "sc-ae2aff6b-5"
52
52
  })([
53
- "margin:0;",
54
- " ",
55
- " ",
56
- ""
53
+ `margin:0;`,
54
+ ` `,
55
+ ` `,
56
+ ``
57
57
  ], applyHyphens, applySpacing, headline2);
58
- export var H3 = styled.h3.withConfig({
58
+ export const H3 = styled.h3.withConfig({
59
59
  displayName: "Headline__H3",
60
60
  componentId: "sc-ae2aff6b-6"
61
61
  })([
62
- "margin:0;",
63
- " ",
64
- " ",
65
- ""
62
+ `margin:0;`,
63
+ ` `,
64
+ ` `,
65
+ ``
66
66
  ], applyHyphens, applySpacing, headline3);
67
- export var H4 = styled.h4.withConfig({
67
+ export const H4 = styled.h4.withConfig({
68
68
  displayName: "Headline__H4",
69
69
  componentId: "sc-ae2aff6b-7"
70
70
  })([
71
- "margin:0;",
72
- " ",
73
- " ",
74
- ""
71
+ `margin:0;`,
72
+ ` `,
73
+ ` `,
74
+ ``
75
75
  ], applyHyphens, applySpacing, headline4);
@@ -1,40 +1,40 @@
1
1
  import styled from 'styled-components';
2
2
  import { paragraph1, paragraph2 } from '../../tokens';
3
3
  import { applyHyphens, applySpacing } from '../../mixins';
4
- export var ParagraphText1 = styled.div.withConfig({
4
+ export const ParagraphText1 = styled.div.withConfig({
5
5
  displayName: "Paragraph__ParagraphText1",
6
6
  componentId: "sc-96b4c682-0"
7
7
  })([
8
- "",
9
- " ",
10
- " ",
11
- ""
8
+ ``,
9
+ ` `,
10
+ ` `,
11
+ ``
12
12
  ], applyHyphens, applySpacing, paragraph1);
13
- export var ParagraphText2 = styled.div.withConfig({
13
+ export const ParagraphText2 = styled.div.withConfig({
14
14
  displayName: "Paragraph__ParagraphText2",
15
15
  componentId: "sc-96b4c682-1"
16
16
  })([
17
- "",
18
- " ",
19
- " ",
20
- ""
17
+ ``,
18
+ ` `,
19
+ ` `,
20
+ ``
21
21
  ], applyHyphens, applySpacing, paragraph2);
22
- export var P1 = styled.p.withConfig({
22
+ export const P1 = styled.p.withConfig({
23
23
  displayName: "Paragraph__P1",
24
24
  componentId: "sc-96b4c682-2"
25
25
  })([
26
- "",
27
- " ",
28
- " ",
29
- " margin:0;"
26
+ ``,
27
+ ` `,
28
+ ` `,
29
+ ` margin:0;`
30
30
  ], applyHyphens, applySpacing, paragraph1);
31
- export var P = P1;
32
- export var P2 = styled.p.withConfig({
31
+ export const P = P1;
32
+ export const P2 = styled.p.withConfig({
33
33
  displayName: "Paragraph__P2",
34
34
  componentId: "sc-96b4c682-3"
35
35
  })([
36
- "",
37
- " ",
38
- " ",
39
- " margin:0;"
36
+ ``,
37
+ ` `,
38
+ ` `,
39
+ ` margin:0;`
40
40
  ], applyHyphens, applySpacing, paragraph2);
@@ -1,12 +1,12 @@
1
1
  import styled from 'styled-components';
2
2
  import { underline } from '../../tokens';
3
3
  import { applyHyphens, applySpacing } from '../../mixins';
4
- export var Underline = styled.div.withConfig({
4
+ export const Underline = styled.div.withConfig({
5
5
  displayName: "Underline",
6
6
  componentId: "sc-7613e3f0-0"
7
7
  })([
8
- "",
9
- " ",
10
- " ",
11
- " text-transform:uppercase;"
8
+ ``,
9
+ ` `,
10
+ ` `,
11
+ ` text-transform:uppercase;`
12
12
  ], applyHyphens, applySpacing, underline);
@@ -1,86 +1,16 @@
1
- function _define_property(obj, key, value) {
2
- if (key in obj) {
3
- Object.defineProperty(obj, key, {
4
- value: value,
5
- enumerable: true,
6
- configurable: true,
7
- writable: true
8
- });
9
- } else {
10
- obj[key] = value;
11
- }
12
- return obj;
13
- }
14
- function _object_spread(target) {
15
- for(var i = 1; i < arguments.length; i++){
16
- var source = arguments[i] != null ? arguments[i] : {};
17
- var ownKeys = Object.keys(source);
18
- if (typeof Object.getOwnPropertySymbols === "function") {
19
- ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function(sym) {
20
- return Object.getOwnPropertyDescriptor(source, sym).enumerable;
21
- }));
22
- }
23
- ownKeys.forEach(function(key) {
24
- _define_property(target, key, source[key]);
25
- });
26
- }
27
- return target;
28
- }
29
- function _object_without_properties(source, excluded) {
30
- if (source == null) return {};
31
- var target = {}, sourceKeys, key, i;
32
- if (typeof Reflect !== "undefined" && Reflect.ownKeys) {
33
- sourceKeys = Reflect.ownKeys(source);
34
- for(i = 0; i < sourceKeys.length; i++){
35
- key = sourceKeys[i];
36
- if (excluded.indexOf(key) >= 0) continue;
37
- if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue;
38
- target[key] = source[key];
39
- }
40
- return target;
41
- }
42
- target = _object_without_properties_loose(source, excluded);
43
- if (Object.getOwnPropertySymbols) {
44
- sourceKeys = Object.getOwnPropertySymbols(source);
45
- for(i = 0; i < sourceKeys.length; i++){
46
- key = sourceKeys[i];
47
- if (excluded.indexOf(key) >= 0) continue;
48
- if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue;
49
- target[key] = source[key];
50
- }
51
- }
52
- return target;
53
- }
54
- function _object_without_properties_loose(source, excluded) {
55
- if (source == null) return {};
56
- var target = {}, sourceKeys = Object.getOwnPropertyNames(source), key, i;
57
- for(i = 0; i < sourceKeys.length; i++){
58
- key = sourceKeys[i];
59
- if (excluded.indexOf(key) >= 0) continue;
60
- if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue;
61
- target[key] = source[key];
62
- }
63
- return target;
64
- }
65
1
  import React, { useEffect, useRef } from 'react';
66
- export var withAutoFocus = function withAutoFocus(Component) {
67
- return function(_0) {
68
- var autoFocus = _0.autoFocus, _0_tabIndex = _0.tabIndex, tabIndex = _0_tabIndex === void 0 ? -1 : _0_tabIndex, _0_preventScroll = _0.preventScroll, preventScroll = _0_preventScroll === void 0 ? true : _0_preventScroll, props = _object_without_properties(_0, [
69
- "autoFocus",
70
- "tabIndex",
71
- "preventScroll"
72
- ]);
73
- var divRef = useRef(null);
74
- useEffect(function() {
2
+ export const withAutoFocus = (Component)=>({ autoFocus, tabIndex = -1, preventScroll = true, ...props })=>{
3
+ const divRef = useRef(null);
4
+ useEffect(()=>{
75
5
  if (autoFocus && divRef.current) {
76
6
  divRef.current.focus({
77
- preventScroll: preventScroll
7
+ preventScroll
78
8
  });
79
9
  }
80
10
  });
81
- return /*#__PURE__*/ React.createElement(Component, _object_spread({
11
+ return /*#__PURE__*/ React.createElement(Component, {
82
12
  tabIndex: tabIndex,
83
- ref: divRef
84
- }, props));
13
+ ref: divRef,
14
+ ...props
15
+ });
85
16
  };
86
- };
@@ -4,17 +4,12 @@ import { applySkeletonGradient } from '../mixins';
4
4
  /**
5
5
  * Делает компонент скелетоном - у него заменяется фоновый цвет,
6
6
  * добавляется градиент и текст становится на 100% прозрачным.
7
- */ export var withSkeleton = function withSkeleton(Component) {
8
- return styled(Component).withConfig({
7
+ */ export const withSkeleton = (Component)=>styled(Component).withConfig({
9
8
  displayName: "withSkeleton",
10
9
  componentId: "sc-764f817c-0"
11
10
  })([
12
- "",
13
- ""
14
- ], function(param) {
15
- var skeleton = param.skeleton;
16
- return skeleton && applySkeletonGradient({
11
+ ``,
12
+ ``
13
+ ], ({ skeleton })=>skeleton && applySkeletonGradient({
17
14
  lighter: true
18
- });
19
- });
20
- };
15
+ }));
@@ -1,28 +1,3 @@
1
- function _array_like_to_array(arr, len) {
2
- if (len == null || len > arr.length) len = arr.length;
3
- for(var i = 0, arr2 = new Array(len); i < len; i++)arr2[i] = arr[i];
4
- return arr2;
5
- }
6
- function _array_without_holes(arr) {
7
- if (Array.isArray(arr)) return _array_like_to_array(arr);
8
- }
9
- function _iterable_to_array(iter) {
10
- if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter);
11
- }
12
- function _non_iterable_spread() {
13
- throw new TypeError("Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
14
- }
15
- function _to_consumable_array(arr) {
16
- return _array_without_holes(arr) || _iterable_to_array(arr) || _unsupported_iterable_to_array(arr) || _non_iterable_spread();
17
- }
18
- function _unsupported_iterable_to_array(o, minLen) {
19
- if (!o) return;
20
- if (typeof o === "string") return _array_like_to_array(o, minLen);
21
- var n = Object.prototype.toString.call(o).slice(8, -1);
22
- if (n === "Object" && o.constructor) n = o.constructor.name;
23
- if (n === "Map" || n === "Set") return Array.from(n);
24
- if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _array_like_to_array(o, minLen);
25
- }
26
1
  import React from 'react';
27
2
  /**
28
3
  * @param {Function} func
@@ -30,7 +5,7 @@ import React from 'react';
30
5
  * @param {boolean} cleanUp
31
6
  * https://habr.com/ru/company/domclick/blog/510616/
32
7
  */ export function useDebouncedFunction(func, delay, cleanUp) {
33
- var timeoutRef = React.useRef();
8
+ const timeoutRef = React.useRef();
34
9
  /**
35
10
  * Очистка таймера
36
11
  */ function clearTimer() {
@@ -42,18 +17,11 @@ import React from 'react';
42
17
  /**
43
18
  * Очищаем таймер при анмаунте компонента, если cleanUp выставлен в true
44
19
  * и тем самым отменяем последний запланированный вызов
45
- */ React.useEffect(function() {
46
- return cleanUp ? clearTimer : undefined;
47
- }, [
20
+ */ React.useEffect(()=>cleanUp ? clearTimer : undefined, [
48
21
  cleanUp
49
22
  ]);
50
- return function() {
51
- for(var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++){
52
- args[_key] = arguments[_key];
53
- }
23
+ return (...args)=>{
54
24
  clearTimer();
55
- timeoutRef.current = setTimeout(function() {
56
- return func.apply(void 0, _to_consumable_array(args));
57
- }, delay);
25
+ timeoutRef.current = setTimeout(()=>func(...args), delay);
58
26
  };
59
27
  }
@@ -3,8 +3,8 @@ import { FocusManager } from '../utils/focusManager';
3
3
  import { focusSelector, isFocusable, isTabble } from '../utils/tabbable';
4
4
  import { scopeTab } from '../utils/scopeTab';
5
5
  // Находим элемент для фокуса
6
- var getFocusElement = function getFocusElement(node, firstFocusSelector) {
7
- var focusElement = null;
6
+ const getFocusElement = (node, firstFocusSelector)=>{
7
+ let focusElement = null;
8
8
  if (firstFocusSelector) {
9
9
  if (typeof firstFocusSelector === 'string') {
10
10
  focusElement = node.querySelector(firstFocusSelector);
@@ -13,10 +13,8 @@ var getFocusElement = function getFocusElement(node, firstFocusSelector) {
13
13
  }
14
14
  }
15
15
  if (!focusElement) {
16
- var children = Array.from(node.querySelectorAll(focusSelector));
17
- focusElement = children.find(function(el) {
18
- return isTabble(el);
19
- }) || null;
16
+ const children = Array.from(node.querySelectorAll(focusSelector));
17
+ focusElement = children.find((el)=>isTabble(el)) || null;
20
18
  }
21
19
  // Если ничего не нашлось, то может ли сама нода быть под фокусом
22
20
  if (!focusElement && isFocusable(node)) {
@@ -24,24 +22,23 @@ var getFocusElement = function getFocusElement(node, firstFocusSelector) {
24
22
  }
25
23
  return focusElement;
26
24
  };
27
- var processNode = function processNode1(node, firstFocusSelector, ref) {
28
- if (ref === null || ref === void 0 ? void 0 : ref.current) {
29
- ref.current.removeEventListener('animationend', function() {
25
+ const processNode = (node, firstFocusSelector, ref)=>{
26
+ if (ref?.current) {
27
+ ref.current.removeEventListener('animationend', ()=>{
30
28
  processNode(node, firstFocusSelector, ref);
31
29
  });
32
30
  }
33
- var focusElement = getFocusElement(node, firstFocusSelector);
31
+ const focusElement = getFocusElement(node, firstFocusSelector);
34
32
  if (focusElement) {
35
33
  focusElement.focus();
36
34
  }
37
35
  };
38
- var focusManager = new FocusManager();
36
+ const focusManager = new FocusManager();
39
37
  /**
40
38
  * Захватывает фокус внутри DOM node.
41
- * */ export var useFocusTrap = function useFocusTrap() {
42
- var active = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : true, firstFocusSelector = arguments.length > 1 ? arguments[1] : void 0, focusAfterNode = arguments.length > 2 ? arguments[2] : void 0, focusAfterAnimation = arguments.length > 3 ? arguments[3] : void 0;
43
- var ref = useRef();
44
- var setRef = useCallback(function(node) {
39
+ * */ export const useFocusTrap = (active = true, firstFocusSelector, focusAfterNode, focusAfterAnimation)=>{
40
+ const ref = useRef();
41
+ const setRef = useCallback((node)=>{
45
42
  if (ref.current) {
46
43
  focusManager.teardownScopedFocus();
47
44
  focusManager.returnFocus();
@@ -50,9 +47,9 @@ var focusManager = new FocusManager();
50
47
  focusManager.setupScopedFocus(node);
51
48
  focusManager.markForFocusAfter(focusAfterNode);
52
49
  // Delay processing the HTML node by a frame. This ensures focus is assigned correctly.
53
- setTimeout(function() {
54
- if ((ref === null || ref === void 0 ? void 0 : ref.current) && node.ownerDocument && focusAfterAnimation) {
55
- ref.current.addEventListener('animationend', function() {
50
+ setTimeout(()=>{
51
+ if (ref?.current && node.ownerDocument && focusAfterAnimation) {
52
+ ref.current.addEventListener('animationend', ()=>{
56
53
  processNode(node, firstFocusSelector, ref);
57
54
  });
58
55
  } else if (node.ownerDocument) {
@@ -67,17 +64,17 @@ var focusManager = new FocusManager();
67
64
  active,
68
65
  firstFocusSelector
69
66
  ]);
70
- useEffect(function() {
67
+ useEffect(()=>{
71
68
  if (!active) {
72
69
  return;
73
70
  }
74
- var handleKeyDown = function handleKeyDown(event) {
71
+ const handleKeyDown = (event)=>{
75
72
  if (event.key === 'Tab' && ref.current) {
76
73
  scopeTab(ref.current, event);
77
74
  }
78
75
  };
79
76
  document.addEventListener('keydown', handleKeyDown);
80
- return function() {
77
+ return ()=>{
81
78
  document.removeEventListener('keydown', handleKeyDown);
82
79
  };
83
80
  }, [
@@ -5,12 +5,12 @@ import { setRef } from '../utils';
5
5
  * @param {React.Ref<T>} refOne
6
6
  * @param {React.Ref<T>} refTwo
7
7
  * @return {Function React.Ref}
8
- */ export var useForkRef = function useForkRef(refOne, refTwo) {
9
- return React.useMemo(function() {
8
+ */ export const useForkRef = (refOne, refTwo)=>{
9
+ return React.useMemo(()=>{
10
10
  if (refOne == null && refTwo === null) {
11
11
  return null;
12
12
  }
13
- return function(refOb) {
13
+ return (refOb)=>{
14
14
  setRef(refOne, refOb);
15
15
  setRef(refTwo, refOb);
16
16
  };
@@ -2,4 +2,4 @@ import { useLayoutEffect, useEffect } from 'react';
2
2
  import { canUseDOM } from '../utils';
3
3
  /**
4
4
  * Runs effect safely on server.
5
- */ export var useIsomorphicLayoutEffect = canUseDOM ? useLayoutEffect : useEffect;
5
+ */ export const useIsomorphicLayoutEffect = canUseDOM ? useLayoutEffect : useEffect;
@@ -4,20 +4,20 @@ import { useEffect } from 'react';
4
4
  * @param {React.Ref<T>} ref - реф элемента, за которым нужно следить
5
5
  * @callback callback - функция, которая вызывается при изменении элемента
6
6
  * @param {Element} element - элемент, размер которого изменился
7
- */ export var useResizeObserver = function useResizeObserver(ref, callback) {
8
- useEffect(function() {
9
- /* istanbul ignore if: убираем проверку на рефы из покрытия */ if (!(ref === null || ref === void 0 ? void 0 : ref.current)) {
7
+ */ export const useResizeObserver = (ref, callback)=>{
8
+ useEffect(()=>{
9
+ /* istanbul ignore if: убираем проверку на рефы из покрытия */ if (!ref?.current) {
10
10
  return;
11
11
  }
12
- var current = ref.current;
13
- var resizeObserver = new window.ResizeObserver(function() {
14
- window.requestAnimationFrame(function() {
12
+ const { current } = ref;
13
+ const resizeObserver = new window.ResizeObserver(()=>{
14
+ window.requestAnimationFrame(()=>{
15
15
  callback(current);
16
16
  });
17
17
  });
18
18
  resizeObserver.observe(ref.current);
19
- return function() {
20
- /* istanbul ignore if: убираем проверку на рефы из покрытия */ if (!(ref === null || ref === void 0 ? void 0 : ref.current)) {
19
+ return ()=>{
20
+ /* istanbul ignore if: убираем проверку на рефы из покрытия */ if (!ref?.current) {
21
21
  return;
22
22
  }
23
23
  resizeObserver.unobserve(ref.current);
@@ -1,59 +1,13 @@
1
- function _array_like_to_array(arr, len) {
2
- if (len == null || len > arr.length) len = arr.length;
3
- for(var i = 0, arr2 = new Array(len); i < len; i++)arr2[i] = arr[i];
4
- return arr2;
5
- }
6
- function _array_with_holes(arr) {
7
- if (Array.isArray(arr)) return arr;
8
- }
9
- function _iterable_to_array_limit(arr, i) {
10
- var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"];
11
- if (_i == null) return;
12
- var _arr = [];
13
- var _n = true;
14
- var _d = false;
15
- var _s, _e;
16
- try {
17
- for(_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true){
18
- _arr.push(_s.value);
19
- if (i && _arr.length === i) break;
20
- }
21
- } catch (err) {
22
- _d = true;
23
- _e = err;
24
- } finally{
25
- try {
26
- if (!_n && _i["return"] != null) _i["return"]();
27
- } finally{
28
- if (_d) throw _e;
29
- }
30
- }
31
- return _arr;
32
- }
33
- function _non_iterable_rest() {
34
- throw new TypeError("Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
35
- }
36
- function _sliced_to_array(arr, i) {
37
- return _array_with_holes(arr) || _iterable_to_array_limit(arr, i) || _unsupported_iterable_to_array(arr, i) || _non_iterable_rest();
38
- }
39
- function _unsupported_iterable_to_array(o, minLen) {
40
- if (!o) return;
41
- if (typeof o === "string") return _array_like_to_array(o, minLen);
42
- var n = Object.prototype.toString.call(o).slice(8, -1);
43
- if (n === "Object" && o.constructor) n = o.constructor.name;
44
- if (n === "Map" || n === "Set") return Array.from(n);
45
- if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _array_like_to_array(o, minLen);
46
- }
47
1
  import { useState, useContext } from 'react';
48
2
  import { SSRContext } from '../components/SSRProvider';
49
- var noSSRId = 0;
3
+ let noSSRId = 0;
50
4
  export function useUniqId() {
51
- var context = useContext(SSRContext);
52
- var _useState = _sliced_to_array(useState(function() {
5
+ const context = useContext(SSRContext);
6
+ const [id] = useState(()=>{
53
7
  if (context.uniqId !== null) {
54
- return "plasma-uniq-id-ssr-".concat(++context.uniqId);
8
+ return `plasma-uniq-id-ssr-${++context.uniqId}`;
55
9
  }
56
- return "plasma-uniq-id-".concat(++noSSRId);
57
- }), 1), id = _useState[0];
10
+ return `plasma-uniq-id-${++noSSRId}`;
11
+ });
58
12
  return id;
59
13
  }
@@ -1,13 +1,11 @@
1
1
  import { css } from 'styled-components';
2
2
  import { buttonFocused } from '../tokens';
3
3
  import 'focus-visible';
4
- export var syntheticFocus = function syntheticFocus(ruleset, focused) {
5
- return css([
6
- "&.focus-visible:focus,&[data-focus-visible-added]{outline:none;",
7
- "}",
8
- ";"
4
+ export const syntheticFocus = (ruleset, focused)=>css([
5
+ `&.focus-visible:focus,&[data-focus-visible-added]{outline:none;`,
6
+ `}`,
7
+ `;`
9
8
  ], ruleset, focused && ruleset);
10
- };
11
9
  /**
12
10
  * Миксин для добавления фокусной рамки к элементу через псевдоэлемент before
13
11
  * @param {FocusProps} props
@@ -27,21 +25,18 @@ export var syntheticFocus = function syntheticFocus(ruleset, focused) {
27
25
  * outlineRadius: '10em 1em',
28
26
  * outlineColor: 'greenyellow',
29
27
  * });
30
- */ export var addFocus = function addFocus(param) {
31
- var lowPerformance = param.lowPerformance, focused = param.focused, _param_outlined = param.outlined, outlined = _param_outlined === void 0 ? true : _param_outlined, _param_outlineSize = param.outlineSize, outlineSize = _param_outlineSize === void 0 ? '0.125rem' : _param_outlineSize, _param_outlineOffset = param.outlineOffset, outlineOffset = _param_outlineOffset === void 0 ? outlineSize : _param_outlineOffset, _param_outlineColor = param.outlineColor, outlineColor = _param_outlineColor === void 0 ? buttonFocused : _param_outlineColor, _param_outlineRadius = param.outlineRadius, outlineRadius = _param_outlineRadius === void 0 ? 0 : _param_outlineRadius, _param_synthesizeFocus = param.synthesizeFocus, synthesizeFocus = _param_synthesizeFocus === void 0 ? syntheticFocus : _param_synthesizeFocus;
32
- return outlined && css([
33
- "position:relative;&::before{content:'';position:absolute;top:-",
34
- ";left:-",
35
- ";right:-",
36
- ";bottom:-",
37
- ";display:block;box-sizing:content-box;border:",
38
- " solid transparent;border-radius:",
39
- ";transition:",
40
- ";pointer-events:none;}",
41
- ""
28
+ */ export const addFocus = ({ lowPerformance, focused, outlined = true, outlineSize = '0.125rem', outlineOffset = outlineSize, outlineColor = buttonFocused, outlineRadius = 0, synthesizeFocus = syntheticFocus })=>outlined && css([
29
+ `position:relative;&::before{content:'';position:absolute;top:-`,
30
+ `;left:-`,
31
+ `;right:-`,
32
+ `;bottom:-`,
33
+ `;display:block;box-sizing:content-box;border:`,
34
+ ` solid transparent;border-radius:`,
35
+ `;transition:`,
36
+ `;pointer-events:none;}`,
37
+ ``
42
38
  ], outlineOffset, outlineOffset, outlineOffset, outlineOffset, outlineSize, outlineRadius, lowPerformance ? 'unset' : 'box-shadow 0.2s ease-in-out', synthesizeFocus(css([
43
- "&::before{box-shadow:0 0 0 ",
44
- " ",
45
- ";}"
39
+ `&::before{box-shadow:0 0 0 `,
40
+ ` `,
41
+ `;}`
46
42
  ], outlineSize, outlineColor), focused));
47
- };