@dxc-technology/halstack-react 10.1.0 → 11.0.0

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 (210) hide show
  1. package/BackgroundColorContext.d.ts +2 -2
  2. package/BackgroundColorContext.js +5 -17
  3. package/HalstackContext.d.ts +18 -6
  4. package/HalstackContext.js +9 -34
  5. package/accordion/Accordion.js +21 -58
  6. package/accordion/Accordion.stories.tsx +1 -15
  7. package/accordion/Accordion.test.js +18 -33
  8. package/accordion/types.d.ts +5 -5
  9. package/accordion-group/AccordionGroup.js +15 -42
  10. package/accordion-group/AccordionGroup.stories.tsx +1 -1
  11. package/accordion-group/AccordionGroup.test.js +42 -60
  12. package/accordion-group/AccordionGroupAccordion.js +9 -21
  13. package/accordion-group/types.d.ts +6 -6
  14. package/alert/Alert.js +14 -46
  15. package/alert/Alert.test.js +28 -45
  16. package/alert/types.d.ts +5 -5
  17. package/badge/Badge.js +4 -17
  18. package/badge/types.d.ts +1 -1
  19. package/bleed/Bleed.js +13 -21
  20. package/bleed/types.d.ts +2 -2
  21. package/box/Box.js +10 -29
  22. package/box/Box.test.js +1 -6
  23. package/box/types.d.ts +3 -3
  24. package/bulleted-list/BulletedList.js +7 -33
  25. package/bulleted-list/BulletedList.stories.tsx +1 -91
  26. package/bulleted-list/types.d.ts +5 -5
  27. package/button/Button.js +23 -46
  28. package/button/Button.stories.tsx +5 -86
  29. package/button/Button.test.js +11 -21
  30. package/button/types.d.ts +4 -4
  31. package/card/Card.js +21 -44
  32. package/card/Card.test.js +10 -21
  33. package/card/types.d.ts +5 -5
  34. package/checkbox/Checkbox.js +81 -111
  35. package/checkbox/Checkbox.stories.tsx +16 -54
  36. package/checkbox/Checkbox.test.js +107 -63
  37. package/checkbox/types.d.ts +8 -4
  38. package/chip/Chip.js +12 -31
  39. package/chip/Chip.test.js +15 -28
  40. package/chip/types.d.ts +4 -4
  41. package/common/coreTokens.js +1 -2
  42. package/common/utils.js +2 -8
  43. package/common/variables.d.ts +15 -6
  44. package/common/variables.js +17 -15
  45. package/date-input/Calendar.js +13 -57
  46. package/date-input/DateInput.js +50 -96
  47. package/date-input/DateInput.stories.tsx +11 -30
  48. package/date-input/DateInput.test.js +674 -701
  49. package/date-input/DatePicker.js +11 -42
  50. package/date-input/Icons.d.ts +6 -6
  51. package/date-input/Icons.js +6 -23
  52. package/date-input/YearPicker.js +8 -34
  53. package/date-input/types.d.ts +27 -21
  54. package/dialog/Dialog.js +11 -35
  55. package/dialog/Dialog.test.js +125 -187
  56. package/dialog/types.d.ts +18 -13
  57. package/dropdown/Dropdown.js +39 -93
  58. package/dropdown/Dropdown.test.js +391 -378
  59. package/dropdown/DropdownMenu.js +8 -19
  60. package/dropdown/DropdownMenuItem.js +5 -17
  61. package/dropdown/types.d.ts +17 -19
  62. package/file-input/FileInput.js +131 -220
  63. package/file-input/FileInput.stories.tsx +1 -1
  64. package/file-input/FileInput.test.js +293 -342
  65. package/file-input/FileItem.js +12 -39
  66. package/file-input/types.d.ts +9 -9
  67. package/flex/Flex.js +25 -39
  68. package/flex/types.d.ts +6 -6
  69. package/footer/Footer.js +9 -39
  70. package/footer/Footer.test.js +18 -32
  71. package/footer/Icons.d.ts +2 -2
  72. package/footer/Icons.js +2 -7
  73. package/footer/types.d.ts +13 -13
  74. package/grid/Grid.js +1 -16
  75. package/grid/types.d.ts +10 -10
  76. package/header/Header.d.ts +1 -1
  77. package/header/Header.js +19 -64
  78. package/header/Header.test.js +12 -25
  79. package/header/Icons.d.ts +2 -2
  80. package/header/Icons.js +2 -7
  81. package/header/types.d.ts +5 -7
  82. package/heading/Heading.js +9 -31
  83. package/heading/Heading.test.js +70 -87
  84. package/heading/types.d.ts +7 -7
  85. package/image/Image.d.ts +2 -2
  86. package/image/Image.js +17 -32
  87. package/image/types.d.ts +2 -2
  88. package/inset/Inset.js +13 -21
  89. package/inset/types.d.ts +2 -2
  90. package/layout/ApplicationLayout.d.ts +1 -1
  91. package/layout/ApplicationLayout.js +14 -54
  92. package/layout/Icons.d.ts +5 -5
  93. package/layout/Icons.js +1 -5
  94. package/layout/SidenavContext.d.ts +1 -1
  95. package/layout/SidenavContext.js +3 -9
  96. package/layout/types.d.ts +3 -3
  97. package/link/Link.js +21 -42
  98. package/link/Link.test.js +23 -41
  99. package/link/types.d.ts +14 -14
  100. package/main.d.ts +1 -1
  101. package/main.js +3 -52
  102. package/nav-tabs/NavTabs.js +11 -43
  103. package/nav-tabs/NavTabs.stories.tsx +1 -1
  104. package/nav-tabs/NavTabs.test.js +36 -43
  105. package/nav-tabs/Tab.js +16 -45
  106. package/nav-tabs/types.d.ts +9 -9
  107. package/number-input/NumberInput.d.ts +1 -1
  108. package/number-input/NumberInput.js +24 -35
  109. package/number-input/NumberInput.stories.tsx +42 -26
  110. package/number-input/NumberInput.test.js +682 -577
  111. package/number-input/types.d.ts +11 -5
  112. package/package.json +27 -25
  113. package/paginator/Icons.d.ts +5 -5
  114. package/paginator/Icons.js +5 -19
  115. package/paginator/Paginator.js +14 -39
  116. package/paginator/Paginator.test.js +224 -207
  117. package/paginator/types.d.ts +3 -3
  118. package/paragraph/Paragraph.js +3 -14
  119. package/paragraph/Paragraph.stories.tsx +0 -17
  120. package/password-input/Icons.d.ts +3 -3
  121. package/password-input/Icons.js +1 -5
  122. package/password-input/PasswordInput.js +26 -48
  123. package/password-input/PasswordInput.stories.tsx +1 -33
  124. package/password-input/PasswordInput.test.js +153 -129
  125. package/password-input/types.d.ts +8 -7
  126. package/progress-bar/ProgressBar.js +16 -42
  127. package/progress-bar/{ProgressBar.stories.jsx → ProgressBar.stories.tsx} +1 -1
  128. package/progress-bar/ProgressBar.test.js +35 -52
  129. package/progress-bar/types.d.ts +3 -3
  130. package/quick-nav/QuickNav.js +4 -27
  131. package/quick-nav/QuickNav.stories.tsx +1 -1
  132. package/quick-nav/types.d.ts +10 -10
  133. package/radio-group/Radio.d.ts +1 -1
  134. package/radio-group/Radio.js +22 -54
  135. package/radio-group/RadioGroup.js +37 -83
  136. package/radio-group/RadioGroup.stories.tsx +10 -10
  137. package/radio-group/RadioGroup.test.js +504 -470
  138. package/radio-group/types.d.ts +8 -8
  139. package/resultset-table/Icons.d.ts +7 -0
  140. package/{resultsetTable → resultset-table}/Icons.js +1 -5
  141. package/{resultsetTable → resultset-table}/ResultsetTable.js +22 -58
  142. package/{resultsetTable → resultset-table}/ResultsetTable.test.js +72 -92
  143. package/{resultsetTable → resultset-table}/types.d.ts +7 -7
  144. package/select/Icons.d.ts +7 -7
  145. package/select/Icons.js +1 -5
  146. package/select/Listbox.js +13 -39
  147. package/select/Option.js +9 -26
  148. package/select/Select.js +54 -138
  149. package/select/Select.test.js +1902 -1796
  150. package/select/types.d.ts +14 -15
  151. package/sidenav/Icons.d.ts +4 -4
  152. package/sidenav/Icons.js +1 -5
  153. package/sidenav/Sidenav.js +24 -63
  154. package/sidenav/Sidenav.test.js +3 -10
  155. package/sidenav/types.d.ts +18 -18
  156. package/slider/Slider.js +38 -86
  157. package/slider/Slider.test.js +107 -103
  158. package/slider/types.d.ts +4 -4
  159. package/spinner/Spinner.js +10 -40
  160. package/spinner/Spinner.test.js +25 -34
  161. package/spinner/types.d.ts +3 -3
  162. package/switch/Switch.js +26 -69
  163. package/switch/Switch.stories.tsx +0 -34
  164. package/switch/Switch.test.js +51 -96
  165. package/switch/types.d.ts +4 -4
  166. package/table/Table.js +4 -23
  167. package/table/Table.test.js +1 -6
  168. package/table/types.d.ts +8 -8
  169. package/tabs/Tab.js +10 -29
  170. package/tabs/Tabs.js +48 -124
  171. package/tabs/Tabs.test.js +62 -118
  172. package/tabs/types.d.ts +19 -19
  173. package/tag/Tag.js +21 -51
  174. package/tag/Tag.test.js +19 -30
  175. package/tag/types.d.ts +7 -7
  176. package/text-input/Icons.d.ts +5 -5
  177. package/text-input/Icons.js +1 -5
  178. package/text-input/Suggestion.js +9 -26
  179. package/text-input/Suggestions.d.ts +1 -1
  180. package/text-input/Suggestions.js +12 -57
  181. package/text-input/TextInput.js +128 -193
  182. package/text-input/TextInput.stories.tsx +48 -152
  183. package/text-input/TextInput.test.js +1210 -1194
  184. package/text-input/types.d.ts +25 -17
  185. package/textarea/Textarea.js +60 -96
  186. package/textarea/{Textarea.stories.jsx → Textarea.stories.tsx} +58 -99
  187. package/textarea/Textarea.test.js +150 -179
  188. package/textarea/types.d.ts +9 -5
  189. package/toggle-group/ToggleGroup.js +20 -57
  190. package/toggle-group/ToggleGroup.stories.tsx +1 -1
  191. package/toggle-group/ToggleGroup.test.js +48 -81
  192. package/toggle-group/types.d.ts +10 -10
  193. package/typography/Typography.js +4 -13
  194. package/typography/types.d.ts +1 -1
  195. package/useTheme.d.ts +12 -3
  196. package/useTheme.js +1 -8
  197. package/useTranslatedLabels.js +1 -7
  198. package/utils/BaseTypography.d.ts +2 -2
  199. package/utils/BaseTypography.js +16 -30
  200. package/utils/FocusLock.js +12 -36
  201. package/wizard/Wizard.js +14 -49
  202. package/wizard/Wizard.test.js +53 -80
  203. package/wizard/types.d.ts +6 -6
  204. package/resultsetTable/Icons.d.ts +0 -7
  205. package/slider/Slider.stories.tsx +0 -240
  206. /package/{resultsetTable → resultset-table}/ResultsetTable.d.ts +0 -0
  207. /package/{resultsetTable → resultset-table}/ResultsetTable.stories.tsx +0 -0
  208. /package/{resultsetTable → resultset-table}/types.js +0 -0
  209. /package/spinner/{Spinner.stories.jsx → Spinner.stories.tsx} +0 -0
  210. /package/table/{Table.stories.jsx → Table.stories.tsx} +0 -0
@@ -1,20 +1,15 @@
1
1
  import React from "react";
2
2
  import { userEvent, within } from "@storybook/testing-library";
3
- import { BackgroundColorProvider } from "../BackgroundColorContext";
4
3
  import Title from "../../.storybook/components/Title";
5
4
  import ExampleContainer from "../../.storybook/components/ExampleContainer";
6
- import DarkContainer from "../../.storybook/components/DarkSection";
7
5
  import DxcTextInput from "./TextInput";
8
- import DxcButton from "../button/Button";
9
- import DxcCheckbox from "../checkbox/Checkbox";
10
- import DxcFlex from "../flex/Flex";
11
6
  import Suggestions from "./Suggestions";
12
7
  import { ThemeProvider } from "styled-components";
13
8
  import useTheme from "../useTheme";
14
9
  import { HalstackProvider } from "../HalstackContext";
15
10
 
16
11
  export default {
17
- title: "Text input",
12
+ title: "Text Input",
18
13
  component: DxcTextInput,
19
14
  };
20
15
 
@@ -48,9 +43,9 @@ const countries = [
48
43
  "Afghanistan",
49
44
  "Albania",
50
45
  "Algeria",
51
- "Andorra Andorra Andorra Andorra Andorra Andorra Andorra Andorra",
46
+ "Andorra",
52
47
  "Angola",
53
- "Antigua and Barbuda Antigua and Barbuda Antigua and Barbuda",
48
+ "Antigua and Barbuda",
54
49
  "Bahamas",
55
50
  "Bahrain",
56
51
  "Bangladesh",
@@ -67,7 +62,6 @@ const countries = [
67
62
  "Dominica",
68
63
  "Denmark",
69
64
  "Djibouti",
70
- "*",
71
65
  ];
72
66
 
73
67
  const opinionatedTheme = {
@@ -186,94 +180,45 @@ export const Chromatic = () => (
186
180
  action={action}
187
181
  />
188
182
  </ExampleContainer>
189
- <BackgroundColorProvider color="#333333">
190
- <DarkContainer>
191
- <Title title="Dark theme" theme="dark" level={2} />
192
- <ExampleContainer pseudoState="pseudo-hover">
193
- <Title title="Hovered" theme="dark" level={4} />
194
- <DxcTextInput label="Text input" />
195
- </ExampleContainer>
196
- <ExampleContainer pseudoState="pseudo-focus-within">
197
- <Title title="Focused" theme="dark" level={4} />
198
- <DxcTextInput label="Text input" />
199
- </ExampleContainer>
200
- <ExampleContainer pseudoState="pseudo-hover">
201
- <Title title="Hovered action" theme="dark" level={4} />
202
- <DxcTextInput label="Text input" defaultValue="Text" clearable />
203
- </ExampleContainer>
204
- <ExampleContainer pseudoState="pseudo-active">
205
- <Title title="Actived action" theme="dark" level={4} />
206
- <DxcTextInput label="Text input" action={action} clearable />
207
- </ExampleContainer>
208
- <ExampleContainer pseudoState="pseudo-focus">
209
- <Title title="Focused action" theme="dark" level={4} />
210
- <DxcTextInput label="Text input" action={action} clearable />
211
- </ExampleContainer>
212
- <ExampleContainer>
213
- <Title title="Helper text, placeholder, optional and action" theme="dark" level={4} />
214
- <DxcTextInput
215
- label="Text input"
216
- helperText="Help message"
217
- placeholder="Placeholder"
218
- clearable
219
- optional
220
- action={action}
221
- />
222
- </ExampleContainer>
223
- <ExampleContainer>
224
- <Title title="Invalid" theme="dark" level={4} />
225
- <DxcTextInput
226
- label="Error text input"
227
- helperText="Help message"
228
- error="Error message."
229
- defaultValue="Text"
230
- clearable
231
- action={action}
232
- />
233
- </ExampleContainer>
234
- <ExampleContainer pseudoState="pseudo-hover">
235
- <Title title="Invalid and hovered" theme="dark" level={4} />
236
- <DxcTextInput
237
- label="Error text input"
238
- helperText="Help message"
239
- placeholder="Placeholder"
240
- error="Error message."
241
- />
242
- </ExampleContainer>
243
- <ExampleContainer>
244
- <Title title="Prefix and suffix" theme="dark" level={4} />
245
- <DxcTextInput label="With prefix and suffix" prefix="+34" suffix="USD" />
246
- </ExampleContainer>
247
- <ExampleContainer>
248
- <Title title="Disabled and placeholder" theme="dark" level={4} />
249
- <DxcTextInput label="Disabled text input" disabled placeholder="Placeholder" />
250
- </ExampleContainer>
251
- <ExampleContainer>
252
- <Title title="Disabled, helper text, optional, value and action" theme="dark" level={4} />
253
- <DxcTextInput
254
- label="Disabled text input"
255
- helperText="Help message"
256
- disabled
257
- optional
258
- defaultValue="Text"
259
- action={action}
260
- />
261
- </ExampleContainer>
262
- <ExampleContainer>
263
- <Title title="Disabled with prefix and suffix" theme="dark" level={4} />
264
- <DxcTextInput
265
- label="Disabled text input"
266
- helperText="Help message"
267
- disabled
268
- optional
269
- prefix="+34"
270
- suffix="USD"
271
- defaultValue="Text"
272
- action={action}
273
- />
274
- </ExampleContainer>
275
- </DarkContainer>
276
- </BackgroundColorProvider>
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>
277
222
  <Title title="Margins" theme="light" level={2} />
278
223
  <ExampleContainer>
279
224
  <Title title="Xxsmall margin" theme="light" level={4} />
@@ -434,7 +379,7 @@ const AutosuggestListbox = () => {
434
379
  searchHasErrors={false}
435
380
  isSearching={false}
436
381
  suggestionOnClick={() => {}}
437
- getTextInputWidth={() => 350}
382
+ styles={{ width: 350 }}
438
383
  />
439
384
  </ExampleContainer>
440
385
  <ExampleContainer pseudoState="pseudo-active">
@@ -448,7 +393,7 @@ const AutosuggestListbox = () => {
448
393
  searchHasErrors={false}
449
394
  isSearching={false}
450
395
  suggestionOnClick={(suggestion) => {}}
451
- getTextInputWidth={() => 350}
396
+ styles={{ width: 350 }}
452
397
  />
453
398
  </ExampleContainer>
454
399
  <ExampleContainer>
@@ -462,7 +407,7 @@ const AutosuggestListbox = () => {
462
407
  searchHasErrors={false}
463
408
  isSearching={false}
464
409
  suggestionOnClick={(suggestion) => {}}
465
- getTextInputWidth={() => 350}
410
+ styles={{ width: 350 }}
466
411
  />
467
412
  </ExampleContainer>
468
413
  <ExampleContainer>
@@ -476,7 +421,7 @@ const AutosuggestListbox = () => {
476
421
  searchHasErrors={false}
477
422
  isSearching={false}
478
423
  suggestionOnClick={(suggestion) => {}}
479
- getTextInputWidth={() => 350}
424
+ styles={{ width: 350 }}
480
425
  />
481
426
  </ExampleContainer>
482
427
  </ExampleContainer>
@@ -491,7 +436,7 @@ const AutosuggestListbox = () => {
491
436
  searchHasErrors={true}
492
437
  isSearching={false}
493
438
  suggestionOnClick={(suggestion) => {}}
494
- getTextInputWidth={() => 350}
439
+ styles={{ width: 350 }}
495
440
  />
496
441
  </ExampleContainer>
497
442
  <ExampleContainer>
@@ -505,65 +450,16 @@ const AutosuggestListbox = () => {
505
450
  searchHasErrors={false}
506
451
  isSearching={true}
507
452
  suggestionOnClick={(suggestion) => {}}
508
- getTextInputWidth={() => 350}
453
+ styles={{ width: 350 }}
509
454
  />
510
455
  </ExampleContainer>
511
456
  </ThemeProvider>
512
457
  );
513
458
  };
514
459
 
515
- const DarkAutosuggestListbox = () => {
516
- const colorsTheme: any = useTheme();
517
-
518
- return (
519
- <ThemeProvider theme={colorsTheme.textInput}>
520
- <BackgroundColorProvider color="#333333">
521
- <DarkContainer>
522
- <Title title="Dark theme" theme="dark" level={2} />
523
- <ExampleContainer>
524
- <Title title="Default with opened suggestions" theme="dark" level={3} />
525
- <DxcFlex direction="column" gap="5rem">
526
- <DxcTextInput label="Label" suggestions={countries} optional placeholder="Choose an option" />
527
- <DxcCheckbox
528
- label="You understand the selection and give your consent"
529
- onChange={() => {}}
530
- labelPosition="after"
531
- />
532
- <DxcButton label="Submit" onClick={() => {}} size="medium" margin={{ bottom: "xxlarge" }} />
533
- </DxcFlex>
534
- </ExampleContainer>
535
- <ExampleContainer>
536
- <Title title="Autosuggest Error" theme="dark" level={3} />
537
- <div style={{ height: "100px" }}>
538
- <Suggestions
539
- id="x"
540
- value=""
541
- suggestions={country}
542
- visualFocusIndex={-1}
543
- highlightedSuggestions={false}
544
- searchHasErrors={true}
545
- isSearching={false}
546
- suggestionOnClick={(suggestion) => {}}
547
- getTextInputWidth={() => 350}
548
- />
549
- </div>
550
- </ExampleContainer>
551
- </DarkContainer>
552
- </BackgroundColorProvider>
553
- </ThemeProvider>
554
- );
555
- };
556
-
557
460
  export const AutosuggestListboxStates = AutosuggestListbox.bind({});
558
461
  AutosuggestListboxStates.play = async ({ canvasElement }) => {
559
462
  const canvas = within(canvasElement);
560
463
  const select = canvas.getByRole("combobox");
561
464
  await userEvent.click(select);
562
465
  };
563
-
564
- export const AutosuggestListboxOnDark = DarkAutosuggestListbox.bind({});
565
- AutosuggestListboxOnDark.play = async ({ canvasElement }) => {
566
- const canvas = within(canvasElement);
567
- const select = canvas.getByRole("combobox");
568
- await userEvent.click(select);
569
- };