dash-ui-kit 1.0.94 → 2.1.0-dev

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (201) hide show
  1. package/README.md +52 -0
  2. package/dist/react/components/accordion/index.cjs.js +193 -0
  3. package/dist/react/components/accordion/index.cjs.js.map +1 -0
  4. package/dist/react/components/accordion/index.esm.js +169 -0
  5. package/dist/react/components/accordion/index.esm.js.map +1 -0
  6. package/dist/react/components/avatar/index.cjs.js +39 -0
  7. package/dist/react/components/avatar/index.cjs.js.map +1 -0
  8. package/dist/react/components/avatar/index.esm.js +34 -0
  9. package/dist/react/components/avatar/index.esm.js.map +1 -0
  10. package/dist/react/components/badge/index.cjs.js +97 -0
  11. package/dist/react/components/badge/index.cjs.js.map +1 -0
  12. package/dist/react/components/badge/index.d.ts +10 -1
  13. package/dist/react/components/badge/index.esm.js +92 -0
  14. package/dist/react/components/badge/index.esm.js.map +1 -0
  15. package/dist/react/components/bigNumber/index.cjs.js +100 -0
  16. package/dist/react/components/bigNumber/index.cjs.js.map +1 -0
  17. package/dist/react/components/bigNumber/index.esm.js +95 -0
  18. package/dist/react/components/bigNumber/index.esm.js.map +1 -0
  19. package/dist/react/components/button/index.cjs.js +540 -0
  20. package/dist/react/components/button/index.cjs.js.map +1 -0
  21. package/dist/react/components/button/index.d.ts +7 -1
  22. package/dist/react/components/button/index.esm.js +535 -0
  23. package/dist/react/components/button/index.esm.js.map +1 -0
  24. package/dist/react/components/copyButton/index.cjs.js +95 -0
  25. package/dist/react/components/copyButton/index.cjs.js.map +1 -0
  26. package/dist/react/components/copyButton/index.esm.js +71 -0
  27. package/dist/react/components/copyButton/index.esm.js.map +1 -0
  28. package/dist/react/components/dashLogo/index.cjs.js +74 -0
  29. package/dist/react/components/dashLogo/index.cjs.js.map +1 -0
  30. package/dist/react/components/dashLogo/index.esm.js +69 -0
  31. package/dist/react/components/dashLogo/index.esm.js.map +1 -0
  32. package/dist/react/components/dateBlock/index.cjs.js +120 -0
  33. package/dist/react/components/dateBlock/index.cjs.js.map +1 -0
  34. package/dist/react/components/dateBlock/index.esm.js +115 -0
  35. package/dist/react/components/dateBlock/index.esm.js.map +1 -0
  36. package/dist/react/components/dialog/index.cjs.js +292 -0
  37. package/dist/react/components/dialog/index.cjs.js.map +1 -0
  38. package/dist/react/components/dialog/index.esm.js +270 -0
  39. package/dist/react/components/dialog/index.esm.js.map +1 -0
  40. package/dist/react/components/heading/index.cjs.js +65 -0
  41. package/dist/react/components/heading/index.cjs.js.map +1 -0
  42. package/dist/react/components/heading/index.d.ts +4 -1
  43. package/dist/react/components/heading/index.esm.js +63 -0
  44. package/dist/react/components/heading/index.esm.js.map +1 -0
  45. package/dist/react/components/icons/index.cjs.js +1173 -0
  46. package/dist/react/components/icons/index.cjs.js.map +1 -0
  47. package/dist/react/components/icons/index.d.ts +2 -0
  48. package/dist/react/components/icons/index.esm.js +1128 -0
  49. package/dist/react/components/icons/index.esm.js.map +1 -0
  50. package/dist/react/components/identifier/index.cjs.js +286 -0
  51. package/dist/react/components/identifier/index.cjs.js.map +1 -0
  52. package/dist/react/components/identifier/index.esm.js +282 -0
  53. package/dist/react/components/identifier/index.esm.js.map +1 -0
  54. package/dist/react/components/index.cjs.js +101 -0
  55. package/dist/react/components/index.cjs.js.map +1 -0
  56. package/dist/react/components/index.d.ts +1 -1
  57. package/dist/react/components/index.esm.js +29 -0
  58. package/dist/react/components/index.esm.js.map +1 -0
  59. package/dist/react/components/input/index.cjs.js +242 -0
  60. package/dist/react/components/input/index.cjs.js.map +1 -0
  61. package/dist/react/components/input/index.d.ts +4 -0
  62. package/dist/react/components/input/index.esm.js +237 -0
  63. package/dist/react/components/input/index.esm.js.map +1 -0
  64. package/dist/react/components/list/index.cjs.js +49 -0
  65. package/dist/react/components/list/index.cjs.js.map +1 -0
  66. package/dist/react/components/list/index.esm.js +47 -0
  67. package/dist/react/components/list/index.esm.js.map +1 -0
  68. package/dist/react/components/notActive/index.cjs.js +40 -0
  69. package/dist/react/components/notActive/index.cjs.js.map +1 -0
  70. package/dist/react/components/notActive/index.esm.js +38 -0
  71. package/dist/react/components/notActive/index.esm.js.map +1 -0
  72. package/dist/react/components/overlayMenu/index.cjs.js +469 -0
  73. package/dist/react/components/overlayMenu/index.cjs.js.map +1 -0
  74. package/dist/react/components/overlayMenu/index.d.ts +9 -10
  75. package/dist/react/components/overlayMenu/index.esm.js +464 -0
  76. package/dist/react/components/overlayMenu/index.esm.js.map +1 -0
  77. package/dist/react/components/overlaySelect/index.cjs.js +350 -0
  78. package/dist/react/components/overlaySelect/index.cjs.js.map +1 -0
  79. package/dist/react/components/overlaySelect/index.d.ts +4 -0
  80. package/dist/react/components/overlaySelect/index.esm.js +345 -0
  81. package/dist/react/components/overlaySelect/index.esm.js.map +1 -0
  82. package/dist/react/components/progressStepBar/index.cjs.js +54 -0
  83. package/dist/react/components/progressStepBar/index.cjs.js.map +1 -0
  84. package/dist/react/components/progressStepBar/index.d.ts +5 -2
  85. package/dist/react/components/progressStepBar/index.esm.js +52 -0
  86. package/dist/react/components/progressStepBar/index.esm.js.map +1 -0
  87. package/dist/react/components/select/index.cjs.js +241 -0
  88. package/dist/react/components/select/index.cjs.js.map +1 -0
  89. package/dist/react/components/select/index.d.ts +4 -0
  90. package/dist/react/components/select/index.esm.js +217 -0
  91. package/dist/react/components/select/index.esm.js.map +1 -0
  92. package/dist/react/components/switch/index.cjs.js +184 -0
  93. package/dist/react/components/switch/index.cjs.js.map +1 -0
  94. package/dist/react/components/switch/index.esm.js +179 -0
  95. package/dist/react/components/switch/index.esm.js.map +1 -0
  96. package/dist/react/components/tabs/index.cjs.js +178 -0
  97. package/dist/react/components/tabs/index.cjs.js.map +1 -0
  98. package/dist/react/components/tabs/index.esm.js +154 -0
  99. package/dist/react/components/tabs/index.esm.js.map +1 -0
  100. package/dist/react/components/text/index.cjs.js +126 -0
  101. package/dist/react/components/text/index.cjs.js.map +1 -0
  102. package/dist/react/components/text/index.d.ts +5 -0
  103. package/dist/react/components/text/index.esm.js +121 -0
  104. package/dist/react/components/text/index.esm.js.map +1 -0
  105. package/dist/react/components/textarea/index.cjs.js +260 -0
  106. package/dist/react/components/textarea/index.cjs.js.map +1 -0
  107. package/dist/react/components/textarea/index.d.ts +4 -0
  108. package/dist/react/components/textarea/index.esm.js +255 -0
  109. package/dist/react/components/textarea/index.esm.js.map +1 -0
  110. package/dist/react/components/timeDelta/index.cjs.js +93 -0
  111. package/dist/react/components/timeDelta/index.cjs.js.map +1 -0
  112. package/dist/react/components/timeDelta/index.d.ts +1 -1
  113. package/dist/react/components/timeDelta/index.esm.js +88 -0
  114. package/dist/react/components/timeDelta/index.esm.js.map +1 -0
  115. package/dist/react/components/transactionStatusIcon/index.cjs.js +59 -0
  116. package/dist/react/components/transactionStatusIcon/index.cjs.js.map +1 -0
  117. package/dist/react/components/transactionStatusIcon/index.esm.js +54 -0
  118. package/dist/react/components/transactionStatusIcon/index.esm.js.map +1 -0
  119. package/dist/react/components/valueCard/index.cjs.js +181 -0
  120. package/dist/react/components/valueCard/index.cjs.js.map +1 -0
  121. package/dist/react/components/valueCard/index.d.ts +5 -1
  122. package/dist/react/components/valueCard/index.esm.js +176 -0
  123. package/dist/react/components/valueCard/index.esm.js.map +1 -0
  124. package/dist/react/contexts/ThemeContext.cjs.js +79 -0
  125. package/dist/react/contexts/ThemeContext.cjs.js.map +1 -0
  126. package/dist/react/contexts/ThemeContext.esm.js +76 -0
  127. package/dist/react/contexts/ThemeContext.esm.js.map +1 -0
  128. package/dist/react/contexts/index.cjs.js +11 -0
  129. package/dist/react/contexts/index.cjs.js.map +1 -0
  130. package/dist/react/contexts/index.esm.js +4 -0
  131. package/dist/react/contexts/index.esm.js.map +1 -0
  132. package/dist/react/hooks/index.d.ts +1 -0
  133. package/dist/react/hooks/useColorScheme.cjs.js +25 -0
  134. package/dist/react/hooks/useColorScheme.cjs.js.map +1 -0
  135. package/dist/react/hooks/useColorScheme.d.ts +9 -0
  136. package/dist/react/hooks/useColorScheme.esm.js +23 -0
  137. package/dist/react/hooks/useColorScheme.esm.js.map +1 -0
  138. package/dist/react/hooks/useDebounce.cjs.js +83 -0
  139. package/dist/react/hooks/useDebounce.cjs.js.map +1 -0
  140. package/dist/react/hooks/useDebounce.esm.js +78 -0
  141. package/dist/react/hooks/useDebounce.esm.js.map +1 -0
  142. package/dist/react/index.cjs.js +99 -12833
  143. package/dist/react/index.cjs.js.map +1 -1
  144. package/dist/react/index.d.ts +1 -1
  145. package/dist/react/index.esm.js +27 -12747
  146. package/dist/react/index.esm.js.map +1 -1
  147. package/dist/react/shared/utils/datetime.cjs.js +59 -0
  148. package/dist/react/shared/utils/datetime.cjs.js.map +1 -0
  149. package/dist/react/shared/utils/datetime.esm.js +57 -0
  150. package/dist/react/shared/utils/datetime.esm.js.map +1 -0
  151. package/dist/react/utils/copyToClipboard.cjs.js +31 -0
  152. package/dist/react/utils/copyToClipboard.cjs.js.map +1 -0
  153. package/dist/react/utils/copyToClipboard.esm.js +26 -0
  154. package/dist/react/utils/copyToClipboard.esm.js.map +1 -0
  155. package/dist/react/utils/index.d.ts +1 -1
  156. package/dist/react-native/components/avatar/index.d.ts +26 -0
  157. package/dist/react-native/components/avatar/index.web.d.ts +24 -0
  158. package/dist/react-native/components/badge/index.d.ts +63 -0
  159. package/dist/react-native/components/bigNumber/index.d.ts +26 -0
  160. package/dist/react-native/components/button/index.d.ts +45 -0
  161. package/dist/react-native/components/copyButton/index.d.ts +22 -0
  162. package/dist/react-native/components/copyButton/index.web.d.ts +20 -0
  163. package/dist/react-native/components/dashLogo/index.d.ts +30 -0
  164. package/dist/react-native/components/heading/index.d.ts +25 -0
  165. package/dist/react-native/components/icons/index.d.ts +43 -0
  166. package/dist/react-native/components/identifier/index.d.ts +47 -0
  167. package/dist/react-native/components/index.d.ts +15 -0
  168. package/dist/react-native/components/input/index.d.ts +59 -0
  169. package/dist/react-native/components/notActive/index.d.ts +16 -0
  170. package/dist/react-native/components/tabs/index.d.ts +50 -0
  171. package/dist/react-native/components/text/index.d.ts +28 -0
  172. package/dist/react-native/components/transactionStatusIcon/index.d.ts +24 -0
  173. package/dist/react-native/components/valueCard/index.d.ts +47 -0
  174. package/dist/react-native/hooks/index.d.ts +1 -0
  175. package/dist/react-native/hooks/useDebounce.d.ts +43 -0
  176. package/dist/react-native/index.cjs.js +2882 -0
  177. package/dist/react-native/index.cjs.js.map +1 -0
  178. package/dist/react-native/index.d.ts +4 -0
  179. package/dist/react-native/index.esm.js +2833 -0
  180. package/dist/react-native/index.esm.js.map +1 -0
  181. package/dist/react-native/styles/index.d.ts +11 -0
  182. package/dist/react-native/styles/tokens.d.ts +308 -0
  183. package/dist/react-native/styles/utils.d.ts +65 -0
  184. package/dist/react-native/utils/clipboard.d.ts +27 -0
  185. package/dist/react-native/utils/index.d.ts +3 -0
  186. package/dist/react-native/utils/resolveColorScheme.d.ts +1 -0
  187. package/dist/react-native/utils/tw.d.ts +7 -0
  188. package/dist/shared/constants/colors.d.ts +25 -0
  189. package/dist/shared/constants/index.d.ts +2 -0
  190. package/dist/shared/constants/sizes.d.ts +49 -0
  191. package/dist/shared/index.cjs.js +171 -0
  192. package/dist/shared/index.cjs.js.map +1 -0
  193. package/dist/shared/index.d.ts +3 -0
  194. package/dist/shared/index.esm.js +161 -0
  195. package/dist/shared/index.esm.js.map +1 -0
  196. package/dist/shared/types/common.d.ts +33 -0
  197. package/dist/shared/types/index.d.ts +1 -0
  198. package/dist/shared/utils/index.d.ts +1 -0
  199. package/dist/styles.css +1 -1
  200. package/package.json +50 -8
  201. /package/dist/{react → shared}/utils/datetime.d.ts +0 -0
@@ -0,0 +1,260 @@
1
+ "use client";
2
+
3
+ 'use strict';
4
+
5
+ Object.defineProperty(exports, '__esModule', { value: true });
6
+
7
+ var tslib = require('tslib');
8
+ var jsxRuntime = require('react/jsx-runtime');
9
+ var React = require('react');
10
+ var index = require('../button/index.cjs.js');
11
+ var classVarianceAuthority = require('class-variance-authority');
12
+ var ThemeContext = require('../../contexts/ThemeContext.cjs.js');
13
+ var useColorScheme = require('../../hooks/useColorScheme.cjs.js');
14
+
15
+ const textareaContainer = classVarianceAuthority.cva('relative flex items-baseline transition-all w-full', {
16
+ variants: {
17
+ theme: {
18
+ light: 'bg-white',
19
+ dark: 'bg-gray-800'
20
+ },
21
+ hasValue: {
22
+ true: '',
23
+ false: ''
24
+ },
25
+ colorScheme: {
26
+ default: 'focus-within:ring-blue-500/20',
27
+ brand: 'focus-within:ring-dash-brand/20',
28
+ error: 'focus-within:ring-red-500/20',
29
+ success: 'focus-within:ring-green-500/20'
30
+ },
31
+ size: {
32
+ sm: 'dash-block-sm',
33
+ md: 'dash-block-md',
34
+ xl: 'dash-block-xl'
35
+ },
36
+ variant: {
37
+ outlined: 'outline outline-1 outline-offset-[-1px]'
38
+ },
39
+ isValid: {
40
+ true: '',
41
+ false: '',
42
+ null: ''
43
+ },
44
+ disabled: {
45
+ false: '',
46
+ true: 'opacity-60 cursor-not-allowed'
47
+ }
48
+ },
49
+ compoundVariants: [
50
+ // Outlined variant colors
51
+ {
52
+ variant: 'outlined',
53
+ colorScheme: 'default',
54
+ class: 'outline-[rgba(17,17,17,0.32)] focus-within:outline-[rgba(17,17,17,0.6)]'
55
+ }, {
56
+ variant: 'outlined',
57
+ colorScheme: 'brand',
58
+ class: 'outline-dash-brand/30 focus-within:outline-dash-brand'
59
+ }, {
60
+ variant: 'outlined',
61
+ colorScheme: 'error',
62
+ isValid: false,
63
+ class: 'outline-red-500 focus-within:outline-red-500'
64
+ }, {
65
+ variant: 'outlined',
66
+ colorScheme: 'success',
67
+ isValid: true,
68
+ class: 'outline-green-500 focus-within:outline-green-500'
69
+ },
70
+ // Outlined variant with focus ring
71
+ {
72
+ variant: 'outlined',
73
+ class: 'focus-within:ring-2'
74
+ },
75
+ // Add extra padding for PASTE button when no value
76
+ {
77
+ hasValue: false,
78
+ size: 'sm',
79
+ class: 'pr-[70px]'
80
+ }, {
81
+ hasValue: false,
82
+ size: 'md',
83
+ class: 'pr-[70px]'
84
+ }, {
85
+ hasValue: false,
86
+ size: 'xl',
87
+ class: 'pr-[70px]'
88
+ }],
89
+ defaultVariants: {
90
+ theme: 'light',
91
+ hasValue: false,
92
+ colorScheme: 'default',
93
+ size: 'xl',
94
+ variant: 'outlined',
95
+ isValid: null,
96
+ disabled: false
97
+ }
98
+ });
99
+ const textarea = classVarianceAuthority.cva('w-full bg-transparent outline-none resize-none transition-all text-[0.875rem] leading-[1.0625rem] placeholder:text-opacity-60', {
100
+ variants: {
101
+ theme: {
102
+ light: 'text-[#111111] placeholder:text-[rgba(17,17,17,0.6)]',
103
+ dark: 'text-white placeholder:text-gray-400'
104
+ },
105
+ font: {
106
+ main: 'font-dash-main',
107
+ grotesque: 'font-dash-grotesque'
108
+ },
109
+ weight: {
110
+ light: 'font-light',
111
+ normal: 'font-normal',
112
+ medium: 'font-medium',
113
+ semibold: 'font-semibold',
114
+ bold: 'font-bold'
115
+ },
116
+ size: {
117
+ sm: '',
118
+ md: '',
119
+ xl: ''
120
+ },
121
+ disabled: {
122
+ false: '',
123
+ true: 'cursor-not-allowed'
124
+ }
125
+ },
126
+ defaultVariants: {
127
+ theme: 'light',
128
+ font: 'main',
129
+ weight: 'light',
130
+ size: 'xl',
131
+ disabled: false
132
+ }
133
+ });
134
+ /**
135
+ * A versatile textarea component that adapts to light/dark theme,
136
+ * supports various color schemes, sizes, variants, and states.
137
+ * Includes optional paste functionality and validation.
138
+ *
139
+ * @example
140
+ * <Textarea
141
+ * placeholder='Enter your message'
142
+ * colorScheme='brand'
143
+ * size='xl'
144
+ * font='grotesque'
145
+ * weight='medium'
146
+ * rows={4}
147
+ * showPasteButton={true}
148
+ * />
149
+ */
150
+ const Textarea = _a => {
151
+ var _b, _c, _d;
152
+ var {
153
+ className = '',
154
+ onChange,
155
+ showPasteButton = true,
156
+ validator = null,
157
+ rows = 3,
158
+ size = 'xl',
159
+ variant = 'outlined',
160
+ colorScheme,
161
+ colorSchemeLight,
162
+ colorSchemeDark,
163
+ font = 'main',
164
+ weight = 'light',
165
+ error = false,
166
+ success = false,
167
+ disabled = false
168
+ } = _a,
169
+ props = tslib.__rest(_a, ["className", "onChange", "showPasteButton", "validator", "rows", "size", "variant", "colorScheme", "colorSchemeLight", "colorSchemeDark", "font", "weight", "error", "success", "disabled"]);
170
+ const {
171
+ theme
172
+ } = ThemeContext.useTheme();
173
+ const effectiveColorScheme = (_b = useColorScheme.useColorScheme(colorScheme, colorSchemeLight, colorSchemeDark)) !== null && _b !== void 0 ? _b : 'default';
174
+ const [value, setValue] = React.useState((_d = (_c = props.value) !== null && _c !== void 0 ? _c : props.defaultValue) !== null && _d !== void 0 ? _d : '');
175
+ const [isValid, setIsValid] = React.useState(null);
176
+ const textareaRef = React.useRef(null);
177
+ const handleChange = e => {
178
+ const newValue = e.target.value;
179
+ setValue(newValue);
180
+ if (typeof onChange === 'function') {
181
+ onChange(newValue);
182
+ }
183
+ validateInput(newValue);
184
+ };
185
+ const validateInput = input => {
186
+ if (validator === null) {
187
+ setIsValid(null);
188
+ return;
189
+ }
190
+ if (typeof validator === 'function') {
191
+ setIsValid(validator(input));
192
+ } else {
193
+ setIsValid(Boolean(validator));
194
+ }
195
+ };
196
+ const handlePaste = () => {
197
+ navigator.clipboard.readText().then(text => {
198
+ if (text !== '') {
199
+ setValue(text);
200
+ if (textareaRef.current != null) {
201
+ textareaRef.current.value = text;
202
+ }
203
+ if (onChange != null) {
204
+ onChange(text);
205
+ }
206
+ validateInput(text);
207
+ }
208
+ }).catch(err => {
209
+ console.error('Failed to read clipboard contents: ', err);
210
+ });
211
+ };
212
+ const hasValue = value !== '';
213
+ // Determine color scheme based on state
214
+ let finalColorScheme = effectiveColorScheme;
215
+ let finalIsValid = isValid;
216
+ if (error) {
217
+ finalColorScheme = 'error';
218
+ finalIsValid = false;
219
+ } else if (success) {
220
+ finalColorScheme = 'success';
221
+ finalIsValid = true;
222
+ }
223
+ const containerClasses = textareaContainer({
224
+ theme,
225
+ hasValue,
226
+ colorScheme: finalColorScheme,
227
+ size,
228
+ variant,
229
+ isValid: finalIsValid,
230
+ disabled
231
+ });
232
+ const textareaClasses = textarea({
233
+ theme,
234
+ font,
235
+ weight,
236
+ size,
237
+ disabled
238
+ }) + ' ' + className;
239
+ return jsxRuntime.jsxs("div", {
240
+ className: containerClasses,
241
+ children: [jsxRuntime.jsx("textarea", Object.assign({
242
+ ref: textareaRef,
243
+ value: value,
244
+ onChange: handleChange,
245
+ rows: rows,
246
+ className: textareaClasses,
247
+ disabled: disabled
248
+ }, props)), showPasteButton && !hasValue && !disabled && jsxRuntime.jsx(index.Button, {
249
+ colorScheme: 'brand',
250
+ size: 'sm',
251
+ onClick: handlePaste,
252
+ className: `absolute top-1/2 !-translate-y-1/2 ${size === 'sm' ? 'right-3' : size === 'md' ? 'right-[1.125rem]' : 'right-[1.5625rem]'}`,
253
+ children: "PASTE"
254
+ })]
255
+ });
256
+ };
257
+
258
+ exports.Textarea = Textarea;
259
+ exports.default = Textarea;
260
+ //# sourceMappingURL=index.cjs.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.cjs.js","sources":["../../../../src/react/components/textarea/index.tsx"],"sourcesContent":["import React, { useState, useRef, TextareaHTMLAttributes } from 'react'\nimport { Button } from '../button'\nimport { cva, VariantProps } from 'class-variance-authority'\nimport { useTheme } from '../../contexts/ThemeContext'\nimport { useColorScheme } from '../../hooks/useColorScheme'\n\nconst textareaContainer = cva(\n 'relative flex items-baseline transition-all w-full',\n {\n variants: {\n theme: {\n light: 'bg-white',\n dark: 'bg-gray-800'\n },\n hasValue: {\n true: '',\n false: ''\n },\n colorScheme: {\n default: 'focus-within:ring-blue-500/20',\n brand: 'focus-within:ring-dash-brand/20',\n error: 'focus-within:ring-red-500/20',\n success: 'focus-within:ring-green-500/20'\n },\n size: {\n sm: 'dash-block-sm',\n md: 'dash-block-md',\n xl: 'dash-block-xl'\n },\n variant: {\n outlined: 'outline outline-1 outline-offset-[-1px]'\n },\n isValid: {\n true: '',\n false: '',\n null: ''\n },\n disabled: {\n false: '',\n true: 'opacity-60 cursor-not-allowed'\n }\n },\n compoundVariants: [\n // Outlined variant colors\n {\n variant: 'outlined',\n colorScheme: 'default',\n class: 'outline-[rgba(17,17,17,0.32)] focus-within:outline-[rgba(17,17,17,0.6)]'\n },\n {\n variant: 'outlined',\n colorScheme: 'brand',\n class: 'outline-dash-brand/30 focus-within:outline-dash-brand'\n },\n {\n variant: 'outlined',\n colorScheme: 'error',\n isValid: false,\n class: 'outline-red-500 focus-within:outline-red-500'\n },\n {\n variant: 'outlined',\n colorScheme: 'success',\n isValid: true,\n class: 'outline-green-500 focus-within:outline-green-500'\n },\n // Outlined variant with focus ring\n {\n variant: 'outlined',\n class: 'focus-within:ring-2'\n },\n // Add extra padding for PASTE button when no value\n { hasValue: false, size: 'sm', class: 'pr-[70px]' },\n { hasValue: false, size: 'md', class: 'pr-[70px]' },\n { hasValue: false, size: 'xl', class: 'pr-[70px]' }\n ],\n defaultVariants: {\n theme: 'light',\n hasValue: false,\n colorScheme: 'default',\n size: 'xl',\n variant: 'outlined',\n isValid: null,\n disabled: false\n }\n }\n)\n\nconst textarea = cva(\n 'w-full bg-transparent outline-none resize-none transition-all text-[0.875rem] leading-[1.0625rem] placeholder:text-opacity-60',\n {\n variants: {\n theme: {\n light: 'text-[#111111] placeholder:text-[rgba(17,17,17,0.6)]',\n dark: 'text-white placeholder:text-gray-400'\n },\n font: {\n main: 'font-dash-main',\n grotesque: 'font-dash-grotesque'\n },\n weight: {\n light: 'font-light',\n normal: 'font-normal',\n medium: 'font-medium',\n semibold: 'font-semibold',\n bold: 'font-bold'\n },\n size: {\n sm: '',\n md: '',\n xl: ''\n },\n disabled: {\n false: '',\n true: 'cursor-not-allowed'\n }\n },\n defaultVariants: {\n theme: 'light',\n font: 'main',\n weight: 'light',\n size: 'xl',\n disabled: false\n }\n }\n)\n\ntype TextareaVariants = VariantProps<typeof textareaContainer>\n\nexport interface TextareaProps extends Omit<TextareaHTMLAttributes<HTMLTextAreaElement>, 'onChange' | 'size'>, Omit<TextareaVariants, 'theme' | 'hasValue' | 'isValid' | 'disabled'> {\n className?: string\n onChange?: (value: string) => void\n showPasteButton?: boolean\n validator?: ((value: string) => boolean) | boolean\n rows?: number\n font?: 'main' | 'grotesque'\n weight?: 'light' | 'normal' | 'medium' | 'semibold' | 'bold'\n error?: boolean\n success?: boolean\n /** Color scheme override for light theme */\n colorSchemeLight?: 'default' | 'brand' | 'error' | 'success'\n /** Color scheme override for dark theme */\n colorSchemeDark?: 'default' | 'brand' | 'error' | 'success'\n}\n\n/**\n * A versatile textarea component that adapts to light/dark theme,\n * supports various color schemes, sizes, variants, and states.\n * Includes optional paste functionality and validation.\n *\n * @example\n * <Textarea\n * placeholder='Enter your message'\n * colorScheme='brand'\n * size='xl'\n * font='grotesque'\n * weight='medium'\n * rows={4}\n * showPasteButton={true}\n * />\n */\nexport const Textarea: React.FC<TextareaProps> = ({\n className = '',\n onChange,\n showPasteButton = true,\n validator = null,\n rows = 3,\n size = 'xl',\n variant = 'outlined',\n colorScheme,\n colorSchemeLight,\n colorSchemeDark,\n font = 'main',\n weight = 'light',\n error = false,\n success = false,\n disabled = false,\n ...props\n}) => {\n const { theme } = useTheme()\n const effectiveColorScheme = useColorScheme(colorScheme, colorSchemeLight, colorSchemeDark) ?? 'default'\n const [value, setValue] = useState<string>((props.value as string) ?? (props.defaultValue as string) ?? '')\n const [isValid, setIsValid] = useState<boolean | null>(null)\n const textareaRef = useRef<HTMLTextAreaElement>(null)\n\n const handleChange = (e: React.ChangeEvent<HTMLTextAreaElement>): void => {\n const newValue = e.target.value\n setValue(newValue)\n\n if (typeof onChange === 'function') {\n onChange(newValue)\n }\n\n validateInput(newValue)\n }\n\n const validateInput = (input: string): void => {\n if (validator === null) {\n setIsValid(null)\n return\n }\n\n if (typeof validator === 'function') {\n setIsValid(validator(input))\n } else {\n setIsValid(Boolean(validator))\n }\n }\n\n const handlePaste = (): void => {\n navigator.clipboard.readText()\n .then((text) => {\n if (text !== '') {\n setValue(text)\n if (textareaRef.current != null) {\n textareaRef.current.value = text\n }\n if (onChange != null) {\n onChange(text)\n }\n validateInput(text)\n }\n })\n .catch((err) => {\n console.error('Failed to read clipboard contents: ', err)\n })\n }\n\n const hasValue = value !== ''\n\n // Determine color scheme based on state\n let finalColorScheme = effectiveColorScheme\n let finalIsValid: boolean | null = isValid\n \n if (error) {\n finalColorScheme = 'error'\n finalIsValid = false\n } else if (success) {\n finalColorScheme = 'success'\n finalIsValid = true\n }\n\n const containerClasses = textareaContainer({\n theme,\n hasValue,\n colorScheme: finalColorScheme,\n size,\n variant,\n isValid: finalIsValid,\n disabled\n })\n\n const textareaClasses = textarea({\n theme,\n font,\n weight,\n size,\n disabled\n }) + ' ' + className\n\n return (\n <div className={containerClasses}>\n <textarea\n ref={textareaRef}\n value={value}\n onChange={handleChange}\n rows={rows}\n className={textareaClasses}\n disabled={disabled}\n {...props}\n />\n\n {showPasteButton && !hasValue && !disabled && (\n <Button \n colorScheme='brand' \n size='sm' \n onClick={handlePaste}\n className={`absolute top-1/2 !-translate-y-1/2 ${\n size === 'sm' ? 'right-3' : \n size === 'md' ? 'right-[1.125rem]' : \n 'right-[1.5625rem]'\n }`}\n >\n PASTE\n </Button>\n )}\n </div>\n )\n}\n\nexport default Textarea "],"names":["textareaContainer","cva","variants","theme","light","dark","hasValue","true","false","colorScheme","default","brand","error","success","size","sm","md","xl","variant","outlined","isValid","null","disabled","compoundVariants","class","defaultVariants","textarea","font","main","grotesque","weight","normal","medium","semibold","bold","Textarea","_a","className","onChange","showPasteButton","validator","rows","colorSchemeLight","colorSchemeDark","props","__rest","useTheme","effectiveColorScheme","_b","useColorScheme","value","setValue","useState","_d","_c","defaultValue","setIsValid","textareaRef","useRef","handleChange","e","newValue","target","validateInput","input","Boolean","handlePaste","navigator","clipboard","readText","then","text","current","catch","err","console","finalColorScheme","finalIsValid","containerClasses","textareaClasses","_jsxs","children","_jsx","Object","assign","ref","Button","onClick"],"mappings":"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"}
@@ -20,6 +20,10 @@ export interface TextareaProps extends Omit<TextareaHTMLAttributes<HTMLTextAreaE
20
20
  weight?: 'light' | 'normal' | 'medium' | 'semibold' | 'bold';
21
21
  error?: boolean;
22
22
  success?: boolean;
23
+ /** Color scheme override for light theme */
24
+ colorSchemeLight?: 'default' | 'brand' | 'error' | 'success';
25
+ /** Color scheme override for dark theme */
26
+ colorSchemeDark?: 'default' | 'brand' | 'error' | 'success';
23
27
  }
24
28
  /**
25
29
  * A versatile textarea component that adapts to light/dark theme,
@@ -0,0 +1,255 @@
1
+ "use client";
2
+
3
+ import { __rest } from 'tslib';
4
+ import { jsxs, jsx } from 'react/jsx-runtime';
5
+ import { useState, useRef } from 'react';
6
+ import { Button } from '../button/index.esm.js';
7
+ import { cva } from 'class-variance-authority';
8
+ import { useTheme } from '../../contexts/ThemeContext.esm.js';
9
+ import { useColorScheme } from '../../hooks/useColorScheme.esm.js';
10
+
11
+ const textareaContainer = cva('relative flex items-baseline transition-all w-full', {
12
+ variants: {
13
+ theme: {
14
+ light: 'bg-white',
15
+ dark: 'bg-gray-800'
16
+ },
17
+ hasValue: {
18
+ true: '',
19
+ false: ''
20
+ },
21
+ colorScheme: {
22
+ default: 'focus-within:ring-blue-500/20',
23
+ brand: 'focus-within:ring-dash-brand/20',
24
+ error: 'focus-within:ring-red-500/20',
25
+ success: 'focus-within:ring-green-500/20'
26
+ },
27
+ size: {
28
+ sm: 'dash-block-sm',
29
+ md: 'dash-block-md',
30
+ xl: 'dash-block-xl'
31
+ },
32
+ variant: {
33
+ outlined: 'outline outline-1 outline-offset-[-1px]'
34
+ },
35
+ isValid: {
36
+ true: '',
37
+ false: '',
38
+ null: ''
39
+ },
40
+ disabled: {
41
+ false: '',
42
+ true: 'opacity-60 cursor-not-allowed'
43
+ }
44
+ },
45
+ compoundVariants: [
46
+ // Outlined variant colors
47
+ {
48
+ variant: 'outlined',
49
+ colorScheme: 'default',
50
+ class: 'outline-[rgba(17,17,17,0.32)] focus-within:outline-[rgba(17,17,17,0.6)]'
51
+ }, {
52
+ variant: 'outlined',
53
+ colorScheme: 'brand',
54
+ class: 'outline-dash-brand/30 focus-within:outline-dash-brand'
55
+ }, {
56
+ variant: 'outlined',
57
+ colorScheme: 'error',
58
+ isValid: false,
59
+ class: 'outline-red-500 focus-within:outline-red-500'
60
+ }, {
61
+ variant: 'outlined',
62
+ colorScheme: 'success',
63
+ isValid: true,
64
+ class: 'outline-green-500 focus-within:outline-green-500'
65
+ },
66
+ // Outlined variant with focus ring
67
+ {
68
+ variant: 'outlined',
69
+ class: 'focus-within:ring-2'
70
+ },
71
+ // Add extra padding for PASTE button when no value
72
+ {
73
+ hasValue: false,
74
+ size: 'sm',
75
+ class: 'pr-[70px]'
76
+ }, {
77
+ hasValue: false,
78
+ size: 'md',
79
+ class: 'pr-[70px]'
80
+ }, {
81
+ hasValue: false,
82
+ size: 'xl',
83
+ class: 'pr-[70px]'
84
+ }],
85
+ defaultVariants: {
86
+ theme: 'light',
87
+ hasValue: false,
88
+ colorScheme: 'default',
89
+ size: 'xl',
90
+ variant: 'outlined',
91
+ isValid: null,
92
+ disabled: false
93
+ }
94
+ });
95
+ const textarea = cva('w-full bg-transparent outline-none resize-none transition-all text-[0.875rem] leading-[1.0625rem] placeholder:text-opacity-60', {
96
+ variants: {
97
+ theme: {
98
+ light: 'text-[#111111] placeholder:text-[rgba(17,17,17,0.6)]',
99
+ dark: 'text-white placeholder:text-gray-400'
100
+ },
101
+ font: {
102
+ main: 'font-dash-main',
103
+ grotesque: 'font-dash-grotesque'
104
+ },
105
+ weight: {
106
+ light: 'font-light',
107
+ normal: 'font-normal',
108
+ medium: 'font-medium',
109
+ semibold: 'font-semibold',
110
+ bold: 'font-bold'
111
+ },
112
+ size: {
113
+ sm: '',
114
+ md: '',
115
+ xl: ''
116
+ },
117
+ disabled: {
118
+ false: '',
119
+ true: 'cursor-not-allowed'
120
+ }
121
+ },
122
+ defaultVariants: {
123
+ theme: 'light',
124
+ font: 'main',
125
+ weight: 'light',
126
+ size: 'xl',
127
+ disabled: false
128
+ }
129
+ });
130
+ /**
131
+ * A versatile textarea component that adapts to light/dark theme,
132
+ * supports various color schemes, sizes, variants, and states.
133
+ * Includes optional paste functionality and validation.
134
+ *
135
+ * @example
136
+ * <Textarea
137
+ * placeholder='Enter your message'
138
+ * colorScheme='brand'
139
+ * size='xl'
140
+ * font='grotesque'
141
+ * weight='medium'
142
+ * rows={4}
143
+ * showPasteButton={true}
144
+ * />
145
+ */
146
+ const Textarea = _a => {
147
+ var _b, _c, _d;
148
+ var {
149
+ className = '',
150
+ onChange,
151
+ showPasteButton = true,
152
+ validator = null,
153
+ rows = 3,
154
+ size = 'xl',
155
+ variant = 'outlined',
156
+ colorScheme,
157
+ colorSchemeLight,
158
+ colorSchemeDark,
159
+ font = 'main',
160
+ weight = 'light',
161
+ error = false,
162
+ success = false,
163
+ disabled = false
164
+ } = _a,
165
+ props = __rest(_a, ["className", "onChange", "showPasteButton", "validator", "rows", "size", "variant", "colorScheme", "colorSchemeLight", "colorSchemeDark", "font", "weight", "error", "success", "disabled"]);
166
+ const {
167
+ theme
168
+ } = useTheme();
169
+ const effectiveColorScheme = (_b = useColorScheme(colorScheme, colorSchemeLight, colorSchemeDark)) !== null && _b !== void 0 ? _b : 'default';
170
+ const [value, setValue] = useState((_d = (_c = props.value) !== null && _c !== void 0 ? _c : props.defaultValue) !== null && _d !== void 0 ? _d : '');
171
+ const [isValid, setIsValid] = useState(null);
172
+ const textareaRef = useRef(null);
173
+ const handleChange = e => {
174
+ const newValue = e.target.value;
175
+ setValue(newValue);
176
+ if (typeof onChange === 'function') {
177
+ onChange(newValue);
178
+ }
179
+ validateInput(newValue);
180
+ };
181
+ const validateInput = input => {
182
+ if (validator === null) {
183
+ setIsValid(null);
184
+ return;
185
+ }
186
+ if (typeof validator === 'function') {
187
+ setIsValid(validator(input));
188
+ } else {
189
+ setIsValid(Boolean(validator));
190
+ }
191
+ };
192
+ const handlePaste = () => {
193
+ navigator.clipboard.readText().then(text => {
194
+ if (text !== '') {
195
+ setValue(text);
196
+ if (textareaRef.current != null) {
197
+ textareaRef.current.value = text;
198
+ }
199
+ if (onChange != null) {
200
+ onChange(text);
201
+ }
202
+ validateInput(text);
203
+ }
204
+ }).catch(err => {
205
+ console.error('Failed to read clipboard contents: ', err);
206
+ });
207
+ };
208
+ const hasValue = value !== '';
209
+ // Determine color scheme based on state
210
+ let finalColorScheme = effectiveColorScheme;
211
+ let finalIsValid = isValid;
212
+ if (error) {
213
+ finalColorScheme = 'error';
214
+ finalIsValid = false;
215
+ } else if (success) {
216
+ finalColorScheme = 'success';
217
+ finalIsValid = true;
218
+ }
219
+ const containerClasses = textareaContainer({
220
+ theme,
221
+ hasValue,
222
+ colorScheme: finalColorScheme,
223
+ size,
224
+ variant,
225
+ isValid: finalIsValid,
226
+ disabled
227
+ });
228
+ const textareaClasses = textarea({
229
+ theme,
230
+ font,
231
+ weight,
232
+ size,
233
+ disabled
234
+ }) + ' ' + className;
235
+ return jsxs("div", {
236
+ className: containerClasses,
237
+ children: [jsx("textarea", Object.assign({
238
+ ref: textareaRef,
239
+ value: value,
240
+ onChange: handleChange,
241
+ rows: rows,
242
+ className: textareaClasses,
243
+ disabled: disabled
244
+ }, props)), showPasteButton && !hasValue && !disabled && jsx(Button, {
245
+ colorScheme: 'brand',
246
+ size: 'sm',
247
+ onClick: handlePaste,
248
+ className: `absolute top-1/2 !-translate-y-1/2 ${size === 'sm' ? 'right-3' : size === 'md' ? 'right-[1.125rem]' : 'right-[1.5625rem]'}`,
249
+ children: "PASTE"
250
+ })]
251
+ });
252
+ };
253
+
254
+ export { Textarea, Textarea as default };
255
+ //# sourceMappingURL=index.esm.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.esm.js","sources":["../../../../src/react/components/textarea/index.tsx"],"sourcesContent":["import React, { useState, useRef, TextareaHTMLAttributes } from 'react'\nimport { Button } from '../button'\nimport { cva, VariantProps } from 'class-variance-authority'\nimport { useTheme } from '../../contexts/ThemeContext'\nimport { useColorScheme } from '../../hooks/useColorScheme'\n\nconst textareaContainer = cva(\n 'relative flex items-baseline transition-all w-full',\n {\n variants: {\n theme: {\n light: 'bg-white',\n dark: 'bg-gray-800'\n },\n hasValue: {\n true: '',\n false: ''\n },\n colorScheme: {\n default: 'focus-within:ring-blue-500/20',\n brand: 'focus-within:ring-dash-brand/20',\n error: 'focus-within:ring-red-500/20',\n success: 'focus-within:ring-green-500/20'\n },\n size: {\n sm: 'dash-block-sm',\n md: 'dash-block-md',\n xl: 'dash-block-xl'\n },\n variant: {\n outlined: 'outline outline-1 outline-offset-[-1px]'\n },\n isValid: {\n true: '',\n false: '',\n null: ''\n },\n disabled: {\n false: '',\n true: 'opacity-60 cursor-not-allowed'\n }\n },\n compoundVariants: [\n // Outlined variant colors\n {\n variant: 'outlined',\n colorScheme: 'default',\n class: 'outline-[rgba(17,17,17,0.32)] focus-within:outline-[rgba(17,17,17,0.6)]'\n },\n {\n variant: 'outlined',\n colorScheme: 'brand',\n class: 'outline-dash-brand/30 focus-within:outline-dash-brand'\n },\n {\n variant: 'outlined',\n colorScheme: 'error',\n isValid: false,\n class: 'outline-red-500 focus-within:outline-red-500'\n },\n {\n variant: 'outlined',\n colorScheme: 'success',\n isValid: true,\n class: 'outline-green-500 focus-within:outline-green-500'\n },\n // Outlined variant with focus ring\n {\n variant: 'outlined',\n class: 'focus-within:ring-2'\n },\n // Add extra padding for PASTE button when no value\n { hasValue: false, size: 'sm', class: 'pr-[70px]' },\n { hasValue: false, size: 'md', class: 'pr-[70px]' },\n { hasValue: false, size: 'xl', class: 'pr-[70px]' }\n ],\n defaultVariants: {\n theme: 'light',\n hasValue: false,\n colorScheme: 'default',\n size: 'xl',\n variant: 'outlined',\n isValid: null,\n disabled: false\n }\n }\n)\n\nconst textarea = cva(\n 'w-full bg-transparent outline-none resize-none transition-all text-[0.875rem] leading-[1.0625rem] placeholder:text-opacity-60',\n {\n variants: {\n theme: {\n light: 'text-[#111111] placeholder:text-[rgba(17,17,17,0.6)]',\n dark: 'text-white placeholder:text-gray-400'\n },\n font: {\n main: 'font-dash-main',\n grotesque: 'font-dash-grotesque'\n },\n weight: {\n light: 'font-light',\n normal: 'font-normal',\n medium: 'font-medium',\n semibold: 'font-semibold',\n bold: 'font-bold'\n },\n size: {\n sm: '',\n md: '',\n xl: ''\n },\n disabled: {\n false: '',\n true: 'cursor-not-allowed'\n }\n },\n defaultVariants: {\n theme: 'light',\n font: 'main',\n weight: 'light',\n size: 'xl',\n disabled: false\n }\n }\n)\n\ntype TextareaVariants = VariantProps<typeof textareaContainer>\n\nexport interface TextareaProps extends Omit<TextareaHTMLAttributes<HTMLTextAreaElement>, 'onChange' | 'size'>, Omit<TextareaVariants, 'theme' | 'hasValue' | 'isValid' | 'disabled'> {\n className?: string\n onChange?: (value: string) => void\n showPasteButton?: boolean\n validator?: ((value: string) => boolean) | boolean\n rows?: number\n font?: 'main' | 'grotesque'\n weight?: 'light' | 'normal' | 'medium' | 'semibold' | 'bold'\n error?: boolean\n success?: boolean\n /** Color scheme override for light theme */\n colorSchemeLight?: 'default' | 'brand' | 'error' | 'success'\n /** Color scheme override for dark theme */\n colorSchemeDark?: 'default' | 'brand' | 'error' | 'success'\n}\n\n/**\n * A versatile textarea component that adapts to light/dark theme,\n * supports various color schemes, sizes, variants, and states.\n * Includes optional paste functionality and validation.\n *\n * @example\n * <Textarea\n * placeholder='Enter your message'\n * colorScheme='brand'\n * size='xl'\n * font='grotesque'\n * weight='medium'\n * rows={4}\n * showPasteButton={true}\n * />\n */\nexport const Textarea: React.FC<TextareaProps> = ({\n className = '',\n onChange,\n showPasteButton = true,\n validator = null,\n rows = 3,\n size = 'xl',\n variant = 'outlined',\n colorScheme,\n colorSchemeLight,\n colorSchemeDark,\n font = 'main',\n weight = 'light',\n error = false,\n success = false,\n disabled = false,\n ...props\n}) => {\n const { theme } = useTheme()\n const effectiveColorScheme = useColorScheme(colorScheme, colorSchemeLight, colorSchemeDark) ?? 'default'\n const [value, setValue] = useState<string>((props.value as string) ?? (props.defaultValue as string) ?? '')\n const [isValid, setIsValid] = useState<boolean | null>(null)\n const textareaRef = useRef<HTMLTextAreaElement>(null)\n\n const handleChange = (e: React.ChangeEvent<HTMLTextAreaElement>): void => {\n const newValue = e.target.value\n setValue(newValue)\n\n if (typeof onChange === 'function') {\n onChange(newValue)\n }\n\n validateInput(newValue)\n }\n\n const validateInput = (input: string): void => {\n if (validator === null) {\n setIsValid(null)\n return\n }\n\n if (typeof validator === 'function') {\n setIsValid(validator(input))\n } else {\n setIsValid(Boolean(validator))\n }\n }\n\n const handlePaste = (): void => {\n navigator.clipboard.readText()\n .then((text) => {\n if (text !== '') {\n setValue(text)\n if (textareaRef.current != null) {\n textareaRef.current.value = text\n }\n if (onChange != null) {\n onChange(text)\n }\n validateInput(text)\n }\n })\n .catch((err) => {\n console.error('Failed to read clipboard contents: ', err)\n })\n }\n\n const hasValue = value !== ''\n\n // Determine color scheme based on state\n let finalColorScheme = effectiveColorScheme\n let finalIsValid: boolean | null = isValid\n \n if (error) {\n finalColorScheme = 'error'\n finalIsValid = false\n } else if (success) {\n finalColorScheme = 'success'\n finalIsValid = true\n }\n\n const containerClasses = textareaContainer({\n theme,\n hasValue,\n colorScheme: finalColorScheme,\n size,\n variant,\n isValid: finalIsValid,\n disabled\n })\n\n const textareaClasses = textarea({\n theme,\n font,\n weight,\n size,\n disabled\n }) + ' ' + className\n\n return (\n <div className={containerClasses}>\n <textarea\n ref={textareaRef}\n value={value}\n onChange={handleChange}\n rows={rows}\n className={textareaClasses}\n disabled={disabled}\n {...props}\n />\n\n {showPasteButton && !hasValue && !disabled && (\n <Button \n colorScheme='brand' \n size='sm' \n onClick={handlePaste}\n className={`absolute top-1/2 !-translate-y-1/2 ${\n size === 'sm' ? 'right-3' : \n size === 'md' ? 'right-[1.125rem]' : \n 'right-[1.5625rem]'\n }`}\n >\n PASTE\n </Button>\n )}\n </div>\n )\n}\n\nexport default Textarea "],"names":["textareaContainer","cva","variants","theme","light","dark","hasValue","true","false","colorScheme","default","brand","error","success","size","sm","md","xl","variant","outlined","isValid","null","disabled","compoundVariants","class","defaultVariants","textarea","font","main","grotesque","weight","normal","medium","semibold","bold","Textarea","_a","className","onChange","showPasteButton","validator","rows","colorSchemeLight","colorSchemeDark","props","__rest","useTheme","effectiveColorScheme","_b","useColorScheme","value","setValue","useState","_d","_c","defaultValue","setIsValid","textareaRef","useRef","handleChange","e","newValue","target","validateInput","input","Boolean","handlePaste","navigator","clipboard","readText","then","text","current","catch","err","console","finalColorScheme","finalIsValid","containerClasses","textareaClasses","_jsxs","children","_jsx","Object","assign","ref","Button","onClick"],"mappings":"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"}