@salutejs/plasma-new-hope 0.144.0-canary.1418.10833167538.0 → 0.144.0-canary.1430.10833771822.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (252) hide show
  1. package/cjs/components/Editable/Editable.css +8 -0
  2. package/cjs/components/Editable/Editable.js +155 -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/index.css +9 -0
  20. package/cjs/index.js +7 -0
  21. package/cjs/index.js.map +1 -1
  22. package/cjs/utils/constants.js +20 -0
  23. package/cjs/utils/constants.js.map +1 -0
  24. package/cjs/utils/index.js.map +1 -1
  25. package/emotion/cjs/components/Editable/Editable.js +160 -0
  26. package/emotion/cjs/components/Editable/Editable.styles.js +26 -0
  27. package/emotion/cjs/components/Editable/Editable.tokens.js +19 -0
  28. package/emotion/cjs/components/Editable/index.js +25 -0
  29. package/emotion/cjs/components/Editable/utils/clearSelection.js +19 -0
  30. package/emotion/cjs/components/Editable/utils/index.js +19 -0
  31. package/emotion/cjs/components/Editable/utils/selectText.js +26 -0
  32. package/emotion/cjs/components/Editable/variations/_size/base.js +10 -0
  33. package/emotion/cjs/components/Editable/variations/_size/tokens.json +1 -0
  34. package/emotion/cjs/components/Editable/variations/_view/base.js +10 -0
  35. package/emotion/cjs/components/Editable/variations/_view/tokens.json +5 -0
  36. package/emotion/cjs/examples/plasma_b2c/components/Editable/Editable.config.js +22 -0
  37. package/emotion/cjs/examples/plasma_b2c/components/Editable/Editable.js +22 -0
  38. package/emotion/cjs/examples/plasma_b2c/components/Editable/Editable.stories.tsx +81 -0
  39. package/emotion/cjs/examples/plasma_web/components/Editable/Editable.config.js +22 -0
  40. package/emotion/cjs/examples/plasma_web/components/Editable/Editable.js +22 -0
  41. package/emotion/cjs/examples/plasma_web/components/Editable/Editable.stories.tsx +81 -0
  42. package/emotion/cjs/index.js +11 -0
  43. package/emotion/cjs/utils/constants.js +19 -0
  44. package/emotion/cjs/utils/index.js +8 -2
  45. package/emotion/es/components/Editable/Editable.js +151 -0
  46. package/emotion/es/components/Editable/Editable.styles.js +19 -0
  47. package/emotion/es/components/Editable/Editable.tokens.js +13 -0
  48. package/emotion/es/components/Editable/index.js +2 -0
  49. package/emotion/es/components/Editable/utils/clearSelection.js +13 -0
  50. package/emotion/es/components/Editable/utils/index.js +2 -0
  51. package/emotion/es/components/Editable/utils/selectText.js +20 -0
  52. package/emotion/es/components/Editable/variations/_size/base.js +4 -0
  53. package/emotion/es/components/Editable/variations/_size/tokens.json +1 -0
  54. package/emotion/es/components/Editable/variations/_view/base.js +4 -0
  55. package/emotion/es/components/Editable/variations/_view/tokens.json +5 -0
  56. package/emotion/es/examples/plasma_b2c/components/Editable/Editable.config.js +16 -0
  57. package/emotion/es/examples/plasma_b2c/components/Editable/Editable.js +16 -0
  58. package/emotion/es/examples/plasma_b2c/components/Editable/Editable.stories.tsx +81 -0
  59. package/emotion/es/examples/plasma_web/components/Editable/Editable.config.js +16 -0
  60. package/emotion/es/examples/plasma_web/components/Editable/Editable.js +16 -0
  61. package/emotion/es/examples/plasma_web/components/Editable/Editable.stories.tsx +81 -0
  62. package/emotion/es/index.js +2 -1
  63. package/emotion/es/utils/constants.js +13 -0
  64. package/emotion/es/utils/index.js +2 -0
  65. package/es/components/Editable/Editable.css +8 -0
  66. package/es/components/Editable/Editable.js +150 -0
  67. package/es/components/Editable/Editable.js.map +1 -0
  68. package/es/components/Editable/Editable.styles.js +31 -0
  69. package/es/components/Editable/Editable.styles.js.map +1 -0
  70. package/es/components/Editable/Editable.styles_somxw2.css +4 -0
  71. package/es/components/Editable/Editable.tokens.js +16 -0
  72. package/es/components/Editable/Editable.tokens.js.map +1 -0
  73. package/es/components/Editable/utils/clearSelection.js +19 -0
  74. package/es/components/Editable/utils/clearSelection.js.map +1 -0
  75. package/es/components/Editable/utils/selectText.js +26 -0
  76. package/es/components/Editable/utils/selectText.js.map +1 -0
  77. package/es/components/Editable/variations/_size/base.js +5 -0
  78. package/es/components/Editable/variations/_size/base.js.map +1 -0
  79. package/es/components/Editable/variations/_size/base_54y6eh.css +1 -0
  80. package/es/components/Editable/variations/_view/base.js +5 -0
  81. package/es/components/Editable/variations/_view/base.js.map +1 -0
  82. package/es/components/Editable/variations/_view/base_11fpjfv.css +1 -0
  83. package/es/index.css +9 -0
  84. package/es/index.js +4 -0
  85. package/es/index.js.map +1 -1
  86. package/es/utils/constants.js +16 -0
  87. package/es/utils/constants.js.map +1 -0
  88. package/es/utils/index.js.map +1 -1
  89. package/package.json +2 -2
  90. package/styled-components/cjs/components/Editable/Editable.js +160 -0
  91. package/styled-components/cjs/components/Editable/Editable.styles.js +26 -0
  92. package/styled-components/cjs/components/Editable/Editable.tokens.js +19 -0
  93. package/styled-components/cjs/components/Editable/index.js +25 -0
  94. package/styled-components/cjs/components/Editable/utils/clearSelection.js +19 -0
  95. package/styled-components/cjs/components/Editable/utils/index.js +19 -0
  96. package/styled-components/cjs/components/Editable/utils/selectText.js +26 -0
  97. package/styled-components/cjs/components/Editable/variations/_size/base.js +10 -0
  98. package/styled-components/cjs/components/Editable/variations/_size/tokens.json +1 -0
  99. package/styled-components/cjs/components/Editable/variations/_view/base.js +10 -0
  100. package/styled-components/cjs/components/Editable/variations/_view/tokens.json +5 -0
  101. package/styled-components/cjs/examples/plasma_b2c/components/Editable/Editable.config.js +22 -0
  102. package/styled-components/cjs/examples/plasma_b2c/components/Editable/Editable.js +22 -0
  103. package/styled-components/cjs/examples/plasma_b2c/components/Editable/Editable.stories.tsx +81 -0
  104. package/styled-components/cjs/examples/plasma_web/components/Editable/Editable.config.js +22 -0
  105. package/styled-components/cjs/examples/plasma_web/components/Editable/Editable.js +22 -0
  106. package/styled-components/cjs/examples/plasma_web/components/Editable/Editable.stories.tsx +81 -0
  107. package/styled-components/cjs/index.js +11 -0
  108. package/styled-components/cjs/utils/constants.js +19 -0
  109. package/styled-components/cjs/utils/index.js +8 -2
  110. package/styled-components/es/components/Editable/Editable.js +151 -0
  111. package/styled-components/es/components/Editable/Editable.styles.js +18 -0
  112. package/styled-components/es/components/Editable/Editable.tokens.js +13 -0
  113. package/styled-components/es/components/Editable/index.js +2 -0
  114. package/styled-components/es/components/Editable/utils/clearSelection.js +13 -0
  115. package/styled-components/es/components/Editable/utils/index.js +2 -0
  116. package/styled-components/es/components/Editable/utils/selectText.js +20 -0
  117. package/styled-components/es/components/Editable/variations/_size/base.js +4 -0
  118. package/styled-components/es/components/Editable/variations/_size/tokens.json +1 -0
  119. package/styled-components/es/components/Editable/variations/_view/base.js +4 -0
  120. package/styled-components/es/components/Editable/variations/_view/tokens.json +5 -0
  121. package/styled-components/es/examples/plasma_b2c/components/Editable/Editable.config.js +16 -0
  122. package/styled-components/es/examples/plasma_b2c/components/Editable/Editable.js +16 -0
  123. package/styled-components/es/examples/plasma_b2c/components/Editable/Editable.stories.tsx +81 -0
  124. package/styled-components/es/examples/plasma_web/components/Editable/Editable.config.js +16 -0
  125. package/styled-components/es/examples/plasma_web/components/Editable/Editable.js +16 -0
  126. package/styled-components/es/examples/plasma_web/components/Editable/Editable.stories.tsx +81 -0
  127. package/styled-components/es/index.js +2 -1
  128. package/styled-components/es/utils/constants.js +13 -0
  129. package/styled-components/es/utils/index.js +2 -0
  130. package/types/components/Editable/Editable.d.ts +23 -0
  131. package/types/components/Editable/Editable.d.ts.map +1 -0
  132. package/types/components/Editable/Editable.styles.d.ts +8 -0
  133. package/types/components/Editable/Editable.styles.d.ts.map +1 -0
  134. package/types/components/Editable/Editable.tokens.d.ts +14 -0
  135. package/types/components/Editable/Editable.tokens.d.ts.map +1 -0
  136. package/types/components/Editable/Editable.types.d.ts +39 -0
  137. package/types/components/Editable/Editable.types.d.ts.map +1 -0
  138. package/types/components/Editable/index.d.ts +3 -0
  139. package/types/components/Editable/index.d.ts.map +1 -0
  140. package/types/components/Editable/utils/clearSelection.d.ts +2 -0
  141. package/types/components/Editable/utils/clearSelection.d.ts.map +1 -0
  142. package/types/components/Editable/utils/index.d.ts +3 -0
  143. package/types/components/Editable/utils/index.d.ts.map +1 -0
  144. package/types/components/Editable/utils/selectText.d.ts +2 -0
  145. package/types/components/Editable/utils/selectText.d.ts.map +1 -0
  146. package/types/components/Editable/variations/_size/base.d.ts +2 -0
  147. package/types/components/Editable/variations/_size/base.d.ts.map +1 -0
  148. package/types/components/Editable/variations/_view/base.d.ts +2 -0
  149. package/types/components/Editable/variations/_view/base.d.ts.map +1 -0
  150. package/types/components/Pagination/utils/index.d.ts +1 -1
  151. package/types/examples/plasma_b2c/components/Editable/Editable.config.d.ts +15 -0
  152. package/types/examples/plasma_b2c/components/Editable/Editable.config.d.ts.map +1 -0
  153. package/types/examples/plasma_b2c/components/Editable/Editable.d.ts +57 -0
  154. package/types/examples/plasma_b2c/components/Editable/Editable.d.ts.map +1 -0
  155. package/types/examples/plasma_web/components/Editable/Editable.config.d.ts +15 -0
  156. package/types/examples/plasma_web/components/Editable/Editable.config.d.ts.map +1 -0
  157. package/types/examples/plasma_web/components/Editable/Editable.d.ts +57 -0
  158. package/types/examples/plasma_web/components/Editable/Editable.d.ts.map +1 -0
  159. package/types/index.d.ts +1 -0
  160. package/types/index.d.ts.map +1 -1
  161. package/types/utils/constants.d.ts +14 -0
  162. package/types/utils/constants.d.ts.map +1 -0
  163. package/types/utils/index.d.ts +1 -0
  164. package/types/utils/index.d.ts.map +1 -1
  165. package/emotion/cjs/components/Mask/Mask.js +0 -207
  166. package/emotion/cjs/components/Mask/index.js +0 -12
  167. package/emotion/cjs/components/Mask/utils/constants.js +0 -31
  168. package/emotion/cjs/components/Mask/utils/createMask.js +0 -50
  169. package/emotion/cjs/components/Mask/utils/mask.js +0 -248
  170. package/emotion/cjs/components/Mask/utils/parseMask.js +0 -36
  171. package/emotion/cjs/components/Mask/utils/processInput.js +0 -52
  172. package/emotion/cjs/components/Mask/utils/processMask.js +0 -99
  173. package/emotion/cjs/components/Mask/utils/selection.js +0 -48
  174. package/emotion/cjs/components/Mask/utils/types/mask.types.js +0 -5
  175. package/emotion/cjs/components/Mask/utils/types/selectRange.types.js +0 -5
  176. package/emotion/cjs/examples/plasma_b2c/components/Mask/Mask.js +0 -9
  177. package/emotion/cjs/examples/plasma_b2c/components/Mask/Mask.stories.tsx +0 -131
  178. package/emotion/es/components/Mask/Mask.js +0 -199
  179. package/emotion/es/components/Mask/index.js +0 -1
  180. package/emotion/es/components/Mask/utils/constants.js +0 -25
  181. package/emotion/es/components/Mask/utils/createMask.js +0 -44
  182. package/emotion/es/components/Mask/utils/mask.js +0 -242
  183. package/emotion/es/components/Mask/utils/parseMask.js +0 -30
  184. package/emotion/es/components/Mask/utils/processInput.js +0 -46
  185. package/emotion/es/components/Mask/utils/processMask.js +0 -93
  186. package/emotion/es/components/Mask/utils/selection.js +0 -42
  187. package/emotion/es/components/Mask/utils/types/mask.types.js +0 -1
  188. package/emotion/es/components/Mask/utils/types/selectRange.types.js +0 -1
  189. package/emotion/es/examples/plasma_b2c/components/Mask/Mask.js +0 -3
  190. package/emotion/es/examples/plasma_b2c/components/Mask/Mask.stories.tsx +0 -131
  191. package/styled-components/cjs/components/Mask/Mask.js +0 -207
  192. package/styled-components/cjs/components/Mask/Mask.types.js +0 -5
  193. package/styled-components/cjs/components/Mask/index.js +0 -12
  194. package/styled-components/cjs/components/Mask/utils/constants.js +0 -31
  195. package/styled-components/cjs/components/Mask/utils/createMask.js +0 -50
  196. package/styled-components/cjs/components/Mask/utils/mask.js +0 -248
  197. package/styled-components/cjs/components/Mask/utils/parseMask.js +0 -36
  198. package/styled-components/cjs/components/Mask/utils/processInput.js +0 -52
  199. package/styled-components/cjs/components/Mask/utils/processMask.js +0 -99
  200. package/styled-components/cjs/components/Mask/utils/selection.js +0 -48
  201. package/styled-components/cjs/components/Mask/utils/types/input.types.js +0 -5
  202. package/styled-components/cjs/components/Mask/utils/types/mask.types.js +0 -5
  203. package/styled-components/cjs/components/Mask/utils/types/selectRange.types.js +0 -5
  204. package/styled-components/cjs/examples/plasma_b2c/components/Mask/Mask.js +0 -9
  205. package/styled-components/cjs/examples/plasma_b2c/components/Mask/Mask.stories.tsx +0 -131
  206. package/styled-components/es/components/Mask/Mask.js +0 -199
  207. package/styled-components/es/components/Mask/Mask.types.js +0 -1
  208. package/styled-components/es/components/Mask/index.js +0 -1
  209. package/styled-components/es/components/Mask/utils/constants.js +0 -25
  210. package/styled-components/es/components/Mask/utils/createMask.js +0 -44
  211. package/styled-components/es/components/Mask/utils/mask.js +0 -242
  212. package/styled-components/es/components/Mask/utils/parseMask.js +0 -30
  213. package/styled-components/es/components/Mask/utils/processInput.js +0 -46
  214. package/styled-components/es/components/Mask/utils/processMask.js +0 -93
  215. package/styled-components/es/components/Mask/utils/selection.js +0 -42
  216. package/styled-components/es/components/Mask/utils/types/input.types.js +0 -1
  217. package/styled-components/es/components/Mask/utils/types/mask.types.js +0 -1
  218. package/styled-components/es/components/Mask/utils/types/selectRange.types.js +0 -1
  219. package/styled-components/es/examples/plasma_b2c/components/Mask/Mask.js +0 -3
  220. package/styled-components/es/examples/plasma_b2c/components/Mask/Mask.stories.tsx +0 -131
  221. package/types/components/Mask/Mask.d.ts +0 -5
  222. package/types/components/Mask/Mask.d.ts.map +0 -1
  223. package/types/components/Mask/Mask.types.d.ts +0 -49
  224. package/types/components/Mask/Mask.types.d.ts.map +0 -1
  225. package/types/components/Mask/index.d.ts +0 -2
  226. package/types/components/Mask/index.d.ts.map +0 -1
  227. package/types/components/Mask/utils/constants.d.ts +0 -15
  228. package/types/components/Mask/utils/constants.d.ts.map +0 -1
  229. package/types/components/Mask/utils/createMask.d.ts +0 -19
  230. package/types/components/Mask/utils/createMask.d.ts.map +0 -1
  231. package/types/components/Mask/utils/mask.d.ts +0 -44
  232. package/types/components/Mask/utils/mask.d.ts.map +0 -1
  233. package/types/components/Mask/utils/parseMask.d.ts +0 -3
  234. package/types/components/Mask/utils/parseMask.d.ts.map +0 -1
  235. package/types/components/Mask/utils/processInput.d.ts +0 -15
  236. package/types/components/Mask/utils/processInput.d.ts.map +0 -1
  237. package/types/components/Mask/utils/processMask.d.ts +0 -9
  238. package/types/components/Mask/utils/processMask.d.ts.map +0 -1
  239. package/types/components/Mask/utils/selection.d.ts +0 -11
  240. package/types/components/Mask/utils/selection.d.ts.map +0 -1
  241. package/types/components/Mask/utils/types/input.types.d.ts +0 -26
  242. package/types/components/Mask/utils/types/input.types.d.ts.map +0 -1
  243. package/types/components/Mask/utils/types/mask.types.d.ts +0 -9
  244. package/types/components/Mask/utils/types/mask.types.d.ts.map +0 -1
  245. package/types/components/Mask/utils/types/selectRange.types.d.ts +0 -5
  246. package/types/components/Mask/utils/types/selectRange.types.d.ts.map +0 -1
  247. package/types/examples/plasma_b2c/components/Mask/Mask.d.ts +0 -191
  248. package/types/examples/plasma_b2c/components/Mask/Mask.d.ts.map +0 -1
  249. /package/emotion/cjs/components/{Mask/Mask.types.js → Editable/Editable.types.js} +0 -0
  250. /package/emotion/es/components/{Mask/Mask.types.js → Editable/Editable.types.js} +0 -0
  251. /package/{emotion/cjs/components/Mask/utils/types/input.types.js → styled-components/cjs/components/Editable/Editable.types.js} +0 -0
  252. /package/{emotion/es/components/Mask/utils/types/input.types.js → styled-components/es/components/Editable/Editable.types.js} +0 -0
@@ -0,0 +1,19 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.tokens = exports.classes = void 0;
7
+ var classes = exports.classes = {
8
+ editableTextBox: 'editable-text-box'
9
+ };
10
+ var tokens = exports.tokens = {
11
+ editButtonBackground: '--plasma-editable-edit-button-background',
12
+ editButtonColor: '--plasma-editable-edit-button-color',
13
+ editButtonColorHover: '--plasma-editable-edit-button-color-hover',
14
+ editButtonPaddingLeft: '--plasma-editable-edit-button-padding-left',
15
+ placeholderColor: '--plasma-editable-placeholder-color',
16
+ caretColor: '--plasma-editable-caret-color',
17
+ textBoxMarginRight: '--plasma-editable-text-box-margin-right',
18
+ textBoxPaddingRight: '--plasma-editable-text-box-padding-right'
19
+ };
@@ -0,0 +1,25 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ Object.defineProperty(exports, "editableConfig", {
7
+ enumerable: true,
8
+ get: function get() {
9
+ return _Editable.editableConfig;
10
+ }
11
+ });
12
+ Object.defineProperty(exports, "editableRoot", {
13
+ enumerable: true,
14
+ get: function get() {
15
+ return _Editable.editableRoot;
16
+ }
17
+ });
18
+ Object.defineProperty(exports, "editableTokens", {
19
+ enumerable: true,
20
+ get: function get() {
21
+ return _Editable2.tokens;
22
+ }
23
+ });
24
+ var _Editable = /*#__PURE__*/require("./Editable");
25
+ var _Editable2 = /*#__PURE__*/require("./Editable.tokens");
@@ -0,0 +1,19 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.clearSelection = void 0;
7
+ var _utils = /*#__PURE__*/require("../../../utils");
8
+ var clearSelection = exports.clearSelection = function clearSelection() {
9
+ if (!_utils.canUseDOM) {
10
+ return;
11
+ }
12
+ var doc = document;
13
+ if (window.getSelection) {
14
+ var _window$getSelection;
15
+ (_window$getSelection = window.getSelection()) === null || _window$getSelection === void 0 || _window$getSelection.removeAllRanges();
16
+ } else if (doc.selection) {
17
+ doc.selection.empty();
18
+ }
19
+ };
@@ -0,0 +1,19 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ Object.defineProperty(exports, "clearSelection", {
7
+ enumerable: true,
8
+ get: function get() {
9
+ return _clearSelection.clearSelection;
10
+ }
11
+ });
12
+ Object.defineProperty(exports, "selectText", {
13
+ enumerable: true,
14
+ get: function get() {
15
+ return _selectText.selectText;
16
+ }
17
+ });
18
+ var _clearSelection = /*#__PURE__*/require("./clearSelection");
19
+ var _selectText = /*#__PURE__*/require("./selectText");
@@ -0,0 +1,26 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.selectText = void 0;
7
+ var _utils = /*#__PURE__*/require("../../../utils");
8
+ var selectText = exports.selectText = function selectText(node) {
9
+ if (!_utils.canUseDOM) {
10
+ return;
11
+ }
12
+ setTimeout(function () {
13
+ var body = document.body;
14
+ if (window.getSelection && document.createRange) {
15
+ var range = document.createRange();
16
+ range.selectNodeContents(node);
17
+ var selection = window.getSelection();
18
+ selection === null || selection === void 0 || selection.removeAllRanges();
19
+ selection === null || selection === void 0 || selection.addRange(range);
20
+ } else if (body.createTextRange) {
21
+ var _range = body.createTextRange();
22
+ _range.moveToElementText(node);
23
+ _range.select();
24
+ }
25
+ });
26
+ };
@@ -0,0 +1,10 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.base = void 0;
7
+ var _styledComponents = /*#__PURE__*/require("styled-components");
8
+ var _Editable = /*#__PURE__*/require("../../Editable.tokens");
9
+ var _Editable2 = /*#__PURE__*/require("../../Editable.styles");
10
+ var base = exports.base = /*#__PURE__*/(0, _styledComponents.css)(["", "{padding-left:var(", ");}.", "{margin-right:var(", ");padding-right:var(", ");}"], _Editable2.EditButton, _Editable.tokens.editButtonPaddingLeft, _Editable.classes.editableTextBox, _Editable.tokens.textBoxMarginRight, _Editable.tokens.textBoxPaddingRight);
@@ -0,0 +1 @@
1
+ ["--plasma-editable-edit-button-padding-left"]
@@ -0,0 +1,10 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.base = void 0;
7
+ var _styledComponents = /*#__PURE__*/require("styled-components");
8
+ var _Editable = /*#__PURE__*/require("../../Editable.tokens");
9
+ var _Editable2 = /*#__PURE__*/require("../../Editable.styles");
10
+ var base = exports.base = /*#__PURE__*/(0, _styledComponents.css)(["", "{background:var( --plasma-editable-icon-background,linear-gradient(270deg,var(", ") 70%,rgba(0,0,0,0) 120%) );color:var(", ");}&:hover > ", "{color:var(", ");}"], _Editable2.EditButton, _Editable.tokens.editButtonBackground, _Editable.tokens.editButtonColor, _Editable2.EditButton, _Editable.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
+ ]
@@ -0,0 +1,22 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.config = void 0;
7
+ var _styledComponents = /*#__PURE__*/require("styled-components");
8
+ var _Editable = /*#__PURE__*/require("../../../../components/Editable");
9
+ var config = exports.config = {
10
+ defaults: {
11
+ view: 'default',
12
+ size: 'm'
13
+ },
14
+ variations: {
15
+ view: {
16
+ "default": /*#__PURE__*/(0, _styledComponents.css)(["", ":var(--background-primary);", ":var(--text-tertiary);", ":var(--text-primary);", ":var(--text-secondary);", ":var(--text-accent);"], _Editable.editableTokens.editButtonBackground, _Editable.editableTokens.editButtonColor, _Editable.editableTokens.editButtonColorHover, _Editable.editableTokens.placeholderColor, _Editable.editableTokens.caretColor)
17
+ },
18
+ size: {
19
+ m: /*#__PURE__*/(0, _styledComponents.css)(["", ":1rem;", ":1rem;", ":-1rem;"], _Editable.editableTokens.editButtonPaddingLeft, _Editable.editableTokens.textBoxPaddingRight, _Editable.editableTokens.textBoxMarginRight)
20
+ }
21
+ }
22
+ };
@@ -0,0 +1,22 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.typographyVariants = exports.Editable = void 0;
7
+ var _Editable = /*#__PURE__*/require("../../../../components/Editable");
8
+ var _engines = /*#__PURE__*/require("../../../../engines");
9
+ var _Body = /*#__PURE__*/require("../../../typograpy/components/Body/Body");
10
+ var _Dspl = /*#__PURE__*/require("../../../typograpy/components/Dspl/Dspl");
11
+ var _Heading = /*#__PURE__*/require("../../../typograpy/components/Heading/Heading");
12
+ var _Text = /*#__PURE__*/require("../../../typograpy/components/Text/Text");
13
+ var _Editable2 = /*#__PURE__*/require("./Editable.config");
14
+ var typographyVariants = exports.typographyVariants = {
15
+ Body: _Body.Body,
16
+ Dspl: _Dspl.Dspl,
17
+ Heading: _Heading.Heading,
18
+ Text: _Text.Text
19
+ };
20
+ var finalConfig = /*#__PURE__*/(0, _Editable.editableConfig)(typographyVariants);
21
+ var mergedConfig = /*#__PURE__*/(0, _engines.mergeConfig)(finalConfig, _Editable2.config);
22
+ var Editable = exports.Editable = /*#__PURE__*/(0, _engines.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,22 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.config = void 0;
7
+ var _styledComponents = /*#__PURE__*/require("styled-components");
8
+ var _Editable = /*#__PURE__*/require("../../../../components/Editable");
9
+ var config = exports.config = {
10
+ defaults: {
11
+ view: 'default',
12
+ size: 'm'
13
+ },
14
+ variations: {
15
+ view: {
16
+ "default": /*#__PURE__*/(0, _styledComponents.css)(["", ":var(--background-primary);", ":var(--text-tertiary);", ":var(--text-primary);", ":var(--text-secondary);", ":var(--text-accent);"], _Editable.editableTokens.editButtonBackground, _Editable.editableTokens.editButtonColor, _Editable.editableTokens.editButtonColorHover, _Editable.editableTokens.placeholderColor, _Editable.editableTokens.caretColor)
17
+ },
18
+ size: {
19
+ m: /*#__PURE__*/(0, _styledComponents.css)(["", ":1rem;", ":1rem;", ":-1rem;"], _Editable.editableTokens.editButtonPaddingLeft, _Editable.editableTokens.textBoxPaddingRight, _Editable.editableTokens.textBoxMarginRight)
20
+ }
21
+ }
22
+ };
@@ -0,0 +1,22 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.typographyVariants = exports.Editable = void 0;
7
+ var _Editable = /*#__PURE__*/require("../../../../components/Editable");
8
+ var _engines = /*#__PURE__*/require("../../../../engines");
9
+ var _Body = /*#__PURE__*/require("../../../typograpy/components/Body/Body");
10
+ var _Dspl = /*#__PURE__*/require("../../../typograpy/components/Dspl/Dspl");
11
+ var _Heading = /*#__PURE__*/require("../../../typograpy/components/Heading/Heading");
12
+ var _Text = /*#__PURE__*/require("../../../typograpy/components/Text/Text");
13
+ var _Editable2 = /*#__PURE__*/require("./Editable.config");
14
+ var typographyVariants = exports.typographyVariants = {
15
+ Body: _Body.Body,
16
+ Dspl: _Dspl.Dspl,
17
+ Heading: _Heading.Heading,
18
+ Text: _Text.Text
19
+ };
20
+ var finalConfig = /*#__PURE__*/(0, _Editable.editableConfig)(typographyVariants);
21
+ var mergedConfig = /*#__PURE__*/(0, _engines.mergeConfig)(finalConfig, _Editable2.config);
22
+ var Editable = exports.Editable = /*#__PURE__*/(0, _engines.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
+ };
@@ -618,4 +618,15 @@ Object.keys(_EmptyState).forEach(function (key) {
618
618
  return _EmptyState[key];
619
619
  }
620
620
  });
621
+ });
622
+ var _Editable = /*#__PURE__*/require("./components/Editable");
623
+ Object.keys(_Editable).forEach(function (key) {
624
+ if (key === "default" || key === "__esModule") return;
625
+ if (key in exports && exports[key] === _Editable[key]) return;
626
+ Object.defineProperty(exports, key, {
627
+ enumerable: true,
628
+ get: function get() {
629
+ return _Editable[key];
630
+ }
631
+ });
621
632
  });
@@ -0,0 +1,19 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.keyCodes = void 0;
7
+ var keyCodes = exports.keyCodes = {
8
+ PageUp: 33,
9
+ PageDown: 34,
10
+ Home: 36,
11
+ End: 35,
12
+ Left: 37,
13
+ Right: 39,
14
+ Up: 38,
15
+ Down: 40,
16
+ Enter: 13,
17
+ Space: 32,
18
+ Escape: 27
19
+ };
@@ -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,151 @@
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
+ var editableElement = inputRef.current;
67
+ if (editableElement && editableElement.innerHTML === '<br>') {
68
+ editableElement.innerHTML = '';
69
+ }
70
+ if (onBlur) {
71
+ onBlur(e);
72
+ }
73
+ };
74
+ var handleFocus = function handleFocus() {
75
+ setIsEditing(true);
76
+ inputRef.current && selectText(inputRef.current);
77
+ };
78
+ var handleEditClick = function handleEditClick() {
79
+ var _inputRef$current;
80
+ (_inputRef$current = inputRef.current) === null || _inputRef$current === void 0 || _inputRef$current.focus();
81
+ };
82
+ var handleKeyDown = function handleKeyDown(e) {
83
+ if ([constants.keyCodes.Enter, constants.keyCodes.Escape].includes(e.keyCode)) {
84
+ var _inputRef$current2;
85
+ (_inputRef$current2 = inputRef.current) === null || _inputRef$current2 === void 0 || _inputRef$current2.blur();
86
+ }
87
+ };
88
+ var handleChange = function handleChange(e) {
89
+ var _inputRef$current$tex;
90
+ if (!inputRef.current) {
91
+ return;
92
+ }
93
+ var contentLength = ((_inputRef$current$tex = inputRef.current.textContent) === null || _inputRef$current$tex === void 0 ? void 0 : _inputRef$current$tex.length) || 0;
94
+ if (!maxLength || contentLength <= maxLength) {
95
+ prevValueRef.current = inputRef.current.textContent || '';
96
+ onChange && onChange(e);
97
+ } else {
98
+ inputRef.current.textContent = prevValueRef.current;
99
+ }
100
+ };
101
+ useEffect(function () {
102
+ if (!inputRef.current || typeof value === 'undefined' || value === inputRef.current.textContent) {
103
+ return;
104
+ }
105
+ inputRef.current.textContent = value;
106
+ }, [value, textComponent]);
107
+ return /*#__PURE__*/React.createElement(Root, props, /*#__PURE__*/React.createElement(Component, {
108
+ ref: innerRef,
109
+ className: classes.editableTextBox,
110
+ role: "textbox",
111
+ spellCheck: spellCheck,
112
+ contentEditable: true,
113
+ onPaste: handlePaste,
114
+ onInput: handleChange,
115
+ onBlur: handleBlur,
116
+ onFocus: handleFocus,
117
+ onKeyDown: handleKeyDown,
118
+ "aria-label": placeholder
119
+ }), ((_prevValueRef$current = prevValueRef.current) === null || _prevValueRef$current === void 0 ? void 0 : _prevValueRef$current.length) === 0 && !isEditing && /*#__PURE__*/React.createElement(Component, null, /*#__PURE__*/React.createElement(StyledPlacehpolder, {
120
+ onClick: handleEditClick
121
+ }, placeholder)), /*#__PURE__*/React.createElement(StyledInput, {
122
+ type: "hidden",
123
+ value: prevValueRef.current,
124
+ name: name
125
+ }), /*#__PURE__*/React.createElement(EditButton, {
126
+ onClick: handleEditClick,
127
+ isHidden: isEditing
128
+ }, icon));
129
+ });
130
+ };
131
+ };
132
+ export var editableConfig = function editableConfig(typographyVariants) {
133
+ return {
134
+ name: 'Editable',
135
+ tag: 'span',
136
+ layout: editableRoot(typographyVariants),
137
+ base: base,
138
+ variations: {
139
+ view: {
140
+ css: viewCSS
141
+ },
142
+ size: {
143
+ css: sizeCSS
144
+ }
145
+ },
146
+ defaults: {
147
+ view: 'default',
148
+ size: 'm'
149
+ }
150
+ };
151
+ };
@@ -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);