@salutejs/plasma-new-hope 0.143.1-dev.0 → 0.144.0-canary.1430.10832391195.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (176) hide show
  1. package/cjs/components/Editable/Editable.css +8 -0
  2. package/cjs/components/Editable/Editable.js +156 -0
  3. package/cjs/components/Editable/Editable.js.map +1 -0
  4. package/cjs/components/Editable/Editable.styles.js +38 -0
  5. package/cjs/components/Editable/Editable.styles.js.map +1 -0
  6. package/cjs/components/Editable/Editable.styles_somxw2.css +4 -0
  7. package/cjs/components/Editable/Editable.tokens.js +21 -0
  8. package/cjs/components/Editable/Editable.tokens.js.map +1 -0
  9. package/cjs/components/Editable/utils/clearSelection.js +23 -0
  10. package/cjs/components/Editable/utils/clearSelection.js.map +1 -0
  11. package/cjs/components/Editable/utils/selectText.js +30 -0
  12. package/cjs/components/Editable/utils/selectText.js.map +1 -0
  13. package/cjs/components/Editable/variations/_size/base.js +9 -0
  14. package/cjs/components/Editable/variations/_size/base.js.map +1 -0
  15. package/cjs/components/Editable/variations/_size/base_54y6eh.css +1 -0
  16. package/cjs/components/Editable/variations/_view/base.js +9 -0
  17. package/cjs/components/Editable/variations/_view/base.js.map +1 -0
  18. package/cjs/components/Editable/variations/_view/base_11fpjfv.css +1 -0
  19. package/cjs/components/Grid/Grid.js +1 -1
  20. package/cjs/components/Grid/Grid.js.map +1 -1
  21. package/cjs/index.css +9 -0
  22. package/cjs/index.js +7 -0
  23. package/cjs/index.js.map +1 -1
  24. package/cjs/utils/constants.js +20 -0
  25. package/cjs/utils/constants.js.map +1 -0
  26. package/cjs/utils/index.js.map +1 -1
  27. package/emotion/cjs/components/Editable/Editable.js +161 -0
  28. package/emotion/cjs/components/Editable/Editable.styles.js +26 -0
  29. package/emotion/cjs/components/Editable/Editable.tokens.js +19 -0
  30. package/emotion/cjs/components/Editable/Editable.types.js +5 -0
  31. package/emotion/cjs/components/Editable/index.js +25 -0
  32. package/emotion/cjs/components/Editable/utils/clearSelection.js +19 -0
  33. package/emotion/cjs/components/Editable/utils/index.js +19 -0
  34. package/emotion/cjs/components/Editable/utils/selectText.js +26 -0
  35. package/emotion/cjs/components/Editable/variations/_size/base.js +10 -0
  36. package/emotion/cjs/components/Editable/variations/_size/tokens.json +1 -0
  37. package/emotion/cjs/components/Editable/variations/_view/base.js +10 -0
  38. package/emotion/cjs/components/Editable/variations/_view/tokens.json +5 -0
  39. package/emotion/cjs/components/Grid/Grid.js +1 -1
  40. package/emotion/cjs/examples/plasma_b2c/components/Editable/Editable.config.js +22 -0
  41. package/emotion/cjs/examples/plasma_b2c/components/Editable/Editable.js +22 -0
  42. package/emotion/cjs/examples/plasma_b2c/components/Editable/Editable.stories.tsx +81 -0
  43. package/emotion/cjs/examples/plasma_web/components/Editable/Editable.config.js +22 -0
  44. package/emotion/cjs/examples/plasma_web/components/Editable/Editable.js +22 -0
  45. package/emotion/cjs/examples/plasma_web/components/Editable/Editable.stories.tsx +81 -0
  46. package/emotion/cjs/index.js +11 -0
  47. package/emotion/cjs/utils/constants.js +19 -0
  48. package/emotion/cjs/utils/index.js +8 -2
  49. package/emotion/es/components/Editable/Editable.js +152 -0
  50. package/emotion/es/components/Editable/Editable.styles.js +19 -0
  51. package/emotion/es/components/Editable/Editable.tokens.js +13 -0
  52. package/emotion/es/components/Editable/Editable.types.js +1 -0
  53. package/emotion/es/components/Editable/index.js +2 -0
  54. package/emotion/es/components/Editable/utils/clearSelection.js +13 -0
  55. package/emotion/es/components/Editable/utils/index.js +2 -0
  56. package/emotion/es/components/Editable/utils/selectText.js +20 -0
  57. package/emotion/es/components/Editable/variations/_size/base.js +4 -0
  58. package/emotion/es/components/Editable/variations/_size/tokens.json +1 -0
  59. package/emotion/es/components/Editable/variations/_view/base.js +4 -0
  60. package/emotion/es/components/Editable/variations/_view/tokens.json +5 -0
  61. package/emotion/es/components/Grid/Grid.js +1 -1
  62. package/emotion/es/examples/plasma_b2c/components/Editable/Editable.config.js +16 -0
  63. package/emotion/es/examples/plasma_b2c/components/Editable/Editable.js +16 -0
  64. package/emotion/es/examples/plasma_b2c/components/Editable/Editable.stories.tsx +81 -0
  65. package/emotion/es/examples/plasma_web/components/Editable/Editable.config.js +16 -0
  66. package/emotion/es/examples/plasma_web/components/Editable/Editable.js +16 -0
  67. package/emotion/es/examples/plasma_web/components/Editable/Editable.stories.tsx +81 -0
  68. package/emotion/es/index.js +2 -1
  69. package/emotion/es/utils/constants.js +13 -0
  70. package/emotion/es/utils/index.js +2 -0
  71. package/es/components/Editable/Editable.css +8 -0
  72. package/es/components/Editable/Editable.js +151 -0
  73. package/es/components/Editable/Editable.js.map +1 -0
  74. package/es/components/Editable/Editable.styles.js +31 -0
  75. package/es/components/Editable/Editable.styles.js.map +1 -0
  76. package/es/components/Editable/Editable.styles_somxw2.css +4 -0
  77. package/es/components/Editable/Editable.tokens.js +16 -0
  78. package/es/components/Editable/Editable.tokens.js.map +1 -0
  79. package/es/components/Editable/utils/clearSelection.js +19 -0
  80. package/es/components/Editable/utils/clearSelection.js.map +1 -0
  81. package/es/components/Editable/utils/selectText.js +26 -0
  82. package/es/components/Editable/utils/selectText.js.map +1 -0
  83. package/es/components/Editable/variations/_size/base.js +5 -0
  84. package/es/components/Editable/variations/_size/base.js.map +1 -0
  85. package/es/components/Editable/variations/_size/base_54y6eh.css +1 -0
  86. package/es/components/Editable/variations/_view/base.js +5 -0
  87. package/es/components/Editable/variations/_view/base.js.map +1 -0
  88. package/es/components/Editable/variations/_view/base_11fpjfv.css +1 -0
  89. package/es/components/Grid/Grid.js +1 -1
  90. package/es/components/Grid/Grid.js.map +1 -1
  91. package/es/index.css +9 -0
  92. package/es/index.js +4 -0
  93. package/es/index.js.map +1 -1
  94. package/es/utils/constants.js +16 -0
  95. package/es/utils/constants.js.map +1 -0
  96. package/es/utils/index.js.map +1 -1
  97. package/package.json +2 -2
  98. package/styled-components/cjs/components/Editable/Editable.js +161 -0
  99. package/styled-components/cjs/components/Editable/Editable.styles.js +26 -0
  100. package/styled-components/cjs/components/Editable/Editable.tokens.js +19 -0
  101. package/styled-components/cjs/components/Editable/Editable.types.js +5 -0
  102. package/styled-components/cjs/components/Editable/index.js +25 -0
  103. package/styled-components/cjs/components/Editable/utils/clearSelection.js +19 -0
  104. package/styled-components/cjs/components/Editable/utils/index.js +19 -0
  105. package/styled-components/cjs/components/Editable/utils/selectText.js +26 -0
  106. package/styled-components/cjs/components/Editable/variations/_size/base.js +10 -0
  107. package/styled-components/cjs/components/Editable/variations/_size/tokens.json +1 -0
  108. package/styled-components/cjs/components/Editable/variations/_view/base.js +10 -0
  109. package/styled-components/cjs/components/Editable/variations/_view/tokens.json +5 -0
  110. package/styled-components/cjs/components/Grid/Grid.js +1 -1
  111. package/styled-components/cjs/examples/plasma_b2c/components/Editable/Editable.config.js +22 -0
  112. package/styled-components/cjs/examples/plasma_b2c/components/Editable/Editable.js +22 -0
  113. package/styled-components/cjs/examples/plasma_b2c/components/Editable/Editable.stories.tsx +81 -0
  114. package/styled-components/cjs/examples/plasma_web/components/Editable/Editable.config.js +22 -0
  115. package/styled-components/cjs/examples/plasma_web/components/Editable/Editable.js +22 -0
  116. package/styled-components/cjs/examples/plasma_web/components/Editable/Editable.stories.tsx +81 -0
  117. package/styled-components/cjs/index.js +11 -0
  118. package/styled-components/cjs/utils/constants.js +19 -0
  119. package/styled-components/cjs/utils/index.js +8 -2
  120. package/styled-components/es/components/Editable/Editable.js +152 -0
  121. package/styled-components/es/components/Editable/Editable.styles.js +18 -0
  122. package/styled-components/es/components/Editable/Editable.tokens.js +13 -0
  123. package/styled-components/es/components/Editable/Editable.types.js +1 -0
  124. package/styled-components/es/components/Editable/index.js +2 -0
  125. package/styled-components/es/components/Editable/utils/clearSelection.js +13 -0
  126. package/styled-components/es/components/Editable/utils/index.js +2 -0
  127. package/styled-components/es/components/Editable/utils/selectText.js +20 -0
  128. package/styled-components/es/components/Editable/variations/_size/base.js +4 -0
  129. package/styled-components/es/components/Editable/variations/_size/tokens.json +1 -0
  130. package/styled-components/es/components/Editable/variations/_view/base.js +4 -0
  131. package/styled-components/es/components/Editable/variations/_view/tokens.json +5 -0
  132. package/styled-components/es/components/Grid/Grid.js +1 -1
  133. package/styled-components/es/examples/plasma_b2c/components/Editable/Editable.config.js +16 -0
  134. package/styled-components/es/examples/plasma_b2c/components/Editable/Editable.js +16 -0
  135. package/styled-components/es/examples/plasma_b2c/components/Editable/Editable.stories.tsx +81 -0
  136. package/styled-components/es/examples/plasma_web/components/Editable/Editable.config.js +16 -0
  137. package/styled-components/es/examples/plasma_web/components/Editable/Editable.js +16 -0
  138. package/styled-components/es/examples/plasma_web/components/Editable/Editable.stories.tsx +81 -0
  139. package/styled-components/es/index.js +2 -1
  140. package/styled-components/es/utils/constants.js +13 -0
  141. package/styled-components/es/utils/index.js +2 -0
  142. package/types/components/Editable/Editable.d.ts +23 -0
  143. package/types/components/Editable/Editable.d.ts.map +1 -0
  144. package/types/components/Editable/Editable.styles.d.ts +8 -0
  145. package/types/components/Editable/Editable.styles.d.ts.map +1 -0
  146. package/types/components/Editable/Editable.tokens.d.ts +14 -0
  147. package/types/components/Editable/Editable.tokens.d.ts.map +1 -0
  148. package/types/components/Editable/Editable.types.d.ts +39 -0
  149. package/types/components/Editable/Editable.types.d.ts.map +1 -0
  150. package/types/components/Editable/index.d.ts +3 -0
  151. package/types/components/Editable/index.d.ts.map +1 -0
  152. package/types/components/Editable/utils/clearSelection.d.ts +2 -0
  153. package/types/components/Editable/utils/clearSelection.d.ts.map +1 -0
  154. package/types/components/Editable/utils/index.d.ts +3 -0
  155. package/types/components/Editable/utils/index.d.ts.map +1 -0
  156. package/types/components/Editable/utils/selectText.d.ts +2 -0
  157. package/types/components/Editable/utils/selectText.d.ts.map +1 -0
  158. package/types/components/Editable/variations/_size/base.d.ts +2 -0
  159. package/types/components/Editable/variations/_size/base.d.ts.map +1 -0
  160. package/types/components/Editable/variations/_view/base.d.ts +2 -0
  161. package/types/components/Editable/variations/_view/base.d.ts.map +1 -0
  162. package/types/components/Pagination/utils/index.d.ts +1 -1
  163. package/types/examples/plasma_b2c/components/Editable/Editable.config.d.ts +15 -0
  164. package/types/examples/plasma_b2c/components/Editable/Editable.config.d.ts.map +1 -0
  165. package/types/examples/plasma_b2c/components/Editable/Editable.d.ts +57 -0
  166. package/types/examples/plasma_b2c/components/Editable/Editable.d.ts.map +1 -0
  167. package/types/examples/plasma_web/components/Editable/Editable.config.d.ts +15 -0
  168. package/types/examples/plasma_web/components/Editable/Editable.config.d.ts.map +1 -0
  169. package/types/examples/plasma_web/components/Editable/Editable.d.ts +57 -0
  170. package/types/examples/plasma_web/components/Editable/Editable.d.ts.map +1 -0
  171. package/types/index.d.ts +1 -0
  172. package/types/index.d.ts.map +1 -1
  173. package/types/utils/constants.d.ts +14 -0
  174. package/types/utils/constants.d.ts.map +1 -0
  175. package/types/utils/index.d.ts +1 -0
  176. package/types/utils/index.d.ts.map +1 -1
@@ -1,5 +1,6 @@
1
1
  "use strict";
2
2
 
3
+ function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
3
4
  Object.defineProperty(exports, "__esModule", {
4
5
  value: true
5
6
  });
@@ -12,7 +13,8 @@ var _exportNames = {
12
13
  IS_REACT_18: true,
13
14
  safeUseId: true,
14
15
  isNumber: true,
15
- isEmpty: true
16
+ isEmpty: true,
17
+ constants: true
16
18
  };
17
19
  Object.defineProperty(exports, "IS_REACT_18", {
18
20
  enumerable: true,
@@ -26,7 +28,7 @@ Object.defineProperty(exports, "canUseDOM", {
26
28
  return _canUseDOM.canUseDOM;
27
29
  }
28
30
  });
29
- exports.cx = exports.composableStyle = void 0;
31
+ exports.cx = exports.constants = exports.composableStyle = void 0;
30
32
  Object.defineProperty(exports, "extractTextFrom", {
31
33
  enumerable: true,
32
34
  get: function get() {
@@ -63,6 +65,8 @@ var _getSizeValueFromProp = /*#__PURE__*/require("./getSizeValueFromProp");
63
65
  var _react = /*#__PURE__*/require("./react");
64
66
  var _isNumber = /*#__PURE__*/require("./isNumber");
65
67
  var _isEmpty = /*#__PURE__*/require("./isEmpty");
68
+ var _constants = /*#__PURE__*/_interopRequireWildcard( /*#__PURE__*/require("./constants"));
69
+ exports.constants = _constants;
66
70
  var _getPopoverPlacement = /*#__PURE__*/require("./getPopoverPlacement");
67
71
  Object.keys(_getPopoverPlacement).forEach(function (key) {
68
72
  if (key === "default" || key === "__esModule") return;
@@ -75,6 +79,8 @@ Object.keys(_getPopoverPlacement).forEach(function (key) {
75
79
  }
76
80
  });
77
81
  });
82
+ function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
83
+ function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
78
84
  var cx = exports.cx = function cx() {
79
85
  for (var _len = arguments.length, classes = new Array(_len), _key = 0; _key < _len; _key++) {
80
86
  classes[_key] = arguments[_key];
@@ -0,0 +1,152 @@
1
+ var _excluded = ["textComponent", "value", "icon", "maxLength", "spellCheck", "placeholder", "name", "onChange", "onBlur", "onPaste"];
2
+ function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
3
+ function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
4
+ function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
5
+ function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
6
+ function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t["return"] && (u = t["return"](), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
7
+ function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
8
+ 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; }
9
+ 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; }
10
+ import React, { forwardRef, useEffect, useRef, useState } from 'react';
11
+ import { useForkRef } from '@salutejs/plasma-core';
12
+ import { constants } from '../../utils';
13
+ import { clearSelection, selectText } from './utils';
14
+ import { classes } from './Editable.tokens';
15
+ import { base, EditButton, StyledInput, StyledPlacehpolder } from './Editable.styles';
16
+ import { base as viewCSS } from './variations/_view/base';
17
+ import { base as sizeCSS } from './variations/_size/base';
18
+ export var editableRoot = function editableRoot(typograpyVariants) {
19
+ return function (Root) {
20
+ return /*#__PURE__*/forwardRef(function (_ref, outerRef) {
21
+ var _prevValueRef$current;
22
+ var textComponent = _ref.textComponent,
23
+ value = _ref.value,
24
+ icon = _ref.icon,
25
+ maxLength = _ref.maxLength,
26
+ _ref$spellCheck = _ref.spellCheck,
27
+ spellCheck = _ref$spellCheck === void 0 ? 'false' : _ref$spellCheck,
28
+ placeholder = _ref.placeholder,
29
+ name = _ref.name,
30
+ onChange = _ref.onChange,
31
+ onBlur = _ref.onBlur,
32
+ onPaste = _ref.onPaste,
33
+ props = _objectWithoutProperties(_ref, _excluded);
34
+ var Component = textComponent;
35
+ var _useState = useState(false),
36
+ _useState2 = _slicedToArray(_useState, 2),
37
+ isEditing = _useState2[0],
38
+ setIsEditing = _useState2[1];
39
+ var inputRef = useRef(null);
40
+ var innerRef = useForkRef(inputRef, outerRef);
41
+ var prevValueRef = useRef(value || '');
42
+ var handlePaste = function handlePaste(e) {
43
+ if (!inputRef.current) {
44
+ return;
45
+ }
46
+ e.preventDefault();
47
+ var text = e.clipboardData.getData('text/plain').replace(/[\n\r]/gi, '');
48
+ if (document.queryCommandSupported('insertText')) {
49
+ document.execCommand('insertText', false, text);
50
+ } else {
51
+ try {
52
+ navigator.clipboard.writeText(text);
53
+ } catch (_unused) {
54
+ inputRef.current.textContent = text;
55
+ }
56
+ }
57
+ if (onPaste) {
58
+ onPaste(e);
59
+ }
60
+ };
61
+ var handleBlur = function handleBlur(e) {
62
+ setIsEditing(false);
63
+ clearSelection();
64
+
65
+ // NOTE: Remove <br> tag inserted by Safari
66
+ // const editableElement = inputRef.current;
67
+ // if (editableElement && editableElement.innerHTML === '<br>') {
68
+ // editableElement.innerHTML = '';
69
+ // }
70
+
71
+ if (onBlur) {
72
+ onBlur(e);
73
+ }
74
+ };
75
+ var handleFocus = function handleFocus() {
76
+ setIsEditing(true);
77
+ inputRef.current && selectText(inputRef.current);
78
+ };
79
+ var handleEditClick = function handleEditClick() {
80
+ var _inputRef$current;
81
+ (_inputRef$current = inputRef.current) === null || _inputRef$current === void 0 || _inputRef$current.focus();
82
+ };
83
+ var handleKeyDown = function handleKeyDown(e) {
84
+ if ([constants.keyCodes.Enter, constants.keyCodes.Escape].includes(e.keyCode)) {
85
+ var _inputRef$current2;
86
+ (_inputRef$current2 = inputRef.current) === null || _inputRef$current2 === void 0 || _inputRef$current2.blur();
87
+ }
88
+ };
89
+ var handleChange = function handleChange(e) {
90
+ var _inputRef$current$tex;
91
+ if (!inputRef.current) {
92
+ return;
93
+ }
94
+ var contentLength = ((_inputRef$current$tex = inputRef.current.textContent) === null || _inputRef$current$tex === void 0 ? void 0 : _inputRef$current$tex.length) || 0;
95
+ if (!maxLength || contentLength <= maxLength) {
96
+ prevValueRef.current = inputRef.current.textContent || '';
97
+ onChange && onChange(e);
98
+ } else {
99
+ inputRef.current.textContent = prevValueRef.current;
100
+ }
101
+ };
102
+ useEffect(function () {
103
+ if (!inputRef.current || typeof value === 'undefined' || value === inputRef.current.textContent) {
104
+ return;
105
+ }
106
+ inputRef.current.textContent = value;
107
+ }, [value, textComponent]);
108
+ return /*#__PURE__*/React.createElement(Root, props, /*#__PURE__*/React.createElement(Component, {
109
+ ref: innerRef,
110
+ className: classes.editableTextBox,
111
+ role: "textbox",
112
+ spellCheck: spellCheck,
113
+ contentEditable: true,
114
+ onPaste: handlePaste,
115
+ onInput: handleChange,
116
+ onBlur: handleBlur,
117
+ onFocus: handleFocus,
118
+ onKeyDown: handleKeyDown,
119
+ "aria-label": placeholder
120
+ }), ((_prevValueRef$current = prevValueRef.current) === null || _prevValueRef$current === void 0 ? void 0 : _prevValueRef$current.length) === 0 && !isEditing && /*#__PURE__*/React.createElement(StyledPlacehpolder, {
121
+ onClick: handleEditClick
122
+ }, placeholder), /*#__PURE__*/React.createElement(StyledInput, {
123
+ type: "hidden",
124
+ value: prevValueRef.current,
125
+ name: name
126
+ }), /*#__PURE__*/React.createElement(EditButton, {
127
+ onClick: handleEditClick,
128
+ isHidden: isEditing
129
+ }, icon));
130
+ });
131
+ };
132
+ };
133
+ export var editableConfig = function editableConfig(typographyVariants) {
134
+ return {
135
+ name: 'Editable',
136
+ tag: 'span',
137
+ layout: editableRoot(typographyVariants),
138
+ base: base,
139
+ variations: {
140
+ view: {
141
+ css: viewCSS
142
+ },
143
+ size: {
144
+ css: sizeCSS
145
+ }
146
+ },
147
+ defaults: {
148
+ view: 'default',
149
+ size: 'm'
150
+ }
151
+ };
152
+ };
@@ -0,0 +1,18 @@
1
+ var _templateObject;
2
+ function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); }
3
+ import { css } from 'styled-components';
4
+ import styled from 'styled-components';
5
+ import { classes, tokens } from './Editable.tokens';
6
+ export var EditButton = /*#__PURE__*/styled.span.withConfig({
7
+ componentId: "plasma-new-hope__sc-ss2coc-0"
8
+ })(["position:relative;align-self:stretch;display:", ";"], function (_ref) {
9
+ var isHidden = _ref.isHidden;
10
+ return isHidden ? 'none' : '';
11
+ });
12
+ export var StyledInput = /*#__PURE__*/styled.input.withConfig({
13
+ componentId: "plasma-new-hope__sc-ss2coc-1"
14
+ })([""]);
15
+ export var StyledPlacehpolder = /*#__PURE__*/styled.span.withConfig({
16
+ componentId: "plasma-new-hope__sc-ss2coc-2"
17
+ })(["display:inline-block;color:var(", ");"], tokens.placeholderColor);
18
+ export var base = /*#__PURE__*/css(_templateObject || (_templateObject = /*#__PURE__*/_taggedTemplateLiteral(["\n display: inline-flex;\n align-items: center;\n max-width: 100%;\n cursor: pointer;\n\n .", " {\n outline: none;\n overflow: hidden;\n white-space: nowrap;\n caret-color: var(", ");\n }\n"])), classes.editableTextBox, tokens.caretColor);
@@ -0,0 +1,13 @@
1
+ export var classes = {
2
+ editableTextBox: 'editable-text-box'
3
+ };
4
+ export var tokens = {
5
+ editButtonBackground: '--plasma-editable-edit-button-background',
6
+ editButtonColor: '--plasma-editable-edit-button-color',
7
+ editButtonColorHover: '--plasma-editable-edit-button-color-hover',
8
+ editButtonPaddingLeft: '--plasma-editable-edit-button-padding-left',
9
+ placeholderColor: '--plasma-editable-placeholder-color',
10
+ caretColor: '--plasma-editable-caret-color',
11
+ textBoxMarginRight: '--plasma-editable-text-box-margin-right',
12
+ textBoxPaddingRight: '--plasma-editable-text-box-padding-right'
13
+ };
@@ -0,0 +1,2 @@
1
+ export { editableConfig, editableRoot } from './Editable';
2
+ export { tokens as editableTokens } from './Editable.tokens';
@@ -0,0 +1,13 @@
1
+ import { canUseDOM } from '../../../utils';
2
+ export var clearSelection = function clearSelection() {
3
+ if (!canUseDOM) {
4
+ return;
5
+ }
6
+ var doc = document;
7
+ if (window.getSelection) {
8
+ var _window$getSelection;
9
+ (_window$getSelection = window.getSelection()) === null || _window$getSelection === void 0 || _window$getSelection.removeAllRanges();
10
+ } else if (doc.selection) {
11
+ doc.selection.empty();
12
+ }
13
+ };
@@ -0,0 +1,2 @@
1
+ export { clearSelection } from './clearSelection';
2
+ export { selectText } from './selectText';
@@ -0,0 +1,20 @@
1
+ import { canUseDOM } from '../../../utils';
2
+ export var selectText = function selectText(node) {
3
+ if (!canUseDOM) {
4
+ return;
5
+ }
6
+ setTimeout(function () {
7
+ var body = document.body;
8
+ if (window.getSelection && document.createRange) {
9
+ var range = document.createRange();
10
+ range.selectNodeContents(node);
11
+ var selection = window.getSelection();
12
+ selection === null || selection === void 0 || selection.removeAllRanges();
13
+ selection === null || selection === void 0 || selection.addRange(range);
14
+ } else if (body.createTextRange) {
15
+ var _range = body.createTextRange();
16
+ _range.moveToElementText(node);
17
+ _range.select();
18
+ }
19
+ });
20
+ };
@@ -0,0 +1,4 @@
1
+ import { css } from 'styled-components';
2
+ import { classes, tokens } from '../../Editable.tokens';
3
+ import { EditButton } from '../../Editable.styles';
4
+ export var base = /*#__PURE__*/css(["", "{padding-left:var(", ");}.", "{margin-right:var(", ");padding-right:var(", ");}"], EditButton, tokens.editButtonPaddingLeft, classes.editableTextBox, tokens.textBoxMarginRight, tokens.textBoxPaddingRight);
@@ -0,0 +1 @@
1
+ ["--plasma-editable-edit-button-padding-left"]
@@ -0,0 +1,4 @@
1
+ import { css } from 'styled-components';
2
+ import { tokens } from '../../Editable.tokens';
3
+ import { EditButton } from '../../Editable.styles';
4
+ export var base = /*#__PURE__*/css(["", "{background:var( --plasma-editable-icon-background,linear-gradient(270deg,var(", ") 70%,rgba(0,0,0,0) 120%) );color:var(", ");}&:hover > ", "{color:var(", ");}"], EditButton, tokens.editButtonBackground, tokens.editButtonColor, EditButton, tokens.editButtonColorHover);
@@ -0,0 +1,5 @@
1
+ [
2
+ "--plasma-editable-edit-button-background",
3
+ "--plasma-editable-edit-button-color",
4
+ "--plasma-editable-edit-button-color-hover"
5
+ ]
@@ -21,7 +21,7 @@ export var gridRoot = function gridRoot(Root) {
21
21
  style = props.style,
22
22
  maxWidth = props.maxWidth,
23
23
  rest = _objectWithoutProperties(props, _excluded);
24
- var viewClass = getGridViewClass(view || 'default');
24
+ var viewClass = getGridViewClass(view || 'deafult');
25
25
  var maxWidthValue = view === 'legacy' ? '90rem' : null;
26
26
  var maxWidthToken = maxWidthValue || maxWidth ? {
27
27
  '--plasma_private-grid-max-width': maxWidth || maxWidthValue
@@ -0,0 +1,16 @@
1
+ import { css } from 'styled-components';
2
+ import { editableTokens } from '../../../../components/Editable';
3
+ export var config = {
4
+ defaults: {
5
+ view: 'default',
6
+ size: 'm'
7
+ },
8
+ variations: {
9
+ view: {
10
+ "default": /*#__PURE__*/css(["", ":var(--background-primary);", ":var(--text-tertiary);", ":var(--text-primary);", ":var(--text-secondary);", ":var(--text-accent);"], editableTokens.editButtonBackground, editableTokens.editButtonColor, editableTokens.editButtonColorHover, editableTokens.placeholderColor, editableTokens.caretColor)
11
+ },
12
+ size: {
13
+ m: /*#__PURE__*/css(["", ":1rem;", ":1rem;", ":-1rem;"], editableTokens.editButtonPaddingLeft, editableTokens.textBoxPaddingRight, editableTokens.textBoxMarginRight)
14
+ }
15
+ }
16
+ };
@@ -0,0 +1,16 @@
1
+ import { editableConfig } from '../../../../components/Editable';
2
+ import { component, mergeConfig } from '../../../../engines';
3
+ import { Body } from '../../../typograpy/components/Body/Body';
4
+ import { Dspl } from '../../../typograpy/components/Dspl/Dspl';
5
+ import { Heading } from '../../../typograpy/components/Heading/Heading';
6
+ import { Text } from '../../../typograpy/components/Text/Text';
7
+ import { config } from './Editable.config';
8
+ export var typographyVariants = {
9
+ Body: Body,
10
+ Dspl: Dspl,
11
+ Heading: Heading,
12
+ Text: Text
13
+ };
14
+ var finalConfig = /*#__PURE__*/editableConfig(typographyVariants);
15
+ var mergedConfig = /*#__PURE__*/mergeConfig(finalConfig, config);
16
+ export var Editable = /*#__PURE__*/component(mergedConfig);
@@ -0,0 +1,81 @@
1
+ import React, { useState } from 'react';
2
+ import type { ComponentProps } from 'react';
3
+ import type { StoryObj, Meta } from '@storybook/react';
4
+ import { disableProps } from '@salutejs/plasma-sb-utils';
5
+
6
+ import { IconDisclosureLeft } from '../../../../components/_Icon';
7
+ import { WithTheme } from '../../../_helpers';
8
+
9
+ import { Editable, typographyVariants } from './Editable';
10
+
11
+ const iconSizes = ['s', 'xs'] as const;
12
+
13
+ const meta: Meta<typeof Editable> = {
14
+ title: 'plasma_b2c/Editable',
15
+ decorators: [WithTheme],
16
+ component: Editable,
17
+ argTypes: {
18
+ ...disableProps([
19
+ 'ref',
20
+ 'theme',
21
+ 'as',
22
+ 'forwardedAs',
23
+ 'textComponent',
24
+ 'icon',
25
+ 'onChange',
26
+ 'onBlur',
27
+ 'onPaste',
28
+ 'value',
29
+ 'view',
30
+ 'size',
31
+ ]),
32
+ },
33
+ };
34
+
35
+ export default meta;
36
+
37
+ type StoryPropsDefault = ComponentProps<typeof Editable> & {
38
+ iconSize: typeof iconSizes[number];
39
+ componentName: keyof typeof typographyVariants;
40
+ defaultValue: string;
41
+ };
42
+
43
+ const StoryDefault = ({ defaultValue, componentName, iconSize, ...rest }: StoryPropsDefault) => {
44
+ const [, setValue] = useState<string>(defaultValue);
45
+
46
+ const handleChange = (e) => {
47
+ setValue(e.target.textContent);
48
+ };
49
+
50
+ return (
51
+ <Editable
52
+ {...rest}
53
+ icon={<IconDisclosureLeft size={iconSize} color="inherit" />}
54
+ textComponent={typographyVariants[componentName]}
55
+ value={defaultValue}
56
+ onChange={handleChange}
57
+ />
58
+ );
59
+ };
60
+
61
+ export const Default: StoryObj<StoryPropsDefault> = {
62
+ argTypes: {
63
+ iconSize: {
64
+ options: iconSizes,
65
+ control: { type: 'select' },
66
+ },
67
+ componentName: {
68
+ options: Object.keys(typographyVariants),
69
+ control: { type: 'select' },
70
+ },
71
+ },
72
+ args: {
73
+ view: 'default',
74
+ size: 'm',
75
+ iconSize: 'xs',
76
+ componentName: 'Body',
77
+ defaultValue: 'Document 1',
78
+ placeholder: 'Компонент с возможностью редактирования текста',
79
+ },
80
+ render: (args) => <StoryDefault {...args} />,
81
+ };
@@ -0,0 +1,16 @@
1
+ import { css } from 'styled-components';
2
+ import { editableTokens } from '../../../../components/Editable';
3
+ export var config = {
4
+ defaults: {
5
+ view: 'default',
6
+ size: 'm'
7
+ },
8
+ variations: {
9
+ view: {
10
+ "default": /*#__PURE__*/css(["", ":var(--background-primary);", ":var(--text-tertiary);", ":var(--text-primary);", ":var(--text-secondary);", ":var(--text-accent);"], editableTokens.editButtonBackground, editableTokens.editButtonColor, editableTokens.editButtonColorHover, editableTokens.placeholderColor, editableTokens.caretColor)
11
+ },
12
+ size: {
13
+ m: /*#__PURE__*/css(["", ":1rem;", ":1rem;", ":-1rem;"], editableTokens.editButtonPaddingLeft, editableTokens.textBoxPaddingRight, editableTokens.textBoxMarginRight)
14
+ }
15
+ }
16
+ };
@@ -0,0 +1,16 @@
1
+ import { editableConfig } from '../../../../components/Editable';
2
+ import { component, mergeConfig } from '../../../../engines';
3
+ import { Body } from '../../../typograpy/components/Body/Body';
4
+ import { Dspl } from '../../../typograpy/components/Dspl/Dspl';
5
+ import { Heading } from '../../../typograpy/components/Heading/Heading';
6
+ import { Text } from '../../../typograpy/components/Text/Text';
7
+ import { config } from './Editable.config';
8
+ export var typographyVariants = {
9
+ Body: Body,
10
+ Dspl: Dspl,
11
+ Heading: Heading,
12
+ Text: Text
13
+ };
14
+ var finalConfig = /*#__PURE__*/editableConfig(typographyVariants);
15
+ var mergedConfig = /*#__PURE__*/mergeConfig(finalConfig, config);
16
+ export var Editable = /*#__PURE__*/component(mergedConfig);
@@ -0,0 +1,81 @@
1
+ import React, { useState } from 'react';
2
+ import type { ComponentProps } from 'react';
3
+ import type { StoryObj, Meta } from '@storybook/react';
4
+ import { disableProps } from '@salutejs/plasma-sb-utils';
5
+
6
+ import { IconDisclosureLeft } from '../../../../components/_Icon';
7
+ import { WithTheme } from '../../../_helpers';
8
+
9
+ import { Editable, typographyVariants } from './Editable';
10
+
11
+ const iconSizes = ['s', 'xs'] as const;
12
+
13
+ const meta: Meta<typeof Editable> = {
14
+ title: 'plasma_web/Editable',
15
+ decorators: [WithTheme],
16
+ component: Editable,
17
+ argTypes: {
18
+ ...disableProps([
19
+ 'ref',
20
+ 'theme',
21
+ 'as',
22
+ 'forwardedAs',
23
+ 'textComponent',
24
+ 'icon',
25
+ 'onChange',
26
+ 'onBlur',
27
+ 'onPaste',
28
+ 'value',
29
+ 'view',
30
+ 'size',
31
+ ]),
32
+ },
33
+ };
34
+
35
+ export default meta;
36
+
37
+ type StoryPropsDefault = ComponentProps<typeof Editable> & {
38
+ iconSize: typeof iconSizes[number];
39
+ componentName: keyof typeof typographyVariants;
40
+ defaultValue: string;
41
+ };
42
+
43
+ const StoryDefault = ({ defaultValue, componentName, iconSize, ...rest }: StoryPropsDefault) => {
44
+ const [, setValue] = useState<string>(defaultValue);
45
+
46
+ const handleChange = (e) => {
47
+ setValue(e.target.textContent);
48
+ };
49
+
50
+ return (
51
+ <Editable
52
+ {...rest}
53
+ icon={<IconDisclosureLeft size={iconSize} color="inherit" />}
54
+ textComponent={typographyVariants[componentName]}
55
+ value={defaultValue}
56
+ onChange={handleChange}
57
+ />
58
+ );
59
+ };
60
+
61
+ export const Default: StoryObj<StoryPropsDefault> = {
62
+ argTypes: {
63
+ iconSize: {
64
+ options: iconSizes,
65
+ control: { type: 'select' },
66
+ },
67
+ componentName: {
68
+ options: Object.keys(typographyVariants),
69
+ control: { type: 'select' },
70
+ },
71
+ },
72
+ args: {
73
+ view: 'default',
74
+ size: 'm',
75
+ iconSize: 'xs',
76
+ componentName: 'Body',
77
+ defaultValue: 'Document 1',
78
+ placeholder: 'Компонент с возможностью редактирования текста',
79
+ },
80
+ render: (args) => <StoryDefault {...args} />,
81
+ };
@@ -55,4 +55,5 @@ export * from './components/DatePicker';
55
55
  export * from './components/Portal';
56
56
  export * from './components/Price';
57
57
  export * from './components/Autocomplete';
58
- export * from './components/EmptyState';
58
+ export * from './components/EmptyState';
59
+ export * from './components/Editable';
@@ -0,0 +1,13 @@
1
+ export var keyCodes = {
2
+ PageUp: 33,
3
+ PageDown: 34,
4
+ Home: 36,
5
+ End: 35,
6
+ Left: 37,
7
+ Right: 39,
8
+ Up: 38,
9
+ Down: 40,
10
+ Enter: 13,
11
+ Space: 32,
12
+ Escape: 27
13
+ };
@@ -4,6 +4,8 @@ export { getSizeValueFromProp } from './getSizeValueFromProp';
4
4
  export { IS_REACT_18, safeUseId } from './react';
5
5
  export { isNumber } from './isNumber';
6
6
  export { isEmpty } from './isEmpty';
7
+ import * as _constants from './constants';
8
+ export { _constants as constants };
7
9
  export * from './getPopoverPlacement';
8
10
  export var cx = function cx() {
9
11
  for (var _len = arguments.length, classes = new Array(_len), _key = 0; _key < _len; _key++) {
@@ -0,0 +1,23 @@
1
+ import React from 'react';
2
+ import type { RootProps } from '../../engines';
3
+ import type { EditableProps, TypographyVariants } from './Editable.types';
4
+ export declare const editableRoot: (typograpyVariants: TypographyVariants) => (Root: RootProps<HTMLSpanElement, Omit<EditableProps<TypographyVariants>, "textComponent">>) => React.ForwardRefExoticComponent<EditableProps<TypographyVariants> & React.RefAttributes<HTMLInputElement>>;
5
+ export declare const editableConfig: (typographyVariants: TypographyVariants) => {
6
+ name: string;
7
+ tag: string;
8
+ layout: (Root: RootProps<HTMLSpanElement, Omit<EditableProps<TypographyVariants>, "textComponent">>) => React.ForwardRefExoticComponent<EditableProps<TypographyVariants> & React.RefAttributes<HTMLInputElement>>;
9
+ base: import("@linaria/core").LinariaClassName;
10
+ variations: {
11
+ view: {
12
+ css: import("@linaria/core").LinariaClassName;
13
+ };
14
+ size: {
15
+ css: import("@linaria/core").LinariaClassName;
16
+ };
17
+ };
18
+ defaults: {
19
+ view: string;
20
+ size: string;
21
+ };
22
+ };
23
+ //# sourceMappingURL=Editable.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Editable.d.ts","sourceRoot":"","sources":["../../../src/components/Editable/Editable.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAkD,MAAM,OAAO,CAAC;AAYvE,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAG/C,OAAO,KAAK,EAAE,aAAa,EAAE,kBAAkB,EAAE,MAAM,kBAAkB,CAAC;AAO1E,eAAO,MAAM,YAAY,sBAAuB,kBAAkB,+MAsI7D,CAAC;AAEN,eAAO,MAAM,cAAc,uBAAwB,kBAAkB;;;;;;;;;;;;;;;;;CAiBnE,CAAC"}
@@ -0,0 +1,8 @@
1
+ /// <reference types="react" />
2
+ export declare const EditButton: import("@linaria/react").StyledComponent<import("react").ClassAttributes<HTMLSpanElement> & import("react").HTMLAttributes<HTMLSpanElement> & {
3
+ isHidden: boolean;
4
+ }>;
5
+ export declare const StyledInput: import("@linaria/react").StyledComponent<import("react").ClassAttributes<HTMLInputElement> & import("react").InputHTMLAttributes<HTMLInputElement> & Record<never, unknown>>;
6
+ export declare const StyledPlacehpolder: import("@linaria/react").StyledComponent<import("react").ClassAttributes<HTMLSpanElement> & import("react").HTMLAttributes<HTMLSpanElement> & Record<never, unknown>>;
7
+ export declare const base: import("@linaria/core").LinariaClassName;
8
+ //# sourceMappingURL=Editable.styles.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Editable.styles.d.ts","sourceRoot":"","sources":["../../../src/components/Editable/Editable.styles.ts"],"names":[],"mappings":";AAKA,eAAO,MAAM,UAAU;cAA2B,OAAO;EAKxD,CAAC;AAEF,eAAO,MAAM,WAAW,8KAAiB,CAAC;AAE1C,eAAO,MAAM,kBAAkB,uKAG9B,CAAC;AAEF,eAAO,MAAM,IAAI,0CAYhB,CAAC"}
@@ -0,0 +1,14 @@
1
+ export declare const classes: {
2
+ editableTextBox: string;
3
+ };
4
+ export declare const tokens: {
5
+ editButtonBackground: string;
6
+ editButtonColor: string;
7
+ editButtonColorHover: string;
8
+ editButtonPaddingLeft: string;
9
+ placeholderColor: string;
10
+ caretColor: string;
11
+ textBoxMarginRight: string;
12
+ textBoxPaddingRight: string;
13
+ };
14
+ //# sourceMappingURL=Editable.tokens.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Editable.tokens.d.ts","sourceRoot":"","sources":["../../../src/components/Editable/Editable.tokens.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,OAAO;;CAEnB,CAAC;AAEF,eAAO,MAAM,MAAM;;;;;;;;;CASlB,CAAC"}