@dxc-technology/halstack-react 0.0.0-c9b5c13 → 0.0.0-c9c1158

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 (301) hide show
  1. package/BackgroundColorContext.d.ts +3 -3
  2. package/BackgroundColorContext.js +6 -18
  3. package/HalstackContext.d.ts +1347 -6
  4. package/HalstackContext.js +125 -110
  5. package/README.md +47 -0
  6. package/accordion/Accordion.d.ts +1 -1
  7. package/accordion/Accordion.js +116 -157
  8. package/accordion/Accordion.stories.tsx +102 -126
  9. package/accordion/Accordion.test.js +25 -41
  10. package/accordion/types.d.ts +5 -16
  11. package/accordion-group/AccordionGroup.d.ts +4 -3
  12. package/accordion-group/AccordionGroup.js +31 -98
  13. package/accordion-group/AccordionGroup.stories.tsx +94 -67
  14. package/accordion-group/AccordionGroup.test.js +52 -105
  15. package/accordion-group/AccordionGroupAccordion.d.ts +4 -0
  16. package/accordion-group/AccordionGroupAccordion.js +31 -0
  17. package/accordion-group/types.d.ts +11 -16
  18. package/alert/Alert.js +19 -55
  19. package/alert/Alert.stories.tsx +28 -0
  20. package/alert/Alert.test.js +29 -46
  21. package/alert/types.d.ts +5 -5
  22. package/badge/Badge.js +4 -17
  23. package/badge/types.d.ts +1 -1
  24. package/bleed/Bleed.js +14 -55
  25. package/bleed/Bleed.stories.tsx +95 -95
  26. package/bleed/types.d.ts +2 -2
  27. package/box/Box.d.ts +1 -1
  28. package/box/Box.js +18 -56
  29. package/box/Box.stories.tsx +38 -51
  30. package/box/Box.test.js +2 -7
  31. package/box/types.d.ts +3 -14
  32. package/bulleted-list/BulletedList.d.ts +7 -0
  33. package/bulleted-list/BulletedList.js +99 -0
  34. package/bulleted-list/BulletedList.stories.tsx +116 -0
  35. package/bulleted-list/types.d.ts +38 -0
  36. package/button/Button.d.ts +1 -1
  37. package/button/Button.js +61 -114
  38. package/button/Button.stories.tsx +160 -90
  39. package/button/Button.test.js +18 -17
  40. package/button/types.d.ts +12 -8
  41. package/card/Card.d.ts +1 -1
  42. package/card/Card.js +48 -89
  43. package/card/Card.stories.tsx +12 -42
  44. package/card/Card.test.js +11 -22
  45. package/card/types.d.ts +6 -11
  46. package/checkbox/Checkbox.d.ts +2 -2
  47. package/checkbox/Checkbox.js +141 -178
  48. package/checkbox/Checkbox.stories.tsx +128 -94
  49. package/checkbox/Checkbox.test.js +160 -39
  50. package/checkbox/types.d.ts +11 -3
  51. package/chip/Chip.js +39 -79
  52. package/chip/Chip.stories.tsx +121 -26
  53. package/chip/Chip.test.js +16 -31
  54. package/chip/types.d.ts +4 -4
  55. package/common/OpenSans.css +68 -80
  56. package/common/coreTokens.d.ts +237 -0
  57. package/common/coreTokens.js +184 -0
  58. package/common/utils.d.ts +1 -0
  59. package/common/utils.js +6 -12
  60. package/common/variables.d.ts +1499 -0
  61. package/common/variables.js +1027 -1126
  62. package/container/Container.d.ts +4 -0
  63. package/container/Container.js +198 -0
  64. package/container/Container.stories.tsx +229 -0
  65. package/container/types.d.ts +74 -0
  66. package/date-input/Calendar.d.ts +4 -0
  67. package/date-input/Calendar.js +214 -0
  68. package/date-input/DateInput.js +150 -299
  69. package/date-input/DateInput.stories.tsx +203 -56
  70. package/date-input/DateInput.test.js +700 -371
  71. package/date-input/DatePicker.d.ts +4 -0
  72. package/date-input/DatePicker.js +115 -0
  73. package/date-input/Icons.d.ts +6 -0
  74. package/date-input/Icons.js +58 -0
  75. package/date-input/YearPicker.d.ts +4 -0
  76. package/date-input/YearPicker.js +100 -0
  77. package/date-input/types.d.ts +72 -15
  78. package/dialog/Dialog.d.ts +1 -1
  79. package/dialog/Dialog.js +75 -106
  80. package/dialog/Dialog.stories.tsx +154 -171
  81. package/dialog/Dialog.test.js +287 -20
  82. package/dialog/types.d.ts +18 -25
  83. package/dropdown/Dropdown.d.ts +1 -1
  84. package/dropdown/Dropdown.js +243 -300
  85. package/dropdown/Dropdown.stories.tsx +245 -56
  86. package/dropdown/Dropdown.test.js +575 -165
  87. package/dropdown/DropdownMenu.d.ts +4 -0
  88. package/dropdown/DropdownMenu.js +63 -0
  89. package/dropdown/DropdownMenuItem.d.ts +4 -0
  90. package/dropdown/DropdownMenuItem.js +67 -0
  91. package/dropdown/types.d.ts +32 -14
  92. package/file-input/FileInput.d.ts +2 -2
  93. package/file-input/FileInput.js +241 -355
  94. package/file-input/FileInput.stories.tsx +123 -12
  95. package/file-input/FileInput.test.js +369 -367
  96. package/file-input/FileItem.d.ts +4 -14
  97. package/file-input/FileItem.js +45 -96
  98. package/file-input/types.d.ts +25 -8
  99. package/flex/Flex.d.ts +4 -0
  100. package/flex/Flex.js +57 -0
  101. package/flex/Flex.stories.tsx +112 -0
  102. package/flex/types.d.ts +97 -0
  103. package/footer/Footer.d.ts +1 -1
  104. package/footer/Footer.js +51 -101
  105. package/footer/Footer.stories.tsx +41 -19
  106. package/footer/Footer.test.js +33 -57
  107. package/footer/Icons.d.ts +2 -2
  108. package/footer/Icons.js +3 -8
  109. package/footer/types.d.ts +21 -22
  110. package/grid/Grid.d.ts +7 -0
  111. package/grid/Grid.js +76 -0
  112. package/grid/Grid.stories.tsx +219 -0
  113. package/grid/types.d.ts +115 -0
  114. package/header/Header.d.ts +4 -3
  115. package/header/Header.js +90 -162
  116. package/header/Header.stories.tsx +118 -39
  117. package/header/Header.test.js +13 -26
  118. package/header/Icons.d.ts +2 -2
  119. package/header/Icons.js +4 -9
  120. package/header/types.d.ts +5 -20
  121. package/heading/Heading.js +10 -32
  122. package/heading/Heading.test.js +71 -88
  123. package/heading/types.d.ts +7 -7
  124. package/image/Image.d.ts +4 -0
  125. package/image/Image.js +70 -0
  126. package/image/Image.stories.tsx +127 -0
  127. package/image/types.d.ts +72 -0
  128. package/inset/Inset.js +14 -55
  129. package/inset/Inset.stories.tsx +37 -36
  130. package/inset/types.d.ts +2 -2
  131. package/layout/ApplicationLayout.d.ts +15 -6
  132. package/layout/ApplicationLayout.js +51 -116
  133. package/layout/ApplicationLayout.stories.tsx +81 -45
  134. package/layout/Icons.d.ts +8 -5
  135. package/layout/Icons.js +51 -59
  136. package/layout/SidenavContext.d.ts +1 -1
  137. package/layout/SidenavContext.js +3 -9
  138. package/layout/types.d.ts +21 -32
  139. package/link/Link.js +25 -46
  140. package/link/Link.stories.tsx +73 -6
  141. package/link/Link.test.js +24 -44
  142. package/link/types.d.ts +14 -14
  143. package/main.d.ts +10 -10
  144. package/main.js +45 -95
  145. package/{tabs-nav → nav-tabs}/NavTabs.d.ts +2 -2
  146. package/{tabs-nav → nav-tabs}/NavTabs.js +22 -57
  147. package/{tabs-nav → nav-tabs}/NavTabs.stories.tsx +111 -7
  148. package/{tabs-nav → nav-tabs}/NavTabs.test.js +37 -44
  149. package/nav-tabs/Tab.js +117 -0
  150. package/{tabs-nav → nav-tabs}/types.d.ts +14 -15
  151. package/number-input/NumberInput.d.ts +7 -0
  152. package/number-input/NumberInput.js +26 -35
  153. package/number-input/NumberInput.stories.tsx +42 -26
  154. package/number-input/NumberInput.test.js +701 -377
  155. package/number-input/types.d.ts +11 -5
  156. package/package.json +43 -45
  157. package/paginator/Icons.d.ts +5 -0
  158. package/paginator/Icons.js +21 -47
  159. package/paginator/Paginator.js +22 -55
  160. package/paginator/Paginator.stories.tsx +24 -0
  161. package/paginator/Paginator.test.js +280 -211
  162. package/paginator/types.d.ts +3 -3
  163. package/paragraph/Paragraph.d.ts +5 -0
  164. package/paragraph/Paragraph.js +27 -0
  165. package/paragraph/Paragraph.stories.tsx +27 -0
  166. package/password-input/Icons.d.ts +6 -0
  167. package/password-input/Icons.js +35 -0
  168. package/password-input/PasswordInput.js +57 -126
  169. package/password-input/PasswordInput.stories.tsx +1 -32
  170. package/password-input/PasswordInput.test.js +160 -142
  171. package/password-input/types.d.ts +8 -7
  172. package/progress-bar/ProgressBar.js +67 -87
  173. package/progress-bar/{ProgressBar.stories.jsx → ProgressBar.stories.tsx} +39 -4
  174. package/progress-bar/ProgressBar.test.js +72 -44
  175. package/progress-bar/types.d.ts +3 -3
  176. package/quick-nav/QuickNav.js +29 -47
  177. package/quick-nav/QuickNav.stories.tsx +146 -27
  178. package/quick-nav/types.d.ts +10 -10
  179. package/radio-group/Radio.d.ts +1 -1
  180. package/radio-group/Radio.js +59 -76
  181. package/radio-group/RadioGroup.js +67 -114
  182. package/radio-group/RadioGroup.stories.tsx +132 -18
  183. package/radio-group/RadioGroup.test.js +518 -457
  184. package/radio-group/types.d.ts +10 -10
  185. package/resultset-table/Icons.d.ts +7 -0
  186. package/resultset-table/Icons.js +47 -0
  187. package/resultset-table/ResultsetTable.js +159 -0
  188. package/{resultsetTable → resultset-table}/ResultsetTable.stories.tsx +50 -25
  189. package/{resultsetTable → resultset-table}/ResultsetTable.test.js +117 -118
  190. package/{resultsetTable → resultset-table}/types.d.ts +7 -7
  191. package/resultset-table/types.js +5 -0
  192. package/select/Icons.d.ts +7 -7
  193. package/select/Icons.js +1 -5
  194. package/select/Listbox.d.ts +1 -1
  195. package/select/Listbox.js +42 -51
  196. package/select/Option.js +20 -50
  197. package/select/Select.js +125 -188
  198. package/select/Select.stories.tsx +516 -139
  199. package/select/Select.test.js +1965 -1751
  200. package/select/types.d.ts +16 -20
  201. package/sidenav/Icons.d.ts +7 -0
  202. package/sidenav/Icons.js +47 -0
  203. package/sidenav/Sidenav.d.ts +6 -5
  204. package/sidenav/Sidenav.js +129 -77
  205. package/sidenav/Sidenav.stories.tsx +251 -151
  206. package/sidenav/Sidenav.test.js +26 -45
  207. package/sidenav/types.d.ts +52 -26
  208. package/slider/Slider.d.ts +2 -2
  209. package/slider/Slider.js +144 -168
  210. package/slider/Slider.test.js +185 -81
  211. package/slider/types.d.ts +7 -3
  212. package/spinner/Spinner.js +27 -63
  213. package/spinner/{Spinner.stories.jsx → Spinner.stories.tsx} +53 -27
  214. package/spinner/Spinner.test.js +26 -35
  215. package/spinner/types.d.ts +3 -3
  216. package/switch/Switch.d.ts +2 -2
  217. package/switch/Switch.js +148 -124
  218. package/switch/Switch.stories.tsx +37 -60
  219. package/switch/Switch.test.js +138 -56
  220. package/switch/types.d.ts +7 -3
  221. package/table/Table.js +7 -26
  222. package/table/{Table.stories.jsx → Table.stories.tsx} +80 -1
  223. package/table/Table.test.js +3 -8
  224. package/table/types.d.ts +8 -8
  225. package/tabs/Tab.d.ts +4 -0
  226. package/tabs/Tab.js +113 -0
  227. package/tabs/Tabs.js +315 -141
  228. package/tabs/Tabs.stories.tsx +119 -5
  229. package/tabs/Tabs.test.js +223 -69
  230. package/tabs/types.d.ts +28 -18
  231. package/tag/Tag.js +29 -61
  232. package/tag/Tag.stories.tsx +14 -1
  233. package/tag/Tag.test.js +20 -31
  234. package/tag/types.d.ts +7 -7
  235. package/text-input/Icons.d.ts +8 -0
  236. package/text-input/Icons.js +56 -0
  237. package/text-input/Suggestion.js +40 -28
  238. package/text-input/Suggestions.d.ts +4 -0
  239. package/text-input/Suggestions.js +89 -0
  240. package/text-input/TextInput.js +280 -458
  241. package/text-input/TextInput.stories.tsx +266 -275
  242. package/text-input/TextInput.test.js +1402 -1375
  243. package/text-input/types.d.ts +43 -16
  244. package/textarea/Textarea.js +63 -100
  245. package/textarea/Textarea.stories.tsx +175 -0
  246. package/textarea/Textarea.test.js +152 -183
  247. package/textarea/types.d.ts +9 -5
  248. package/toggle-group/ToggleGroup.d.ts +2 -2
  249. package/toggle-group/ToggleGroup.js +95 -106
  250. package/toggle-group/ToggleGroup.stories.tsx +49 -4
  251. package/toggle-group/ToggleGroup.test.js +69 -88
  252. package/toggle-group/types.d.ts +26 -17
  253. package/typography/Typography.d.ts +4 -0
  254. package/typography/Typography.js +23 -0
  255. package/typography/Typography.stories.tsx +198 -0
  256. package/typography/types.d.ts +18 -0
  257. package/typography/types.js +5 -0
  258. package/useTheme.d.ts +1251 -1
  259. package/useTheme.js +2 -9
  260. package/useTranslatedLabels.d.ts +84 -1
  261. package/useTranslatedLabels.js +1 -7
  262. package/utils/BaseTypography.d.ts +21 -0
  263. package/utils/BaseTypography.js +94 -0
  264. package/utils/FocusLock.d.ts +13 -0
  265. package/utils/FocusLock.js +114 -0
  266. package/wizard/Wizard.js +24 -66
  267. package/wizard/Wizard.stories.tsx +40 -1
  268. package/wizard/Wizard.test.js +54 -81
  269. package/wizard/types.d.ts +7 -7
  270. package/card/ice-cream.jpg +0 -0
  271. package/common/RequiredComponent.js +0 -32
  272. package/list/List.d.ts +0 -4
  273. package/list/List.js +0 -47
  274. package/list/List.stories.tsx +0 -95
  275. package/list/types.d.ts +0 -7
  276. package/number-input/NumberInputContext.d.ts +0 -4
  277. package/number-input/NumberInputContext.js +0 -19
  278. package/number-input/numberInputContextTypes.d.ts +0 -19
  279. package/resultsetTable/ResultsetTable.js +0 -254
  280. package/row/Row.d.ts +0 -3
  281. package/row/Row.js +0 -127
  282. package/row/Row.stories.tsx +0 -237
  283. package/row/types.d.ts +0 -28
  284. package/slider/Slider.stories.tsx +0 -177
  285. package/stack/Stack.d.ts +0 -3
  286. package/stack/Stack.js +0 -97
  287. package/stack/Stack.stories.tsx +0 -164
  288. package/stack/types.d.ts +0 -24
  289. package/tabs-nav/Tab.js +0 -132
  290. package/text/Text.d.ts +0 -7
  291. package/text/Text.js +0 -30
  292. package/text/Text.stories.tsx +0 -19
  293. package/textarea/Textarea.stories.jsx +0 -157
  294. /package/{list → bulleted-list}/types.js +0 -0
  295. /package/{resultsetTable → container}/types.js +0 -0
  296. /package/{row → flex}/types.js +0 -0
  297. /package/{stack → grid}/types.js +0 -0
  298. /package/{tabs-nav → image}/types.js +0 -0
  299. /package/{tabs-nav → nav-tabs}/Tab.d.ts +0 -0
  300. /package/{number-input/numberInputContextTypes.js → nav-tabs/types.js} +0 -0
  301. /package/{resultsetTable → resultset-table}/ResultsetTable.d.ts +0 -0
@@ -1,27 +1,29 @@
1
1
  /// <reference types="react" />
2
- declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
3
- declare type Margin = {
2
+ type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
3
+ type Margin = {
4
4
  top?: Space;
5
5
  bottom?: Space;
6
6
  left?: Space;
7
7
  right?: Space;
8
8
  };
9
- declare type SVG = React.SVGProps<SVGSVGElement>;
10
- declare type Action = {
9
+ type SVG = React.ReactNode & React.SVGProps<SVGSVGElement>;
10
+ type Action = {
11
11
  /**
12
12
  * This function will be called when the user clicks the action.
13
13
  */
14
14
  onClick: () => void;
15
15
  /**
16
- * Icon to be shown in the action.
16
+ * Icon to be placed in the action..
17
17
  */
18
18
  icon: string | SVG;
19
19
  /**
20
- * Title of the action.
20
+ * Text representing advisory information related
21
+ * to the button's action. Under the hood, this prop also serves
22
+ * as an accessible label for the component.
21
23
  */
22
24
  title?: string;
23
25
  };
24
- declare type Props = {
26
+ type Props = {
25
27
  /**
26
28
  * Text to be placed above the input. This label will be used as the aria-label attribute of the list of suggestions.
27
29
  */
@@ -47,8 +49,7 @@ declare type Props = {
47
49
  */
48
50
  placeholder?: string;
49
51
  /**
50
- * Action to be shown in the input. This is an object composed of an onClick function and an icon,
51
- * being the latter either an inline svg or a URL to the image.
52
+ * Action to be shown in the input.
52
53
  */
53
54
  action?: Action;
54
55
  /**
@@ -59,6 +60,12 @@ declare type Props = {
59
60
  * If true, the component will be disabled.
60
61
  */
61
62
  disabled?: boolean;
63
+ /**
64
+ * If true, the component will not be mutable, meaning the user can not edit the control.
65
+ * In addition, the clear action will not be displayed even if the flag is set to true
66
+ * and the custom action will not execute its onClick event.
67
+ */
68
+ readOnly?: boolean;
62
69
  /**
63
70
  * If true, the input will be optional, showing '(Optional)'
64
71
  * next to the label. Otherwise, the field will be considered required and an error will be
@@ -106,8 +113,9 @@ declare type Props = {
106
113
  /**
107
114
  * These are the options to be displayed as suggestions. It can be either an array or a function:
108
115
  * - Array: Array of options that will be filtered by the component.
109
- * - Function: This function will be called when the user changes the value, we will send as a parameter the new value;
110
- * apart from that this function should return one promise on which we should make 'then' to get the suggestions filtered.
116
+ * - Function: This function will be called when the user changes the value.
117
+ * It will receive the new value as a parameter and should return a promise
118
+ * that resolves to an array with the filtered options.
111
119
  */
112
120
  suggestions?: string[] | ((value: string) => Promise<string[]>);
113
121
  /**
@@ -121,7 +129,7 @@ declare type Props = {
121
129
  */
122
130
  pattern?: string;
123
131
  /**
124
- * Specifies the minimun length allowed by the input.
132
+ * Specifies the minimum length allowed by the input.
125
133
  * This will be checked both when the input element loses the
126
134
  * focus and while typing within it. If the string entered does not
127
135
  * comply the minimum length, the onBlur and onChange functions will be called
@@ -159,20 +167,39 @@ declare type Props = {
159
167
  */
160
168
  tabIndex?: number;
161
169
  };
170
+ /**
171
+ * List of suggestions of an Text Input component.
172
+ */
173
+ export type SuggestionsProps = {
174
+ id: string;
175
+ value: string;
176
+ suggestions: string[];
177
+ visualFocusIndex: number;
178
+ highlightedSuggestions: boolean;
179
+ searchHasErrors: boolean;
180
+ isSearching: boolean;
181
+ suggestionOnClick: (suggestion: string) => void;
182
+ styles: React.CSSProperties;
183
+ };
162
184
  /**
163
185
  * Reference to the component.
164
186
  */
165
- export declare type RefType = HTMLDivElement;
187
+ export type RefType = HTMLDivElement;
166
188
  /**
167
- * Single suggestion of the Autosuggest Text Input component.
189
+ * Single suggestion of an Text Input component.
168
190
  */
169
- export declare type SuggestionProps = {
191
+ export type SuggestionProps = {
170
192
  id: string;
171
193
  value: string;
172
- onClick: () => void;
194
+ onClick: (suggestion: string) => void;
173
195
  suggestion: string;
174
196
  isLast: boolean;
175
197
  visuallyFocused: boolean;
176
198
  highlighted: boolean;
177
199
  };
200
+ export type AutosuggestWrapperProps = {
201
+ condition: boolean;
202
+ wrapper: (children: React.ReactNode) => JSX.Element;
203
+ children: React.ReactNode;
204
+ };
178
205
  export default Props;
@@ -1,101 +1,79 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
4
  var _typeof3 = require("@babel/runtime/helpers/typeof");
6
-
7
5
  Object.defineProperty(exports, "__esModule", {
8
6
  value: true
9
7
  });
10
8
  exports["default"] = void 0;
11
-
12
9
  var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
13
-
14
10
  var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
15
-
16
11
  var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
17
-
18
12
  var _react = _interopRequireWildcard(require("react"));
19
-
20
13
  var _styledComponents = _interopRequireWildcard(require("styled-components"));
21
-
22
- var _utils = require("../common/utils.js");
23
-
14
+ var _utils = require("../common/utils");
24
15
  var _useTheme = _interopRequireDefault(require("../useTheme"));
25
-
26
16
  var _useTranslatedLabels = _interopRequireDefault(require("../useTranslatedLabels"));
27
-
28
- var _variables = require("../common/variables.js");
29
-
17
+ var _variables = require("../common/variables");
30
18
  var _uuid = require("uuid");
31
-
32
19
  var _BackgroundColorContext = _interopRequireDefault(require("../BackgroundColorContext"));
33
-
34
20
  var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6;
35
-
36
- function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
37
-
38
- function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof3(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
39
-
21
+ 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); }
22
+ function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof3(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 && Object.prototype.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; }
40
23
  var patternMatch = function patternMatch(pattern, value) {
41
24
  return new RegExp(pattern).test(value);
42
25
  };
43
-
44
26
  var DxcTextarea = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref) {
45
27
  var label = _ref.label,
46
- _ref$name = _ref.name,
47
- name = _ref$name === void 0 ? "" : _ref$name,
48
- _ref$defaultValue = _ref.defaultValue,
49
- defaultValue = _ref$defaultValue === void 0 ? "" : _ref$defaultValue,
50
- value = _ref.value,
51
- helperText = _ref.helperText,
52
- _ref$placeholder = _ref.placeholder,
53
- placeholder = _ref$placeholder === void 0 ? "" : _ref$placeholder,
54
- _ref$disabled = _ref.disabled,
55
- disabled = _ref$disabled === void 0 ? false : _ref$disabled,
56
- _ref$optional = _ref.optional,
57
- optional = _ref$optional === void 0 ? false : _ref$optional,
58
- _ref$verticalGrow = _ref.verticalGrow,
59
- verticalGrow = _ref$verticalGrow === void 0 ? "auto" : _ref$verticalGrow,
60
- _ref$rows = _ref.rows,
61
- rows = _ref$rows === void 0 ? 4 : _ref$rows,
62
- onChange = _ref.onChange,
63
- onBlur = _ref.onBlur,
64
- error = _ref.error,
65
- pattern = _ref.pattern,
66
- minLength = _ref.minLength,
67
- maxLength = _ref.maxLength,
68
- _ref$autocomplete = _ref.autocomplete,
69
- autocomplete = _ref$autocomplete === void 0 ? "off" : _ref$autocomplete,
70
- margin = _ref.margin,
71
- _ref$size = _ref.size,
72
- size = _ref$size === void 0 ? "medium" : _ref$size,
73
- _ref$tabIndex = _ref.tabIndex,
74
- tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
75
-
28
+ _ref$name = _ref.name,
29
+ name = _ref$name === void 0 ? "" : _ref$name,
30
+ _ref$defaultValue = _ref.defaultValue,
31
+ defaultValue = _ref$defaultValue === void 0 ? "" : _ref$defaultValue,
32
+ value = _ref.value,
33
+ helperText = _ref.helperText,
34
+ _ref$placeholder = _ref.placeholder,
35
+ placeholder = _ref$placeholder === void 0 ? "" : _ref$placeholder,
36
+ _ref$disabled = _ref.disabled,
37
+ disabled = _ref$disabled === void 0 ? false : _ref$disabled,
38
+ _ref$readOnly = _ref.readOnly,
39
+ readOnly = _ref$readOnly === void 0 ? false : _ref$readOnly,
40
+ _ref$optional = _ref.optional,
41
+ optional = _ref$optional === void 0 ? false : _ref$optional,
42
+ _ref$verticalGrow = _ref.verticalGrow,
43
+ verticalGrow = _ref$verticalGrow === void 0 ? "auto" : _ref$verticalGrow,
44
+ _ref$rows = _ref.rows,
45
+ rows = _ref$rows === void 0 ? 4 : _ref$rows,
46
+ onChange = _ref.onChange,
47
+ onBlur = _ref.onBlur,
48
+ error = _ref.error,
49
+ pattern = _ref.pattern,
50
+ minLength = _ref.minLength,
51
+ maxLength = _ref.maxLength,
52
+ _ref$autocomplete = _ref.autocomplete,
53
+ autocomplete = _ref$autocomplete === void 0 ? "off" : _ref$autocomplete,
54
+ margin = _ref.margin,
55
+ _ref$size = _ref.size,
56
+ size = _ref$size === void 0 ? "medium" : _ref$size,
57
+ _ref$tabIndex = _ref.tabIndex,
58
+ tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
76
59
  var _useState = (0, _react.useState)(defaultValue),
77
- _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
78
- innerValue = _useState2[0],
79
- setInnerValue = _useState2[1];
80
-
60
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
61
+ innerValue = _useState2[0],
62
+ setInnerValue = _useState2[1];
81
63
  var _useState3 = (0, _react.useState)("textarea-".concat((0, _uuid.v4)())),
82
- _useState4 = (0, _slicedToArray2["default"])(_useState3, 1),
83
- textareaId = _useState4[0];
84
-
64
+ _useState4 = (0, _slicedToArray2["default"])(_useState3, 1),
65
+ textareaId = _useState4[0];
85
66
  var colorsTheme = (0, _useTheme["default"])();
86
67
  var backgroundType = (0, _react.useContext)(_BackgroundColorContext["default"]);
87
68
  var translatedLabels = (0, _useTranslatedLabels["default"])();
88
69
  var textareaRef = (0, _react.useRef)(null);
89
70
  var errorId = "error-".concat(textareaId);
90
-
91
71
  var isNotOptional = function isNotOptional(value) {
92
72
  return value === "" && !optional;
93
73
  };
94
-
95
74
  var isLengthIncorrect = function isLengthIncorrect(value) {
96
75
  return value !== "" && minLength && maxLength && (value.length < minLength || value.length > maxLength);
97
76
  };
98
-
99
77
  var changeValue = function changeValue(newValue) {
100
78
  value !== null && value !== void 0 ? value : setInnerValue(newValue);
101
79
  if (isNotOptional(newValue)) onChange === null || onChange === void 0 ? void 0 : onChange({
@@ -111,8 +89,14 @@ var DxcTextarea = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref)
111
89
  value: newValue
112
90
  });
113
91
  };
114
-
115
- var handleTOnBlur = function handleTOnBlur(event) {
92
+ var autoVerticalGrow = function autoVerticalGrow() {
93
+ var textareaLineHeight = parseInt(window.getComputedStyle(textareaRef.current)["line-height"]);
94
+ var textareaPaddingTopBottom = parseInt(window.getComputedStyle(textareaRef.current)["padding-top"]) * 2;
95
+ textareaRef.current.style.height = "".concat(textareaLineHeight * rows, "px");
96
+ var newHeight = textareaRef.current.scrollHeight - textareaPaddingTopBottom;
97
+ textareaRef.current.style.height = "".concat(newHeight, "px");
98
+ };
99
+ var handleOnBlur = function handleOnBlur(event) {
116
100
  if (isNotOptional(event.target.value)) onBlur === null || onBlur === void 0 ? void 0 : onBlur({
117
101
  value: event.target.value,
118
102
  error: translatedLabels.formFields.requiredValueErrorMessage
@@ -126,20 +110,10 @@ var DxcTextarea = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref)
126
110
  value: event.target.value
127
111
  });
128
112
  };
129
-
130
- var handleTOnChange = function handleTOnChange(event) {
113
+ var handleOnChange = function handleOnChange(event) {
131
114
  changeValue(event.target.value);
115
+ verticalGrow === "auto" && autoVerticalGrow();
132
116
  };
133
-
134
- (0, _react.useLayoutEffect)(function () {
135
- if (verticalGrow === "auto") {
136
- var textareaLineHeight = parseInt(window.getComputedStyle(textareaRef.current)["line-height"]);
137
- var textareaPaddingTopBottom = parseInt(window.getComputedStyle(textareaRef.current)["padding-top"]) * 2;
138
- textareaRef.current.style.height = "".concat(textareaLineHeight * rows, "px");
139
- var newHeight = textareaRef.current.scrollHeight - textareaPaddingTopBottom;
140
- textareaRef.current.style.height = "".concat(newHeight, "px");
141
- }
142
- }, [value, verticalGrow, rows, innerValue]);
143
117
  return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
144
118
  theme: colorsTheme.textarea
145
119
  }, /*#__PURE__*/_react["default"].createElement(TextareaContainer, {
@@ -161,9 +135,10 @@ var DxcTextarea = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref)
161
135
  placeholder: placeholder,
162
136
  verticalGrow: verticalGrow,
163
137
  rows: rows,
164
- onChange: handleTOnChange,
165
- onBlur: handleTOnBlur,
138
+ onChange: handleOnChange,
139
+ onBlur: handleOnBlur,
166
140
  disabled: disabled,
141
+ readOnly: readOnly,
167
142
  error: error,
168
143
  minLength: minLength,
169
144
  maxLength: maxLength,
@@ -171,29 +146,25 @@ var DxcTextarea = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref)
171
146
  backgroundType: backgroundType,
172
147
  ref: textareaRef,
173
148
  tabIndex: tabIndex,
174
- "aria-disabled": disabled,
175
- "aria-invalid": error ? "true" : "false",
149
+ "aria-invalid": error ? true : false,
176
150
  "aria-errormessage": error ? errorId : undefined,
177
- "aria-required": optional ? "false" : "true"
151
+ "aria-required": !disabled && !optional
178
152
  }), !disabled && typeof error === "string" && /*#__PURE__*/_react["default"].createElement(Error, {
179
153
  id: errorId,
180
154
  backgroundType: backgroundType,
181
155
  "aria-live": error ? "assertive" : "off"
182
156
  }, error)));
183
157
  });
184
-
185
158
  var sizes = {
186
159
  small: "240px",
187
160
  medium: "360px",
188
161
  large: "480px",
189
162
  fillParent: "100%"
190
163
  };
191
-
192
164
  var calculateWidth = function calculateWidth(margin, size) {
193
165
  return size === "fillParent" ? "calc(".concat(sizes[size], " - ").concat((0, _utils.getMargin)(margin, "left"), " - ").concat((0, _utils.getMargin)(margin, "right"), ")") : sizes[size];
194
166
  };
195
-
196
- var TextareaContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: column;\n\n width: ", ";\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n"])), function (props) {
167
+ var TextareaContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: column;\n width: ", ";\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n"])), function (props) {
197
168
  return calculateWidth(props.margin, props.size);
198
169
  }, function (props) {
199
170
  return props.margin && (0, _typeof2["default"])(props.margin) !== "object" ? _variables.spaces[props.margin] : "0px";
@@ -206,7 +177,6 @@ var TextareaContainer = _styledComponents["default"].div(_templateObject || (_te
206
177
  }, function (props) {
207
178
  return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.left ? _variables.spaces[props.margin.left] : "";
208
179
  });
209
-
210
180
  var Label = _styledComponents["default"].label(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n line-height: ", ";\n ", "\n"])), function (props) {
211
181
  return props.disabled ? props.backgroundType === "dark" ? props.theme.disabledLabelFontColorOnDark : props.theme.disabledLabelFontColor : props.backgroundType === "dark" ? props.theme.labelFontColorOnDark : props.theme.labelFontColor;
212
182
  }, function (props) {
@@ -222,11 +192,9 @@ var Label = _styledComponents["default"].label(_templateObject2 || (_templateObj
222
192
  }, function (props) {
223
193
  return !props.helperText && "margin-bottom: 0.25rem";
224
194
  });
225
-
226
195
  var OptionalLabel = _styledComponents["default"].span(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n font-weight: ", ";\n"])), function (props) {
227
196
  return props.theme.optionalLabelFontWeight;
228
197
  });
229
-
230
198
  var HelperText = _styledComponents["default"].span(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n line-height: ", ";\n margin-bottom: 0.25rem;\n"])), function (props) {
231
199
  return props.disabled ? props.backgroundType === "dark" ? props.theme.disabledHelperTextFontColorOnDark : props.theme.disabledHelperTextFontColor : props.backgroundType === "dark" ? props.theme.helperTextFontColorOnDark : props.theme.helperTextFontColor;
232
200
  }, function (props) {
@@ -240,19 +208,17 @@ var HelperText = _styledComponents["default"].span(_templateObject4 || (_templat
240
208
  }, function (props) {
241
209
  return props.theme.helperTextLineHeight;
242
210
  });
243
-
244
- var Textarea = _styledComponents["default"].textarea(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n ", ";\n ", "\n\n padding: 0.5rem 1rem;\n box-shadow: 0 0 0 2px transparent;\n border-radius: 0.25rem;\n border: 1px solid\n ", ";\n ", "\n\n ", ";\n ", ";\n\n color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n line-height: 1.5em;\n\n ::placeholder {\n color: ", ";\n }\n"])), function (props) {
245
- if (props.verticalGrow === "none") return "resize: none;";else if (props.verticalGrow === "auto") return "resize: none; overflow: hidden;";else if (props.verticalGrow === "manual") return "resize: vertical;";else return "resize: none;";
211
+ var Textarea = _styledComponents["default"].textarea(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n ", ";\n\n ", "\n\n padding: 0.5rem 1rem;\n box-shadow: 0 0 0 2px transparent;\n border-radius: 0.25rem;\n border: 1px solid\n ", ";\n\n ", "\n\n ", ";\n\n color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n line-height: 1.5em;\n\n ::placeholder {\n color: ", ";\n }\n"])), function (_ref2) {
212
+ var verticalGrow = _ref2.verticalGrow;
213
+ if (verticalGrow === "none") return "resize: none;";else if (verticalGrow === "auto") return "resize: none; overflow: hidden;";else if (verticalGrow === "manual") return "resize: vertical;";else return "resize: none;";
246
214
  }, function (props) {
247
215
  if (props.disabled) return props.backgroundType === "dark" ? "background-color: ".concat(props.theme.disabledContainerFillColorOnDark, ";") : "background-color: ".concat(props.theme.disabledContainerFillColor, ";");else return "background-color: transparent;";
248
216
  }, function (props) {
249
- if (props.disabled) return props.backgroundType === "dark" ? props.theme.disabledBorderColorOnDark : props.theme.disabledBorderColor;else return props.backgroundType === "dark" ? props.theme.enabledBorderColorOnDark : props.theme.enabledBorderColor;
250
- }, function (props) {
251
- return props.error && !props.disabled && "border-color: transparent;\n box-shadow: 0 0 0 2px ".concat(props.backgroundType === "dark" ? props.theme.errorBorderColorOnDark : props.theme.errorBorderColor, ";\n ");
217
+ if (props.disabled) return props.backgroundType === "dark" ? props.theme.disabledBorderColorOnDark : props.theme.disabledBorderColor;else if (props.error) return "transparent";else if (props.readOnly) return props.theme.readOnlyBorderColor;else return props.backgroundType === "dark" ? props.theme.enabledBorderColorOnDark : props.theme.enabledBorderColor;
252
218
  }, function (props) {
253
- return props.disabled && "cursor: not-allowed;";
219
+ return props.error && !props.disabled && "box-shadow: 0 0 0 2px ".concat(props.backgroundType === "dark" ? props.theme.errorBorderColorOnDark : props.theme.errorBorderColor, ";\n ");
254
220
  }, function (props) {
255
- return !props.disabled && "\n &:hover {\n border-color: ".concat(props.error ? "transparent" : props.backgroundType === "dark" ? props.theme.hoverBorderColorOnDark : props.theme.hoverBorderColor, ";\n ").concat(props.error && "box-shadow: 0 0 0 2px ".concat(props.backgroundType === "dark" ? props.theme.hoverErrorBorderColorOnDark : props.theme.hoverErrorBorderColor, ";"), "\n }\n &:focus {\n outline: none;\n border-color: transparent;\n box-shadow: 0 0 0 2px ").concat(props.backgroundType === "dark" ? props.theme.focusBorderColorOnDark : props.theme.focusBorderColor, ";\n }\n &:focus-within {\n outline: none;\n border-color: transparent;\n box-shadow: 0 0 0 2px ").concat(props.backgroundType === "dark" ? props.theme.focusBorderColorOnDark : props.theme.focusBorderColor, ";\n }\n ");
221
+ return !props.disabled ? "&:hover {\n border-color: ".concat(props.error ? "transparent" : props.readOnly ? props.theme.hoverReadOnlyBorderColor : props.backgroundType === "dark" ? props.theme.hoverBorderColorOnDark : props.theme.hoverBorderColor, ";\n ").concat(props.error && "box-shadow: 0 0 0 2px ".concat(props.backgroundType === "dark" ? props.theme.hoverErrorBorderColorOnDark : props.theme.hoverErrorBorderColor, ";"), "\n }\n &:focus, &:focus-within {\n outline: none;\n border-color: transparent;\n box-shadow: 0 0 0 2px ").concat(props.backgroundType === "dark" ? props.theme.focusBorderColorOnDark : props.theme.focusBorderColor, ";\n }") : "cursor: not-allowed;";
256
222
  }, function (props) {
257
223
  return props.disabled ? props.backgroundType === "dark" ? props.theme.disabledValueFontColorOnDark : props.theme.disabledValueFontColor : props.backgroundType === "dark" ? props.theme.valueFontColorOnDark : props.theme.valueFontColor;
258
224
  }, function (props) {
@@ -266,12 +232,9 @@ var Textarea = _styledComponents["default"].textarea(_templateObject5 || (_templ
266
232
  }, function (props) {
267
233
  return props.disabled ? props.backgroundType === "dark" ? props.theme.disabledPlaceholderFontColorOnDark : props.theme.disabledPlaceholderFontColor : props.backgroundType === "dark" ? props.theme.placeholderFontColorOnDark : props.theme.placeholderFontColor;
268
234
  });
269
-
270
235
  var Error = _styledComponents["default"].span(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n font-family: ", ";\n font-size: 0.75rem;\n font-weight: 400;\n min-height: 1.5em;\n line-height: 1.5em;\n margin-top: 0.25rem;\n"])), function (props) {
271
236
  return props.backgroundType === "dark" ? props.theme.errorMessageColorOnDark : props.theme.errorMessageColor;
272
237
  }, function (props) {
273
238
  return props.theme.fontFamily;
274
239
  });
275
-
276
- var _default = DxcTextarea;
277
- exports["default"] = _default;
240
+ var _default = exports["default"] = DxcTextarea;
@@ -0,0 +1,175 @@
1
+ import React from "react";
2
+ import DxcTextarea from "./Textarea";
3
+ import Title from "../../.storybook/components/Title";
4
+ import ExampleContainer from "../../.storybook/components/ExampleContainer";
5
+ import { BackgroundColorProvider } from "../BackgroundColorContext";
6
+ import { HalstackProvider } from "../HalstackContext";
7
+
8
+ export default {
9
+ title: "Textarea",
10
+ component: DxcTextarea,
11
+ };
12
+
13
+ const opinionatedTheme = {
14
+ textarea: {
15
+ fontColor: "#000000",
16
+ hoverBorderColor: "#a46ede",
17
+ },
18
+ };
19
+
20
+ export const Chromatic = () => (
21
+ <>
22
+ <ExampleContainer pseudoState="pseudo-hover">
23
+ <Title title="Hovered" theme="light" level={4} />
24
+ <DxcTextarea label="Hovered" />
25
+ </ExampleContainer>
26
+ <ExampleContainer pseudoState="pseudo-focus">
27
+ <Title title="Focused" theme="light" level={4} />
28
+ <DxcTextarea label="Focused" />
29
+ </ExampleContainer>
30
+ <ExampleContainer>
31
+ <Title title="Disabled" theme="light" level={4} />
32
+ <DxcTextarea label="Disabled" optional helperText="Sample text" placeholder="Enter your text here..." disabled />
33
+ </ExampleContainer>
34
+ <ExampleContainer>
35
+ <Title title="Disabled with value" theme="light" level={4} />
36
+ <DxcTextarea label="Disabled" defaultValue="Example text" disabled />
37
+ </ExampleContainer>
38
+ <ExampleContainer>
39
+ <Title title="Read only" theme="light" level={4} />
40
+ <DxcTextarea label="Label" readOnly defaultValue="Example text" verticalGrow="manual" />
41
+ </ExampleContainer>
42
+ <ExampleContainer pseudoState="pseudo-hover">
43
+ <Title title="Hovered read only" theme="light" level={4} />
44
+ <DxcTextarea label="Label" readOnly defaultValue="Example text" verticalGrow="manual" />
45
+ </ExampleContainer>
46
+ <ExampleContainer>
47
+ <Title title="With error" theme="light" level={4} />
48
+ <DxcTextarea
49
+ label="Textarea with error"
50
+ helperText="Helper text"
51
+ placeholder="Enter your text here..."
52
+ error="Error message."
53
+ />
54
+ </ExampleContainer>
55
+ <ExampleContainer pseudoState="pseudo-hover">
56
+ <Title title="Hovered with error" theme="light" level={4} />
57
+ <DxcTextarea
58
+ label="Hovered textarea with error"
59
+ helperText="Helper text"
60
+ placeholder="Enter your text here..."
61
+ error="Error message."
62
+ />
63
+ </ExampleContainer>
64
+ <ExampleContainer>
65
+ <Title title="Helper text and optional with value" theme="light" level={4} />
66
+ <DxcTextarea label="Helper & optional" defaultValue="Some text" helperText="Sample text" optional />
67
+ </ExampleContainer>
68
+ <ExampleContainer>
69
+ <Title title="Resizable" theme="light" level={4} />
70
+ <DxcTextarea label="With resizer" helperText="Helper text" verticalGrow="manual" />
71
+ </ExampleContainer>
72
+ <ExampleContainer>
73
+ <Title title="Grow manual" theme="light" level={4} />
74
+ <DxcTextarea
75
+ label="Manual vertical grow"
76
+ verticalGrow="manual"
77
+ defaultValue="Long textttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttt"
78
+ />
79
+ </ExampleContainer>
80
+ <Title title="Sizes" theme="light" level={2} />
81
+ <ExampleContainer>
82
+ <DxcTextarea label="Small" size="small" />
83
+ </ExampleContainer>
84
+ <ExampleContainer>
85
+ <DxcTextarea label="Medium" size="medium" />
86
+ </ExampleContainer>
87
+ <ExampleContainer>
88
+ <DxcTextarea label="Large" size="large" />
89
+ </ExampleContainer>
90
+ <ExampleContainer>
91
+ <DxcTextarea label="Fill parent" size="fillParent" />
92
+ </ExampleContainer>
93
+ <Title title="Margins" theme="light" level={2} />
94
+ <ExampleContainer>
95
+ <Title title="Xxsmall margin" theme="light" level={4} />
96
+ <DxcTextarea label="Xxsmall" margin="xxsmall" />
97
+ </ExampleContainer>
98
+ <ExampleContainer>
99
+ <Title title="Xsmall margin" theme="light" level={4} />
100
+ <DxcTextarea label="xsmall" margin="xsmall" />
101
+ </ExampleContainer>
102
+ <ExampleContainer>
103
+ <Title title="Small margin" theme="light" level={4} />
104
+ <DxcTextarea label="small" margin="small" />
105
+ </ExampleContainer>
106
+ <ExampleContainer>
107
+ <Title title="Medium margin" theme="light" level={4} />
108
+ <DxcTextarea label="medium" margin="medium" />
109
+ </ExampleContainer>
110
+ <ExampleContainer>
111
+ <Title title="Large margin" theme="light" level={4} />
112
+ <DxcTextarea label="Large" margin="large" />
113
+ </ExampleContainer>
114
+ <ExampleContainer>
115
+ <Title title="Xlarge margin" theme="light" level={4} />
116
+ <DxcTextarea label="Xlarge" margin="xlarge" />
117
+ </ExampleContainer>
118
+ <ExampleContainer>
119
+ <Title title="Xxlarge margin" theme="light" level={4} />
120
+ <DxcTextarea label="Xxlarge" margin="xxlarge" />
121
+ </ExampleContainer>
122
+ <Title title="Opinionated theme" theme="light" level={2} />
123
+ <ExampleContainer pseudoState="pseudo-hover">
124
+ <Title title="Hovered" theme="light" level={4} />
125
+ <HalstackProvider theme={opinionatedTheme}>
126
+ <DxcTextarea label="Hovered" helperText="Sample text" placeholder="Placeholder" />
127
+ </HalstackProvider>
128
+ </ExampleContainer>
129
+ <ExampleContainer pseudoState="pseudo-focus">
130
+ <Title title="Focused" theme="light" level={4} />
131
+ <HalstackProvider theme={opinionatedTheme}>
132
+ <DxcTextarea label="Focused" helperText="Sample text" />
133
+ </HalstackProvider>
134
+ </ExampleContainer>
135
+ <ExampleContainer>
136
+ <Title title="Disabled" theme="light" level={4} />
137
+ <HalstackProvider theme={opinionatedTheme}>
138
+ <DxcTextarea
139
+ label="Disabled"
140
+ optional
141
+ helperText="Sample text"
142
+ placeholder="Enter your text here..."
143
+ disabled
144
+ />
145
+ </HalstackProvider>
146
+ </ExampleContainer>
147
+ <ExampleContainer>
148
+ <Title title="Disabled with value" theme="light" level={4} />
149
+ <HalstackProvider theme={opinionatedTheme}>
150
+ <DxcTextarea label="Disabled" helperText="Sample text" defaultValue="Example text" disabled />
151
+ </HalstackProvider>
152
+ </ExampleContainer>
153
+ <ExampleContainer>
154
+ <Title title="With error" theme="light" level={4} />
155
+ <HalstackProvider theme={opinionatedTheme}>
156
+ <DxcTextarea
157
+ label="Textarea with error"
158
+ helperText="Helper text"
159
+ placeholder="Enter your text here..."
160
+ error="Error message."
161
+ />
162
+ </HalstackProvider>
163
+ </ExampleContainer>
164
+ <ExampleContainer>
165
+ <Title title="Grow manual" theme="light" level={4} />{" "}
166
+ <HalstackProvider theme={opinionatedTheme}>
167
+ <DxcTextarea
168
+ label="Manual vertical grow"
169
+ verticalGrow="manual"
170
+ defaultValue="Long textttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttt"
171
+ />
172
+ </HalstackProvider>
173
+ </ExampleContainer>
174
+ </>
175
+ );