@salutejs/plasma-new-hope 0.142.0-canary.1421.10790809666.0 → 0.142.0-canary.1424.10791681494.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (105) hide show
  1. package/cjs/components/Badge/Badge.css +2 -0
  2. package/cjs/components/Badge/Badge.js +12 -3
  3. package/cjs/components/Badge/Badge.js.map +1 -1
  4. package/cjs/components/Badge/Badge.tokens.js +3 -1
  5. package/cjs/components/Badge/Badge.tokens.js.map +1 -1
  6. package/cjs/components/Badge/variations/_clear/base.js +9 -0
  7. package/cjs/components/Badge/variations/_clear/base.js.map +1 -0
  8. package/cjs/components/Badge/variations/_clear/base_oopyb7.css +1 -0
  9. package/cjs/components/TextArea/TextArea.js +2 -4
  10. package/cjs/components/TextArea/TextArea.js.map +1 -1
  11. package/cjs/index.css +2 -0
  12. package/cjs/index.js +0 -3
  13. package/cjs/index.js.map +1 -1
  14. package/cjs/utils/index.js.map +1 -1
  15. package/emotion/cjs/components/Badge/Badge.js +12 -3
  16. package/emotion/cjs/components/Badge/Badge.template-doc.mdx +19 -28
  17. package/emotion/cjs/components/Badge/Badge.tokens.js +3 -1
  18. package/emotion/cjs/components/Badge/variations/_clear/base.js +9 -0
  19. package/emotion/cjs/components/Badge/variations/_clear/tokens.json +1 -0
  20. package/emotion/cjs/components/TextArea/TextArea.js +3 -4
  21. package/emotion/cjs/examples/plasma_b2c/components/Badge/Badge.config.js +15 -12
  22. package/emotion/cjs/examples/plasma_b2c/components/Badge/Badge.stories.tsx +38 -6
  23. package/emotion/cjs/examples/plasma_web/components/Badge/Badge.config.js +15 -12
  24. package/emotion/cjs/examples/plasma_web/components/Badge/Badge.stories.tsx +39 -6
  25. package/emotion/cjs/utils/index.js +0 -15
  26. package/emotion/es/components/Badge/Badge.js +12 -3
  27. package/emotion/es/components/Badge/Badge.template-doc.mdx +19 -28
  28. package/emotion/es/components/Badge/Badge.tokens.js +3 -1
  29. package/emotion/es/components/Badge/variations/_clear/base.js +3 -0
  30. package/emotion/es/components/Badge/variations/_clear/tokens.json +1 -0
  31. package/emotion/es/components/TextArea/TextArea.js +4 -5
  32. package/emotion/es/examples/plasma_b2c/components/Badge/Badge.config.js +15 -12
  33. package/emotion/es/examples/plasma_b2c/components/Badge/Badge.stories.tsx +38 -6
  34. package/emotion/es/examples/plasma_web/components/Badge/Badge.config.js +15 -12
  35. package/emotion/es/examples/plasma_web/components/Badge/Badge.stories.tsx +39 -6
  36. package/emotion/es/utils/index.js +0 -1
  37. package/es/components/Badge/Badge.css +2 -0
  38. package/es/components/Badge/Badge.js +12 -3
  39. package/es/components/Badge/Badge.js.map +1 -1
  40. package/es/components/Badge/Badge.tokens.js +3 -1
  41. package/es/components/Badge/Badge.tokens.js.map +1 -1
  42. package/es/components/Badge/variations/_clear/base.js +5 -0
  43. package/es/components/Badge/variations/_clear/base.js.map +1 -0
  44. package/es/components/Badge/variations/_clear/base_oopyb7.css +1 -0
  45. package/es/components/TextArea/TextArea.js +2 -4
  46. package/es/components/TextArea/TextArea.js.map +1 -1
  47. package/es/index.css +2 -0
  48. package/es/index.js +0 -1
  49. package/es/index.js.map +1 -1
  50. package/es/utils/index.js.map +1 -1
  51. package/package.json +2 -3
  52. package/styled-components/cjs/components/Badge/Badge.js +12 -3
  53. package/styled-components/cjs/components/Badge/Badge.template-doc.mdx +19 -28
  54. package/styled-components/cjs/components/Badge/Badge.tokens.js +3 -1
  55. package/styled-components/cjs/components/Badge/variations/_clear/base.js +9 -0
  56. package/styled-components/cjs/components/Badge/variations/_clear/tokens.json +1 -0
  57. package/styled-components/cjs/components/TextArea/TextArea.js +2 -3
  58. package/styled-components/cjs/examples/plasma_b2c/components/Badge/Badge.config.js +10 -7
  59. package/styled-components/cjs/examples/plasma_b2c/components/Badge/Badge.stories.tsx +38 -6
  60. package/styled-components/cjs/examples/plasma_web/components/Badge/Badge.config.js +10 -7
  61. package/styled-components/cjs/examples/plasma_web/components/Badge/Badge.stories.tsx +39 -6
  62. package/styled-components/cjs/utils/index.js +0 -15
  63. package/styled-components/es/components/Badge/Badge.js +12 -3
  64. package/styled-components/es/components/Badge/Badge.template-doc.mdx +19 -28
  65. package/styled-components/es/components/Badge/Badge.tokens.js +3 -1
  66. package/styled-components/es/components/Badge/variations/_clear/base.js +3 -0
  67. package/styled-components/es/components/Badge/variations/_clear/tokens.json +1 -0
  68. package/styled-components/es/components/TextArea/TextArea.js +3 -4
  69. package/styled-components/es/examples/plasma_b2c/components/Badge/Badge.config.js +10 -7
  70. package/styled-components/es/examples/plasma_b2c/components/Badge/Badge.stories.tsx +38 -6
  71. package/styled-components/es/examples/plasma_web/components/Badge/Badge.config.js +10 -7
  72. package/styled-components/es/examples/plasma_web/components/Badge/Badge.stories.tsx +39 -6
  73. package/styled-components/es/utils/index.js +0 -1
  74. package/types/components/Badge/Badge.d.ts +7 -23
  75. package/types/components/Badge/Badge.d.ts.map +1 -1
  76. package/types/components/Badge/Badge.tokens.d.ts +2 -0
  77. package/types/components/Badge/Badge.tokens.d.ts.map +1 -1
  78. package/types/components/Badge/Badge.types.d.ts +52 -13
  79. package/types/components/Badge/Badge.types.d.ts.map +1 -1
  80. package/types/components/Badge/variations/_clear/base.d.ts +2 -0
  81. package/types/components/Badge/variations/_clear/base.d.ts.map +1 -0
  82. package/types/examples/plasma_b2c/components/Badge/Badge.config.d.ts +3 -0
  83. package/types/examples/plasma_b2c/components/Badge/Badge.config.d.ts.map +1 -1
  84. package/types/examples/plasma_b2c/components/Badge/Badge.d.ts +32 -3
  85. package/types/examples/plasma_b2c/components/Badge/Badge.d.ts.map +1 -1
  86. package/types/examples/plasma_web/components/Badge/Badge.config.d.ts +3 -0
  87. package/types/examples/plasma_web/components/Badge/Badge.config.d.ts.map +1 -1
  88. package/types/examples/plasma_web/components/Badge/Badge.d.ts +32 -3
  89. package/types/examples/plasma_web/components/Badge/Badge.d.ts.map +1 -1
  90. package/types/utils/index.d.ts +0 -1
  91. package/types/utils/index.d.ts.map +1 -1
  92. package/cjs/utils/setRefList.js +0 -28
  93. package/cjs/utils/setRefList.js.map +0 -1
  94. package/emotion/cjs/examples/plasma_b2c/components/Form/Form.stories.tsx +0 -68
  95. package/emotion/cjs/utils/setRefList.js +0 -27
  96. package/emotion/es/examples/plasma_b2c/components/Form/Form.stories.tsx +0 -68
  97. package/emotion/es/utils/setRefList.js +0 -20
  98. package/es/utils/setRefList.js +0 -23
  99. package/es/utils/setRefList.js.map +0 -1
  100. package/styled-components/cjs/examples/plasma_b2c/components/Form/Form.stories.tsx +0 -68
  101. package/styled-components/cjs/utils/setRefList.js +0 -27
  102. package/styled-components/es/examples/plasma_b2c/components/Form/Form.stories.tsx +0 -68
  103. package/styled-components/es/utils/setRefList.js +0 -20
  104. package/types/utils/setRefList.d.ts +0 -6
  105. package/types/utils/setRefList.d.ts.map +0 -1
@@ -1,4 +1,4 @@
1
- import React from 'react';
1
+ import React, { ComponentProps } from 'react';
2
2
  import { disableProps } from '@salutejs/plasma-sb-utils';
3
3
  import type { StoryObj, Meta } from '@storybook/react';
4
4
 
@@ -8,6 +8,7 @@ import { Badge } from './Badge';
8
8
 
9
9
  const meta: Meta<typeof Badge> = {
10
10
  title: 'plasma_web/Badge',
11
+ component: Badge,
11
12
  decorators: [WithTheme],
12
13
  argTypes: {
13
14
  size: {
@@ -22,13 +23,25 @@ const meta: Meta<typeof Badge> = {
22
23
  type: 'select',
23
24
  },
24
25
  },
26
+ pilled: {
27
+ control: { type: 'boolean' },
28
+ if: { arg: 'clear', truthy: false },
29
+ },
30
+ transparent: {
31
+ control: { type: 'boolean' },
32
+ if: { arg: 'clear', truthy: false },
33
+ },
25
34
  ...disableProps(['contentLeft', 'contentRight']),
26
35
  },
27
36
  };
28
37
 
29
38
  export default meta;
30
39
 
31
- type Story = StoryObj<typeof Badge>;
40
+ type StoryProps = ComponentProps<typeof Badge> & {
41
+ enableContentLeft: boolean;
42
+ enableContentRight: boolean;
43
+ };
44
+ type Story = StoryObj<StoryProps>;
32
45
 
33
46
  const BellIcon = (props) => (
34
47
  <svg width="100%" viewBox="0 0 24 24" fill="none" {...props}>
@@ -40,16 +53,36 @@ const BellIcon = (props) => (
40
53
  );
41
54
 
42
55
  export const Default: Story = {
56
+ argTypes: {
57
+ enableContentLeft: {
58
+ control: { type: 'boolean' },
59
+ if: { arg: 'enableContentRight', truthy: false },
60
+ },
61
+ enableContentRight: {
62
+ control: { type: 'boolean' },
63
+ if: { arg: 'enableContentLeft', truthy: false },
64
+ },
65
+ },
43
66
  args: {
44
67
  text: 'Hello',
45
68
  view: 'default',
46
69
  size: 'm',
70
+ enableContentLeft: false,
71
+ enableContentRight: false,
72
+ clear: false,
47
73
  pilled: false,
48
74
  transparent: false,
49
75
  },
50
- };
76
+ render: ({ enableContentLeft, enableContentRight, size, ...rest }: StoryProps) => {
77
+ const iconSize = size === 'l' ? '1rem' : '0.75rem';
51
78
 
52
- export const WithIcon: Story = {
53
- args: { ...Default.args },
54
- render: (args) => <Badge contentLeft={<BellIcon width="1rem" height="1rem" />} {...args} />,
79
+ return (
80
+ <Badge
81
+ contentLeft={enableContentLeft ? <BellIcon width={iconSize} height={iconSize} /> : undefined}
82
+ contentRight={enableContentRight ? <BellIcon width={iconSize} height={iconSize} /> : undefined}
83
+ size={size}
84
+ {...rest}
85
+ />
86
+ );
87
+ },
55
88
  };
@@ -12,8 +12,6 @@ var _exportNames = {
12
12
  IS_REACT_18: true,
13
13
  safeUseId: true,
14
14
  isNumber: true,
15
- mergeRefs: true,
16
- setRefList: true,
17
15
  isEmpty: true
18
16
  };
19
17
  Object.defineProperty(exports, "IS_REACT_18", {
@@ -53,30 +51,17 @@ Object.defineProperty(exports, "isNumber", {
53
51
  return _isNumber.isNumber;
54
52
  }
55
53
  });
56
- Object.defineProperty(exports, "mergeRefs", {
57
- enumerable: true,
58
- get: function get() {
59
- return _setRefList.mergeRefs;
60
- }
61
- });
62
54
  Object.defineProperty(exports, "safeUseId", {
63
55
  enumerable: true,
64
56
  get: function get() {
65
57
  return _react.safeUseId;
66
58
  }
67
59
  });
68
- Object.defineProperty(exports, "setRefList", {
69
- enumerable: true,
70
- get: function get() {
71
- return _setRefList.setRefList;
72
- }
73
- });
74
60
  var _canUseDOM = /*#__PURE__*/require("./canUseDOM");
75
61
  var _extractTextFrom = /*#__PURE__*/require("./extractTextFrom");
76
62
  var _getSizeValueFromProp = /*#__PURE__*/require("./getSizeValueFromProp");
77
63
  var _react = /*#__PURE__*/require("./react");
78
64
  var _isNumber = /*#__PURE__*/require("./isNumber");
79
- var _setRefList = /*#__PURE__*/require("./setRefList");
80
65
  var _isEmpty = /*#__PURE__*/require("./isEmpty");
81
66
  var _getPopoverPlacement = /*#__PURE__*/require("./getPopoverPlacement");
82
67
  Object.keys(_getPopoverPlacement).forEach(function (key) {
@@ -1,4 +1,4 @@
1
- var _excluded = ["children", "className", "text", "contentLeft", "contentRight", "size", "view", "pilled", "transparent"];
1
+ var _excluded = ["children", "className", "text", "contentLeft", "contentRight", "size", "view", "pilled", "transparent", "clear"];
2
2
  function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
3
3
  function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }
4
4
  function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }
@@ -8,6 +8,7 @@ import { base as viewCSS } from './variations/_view/base';
8
8
  import { base as sizeCSS } from './variations/_size/base';
9
9
  import { base as pilledCSS } from './variations/_pilled/base';
10
10
  import { base as transparentCSS } from './variations/_transparent/base';
11
+ import { base as clearCSS } from './variations/_clear/base';
11
12
  import { StyledContentLeft, StyledContentMain, StyledContentRight, base } from './Badge.styles';
12
13
  import { classes } from './Badge.tokens';
13
14
  export var badgeRoot = function badgeRoot(Root) {
@@ -23,17 +24,21 @@ export var badgeRoot = function badgeRoot(Root) {
23
24
  pilled = _props$pilled === void 0 ? false : _props$pilled,
24
25
  _props$transparent = props.transparent,
25
26
  transparent = _props$transparent === void 0 ? false : _props$transparent,
27
+ _props$clear = props.clear,
28
+ clear = _props$clear === void 0 ? false : _props$clear,
26
29
  rest = _objectWithoutProperties(props, _excluded);
27
30
  var pilledClass = pilled ? classes.badgePilled : undefined;
28
31
  var transparentClass = transparent ? classes.badgeTransparent : undefined;
32
+ var clearClass = clear ? classes.badgeClear : undefined;
29
33
  var txt = !text && typeof children === 'string' ? children : text;
30
34
  return /*#__PURE__*/React.createElement(Root, _extends({
31
35
  ref: ref,
32
- className: cx(pilledClass, transparentClass, className),
36
+ className: cx(pilledClass, transparentClass, clearClass, className),
33
37
  view: view,
34
38
  size: size,
35
39
  pilled: pilled,
36
- transparent: transparent
40
+ transparent: transparent,
41
+ clear: clear
37
42
  }, rest), contentLeft && /*#__PURE__*/React.createElement(StyledContentLeft, null, contentLeft), txt ? /*#__PURE__*/React.createElement(StyledContentMain, null, txt) : children, contentRight && /*#__PURE__*/React.createElement(StyledContentRight, null, contentRight));
38
43
  });
39
44
  };
@@ -56,6 +61,10 @@ export var badgeConfig = {
56
61
  transparent: {
57
62
  css: transparentCSS,
58
63
  attrs: true
64
+ },
65
+ clear: {
66
+ css: clearCSS,
67
+ attrs: true
59
68
  }
60
69
  },
61
70
  defaults: {
@@ -60,41 +60,32 @@ export function App() {
60
60
  + `"dark"` – темный badge;
61
61
  + `"light"` – светлый badge.
62
62
 
63
- ```tsx live
64
- import React from 'react';
65
- import { Badge } from '@salutejs/{{ package }}';
66
-
67
- export function App() {
68
- return (
69
- <div>
70
- <Badge text="Бейдж" size="l" view="primary" />
71
- <Badge text="Бейдж" size="l" view="accent" />
72
- <Badge text="Бейдж" size="l" view="positive" />
73
- <Badge text="Бейдж" size="l" view="warning" />
74
- <Badge text="Бейдж" size="l" view="negative" />
75
- <Badge text="Бейдж" size="l" view="dark" />
76
- <Badge text="Бейдж" size="l" view="light" />
77
- </div>
78
- );
79
- }
80
- ```
81
-
82
- Так же на вид badge влияет свойство `transparent`:
63
+ Так же на вид badge влияет свойства `transparent` и `clear`.
83
64
 
84
65
  ```tsx live
85
66
  import React from 'react';
86
67
  import { Badge } from '@salutejs/{{ package }}';
87
68
 
88
69
  export function App() {
70
+ const Badges = ({transparent, clear}) => {
71
+ return (
72
+ <div style=\{{ display: 'flex', gap: '0.5rem' }}>
73
+ <Badge text="Бейдж" size="l" view="primary" transparent={transparent} clear={clear} />
74
+ <Badge text="Бейдж" size="l" view="accent" transparent={transparent} clear={clear} />
75
+ <Badge text="Бейдж" size="l" view="positive" transparent={transparent} clear={clear} />
76
+ <Badge text="Бейдж" size="l" view="warning" transparent={transparent} clear={clear} />
77
+ <Badge text="Бейдж" size="l" view="negative" transparent={transparent} clear={clear} />
78
+ <Badge text="Бейдж" size="l" view="dark" transparent={transparent} clear={clear} />
79
+ <Badge text="Бейдж" size="l" view="light" transparent={transparent} clear={clear} />
80
+ </div>
81
+ )
82
+ }
83
+
89
84
  return (
90
- <div>
91
- <Badge text="Бейдж" size="l" view="primary" transparent />
92
- <Badge text="Бейдж" size="l" view="accent" transparent />
93
- <Badge text="Бейдж" size="l" view="positive" transparent />
94
- <Badge text="Бейдж" size="l" view="warning" transparent />
95
- <Badge text="Бейдж" size="l" view="negative" transparent />
96
- <Badge text="Бейдж" size="l" view="dark" transparent />
97
- <Badge text="Бейдж" size="l" view="light" transparent />
85
+ <div style=\{{ display: 'flex', flexDirection: 'column', gap: '2rem' }}>
86
+ <Badges />
87
+ <Badges transparent />
88
+ <Badges clear />
98
89
  </div>
99
90
  );
100
91
  }
@@ -1,12 +1,14 @@
1
1
  export var classes = {
2
2
  badgePilled: 'badge-pilled',
3
- badgeTransparent: 'badge-transparent'
3
+ badgeTransparent: 'badge-transparent',
4
+ badgeClear: 'badge-clear'
4
5
  };
5
6
  export var tokens = {
6
7
  background: '--plasma-badge-background',
7
8
  color: '--plasma-badge-color',
8
9
  backgroundTransparent: '--plasma-badge-background-transparent',
9
10
  colorTransparent: '--plasma-badge-color-transparent',
11
+ colorClear: '--plasma-badge-color-clear',
10
12
  borderRadius: '--plasma-badge-border-radius',
11
13
  pilledBorderRadius: '--plasma-badge-pilled-border-radius',
12
14
  height: '--plasma-badge-height',
@@ -0,0 +1,3 @@
1
+ import { css } from '@emotion/react';
2
+ import { classes, tokens } from '../../Badge.tokens';
3
+ export var base = /*#__PURE__*/css("&.", /*#__PURE__*/String(classes.badgeClear), "{color:var(", tokens.colorClear, ");background-color:transparent;padding:0;};label:plasma-new-hope__base;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy1lbW90aW9uL2NvbXBvbmVudHMvQmFkZ2UvdmFyaWF0aW9ucy9fY2xlYXIvYmFzZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFJdUIiLCJmaWxlIjoiLi4vLi4vLi4vLi4vLi4vLi4vc3JjLWVtb3Rpb24vY29tcG9uZW50cy9CYWRnZS92YXJpYXRpb25zL19jbGVhci9iYXNlLnRzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuXG5pbXBvcnQgeyBjbGFzc2VzLCB0b2tlbnMgfSBmcm9tICcuLi8uLi9CYWRnZS50b2tlbnMnO1xuXG5leHBvcnQgY29uc3QgYmFzZSA9IGNzc2BcbiAgICAmLiR7U3RyaW5nKGNsYXNzZXMuYmFkZ2VDbGVhcil9IHtcbiAgICAgICAgY29sb3I6IHZhcigke3Rva2Vucy5jb2xvckNsZWFyfSk7XG4gICAgICAgIGJhY2tncm91bmQtY29sb3I6IHRyYW5zcGFyZW50O1xuICAgICAgICBwYWRkaW5nOiAwO1xuICAgIH1cbmA7XG4iXX0= */"));
@@ -0,0 +1 @@
1
+ ["--plasma-badge-color-clear"]
@@ -21,7 +21,7 @@ function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) r
21
21
  import React, { forwardRef, useState, createRef, useCallback } from 'react';
22
22
  import { css } from '@emotion/react';
23
23
  import { useResizeObserver } from '@salutejs/plasma-core';
24
- import { cx, mergeRefs } from '../../utils';
24
+ import { cx } from '../../utils';
25
25
  import { applyDynamicLabel } from './mixins';
26
26
  import { useAutoResize, ROOT_FONT_SIZE } from './hooks';
27
27
  import { StyledContent, StyledHelpers, StyledLeftHelper, StyledRightHelper, StyledLabel, StyledPlaceholder, StyledTextArea, StyledTextAreaWrapper, StyledContainer, StyledIndicator, StyledOptionalText } from './TextArea.styles';
@@ -38,7 +38,7 @@ var innerPlaceholderUp = classes.innerPlaceholderUp,
38
38
  styledPlaceholder = classes.styledPlaceholder,
39
39
  styledHelpers = classes.styledHelpers;
40
40
  var optionalText = 'optional';
41
- var base = /*#__PURE__*/css(applyDynamicLabel, ";position:relative;box-sizing:border-box;;label:plasma-new-hope__base;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src-emotion/components/TextArea/TextArea.tsx"],"names":[],"mappings":"AAyCgB","file":"../../../../src-emotion/components/TextArea/TextArea.tsx","sourcesContent":["import React, { forwardRef, useState, createRef, useCallback } from 'react';\nimport { css } from '@emotion/react';\nimport { useResizeObserver } from '@salutejs/plasma-core';\n\nimport { cx, mergeRefs } from '../../utils';\nimport type { RootProps } from '../../engines/types';\n\nimport { applyDynamicLabel } from './mixins';\nimport { useAutoResize, ROOT_FONT_SIZE } from './hooks';\nimport {\n    StyledContent,\n    StyledHelpers,\n    StyledLeftHelper,\n    StyledRightHelper,\n    StyledLabel,\n    StyledPlaceholder,\n    StyledTextArea,\n    StyledTextAreaWrapper,\n    StyledContainer,\n    StyledIndicator,\n    StyledOptionalText,\n} from './TextArea.styles';\nimport { classes } from './TextArea.tokens';\nimport { base as viewCSS } from './variations/_view/base';\nimport { base as sizeCSS } from './variations/_size/base';\nimport { base as disabledCSS } from './variations/_disabled/base';\nimport type { TextAreaProps } from './TextArea.types';\n\nconst {\n    innerPlaceholderUp,\n    focusedOuterPlaceholderColor,\n    hidePlaceHolder,\n    styledContainer,\n    styledTextArea,\n    styledTextAreaWrapper,\n    styledPlaceholder,\n    styledHelpers,\n} = classes;\n\nconst optionalText = 'optional';\n\nconst base = css`\n    ${applyDynamicLabel};\n\n    position: relative;\n    box-sizing: border-box;\n`;\n\n// TODO: Удалить после отказа от старых библиотек plasma-web / plasma-b2c\nconst fallbackStatusMap = {\n    '': 'primary',\n    success: 'positive',\n    warning: 'warning',\n    error: 'negative',\n};\n\n// TODO: Перенести этот метод в файл applyDynamicLabel.ts\nexport const getDynamicLabelClasses = (props: TextAreaProps, focused: boolean) => {\n    const { readOnly, label, labelPlacement, autoResize, rows, value, size } = props;\n\n    // Добавить класс отвечающий за изменение цвета плейсхолдера при фокусе\n    const withFocusedOuterUpPlaceholder =\n        !readOnly && focused && (!label || labelPlacement === 'outer') ? focusedOuterPlaceholderColor : undefined;\n\n    // Добавить класс отвечающий за поднятие и уменьшение плейсхолдера\n    const withInnerPlaceholderUp =\n        labelPlacement === 'inner' &&\n        label &&\n        !autoResize &&\n        !rows &&\n        size !== 'xs' &&\n        ((!readOnly && (value || focused)) || (readOnly && value))\n            ? innerPlaceholderUp\n            : undefined;\n\n    // Добавить класс отвечающий за скрытие плейсхолдера\n    const withHidePlaceholder =\n        (value && !label) ||\n        (labelPlacement === 'inner' && ((focused && !readOnly) || value) && label && (rows || autoResize)) ||\n        (labelPlacement === 'outer' && value) ||\n        (labelPlacement === 'inner' && size === 'xs' && value)\n            ? hidePlaceHolder\n            : undefined;\n\n    return [withFocusedOuterUpPlaceholder, withInnerPlaceholderUp, withHidePlaceholder];\n};\n\nexport const textAreaRoot = (Root: RootProps<HTMLTextAreaElement, TextAreaProps>) =>\n    forwardRef<HTMLTextAreaElement, TextAreaProps>((props, innerRef) => {\n        const {\n            helperText,\n            status,\n            resize,\n            rightHelper,\n            leftHelper,\n            contentRight,\n            autoResize = false,\n            minAuto = 0,\n            maxAuto,\n            label,\n            labelPlacement = 'inner',\n            placeholder,\n            defaultValue,\n            height,\n            width,\n            value,\n            disabled,\n            required = false,\n            requiredPlacement = 'right',\n            optional = false,\n            size,\n            view,\n            id,\n            style,\n            className,\n            readOnly,\n            rows,\n            cols,\n            onChange,\n            ...rest\n        } = props;\n\n        const [helperWidth, setHelperWidth] = useState<string>(width ? `${width}rem` : '100%');\n        const [focused, setFocused] = useState(false);\n        const [uncontrolledValue, setUncontrolledValue] = useState<string | undefined>();\n\n        const outerRef = createRef<HTMLTextAreaElement>();\n\n        const innerOptional = required ? false : optional;\n        const hasHelper = Boolean(leftHelper || rightHelper || helperText);\n        const hasOuterLabel = Boolean(label && labelPlacement === 'outer');\n        const hasInnerLabel = Boolean(label && labelPlacement === 'inner' && size !== 'xs');\n        const hasPlaceholderOptional = innerOptional && !hasOuterLabel;\n\n        const overriddenView = status !== undefined ? fallbackStatusMap[status] : view;\n        const textareaHelperId = id ? `${id}-helper` : undefined;\n        const applyCustomWidth = resize !== 'horizontal' && resize !== 'both' && !cols;\n        const placeholderLabel = hasInnerLabel ? label : placeholder;\n\n        const requiredPlacementClass = requiredPlacement === 'right' ? 'align-right ' : undefined;\n\n        useResizeObserver(outerRef, (currentElement) => {\n            const { width: inlineWidth } = currentElement.style;\n\n            if (inlineWidth || cols) {\n                const { width: elementWidth } = currentElement.getBoundingClientRect();\n                setHelperWidth(`${elementWidth / ROOT_FONT_SIZE}rem`);\n            }\n        });\n\n        useAutoResize(autoResize, outerRef, value, minAuto, maxAuto);\n\n        const onFocusHandler = useCallback(() => {\n            setFocused(true);\n        }, []);\n\n        const onBlurHandler = useCallback(() => {\n            setFocused(false);\n        }, []);\n\n        const onChangeHandler = useCallback(\n            (event: React.ChangeEvent<HTMLTextAreaElement>) => {\n                // INFO: Для крайне редких кейсов, когда value снаружи не контролируется\n                if (value === undefined) {\n                    setUncontrolledValue(event?.target.value);\n                }\n                console.log(event);\n                onChange?.(event);\n            },\n            [value, onChange],\n        );\n\n        const dynamicLabelClasses = getDynamicLabelClasses(\n            {\n                size,\n                readOnly,\n                label,\n                labelPlacement,\n                value: value || uncontrolledValue || defaultValue,\n                ...(rows ? { rows } : { autoResize }),\n            },\n            focused,\n        );\n\n        const optionalTextNode = innerOptional ? (\n            <StyledOptionalText>\n                {Boolean(hasPlaceholderOptional ? placeholderLabel : label) && '\\xa0'}\n                {optionalText}\n            </StyledOptionalText>\n        ) : null;\n\n        return (\n            <Root\n                view={overriddenView}\n                size={size}\n                disabled={disabled}\n                readOnly={readOnly}\n                style={{ width: helperWidth, ...style }}\n                className={className}\n            >\n                {hasOuterLabel && (\n                    <StyledLabel>\n                        {required && (\n                            <StyledIndicator className={cx(classes.outerLabelPlacement, requiredPlacementClass)} />\n                        )}\n                        {label}\n                        {optionalTextNode}\n                    </StyledLabel>\n                )}\n                <StyledContainer\n                    className={cx(styledContainer, ...dynamicLabelClasses)}\n                    width={helperWidth}\n                    onFocus={onFocusHandler}\n                    onBlur={onBlurHandler}\n                >\n                    {required && !hasOuterLabel && (\n                        <StyledIndicator className={cx(classes.innerLabelPlacement, requiredPlacementClass)} />\n                    )}\n                    {contentRight && <StyledContent>{contentRight}</StyledContent>}\n                    <StyledTextAreaWrapper className={styledTextAreaWrapper} hasHelper={hasHelper}>\n                        <StyledTextArea\n                            className={styledTextArea}\n                            id={id}\n                            hasContentRight={Boolean(contentRight)}\n                            hasHelper={hasHelper}\n                            applyCustomWidth={applyCustomWidth}\n                            ref={mergeRefs(outerRef, innerRef)}\n                            disabled={disabled}\n                            height={autoResize ? minAuto : height}\n                            width={width}\n                            placeholder={placeholderLabel}\n                            aria-describedby={textareaHelperId}\n                            value={value}\n                            readOnly={readOnly}\n                            rows={rows}\n                            cols={cols}\n                            resize={resize}\n                            defaultValue={defaultValue}\n                            onChange={onChangeHandler}\n                            {...rest}\n                        />\n                    </StyledTextAreaWrapper>\n                    {hasHelper && (\n                        <StyledHelpers className={styledHelpers} id={textareaHelperId}>\n                            {(leftHelper || helperText) && (\n                                <StyledLeftHelper>{leftHelper || helperText}</StyledLeftHelper>\n                            )}\n                            {rightHelper && <StyledRightHelper>{rightHelper}</StyledRightHelper>}\n                        </StyledHelpers>\n                    )}\n                    {placeholderLabel && (\n                        <StyledPlaceholder\n                            hasContentRight={Boolean(contentRight)}\n                            className={styledPlaceholder}\n                            htmlFor={id}\n                        >\n                            {placeholderLabel}\n                            {!hasOuterLabel && optionalTextNode}\n                        </StyledPlaceholder>\n                    )}\n                </StyledContainer>\n            </Root>\n        );\n    });\n\nexport const textAreaConfig = {\n    name: 'TextArea',\n    tag: 'div',\n    layout: textAreaRoot,\n    base,\n    variations: {\n        size: {\n            css: sizeCSS,\n        },\n        view: {\n            css: viewCSS,\n        },\n        disabled: {\n            css: disabledCSS,\n            attrs: true,\n        },\n        readOnly: {\n            attrs: true,\n        },\n    },\n    defaults: {\n        size: 'm',\n        view: 'primary',\n    },\n};\n"]} */"));
41
+ var base = /*#__PURE__*/css(applyDynamicLabel, ";position:relative;box-sizing:border-box;;label:plasma-new-hope__base;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src-emotion/components/TextArea/TextArea.tsx"],"names":[],"mappings":"AAyCgB","file":"../../../../src-emotion/components/TextArea/TextArea.tsx","sourcesContent":["import React, { forwardRef, useState, createRef, useCallback } from 'react';\nimport { css } from '@emotion/react';\nimport { useResizeObserver } from '@salutejs/plasma-core';\n\nimport { cx } from '../../utils';\nimport type { RootProps } from '../../engines/types';\n\nimport { applyDynamicLabel } from './mixins';\nimport { useAutoResize, ROOT_FONT_SIZE } from './hooks';\nimport {\n    StyledContent,\n    StyledHelpers,\n    StyledLeftHelper,\n    StyledRightHelper,\n    StyledLabel,\n    StyledPlaceholder,\n    StyledTextArea,\n    StyledTextAreaWrapper,\n    StyledContainer,\n    StyledIndicator,\n    StyledOptionalText,\n} from './TextArea.styles';\nimport { classes } from './TextArea.tokens';\nimport { base as viewCSS } from './variations/_view/base';\nimport { base as sizeCSS } from './variations/_size/base';\nimport { base as disabledCSS } from './variations/_disabled/base';\nimport type { TextAreaProps } from './TextArea.types';\n\nconst {\n    innerPlaceholderUp,\n    focusedOuterPlaceholderColor,\n    hidePlaceHolder,\n    styledContainer,\n    styledTextArea,\n    styledTextAreaWrapper,\n    styledPlaceholder,\n    styledHelpers,\n} = classes;\n\nconst optionalText = 'optional';\n\nconst base = css`\n    ${applyDynamicLabel};\n\n    position: relative;\n    box-sizing: border-box;\n`;\n\n// TODO: Удалить после отказа от старых библиотек plasma-web / plasma-b2c\nconst fallbackStatusMap = {\n    '': 'primary',\n    success: 'positive',\n    warning: 'warning',\n    error: 'negative',\n};\n\n// TODO: Перенести этот метод в файл applyDynamicLabel.ts\nexport const getDynamicLabelClasses = (props: TextAreaProps, focused: boolean) => {\n    const { readOnly, label, labelPlacement, autoResize, rows, value, size } = props;\n\n    // Добавить класс отвечающий за изменение цвета плейсхолдера при фокусе\n    const withFocusedOuterUpPlaceholder =\n        !readOnly && focused && (!label || labelPlacement === 'outer') ? focusedOuterPlaceholderColor : undefined;\n\n    // Добавить класс отвечающий за поднятие и уменьшение плейсхолдера\n    const withInnerPlaceholderUp =\n        labelPlacement === 'inner' &&\n        label &&\n        !autoResize &&\n        !rows &&\n        size !== 'xs' &&\n        ((!readOnly && (value || focused)) || (readOnly && value))\n            ? innerPlaceholderUp\n            : undefined;\n\n    // Добавить класс отвечающий за скрытие плейсхолдера\n    const withHidePlaceholder =\n        (value && !label) ||\n        (labelPlacement === 'inner' && ((focused && !readOnly) || value) && label && (rows || autoResize)) ||\n        (labelPlacement === 'outer' && value) ||\n        (labelPlacement === 'inner' && size === 'xs' && value)\n            ? hidePlaceHolder\n            : undefined;\n\n    return [withFocusedOuterUpPlaceholder, withInnerPlaceholderUp, withHidePlaceholder];\n};\n\nexport const textAreaRoot = (Root: RootProps<HTMLTextAreaElement, TextAreaProps>) =>\n    forwardRef<HTMLTextAreaElement, TextAreaProps>((props, innerRef) => {\n        const {\n            helperText,\n            status,\n            resize,\n            rightHelper,\n            leftHelper,\n            contentRight,\n            autoResize = false,\n            minAuto = 0,\n            maxAuto,\n            label,\n            labelPlacement = 'inner',\n            placeholder,\n            defaultValue,\n            height,\n            width,\n            value,\n            disabled,\n            required = false,\n            requiredPlacement = 'right',\n            optional = false,\n            size,\n            view,\n            id,\n            style,\n            className,\n            readOnly,\n            rows,\n            cols,\n            onChange,\n            ...rest\n        } = props;\n\n        const [helperWidth, setHelperWidth] = useState<string>(width ? `${width}rem` : '100%');\n        const [focused, setFocused] = useState(false);\n        const [uncontrolledValue, setUncontrolledValue] = useState<string | undefined>();\n\n        const outerRef = innerRef && 'current' in innerRef ? innerRef : createRef<HTMLTextAreaElement>();\n\n        const innerOptional = required ? false : optional;\n        const hasHelper = Boolean(leftHelper || rightHelper || helperText);\n        const hasOuterLabel = Boolean(label && labelPlacement === 'outer');\n        const hasInnerLabel = Boolean(label && labelPlacement === 'inner' && size !== 'xs');\n        const hasPlaceholderOptional = innerOptional && !hasOuterLabel;\n\n        const overriddenView = status !== undefined ? fallbackStatusMap[status] : view;\n        const textareaHelperId = id ? `${id}-helper` : undefined;\n        const applyCustomWidth = resize !== 'horizontal' && resize !== 'both' && !cols;\n        const placeholderLabel = hasInnerLabel ? label : placeholder;\n\n        const requiredPlacementClass = requiredPlacement === 'right' ? 'align-right ' : undefined;\n\n        useResizeObserver(outerRef, (currentElement) => {\n            const { width: inlineWidth } = currentElement.style;\n\n            if (inlineWidth || cols) {\n                const { width: elementWidth } = currentElement.getBoundingClientRect();\n                setHelperWidth(`${elementWidth / ROOT_FONT_SIZE}rem`);\n            }\n        });\n\n        useAutoResize(autoResize, outerRef, value, minAuto, maxAuto);\n\n        const onFocusHandler = useCallback(() => {\n            setFocused(true);\n        }, []);\n\n        const onBlurHandler = useCallback(() => {\n            setFocused(false);\n        }, []);\n\n        const onChangeHandler = useCallback(\n            (event: React.ChangeEvent<HTMLTextAreaElement>) => {\n                // INFO: Для крайне редких кейсов, когда value снаружи не контролируется\n                if (value === undefined) {\n                    setUncontrolledValue(event?.target.value);\n                }\n\n                onChange?.(event);\n            },\n            [value, onChange],\n        );\n\n        const dynamicLabelClasses = getDynamicLabelClasses(\n            {\n                size,\n                readOnly,\n                label,\n                labelPlacement,\n                value: value || uncontrolledValue || defaultValue,\n                ...(rows ? { rows } : { autoResize }),\n            },\n            focused,\n        );\n\n        const optionalTextNode = innerOptional ? (\n            <StyledOptionalText>\n                {Boolean(hasPlaceholderOptional ? placeholderLabel : label) && '\\xa0'}\n                {optionalText}\n            </StyledOptionalText>\n        ) : null;\n\n        return (\n            <Root\n                view={overriddenView}\n                size={size}\n                disabled={disabled}\n                readOnly={readOnly}\n                style={{ width: helperWidth, ...style }}\n                className={className}\n            >\n                {hasOuterLabel && (\n                    <StyledLabel>\n                        {required && (\n                            <StyledIndicator className={cx(classes.outerLabelPlacement, requiredPlacementClass)} />\n                        )}\n                        {label}\n                        {optionalTextNode}\n                    </StyledLabel>\n                )}\n                <StyledContainer\n                    className={cx(styledContainer, ...dynamicLabelClasses)}\n                    width={helperWidth}\n                    onFocus={onFocusHandler}\n                    onBlur={onBlurHandler}\n                >\n                    {required && !hasOuterLabel && (\n                        <StyledIndicator className={cx(classes.innerLabelPlacement, requiredPlacementClass)} />\n                    )}\n                    {contentRight && <StyledContent>{contentRight}</StyledContent>}\n                    <StyledTextAreaWrapper className={styledTextAreaWrapper} hasHelper={hasHelper}>\n                        <StyledTextArea\n                            className={styledTextArea}\n                            id={id}\n                            hasContentRight={Boolean(contentRight)}\n                            hasHelper={hasHelper}\n                            applyCustomWidth={applyCustomWidth}\n                            ref={outerRef}\n                            disabled={disabled}\n                            height={autoResize ? minAuto : height}\n                            width={width}\n                            placeholder={placeholderLabel}\n                            aria-describedby={textareaHelperId}\n                            value={value}\n                            readOnly={readOnly}\n                            rows={rows}\n                            cols={cols}\n                            resize={resize}\n                            defaultValue={defaultValue}\n                            onChange={onChangeHandler}\n                            {...rest}\n                        />\n                    </StyledTextAreaWrapper>\n                    {hasHelper && (\n                        <StyledHelpers className={styledHelpers} id={textareaHelperId}>\n                            {(leftHelper || helperText) && (\n                                <StyledLeftHelper>{leftHelper || helperText}</StyledLeftHelper>\n                            )}\n                            {rightHelper && <StyledRightHelper>{rightHelper}</StyledRightHelper>}\n                        </StyledHelpers>\n                    )}\n                    {placeholderLabel && (\n                        <StyledPlaceholder\n                            hasContentRight={Boolean(contentRight)}\n                            className={styledPlaceholder}\n                            htmlFor={id}\n                        >\n                            {placeholderLabel}\n                            {!hasOuterLabel && optionalTextNode}\n                        </StyledPlaceholder>\n                    )}\n                </StyledContainer>\n            </Root>\n        );\n    });\n\nexport const textAreaConfig = {\n    name: 'TextArea',\n    tag: 'div',\n    layout: textAreaRoot,\n    base,\n    variations: {\n        size: {\n            css: sizeCSS,\n        },\n        view: {\n            css: viewCSS,\n        },\n        disabled: {\n            css: disabledCSS,\n            attrs: true,\n        },\n        readOnly: {\n            attrs: true,\n        },\n    },\n    defaults: {\n        size: 'm',\n        view: 'primary',\n    },\n};\n"]} */"));
42
42
 
43
43
  // TODO: Удалить после отказа от старых библиотек plasma-web / plasma-b2c
44
44
  var fallbackStatusMap = {
@@ -118,7 +118,7 @@ export var textAreaRoot = function textAreaRoot(Root) {
118
118
  _useState6 = _slicedToArray(_useState5, 2),
119
119
  uncontrolledValue = _useState6[0],
120
120
  setUncontrolledValue = _useState6[1];
121
- var outerRef = /*#__PURE__*/createRef();
121
+ var outerRef = innerRef && 'current' in innerRef ? innerRef : /*#__PURE__*/createRef();
122
122
  var innerOptional = required ? false : optional;
123
123
  var hasHelper = Boolean(leftHelper || rightHelper || helperText);
124
124
  var hasOuterLabel = Boolean(label && labelPlacement === 'outer');
@@ -149,7 +149,6 @@ export var textAreaRoot = function textAreaRoot(Root) {
149
149
  if (value === undefined) {
150
150
  setUncontrolledValue(event === null || event === void 0 ? void 0 : event.target.value);
151
151
  }
152
- console.log(event);
153
152
  onChange === null || onChange === void 0 || onChange(event);
154
153
  }, [value, onChange]);
155
154
  var dynamicLabelClasses = getDynamicLabelClasses(_objectSpread({
@@ -191,7 +190,7 @@ export var textAreaRoot = function textAreaRoot(Root) {
191
190
  hasContentRight: Boolean(contentRight),
192
191
  hasHelper: hasHelper,
193
192
  applyCustomWidth: applyCustomWidth,
194
- ref: mergeRefs(outerRef, innerRef),
193
+ ref: outerRef,
195
194
  disabled: disabled,
196
195
  height: autoResize ? minAuto : height,
197
196
  width: width,