@dxc-technology/halstack-react 0.0.0-8d998c7 → 0.0.0-8ded8ca

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 (382) hide show
  1. package/BackgroundColorContext.d.ts +1 -0
  2. package/BackgroundColorContext.js +6 -26
  3. package/HalstackContext.d.ts +1235 -0
  4. package/HalstackContext.js +310 -0
  5. package/README.md +47 -0
  6. package/accordion/Accordion.d.ts +1 -1
  7. package/accordion/Accordion.js +118 -194
  8. package/accordion/Accordion.stories.tsx +283 -0
  9. package/accordion/Accordion.test.js +56 -0
  10. package/accordion/types.d.ts +12 -23
  11. package/accordion-group/AccordionGroup.d.ts +5 -4
  12. package/accordion-group/AccordionGroup.js +39 -108
  13. package/accordion-group/AccordionGroup.stories.tsx +252 -0
  14. package/accordion-group/AccordionGroup.test.js +98 -0
  15. package/accordion-group/AccordionGroupAccordion.d.ts +4 -0
  16. package/accordion-group/AccordionGroupAccordion.js +31 -0
  17. package/accordion-group/types.d.ts +18 -23
  18. package/action-icon/ActionIcon.d.ts +4 -0
  19. package/action-icon/ActionIcon.js +43 -0
  20. package/action-icon/types.d.ts +26 -0
  21. package/alert/Alert.js +24 -60
  22. package/alert/Alert.stories.tsx +198 -0
  23. package/alert/Alert.test.js +75 -0
  24. package/alert/types.d.ts +6 -6
  25. package/badge/Badge.d.ts +4 -0
  26. package/badge/Badge.js +9 -20
  27. package/badge/types.d.ts +5 -0
  28. package/badge/types.js +5 -0
  29. package/bleed/Bleed.d.ts +3 -0
  30. package/bleed/Bleed.js +43 -0
  31. package/bleed/Bleed.stories.tsx +342 -0
  32. package/bleed/types.d.ts +37 -0
  33. package/bleed/types.js +5 -0
  34. package/box/Box.d.ts +4 -0
  35. package/box/Box.js +32 -109
  36. package/box/{Box.stories.jsx → Box.stories.tsx} +38 -51
  37. package/box/Box.test.js +13 -0
  38. package/box/types.d.ts +32 -0
  39. package/box/types.js +5 -0
  40. package/bulleted-list/BulletedList.d.ts +7 -0
  41. package/bulleted-list/BulletedList.js +89 -0
  42. package/bulleted-list/BulletedList.stories.tsx +115 -0
  43. package/bulleted-list/types.d.ts +38 -0
  44. package/bulleted-list/types.js +5 -0
  45. package/button/Button.d.ts +1 -1
  46. package/button/Button.js +65 -127
  47. package/button/Button.stories.tsx +329 -278
  48. package/button/Button.test.js +36 -0
  49. package/button/types.d.ts +18 -18
  50. package/card/Card.d.ts +1 -1
  51. package/card/Card.js +59 -104
  52. package/card/Card.stories.tsx +171 -0
  53. package/card/Card.test.js +39 -0
  54. package/card/types.d.ts +8 -15
  55. package/checkbox/Checkbox.d.ts +2 -2
  56. package/checkbox/Checkbox.js +145 -183
  57. package/checkbox/Checkbox.stories.tsx +222 -0
  58. package/checkbox/Checkbox.test.js +199 -0
  59. package/checkbox/types.d.ts +20 -8
  60. package/chip/Chip.d.ts +4 -0
  61. package/chip/Chip.js +48 -148
  62. package/chip/Chip.stories.tsx +214 -0
  63. package/chip/Chip.test.js +41 -0
  64. package/chip/types.d.ts +45 -0
  65. package/chip/types.js +5 -0
  66. package/common/OpenSans.css +68 -80
  67. package/common/coreTokens.d.ts +237 -0
  68. package/common/coreTokens.js +184 -0
  69. package/common/utils.d.ts +1 -0
  70. package/common/utils.js +6 -12
  71. package/common/variables.d.ts +1381 -0
  72. package/common/variables.js +1006 -1322
  73. package/container/Container.d.ts +4 -0
  74. package/container/Container.js +194 -0
  75. package/container/Container.stories.tsx +214 -0
  76. package/container/types.d.ts +74 -0
  77. package/container/types.js +5 -0
  78. package/date-input/Calendar.d.ts +4 -0
  79. package/date-input/Calendar.js +214 -0
  80. package/date-input/DateInput.js +175 -313
  81. package/date-input/DateInput.stories.tsx +285 -0
  82. package/date-input/DateInput.test.js +808 -0
  83. package/date-input/DatePicker.d.ts +4 -0
  84. package/date-input/DatePicker.js +115 -0
  85. package/date-input/Icons.d.ts +6 -0
  86. package/date-input/Icons.js +58 -0
  87. package/date-input/YearPicker.d.ts +4 -0
  88. package/date-input/YearPicker.js +100 -0
  89. package/date-input/types.d.ts +86 -22
  90. package/dialog/Dialog.d.ts +4 -0
  91. package/dialog/Dialog.js +69 -149
  92. package/dialog/Dialog.stories.tsx +365 -0
  93. package/dialog/Dialog.test.js +307 -0
  94. package/dialog/types.d.ts +36 -0
  95. package/dialog/types.js +5 -0
  96. package/dropdown/Dropdown.d.ts +1 -1
  97. package/dropdown/Dropdown.js +245 -328
  98. package/dropdown/Dropdown.stories.tsx +438 -0
  99. package/dropdown/Dropdown.test.js +599 -0
  100. package/dropdown/DropdownMenu.d.ts +4 -0
  101. package/dropdown/DropdownMenu.js +63 -0
  102. package/dropdown/DropdownMenuItem.d.ts +4 -0
  103. package/dropdown/DropdownMenuItem.js +67 -0
  104. package/dropdown/types.d.ts +37 -28
  105. package/file-input/FileInput.d.ts +4 -0
  106. package/file-input/FileInput.js +274 -327
  107. package/file-input/FileInput.stories.tsx +618 -0
  108. package/file-input/FileInput.test.js +459 -0
  109. package/file-input/FileItem.d.ts +4 -0
  110. package/file-input/FileItem.js +54 -112
  111. package/file-input/types.d.ts +129 -0
  112. package/file-input/types.js +5 -0
  113. package/flex/Flex.d.ts +4 -0
  114. package/flex/Flex.js +57 -0
  115. package/flex/Flex.stories.tsx +112 -0
  116. package/flex/types.d.ts +97 -0
  117. package/flex/types.js +5 -0
  118. package/footer/Footer.d.ts +1 -1
  119. package/footer/Footer.js +73 -201
  120. package/footer/Footer.stories.tsx +171 -0
  121. package/footer/Footer.test.js +85 -0
  122. package/footer/Icons.d.ts +3 -0
  123. package/footer/Icons.js +67 -8
  124. package/footer/types.d.ts +41 -38
  125. package/grid/Grid.d.ts +7 -0
  126. package/grid/Grid.js +76 -0
  127. package/grid/Grid.stories.tsx +219 -0
  128. package/grid/types.d.ts +115 -0
  129. package/grid/types.js +5 -0
  130. package/header/Header.d.ts +8 -0
  131. package/header/Header.js +115 -221
  132. package/header/Header.stories.tsx +251 -0
  133. package/header/Header.test.js +66 -0
  134. package/header/Icons.d.ts +2 -0
  135. package/header/Icons.js +5 -35
  136. package/header/types.d.ts +33 -0
  137. package/header/types.js +5 -0
  138. package/heading/Heading.d.ts +4 -0
  139. package/heading/Heading.js +16 -55
  140. package/heading/Heading.stories.tsx +54 -0
  141. package/heading/Heading.test.js +169 -0
  142. package/heading/types.d.ts +33 -0
  143. package/heading/types.js +5 -0
  144. package/image/Image.d.ts +4 -0
  145. package/image/Image.js +70 -0
  146. package/image/Image.stories.tsx +127 -0
  147. package/image/types.d.ts +72 -0
  148. package/image/types.js +5 -0
  149. package/inset/Inset.d.ts +3 -0
  150. package/inset/Inset.js +43 -0
  151. package/inset/Inset.stories.tsx +230 -0
  152. package/inset/types.d.ts +37 -0
  153. package/inset/types.js +5 -0
  154. package/layout/ApplicationLayout.d.ts +20 -0
  155. package/layout/ApplicationLayout.js +83 -184
  156. package/layout/ApplicationLayout.stories.tsx +162 -0
  157. package/layout/Icons.d.ts +8 -0
  158. package/layout/Icons.js +51 -48
  159. package/layout/SidenavContext.d.ts +5 -0
  160. package/layout/SidenavContext.js +13 -0
  161. package/layout/types.d.ts +41 -0
  162. package/layout/types.js +5 -0
  163. package/link/Link.d.ts +4 -0
  164. package/link/Link.js +65 -133
  165. package/link/Link.stories.tsx +253 -0
  166. package/link/Link.test.js +63 -0
  167. package/link/types.d.ts +54 -0
  168. package/link/types.js +5 -0
  169. package/main.d.ts +16 -13
  170. package/main.js +77 -97
  171. package/nav-tabs/NavTabs.d.ts +8 -0
  172. package/nav-tabs/NavTabs.js +93 -0
  173. package/nav-tabs/NavTabs.stories.tsx +274 -0
  174. package/nav-tabs/NavTabs.test.js +75 -0
  175. package/nav-tabs/Tab.d.ts +4 -0
  176. package/nav-tabs/Tab.js +117 -0
  177. package/nav-tabs/types.d.ts +52 -0
  178. package/nav-tabs/types.js +5 -0
  179. package/number-input/NumberInput.d.ts +11 -0
  180. package/number-input/NumberInput.js +28 -89
  181. package/number-input/NumberInput.stories.tsx +131 -0
  182. package/number-input/NumberInput.test.js +830 -0
  183. package/number-input/types.d.ts +130 -0
  184. package/number-input/types.js +5 -0
  185. package/package.json +46 -45
  186. package/paginator/Icons.d.ts +5 -0
  187. package/paginator/Icons.js +21 -47
  188. package/paginator/Paginator.js +35 -98
  189. package/paginator/Paginator.stories.tsx +87 -0
  190. package/paginator/Paginator.test.js +335 -0
  191. package/paginator/types.d.ts +3 -3
  192. package/paragraph/Paragraph.d.ts +5 -0
  193. package/paragraph/Paragraph.js +22 -0
  194. package/paragraph/Paragraph.stories.tsx +27 -0
  195. package/password-input/Icons.d.ts +6 -0
  196. package/password-input/Icons.js +35 -0
  197. package/password-input/PasswordInput.d.ts +4 -0
  198. package/password-input/PasswordInput.js +60 -162
  199. package/password-input/{PasswordInput.stories.jsx → PasswordInput.stories.tsx} +3 -35
  200. package/password-input/PasswordInput.test.js +198 -0
  201. package/password-input/types.d.ts +111 -0
  202. package/password-input/types.js +5 -0
  203. package/progress-bar/ProgressBar.js +67 -93
  204. package/progress-bar/ProgressBar.stories.tsx +93 -0
  205. package/progress-bar/ProgressBar.test.js +93 -0
  206. package/progress-bar/types.d.ts +3 -3
  207. package/quick-nav/QuickNav.d.ts +4 -0
  208. package/quick-nav/QuickNav.js +94 -0
  209. package/quick-nav/QuickNav.stories.tsx +356 -0
  210. package/quick-nav/types.d.ts +21 -0
  211. package/quick-nav/types.js +5 -0
  212. package/radio-group/Radio.d.ts +4 -0
  213. package/radio-group/Radio.js +124 -0
  214. package/radio-group/RadioGroup.d.ts +4 -0
  215. package/radio-group/RadioGroup.js +235 -0
  216. package/radio-group/RadioGroup.stories.tsx +214 -0
  217. package/radio-group/RadioGroup.test.js +756 -0
  218. package/radio-group/types.d.ts +114 -0
  219. package/radio-group/types.js +5 -0
  220. package/resultset-table/Icons.d.ts +7 -0
  221. package/resultset-table/Icons.js +47 -0
  222. package/resultset-table/ResultsetTable.d.ts +4 -0
  223. package/resultset-table/ResultsetTable.js +159 -0
  224. package/resultset-table/ResultsetTable.stories.tsx +300 -0
  225. package/resultset-table/ResultsetTable.test.js +305 -0
  226. package/resultset-table/types.d.ts +67 -0
  227. package/resultset-table/types.js +5 -0
  228. package/select/Icons.d.ts +10 -0
  229. package/select/Icons.js +89 -0
  230. package/select/Listbox.d.ts +4 -0
  231. package/select/Listbox.js +143 -0
  232. package/select/Option.d.ts +4 -0
  233. package/select/Option.js +87 -0
  234. package/select/Select.d.ts +4 -0
  235. package/select/Select.js +240 -515
  236. package/select/Select.stories.tsx +971 -0
  237. package/select/Select.test.js +2370 -0
  238. package/select/types.d.ts +209 -0
  239. package/select/types.js +5 -0
  240. package/sidenav/Icons.d.ts +7 -0
  241. package/sidenav/Icons.js +47 -0
  242. package/sidenav/Sidenav.d.ts +10 -0
  243. package/sidenav/Sidenav.js +132 -81
  244. package/sidenav/Sidenav.stories.tsx +282 -0
  245. package/sidenav/Sidenav.test.js +37 -0
  246. package/sidenav/types.d.ts +76 -0
  247. package/sidenav/types.js +5 -0
  248. package/slider/Slider.d.ts +2 -2
  249. package/slider/Slider.js +162 -183
  250. package/slider/Slider.test.js +254 -0
  251. package/slider/types.d.ts +13 -10
  252. package/spinner/Spinner.d.ts +4 -0
  253. package/spinner/Spinner.js +38 -99
  254. package/spinner/Spinner.stories.tsx +129 -0
  255. package/spinner/Spinner.test.js +55 -0
  256. package/spinner/types.d.ts +32 -0
  257. package/spinner/types.js +5 -0
  258. package/status-light/StatusLight.d.ts +4 -0
  259. package/status-light/StatusLight.js +51 -0
  260. package/status-light/StatusLight.stories.tsx +74 -0
  261. package/status-light/StatusLight.test.js +25 -0
  262. package/status-light/types.d.ts +17 -0
  263. package/status-light/types.js +5 -0
  264. package/switch/Switch.d.ts +2 -2
  265. package/switch/Switch.js +150 -115
  266. package/switch/Switch.stories.tsx +137 -0
  267. package/switch/Switch.test.js +180 -0
  268. package/switch/types.d.ts +13 -5
  269. package/table/Table.d.ts +4 -0
  270. package/table/Table.js +10 -32
  271. package/table/Table.stories.tsx +356 -0
  272. package/table/Table.test.js +21 -0
  273. package/table/types.d.ts +21 -0
  274. package/table/types.js +5 -0
  275. package/tabs/Tab.d.ts +4 -0
  276. package/tabs/Tab.js +113 -0
  277. package/tabs/Tabs.d.ts +1 -1
  278. package/tabs/Tabs.js +318 -145
  279. package/tabs/Tabs.stories.tsx +226 -0
  280. package/tabs/Tabs.test.js +294 -0
  281. package/tabs/types.d.ts +48 -27
  282. package/tag/Tag.d.ts +4 -0
  283. package/tag/Tag.js +55 -112
  284. package/tag/Tag.stories.tsx +155 -0
  285. package/tag/Tag.test.js +49 -0
  286. package/tag/types.d.ts +69 -0
  287. package/tag/types.js +5 -0
  288. package/text-input/Icons.d.ts +8 -0
  289. package/text-input/Icons.js +56 -0
  290. package/text-input/Suggestion.d.ts +4 -0
  291. package/text-input/Suggestion.js +67 -0
  292. package/text-input/Suggestions.d.ts +4 -0
  293. package/text-input/Suggestions.js +84 -0
  294. package/text-input/TextInput.d.ts +4 -0
  295. package/text-input/TextInput.js +332 -585
  296. package/text-input/TextInput.stories.tsx +465 -0
  297. package/text-input/TextInput.test.js +1739 -0
  298. package/text-input/types.d.ts +205 -0
  299. package/text-input/types.js +5 -0
  300. package/textarea/Textarea.d.ts +4 -0
  301. package/textarea/Textarea.js +98 -181
  302. package/textarea/Textarea.stories.tsx +174 -0
  303. package/textarea/Textarea.test.js +406 -0
  304. package/textarea/types.d.ts +141 -0
  305. package/textarea/types.js +5 -0
  306. package/toggle-group/ToggleGroup.d.ts +4 -0
  307. package/toggle-group/ToggleGroup.js +100 -142
  308. package/toggle-group/ToggleGroup.stories.tsx +218 -0
  309. package/toggle-group/ToggleGroup.test.js +137 -0
  310. package/toggle-group/types.d.ts +114 -0
  311. package/toggle-group/types.js +5 -0
  312. package/typography/Typography.d.ts +4 -0
  313. package/typography/Typography.js +23 -0
  314. package/typography/Typography.stories.tsx +198 -0
  315. package/typography/types.d.ts +18 -0
  316. package/typography/types.js +5 -0
  317. package/useTheme.d.ts +1134 -0
  318. package/useTheme.js +4 -11
  319. package/useTranslatedLabels.d.ts +85 -0
  320. package/useTranslatedLabels.js +14 -0
  321. package/utils/BaseTypography.d.ts +21 -0
  322. package/utils/BaseTypography.js +94 -0
  323. package/utils/FocusLock.d.ts +13 -0
  324. package/utils/FocusLock.js +121 -0
  325. package/wizard/Wizard.d.ts +4 -0
  326. package/wizard/Wizard.js +130 -151
  327. package/wizard/Wizard.stories.tsx +253 -0
  328. package/wizard/Wizard.test.js +114 -0
  329. package/wizard/types.d.ts +64 -0
  330. package/wizard/types.js +5 -0
  331. package/ThemeContext.js +0 -246
  332. package/V3Select/V3Select.js +0 -455
  333. package/V3Select/index.d.ts +0 -27
  334. package/V3Textarea/V3Textarea.js +0 -260
  335. package/V3Textarea/index.d.ts +0 -27
  336. package/box/index.d.ts +0 -25
  337. package/chip/index.d.ts +0 -22
  338. package/common/RequiredComponent.js +0 -32
  339. package/date/Date.js +0 -373
  340. package/date/index.d.ts +0 -27
  341. package/dialog/index.d.ts +0 -18
  342. package/file-input/index.d.ts +0 -81
  343. package/header/index.d.ts +0 -25
  344. package/heading/index.d.ts +0 -17
  345. package/input-text/Icons.js +0 -22
  346. package/input-text/InputText.js +0 -611
  347. package/input-text/index.d.ts +0 -36
  348. package/link/index.d.ts +0 -23
  349. package/number-input/NumberInputContext.js +0 -16
  350. package/number-input/index.d.ts +0 -113
  351. package/password-input/index.d.ts +0 -94
  352. package/radio/Radio.d.ts +0 -4
  353. package/radio/Radio.js +0 -174
  354. package/radio/types.d.ts +0 -54
  355. package/resultsetTable/ResultsetTable.js +0 -274
  356. package/resultsetTable/index.d.ts +0 -19
  357. package/select/index.d.ts +0 -131
  358. package/sidenav/index.d.ts +0 -13
  359. package/spinner/index.d.ts +0 -17
  360. package/table/index.d.ts +0 -13
  361. package/tag/index.d.ts +0 -24
  362. package/text-input/index.d.ts +0 -135
  363. package/textarea/Textarea.stories.jsx +0 -135
  364. package/textarea/index.d.ts +0 -117
  365. package/toggle/Toggle.js +0 -186
  366. package/toggle/index.d.ts +0 -21
  367. package/toggle-group/index.d.ts +0 -21
  368. package/upload/Upload.js +0 -201
  369. package/upload/buttons-upload/ButtonsUpload.js +0 -111
  370. package/upload/buttons-upload/Icons.js +0 -40
  371. package/upload/dragAndDropArea/DragAndDropArea.js +0 -225
  372. package/upload/dragAndDropArea/Icons.js +0 -39
  373. package/upload/file-upload/FileToUpload.js +0 -115
  374. package/upload/file-upload/Icons.js +0 -66
  375. package/upload/files-upload/FilesToUpload.js +0 -109
  376. package/upload/index.d.ts +0 -15
  377. package/upload/transaction/Icons.js +0 -160
  378. package/upload/transaction/Transaction.js +0 -104
  379. package/upload/transactions/Transactions.js +0 -94
  380. package/wizard/Icons.js +0 -65
  381. package/wizard/index.d.ts +0 -18
  382. /package/{radio → action-icon}/types.js +0 -0
@@ -0,0 +1,465 @@
1
+ import React from "react";
2
+ import { userEvent, within } from "@storybook/testing-library";
3
+ import Title from "../../.storybook/components/Title";
4
+ import ExampleContainer from "../../.storybook/components/ExampleContainer";
5
+ import DxcTextInput from "./TextInput";
6
+ import Suggestions from "./Suggestions";
7
+ import { ThemeProvider } from "styled-components";
8
+ import useTheme from "../useTheme";
9
+ import { HalstackProvider } from "../HalstackContext";
10
+
11
+ export default {
12
+ title: "Text Input",
13
+ component: DxcTextInput,
14
+ };
15
+
16
+ const action = {
17
+ onClick: () => {},
18
+ icon: (
19
+ <svg xmlns="http://www.w3.org/2000/svg" height="24px" viewBox="0 0 24 24" width="24px" fill="currentColor">
20
+ <path d="M0 0h24v24H0V0z" fill="none" />
21
+ <path d="M16 1H4c-1.1 0-2 .9-2 2v14h2V3h12V1zm3 4H8c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h11c1.1 0 2-.9 2-2V7c0-1.1-.9-2-2-2zm0 16H8V7h11v14z" />
22
+ </svg>
23
+ ),
24
+ };
25
+
26
+ const actionLargeIconSVG = {
27
+ onClick: () => {},
28
+ icon: (
29
+ <svg xmlns="http://www.w3.org/2000/svg" height="48px" viewBox="0 0 24 24" width="48px" fill="currentColor">
30
+ <path d="M0 0h24v24H0V0z" fill="none" />
31
+ <path d="M11.99 2C6.47 2 2 6.48 2 12s4.47 10 9.99 10C17.52 22 22 17.52 22 12S17.52 2 11.99 2zM12 20c-4.42 0-8-3.58-8-8s3.58-8 8-8 8 3.58 8 8-3.58 8-8 8zm.5-13H11v6l5.25 3.15.75-1.23-4.5-2.67z" />
32
+ </svg>
33
+ ),
34
+ };
35
+
36
+ const actionLargeIconURL = {
37
+ onClick: () => {},
38
+ icon: "https://iconape.com/wp-content/files/yd/367773/svg/logo-linkedin-logo-icon-png-svg.png",
39
+ };
40
+
41
+ const country = ["Afghanistan"];
42
+ const countries = [
43
+ "Afghanistan",
44
+ "Albania",
45
+ "Algeria",
46
+ "Andorra",
47
+ "Angola",
48
+ "Antigua and Barbuda",
49
+ "Bahamas",
50
+ "Bahrain",
51
+ "Bangladesh",
52
+ "Barbados",
53
+ "Cabo Verde",
54
+ "Cambodia",
55
+ "Cameroon",
56
+ "Canada",
57
+ "Cayman Islands, The",
58
+ "Central African Republic",
59
+ "Chad",
60
+ "Democratic Republic of the Congo",
61
+ "Dominican Republic",
62
+ "Dominica",
63
+ "Denmark",
64
+ "Djibouti",
65
+ ];
66
+
67
+ const opinionatedTheme = {
68
+ textInput: {
69
+ fontColor: "#000000",
70
+ hoverBorderColor: "#a46ede",
71
+ },
72
+ };
73
+
74
+ export const Chromatic = () => (
75
+ <>
76
+ <ExampleContainer pseudoState="pseudo-hover">
77
+ <Title title="Hovered input" theme="light" level={4} />
78
+ <DxcTextInput label="Text input" />
79
+ </ExampleContainer>
80
+ <ExampleContainer pseudoState="pseudo-focus-within">
81
+ <Title title="Focused input" theme="light" level={4} />
82
+ <DxcTextInput label="Text input" />
83
+ </ExampleContainer>
84
+ <ExampleContainer pseudoState="pseudo-hover">
85
+ <Title title="Hovered action" theme="light" level={4} />
86
+ <DxcTextInput label="Text input" defaultValue="Text" clearable />
87
+ </ExampleContainer>
88
+ <ExampleContainer pseudoState="pseudo-active">
89
+ <Title title="Actived action" theme="light" level={4} />
90
+ <DxcTextInput label="Text input" action={action} clearable />
91
+ </ExampleContainer>
92
+ <ExampleContainer pseudoState="pseudo-focus">
93
+ <Title title="Focused action" theme="light" level={4} />
94
+ <DxcTextInput label="Text input" action={action} clearable />
95
+ </ExampleContainer>
96
+ <ExampleContainer>
97
+ <Title title="Without label" theme="light" level={4} />
98
+ <DxcTextInput />
99
+ </ExampleContainer>
100
+ <ExampleContainer>
101
+ <Title title="With label and placeholder" theme="light" level={4} />
102
+ <DxcTextInput label="Text input" placeholder="Placeholder" />
103
+ </ExampleContainer>
104
+ <ExampleContainer>
105
+ <Title title="Helper text, optional, and clearable" theme="light" level={4} />
106
+ <DxcTextInput label="Text input" clearable defaultValue="Text" helperText="Help message" optional />
107
+ </ExampleContainer>
108
+ <ExampleContainer>
109
+ <Title title="Clearable and large icon action (SVG)" theme="light" level={4} />
110
+ <DxcTextInput
111
+ label="Text input"
112
+ defaultValue="Text text text text text text text text text text"
113
+ clearable
114
+ action={actionLargeIconSVG}
115
+ />
116
+ </ExampleContainer>
117
+ <ExampleContainer>
118
+ <Title title="Clearable and large icon action (URL)" theme="light" level={4} />
119
+ <DxcTextInput
120
+ label="Text input"
121
+ defaultValue="Text text text text text text text text text text"
122
+ clearable
123
+ action={actionLargeIconURL}
124
+ />
125
+ </ExampleContainer>
126
+ <ExampleContainer>
127
+ <Title title="Prefix" theme="light" level={4} />
128
+ <DxcTextInput label="With prefix" prefix="+34" />
129
+ </ExampleContainer>
130
+ <ExampleContainer>
131
+ <Title title="Suffix and action" theme="light" level={4} />
132
+ <DxcTextInput label="With suffix" suffix="USD" action={action} />
133
+ </ExampleContainer>
134
+ <ExampleContainer>
135
+ <Title title="Invalid" theme="light" level={4} />
136
+ <DxcTextInput
137
+ label="Error text input"
138
+ helperText="Help message"
139
+ error="Error message."
140
+ defaultValue="Text"
141
+ clearable
142
+ optional
143
+ action={action}
144
+ />
145
+ </ExampleContainer>
146
+ <ExampleContainer pseudoState="pseudo-hover">
147
+ <Title title="Invalid and hovered" theme="light" level={4} />
148
+ <DxcTextInput
149
+ label="Error text input"
150
+ helperText="Help message"
151
+ placeholder="Placeholder"
152
+ error="Error message."
153
+ />
154
+ </ExampleContainer>
155
+ <ExampleContainer>
156
+ <Title title="Disabled and placeholder" theme="light" level={4} />
157
+ <DxcTextInput label="Disabled text input" disabled placeholder="Placeholder" />
158
+ </ExampleContainer>
159
+ <ExampleContainer>
160
+ <Title title="Disabled, helper text, optional, value and action" theme="light" level={4} />
161
+ <DxcTextInput
162
+ label="Disabled text input"
163
+ helperText="Help message"
164
+ disabled
165
+ optional
166
+ defaultValue="Text"
167
+ action={action}
168
+ />
169
+ </ExampleContainer>
170
+ <ExampleContainer>
171
+ <Title title="Disabled with prefix and suffix" theme="light" level={4} />
172
+ <DxcTextInput
173
+ label="Disabled text input"
174
+ helperText="Help message"
175
+ disabled
176
+ optional
177
+ prefix="+34"
178
+ suffix="USD"
179
+ defaultValue="Text"
180
+ action={action}
181
+ />
182
+ </ExampleContainer>
183
+ <ExampleContainer>
184
+ <Title title="Read only" theme="light" level={4} />
185
+ <DxcTextInput
186
+ label="Example label"
187
+ helperText="Help message"
188
+ clearable
189
+ readOnly
190
+ optional
191
+ prefix="+34"
192
+ defaultValue="Text"
193
+ action={action}
194
+ />
195
+ </ExampleContainer>
196
+ <ExampleContainer pseudoState="pseudo-hover">
197
+ <Title title="Hovered read only" theme="light" level={4} />
198
+ <DxcTextInput
199
+ label="Example label"
200
+ helperText="Help message"
201
+ clearable
202
+ readOnly
203
+ optional
204
+ prefix="+34"
205
+ defaultValue="Text"
206
+ action={action}
207
+ />
208
+ </ExampleContainer>
209
+ <ExampleContainer pseudoState="pseudo-active">
210
+ <Title title="Active read only" theme="light" level={4} />
211
+ <DxcTextInput
212
+ label="Example label"
213
+ helperText="Help message"
214
+ clearable
215
+ readOnly
216
+ optional
217
+ prefix="+34"
218
+ defaultValue="Text"
219
+ action={action}
220
+ />
221
+ </ExampleContainer>
222
+ <Title title="Margins" theme="light" level={2} />
223
+ <ExampleContainer>
224
+ <Title title="Xxsmall margin" theme="light" level={4} />
225
+ <DxcTextInput label="Xxsmall" margin="xxsmall" />
226
+ </ExampleContainer>
227
+ <ExampleContainer>
228
+ <Title title="Xsmall margin" theme="light" level={4} />
229
+ <DxcTextInput label="Xsmall" margin="xsmall" />
230
+ </ExampleContainer>
231
+ <ExampleContainer>
232
+ <Title title="Small margin" theme="light" level={4} />
233
+ <DxcTextInput label="Small" margin="small" />
234
+ </ExampleContainer>
235
+ <ExampleContainer>
236
+ <Title title="Medium margin" theme="light" level={4} />
237
+ <DxcTextInput label="Medium" margin="medium" />
238
+ </ExampleContainer>
239
+ <ExampleContainer>
240
+ <Title title="Large margin" theme="light" level={4} />
241
+ <DxcTextInput label="Large" margin="large" />
242
+ </ExampleContainer>
243
+ <ExampleContainer>
244
+ <Title title="Xlarge margin" theme="light" level={4} />
245
+ <DxcTextInput label="Xlarge" margin="xlarge" />
246
+ </ExampleContainer>
247
+ <ExampleContainer>
248
+ <Title title="Xxlarge margin" theme="light" level={4} />
249
+ <DxcTextInput label="Xxlarge" margin="xxlarge" />
250
+ </ExampleContainer>
251
+ <Title title="Sizes" theme="light" level={2} />
252
+ <ExampleContainer>
253
+ <Title title="Small size" theme="light" level={4} />
254
+ <DxcTextInput label="Small" size="small" />
255
+ </ExampleContainer>
256
+ <ExampleContainer>
257
+ <Title title="Medium size" theme="light" level={4} />
258
+ <DxcTextInput label="Medium" size="medium" />
259
+ </ExampleContainer>
260
+ <ExampleContainer>
261
+ <Title title="Large size" theme="light" level={4} />
262
+ <DxcTextInput label="Large" size="large" />
263
+ </ExampleContainer>
264
+ <ExampleContainer>
265
+ <Title title="FillParent size" theme="light" level={4} />
266
+ <DxcTextInput label="FillParent" size="fillParent" />
267
+ </ExampleContainer>
268
+ <Title title="Opinionated theme" theme="light" level={2} />
269
+ <ExampleContainer>
270
+ <HalstackProvider theme={opinionatedTheme}>
271
+ <ExampleContainer pseudoState="pseudo-hover">
272
+ <Title title="Hovered input" theme="light" level={4} />
273
+ <DxcTextInput label="Text input" helperText="Help message" />
274
+ </ExampleContainer>
275
+ <ExampleContainer pseudoState="pseudo-focus-within">
276
+ <Title title="Focused input" theme="light" level={4} />
277
+ <DxcTextInput label="Text input" helperText="Help message" />
278
+ </ExampleContainer>
279
+ <ExampleContainer pseudoState="pseudo-hover">
280
+ <Title title="Hovered action" theme="light" level={4} />
281
+ <DxcTextInput label="Text input" helperText="Help message" defaultValue="Text" clearable />
282
+ </ExampleContainer>
283
+ <ExampleContainer pseudoState="pseudo-active">
284
+ <Title title="Actived action" theme="light" level={4} />
285
+ <DxcTextInput label="Text input" helperText="Help message" action={action} clearable />
286
+ </ExampleContainer>
287
+ <ExampleContainer pseudoState="pseudo-focus">
288
+ <Title title="Focused action" theme="light" level={4} />
289
+ <DxcTextInput label="Text input" helperText="Help message" action={action} clearable />
290
+ </ExampleContainer>
291
+ <ExampleContainer>
292
+ <Title title="Prefix" theme="light" level={4} />
293
+ <DxcTextInput label="With prefix" prefix="+34" helperText="Help message" />
294
+ </ExampleContainer>
295
+ <ExampleContainer>
296
+ <Title title="Suffix and action" theme="light" level={4} />
297
+ <DxcTextInput label="With suffix" helperText="Help message" suffix="USD" action={action} />
298
+ </ExampleContainer>
299
+ <ExampleContainer>
300
+ <Title title="Invalid" theme="light" level={4} />
301
+ <DxcTextInput
302
+ label="Error text input"
303
+ helperText="Help message"
304
+ error="Error message."
305
+ defaultValue="Text"
306
+ clearable
307
+ optional
308
+ action={action}
309
+ />
310
+ </ExampleContainer>
311
+ <ExampleContainer>
312
+ <Title title="Disabled and placeholder" theme="light" level={4} />
313
+ <DxcTextInput label="Disabled text input" disabled placeholder="Placeholder" prefix="+34" suffix="USD" />
314
+ </ExampleContainer>
315
+ <ExampleContainer>
316
+ <Title title="Disabled, helper text, optional, value and action" theme="light" level={4} />
317
+ <DxcTextInput
318
+ label="Disabled text input"
319
+ helperText="Help message"
320
+ disabled
321
+ optional
322
+ defaultValue="Text"
323
+ action={action}
324
+ />
325
+ </ExampleContainer>
326
+ </HalstackProvider>
327
+ </ExampleContainer>
328
+ </>
329
+ );
330
+
331
+ const AutosuggestListbox = () => {
332
+ const colorsTheme: any = useTheme();
333
+
334
+ return (
335
+ <ThemeProvider theme={colorsTheme.textInput}>
336
+ <ExampleContainer>
337
+ <Title title="Autosuggest listbox" theme="light" level={2} />
338
+ <ExampleContainer>
339
+ <Title
340
+ title="List dialog uses a Radix Popover to appear over elements with a certain z-index"
341
+ theme="light"
342
+ level={3}
343
+ />
344
+ <div
345
+ style={{
346
+ display: "flex",
347
+ flexDirection: "column",
348
+ gap: "20px",
349
+ height: "150px",
350
+ width: "500px",
351
+ marginBottom: "250px",
352
+ padding: "20px",
353
+ border: "1px solid black",
354
+ borderRadius: "4px",
355
+ overflow: "auto",
356
+ zIndex: "1300",
357
+ position: "relative",
358
+ }}
359
+ >
360
+ <DxcTextInput
361
+ label="Label"
362
+ suggestions={countries}
363
+ optional
364
+ placeholder="Choose an option"
365
+ size="fillParent"
366
+ />
367
+ <button style={{ zIndex: "1", width: "100px" }}>Submit</button>
368
+ </div>
369
+ </ExampleContainer>
370
+ <Title title="Listbox suggestion states" theme="light" level={3} />
371
+ <ExampleContainer pseudoState="pseudo-hover">
372
+ <Title title="Hovered suggestion" theme="light" level={4} />
373
+ <Suggestions
374
+ id="x"
375
+ value=""
376
+ suggestions={country}
377
+ visualFocusIndex={-1}
378
+ highlightedSuggestions={false}
379
+ searchHasErrors={false}
380
+ isSearching={false}
381
+ suggestionOnClick={() => {}}
382
+ styles={{ width: 350 }}
383
+ />
384
+ </ExampleContainer>
385
+ <ExampleContainer pseudoState="pseudo-active">
386
+ <Title title="Active suggestion" theme="light" level={4} />
387
+ <Suggestions
388
+ id="x"
389
+ value=""
390
+ suggestions={country}
391
+ visualFocusIndex={-1}
392
+ highlightedSuggestions={false}
393
+ searchHasErrors={false}
394
+ isSearching={false}
395
+ suggestionOnClick={(suggestion) => {}}
396
+ styles={{ width: 350 }}
397
+ />
398
+ </ExampleContainer>
399
+ <ExampleContainer>
400
+ <Title title="Focused suggestion" theme="light" level={4} />
401
+ <Suggestions
402
+ id="x"
403
+ value=""
404
+ suggestions={country}
405
+ visualFocusIndex={0}
406
+ highlightedSuggestions={false}
407
+ searchHasErrors={false}
408
+ isSearching={false}
409
+ suggestionOnClick={(suggestion) => {}}
410
+ styles={{ width: 350 }}
411
+ />
412
+ </ExampleContainer>
413
+ <ExampleContainer>
414
+ <Title title="Highlighted suggestion" theme="light" level={4} />
415
+ <Suggestions
416
+ id="x"
417
+ value="Afgh"
418
+ suggestions={country}
419
+ visualFocusIndex={-1}
420
+ highlightedSuggestions={true}
421
+ searchHasErrors={false}
422
+ isSearching={false}
423
+ suggestionOnClick={(suggestion) => {}}
424
+ styles={{ width: 350 }}
425
+ />
426
+ </ExampleContainer>
427
+ </ExampleContainer>
428
+ <ExampleContainer>
429
+ <Title title="Autosuggest Error" theme="light" level={3} />
430
+ <Suggestions
431
+ id="x"
432
+ value=""
433
+ suggestions={country}
434
+ visualFocusIndex={-1}
435
+ highlightedSuggestions={false}
436
+ searchHasErrors={true}
437
+ isSearching={false}
438
+ suggestionOnClick={(suggestion) => {}}
439
+ styles={{ width: 350 }}
440
+ />
441
+ </ExampleContainer>
442
+ <ExampleContainer>
443
+ <Title title="Autosuggest Searching message" theme="light" level={3} />
444
+ <Suggestions
445
+ id="x"
446
+ value=""
447
+ suggestions={country}
448
+ visualFocusIndex={-1}
449
+ highlightedSuggestions={false}
450
+ searchHasErrors={false}
451
+ isSearching={true}
452
+ suggestionOnClick={(suggestion) => {}}
453
+ styles={{ width: 350 }}
454
+ />
455
+ </ExampleContainer>
456
+ </ThemeProvider>
457
+ );
458
+ };
459
+
460
+ export const AutosuggestListboxStates = AutosuggestListbox.bind({});
461
+ AutosuggestListboxStates.play = async ({ canvasElement }) => {
462
+ const canvas = within(canvasElement);
463
+ const select = canvas.getByRole("combobox");
464
+ await userEvent.click(select);
465
+ };