@dxc-technology/halstack-react 6.0.0 → 6.2.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 (92) hide show
  1. package/accordion/Accordion.js +122 -103
  2. package/accordion/Accordion.stories.tsx +1 -2
  3. package/accordion/Accordion.test.js +9 -10
  4. package/accordion/types.d.ts +4 -4
  5. package/accordion-group/AccordionGroup.js +1 -21
  6. package/accordion-group/AccordionGroup.stories.tsx +27 -1
  7. package/accordion-group/AccordionGroup.test.js +20 -45
  8. package/accordion-group/types.d.ts +9 -3
  9. package/alert/Alert.js +1 -1
  10. package/box/Box.js +1 -1
  11. package/bulleted-list/types.d.ts +1 -1
  12. package/button/Button.js +43 -61
  13. package/button/Button.stories.tsx +9 -0
  14. package/button/types.d.ts +7 -7
  15. package/checkbox/Checkbox.js +88 -95
  16. package/checkbox/Checkbox.test.js +93 -16
  17. package/checkbox/types.d.ts +2 -2
  18. package/chip/types.d.ts +1 -1
  19. package/common/variables.js +23 -10
  20. package/date-input/DateInput.js +3 -3
  21. package/dialog/Dialog.js +52 -28
  22. package/dialog/Dialog.stories.tsx +1 -2
  23. package/dialog/Dialog.test.js +34 -4
  24. package/dialog/types.d.ts +2 -2
  25. package/dropdown/Dropdown.d.ts +1 -1
  26. package/dropdown/Dropdown.js +243 -247
  27. package/dropdown/Dropdown.stories.tsx +126 -63
  28. package/dropdown/Dropdown.test.js +510 -108
  29. package/dropdown/DropdownMenu.d.ts +4 -0
  30. package/dropdown/DropdownMenu.js +80 -0
  31. package/dropdown/DropdownMenuItem.d.ts +4 -0
  32. package/dropdown/DropdownMenuItem.js +92 -0
  33. package/dropdown/types.d.ts +25 -5
  34. package/flex/Flex.js +1 -1
  35. package/flex/types.d.ts +1 -1
  36. package/footer/Footer.stories.tsx +8 -1
  37. package/footer/types.d.ts +1 -1
  38. package/header/Header.js +74 -72
  39. package/header/Header.stories.tsx +4 -4
  40. package/header/Icons.js +2 -2
  41. package/header/types.d.ts +2 -2
  42. package/layout/ApplicationLayout.js +3 -3
  43. package/layout/ApplicationLayout.stories.tsx +1 -0
  44. package/link/Link.js +1 -1
  45. package/link/Link.stories.tsx +12 -5
  46. package/link/types.d.ts +1 -1
  47. package/package.json +10 -10
  48. package/progress-bar/ProgressBar.d.ts +2 -2
  49. package/progress-bar/ProgressBar.js +56 -50
  50. package/progress-bar/ProgressBar.stories.jsx +3 -1
  51. package/progress-bar/ProgressBar.test.js +67 -22
  52. package/progress-bar/types.d.ts +3 -4
  53. package/radio-group/RadioGroup.js +11 -13
  54. package/select/Listbox.d.ts +1 -1
  55. package/select/Listbox.js +25 -2
  56. package/select/Select.js +14 -31
  57. package/select/Select.stories.tsx +6 -5
  58. package/select/Select.test.js +63 -50
  59. package/select/types.d.ts +2 -4
  60. package/sidenav/Sidenav.js +15 -3
  61. package/sidenav/types.d.ts +1 -1
  62. package/slider/Slider.js +114 -93
  63. package/slider/Slider.stories.tsx +7 -1
  64. package/slider/Slider.test.js +121 -21
  65. package/slider/types.d.ts +2 -2
  66. package/switch/Switch.d.ts +1 -1
  67. package/switch/Switch.js +111 -55
  68. package/switch/Switch.stories.tsx +8 -30
  69. package/switch/Switch.test.js +122 -8
  70. package/switch/types.d.ts +3 -4
  71. package/tabs/Tab.d.ts +4 -0
  72. package/tabs/Tab.js +135 -0
  73. package/tabs/Tabs.js +360 -104
  74. package/tabs/Tabs.stories.tsx +74 -0
  75. package/tabs/Tabs.test.js +217 -6
  76. package/tabs/types.d.ts +15 -5
  77. package/tabs-nav/NavTabs.js +5 -5
  78. package/tabs-nav/Tab.js +3 -5
  79. package/tabs-nav/types.d.ts +1 -1
  80. package/tag/Tag.js +1 -1
  81. package/tag/types.d.ts +1 -1
  82. package/text-input/Icons.d.ts +8 -0
  83. package/text-input/Icons.js +60 -0
  84. package/text-input/Suggestion.js +7 -5
  85. package/text-input/Suggestions.d.ts +4 -0
  86. package/text-input/Suggestions.js +134 -0
  87. package/text-input/TextInput.js +115 -222
  88. package/text-input/TextInput.stories.tsx +189 -182
  89. package/text-input/TextInput.test.js +163 -162
  90. package/text-input/types.d.ts +17 -3
  91. package/toggle-group/types.d.ts +1 -1
  92. package/wizard/types.d.ts +1 -1
@@ -1,11 +1,16 @@
1
1
  import React from "react";
2
- import { userEvent, within, waitFor } from "@storybook/testing-library";
3
- import { fireEvent } from "@testing-library/react";
2
+ import { userEvent, within } from "@storybook/testing-library";
4
3
  import { BackgroundColorProvider } from "../BackgroundColorContext";
5
4
  import Title from "../../.storybook/components/Title";
6
5
  import ExampleContainer from "../../.storybook/components/ExampleContainer";
7
6
  import DarkContainer from "../../.storybook/components/DarkSection";
8
7
  import DxcTextInput from "./TextInput";
8
+ import DxcButton from "../button/Button";
9
+ import DxcCheckbox from "../checkbox/Checkbox";
10
+ import DxcFlex from "../flex/Flex";
11
+ import Suggestions from "./Suggestions";
12
+ import { ThemeProvider } from "styled-components";
13
+ import useTheme from "../useTheme";
9
14
 
10
15
  export default {
11
16
  title: "Text input",
@@ -72,6 +77,14 @@ export const Chromatic = () => (
72
77
  <Title title="Hovered action" theme="light" level={4} />
73
78
  <DxcTextInput label="Text input" defaultValue="Text" clearable />
74
79
  </ExampleContainer>
80
+ <ExampleContainer pseudoState="pseudo-active">
81
+ <Title title="Actived action" theme="light" level={4} />
82
+ <DxcTextInput label="Text input" action={action} clearable />
83
+ </ExampleContainer>
84
+ <ExampleContainer pseudoState="pseudo-focus">
85
+ <Title title="Focused action" theme="light" level={4} />
86
+ <DxcTextInput label="Text input" action={action} clearable />
87
+ </ExampleContainer>
75
88
  <ExampleContainer>
76
89
  <Title title="Without label" theme="light" level={4} />
77
90
  <DxcTextInput />
@@ -152,7 +165,7 @@ export const Chromatic = () => (
152
165
  </ExampleContainer>
153
166
  <BackgroundColorProvider color="#333333">
154
167
  <DarkContainer>
155
- <Title title="Dark" theme="dark" level={2} />
168
+ <Title title="Dark theme" theme="dark" level={2} />
156
169
  <ExampleContainer pseudoState="pseudo-hover">
157
170
  <Title title="Hovered" theme="dark" level={4} />
158
171
  <DxcTextInput label="Text input" />
@@ -165,6 +178,14 @@ export const Chromatic = () => (
165
178
  <Title title="Hovered action" theme="dark" level={4} />
166
179
  <DxcTextInput label="Text input" defaultValue="Text" clearable />
167
180
  </ExampleContainer>
181
+ <ExampleContainer pseudoState="pseudo-active">
182
+ <Title title="Actived action" theme="dark" level={4} />
183
+ <DxcTextInput label="Text input" action={action} clearable />
184
+ </ExampleContainer>
185
+ <ExampleContainer pseudoState="pseudo-focus">
186
+ <Title title="Focused action" theme="dark" level={4} />
187
+ <DxcTextInput label="Text input" action={action} clearable />
188
+ </ExampleContainer>
168
189
  <ExampleContainer>
169
190
  <Title title="Helper text, placeholder, optional and action" theme="dark" level={4} />
170
191
  <DxcTextInput
@@ -279,196 +300,182 @@ export const Chromatic = () => (
279
300
  </>
280
301
  );
281
302
 
282
- const FocusedActionTextInput = () => (
283
- <ExampleContainer expanded>
284
- <Title title="Focused action" theme="light" level={4} />
285
- <DxcTextInput label="Text input" action={action} clearable />
286
- </ExampleContainer>
287
- );
288
-
289
- const ActivedActionTextInput = () => (
290
- <ExampleContainer pseudoState="pseudo-active" expanded>
291
- <Title title="Actived action" theme="light" level={4} />
292
- <DxcTextInput label="Text input" action={action} clearable />
293
- </ExampleContainer>
294
- );
295
-
296
- const ShowOptionsAutosuggest = () => (
297
- <ExampleContainer expanded>
298
- <Title title="Show options" theme="light" level={4} />
299
- <DxcTextInput label="Text input" suggestions={countries} clearable />
300
- </ExampleContainer>
301
- );
302
-
303
- const HoveredOptionAutosuggest = () => (
304
- <ExampleContainer expanded pseudoState="pseudo-hover">
305
- <Title title="Hovered option" theme="light" level={4} />
306
- <DxcTextInput label="Text input" suggestions={country} clearable />
307
- </ExampleContainer>
308
- );
309
-
310
- const FocusedOptionAutosuggest = () => (
311
- <ExampleContainer expanded>
312
- <Title title="Focused option" theme="light" level={4} />
313
- <DxcTextInput label="Text input" suggestions={country} clearable />
314
- </ExampleContainer>
315
- );
316
-
317
- const ActivedOptionAutosuggest = () => (
318
- <ExampleContainer expanded pseudoState="pseudo-active">
319
- <Title title="Actived option" theme="light" level={4} />
320
- <DxcTextInput label="Text input" suggestions={country} clearable />
321
- </ExampleContainer>
322
- );
323
-
324
- const FocusedActionTextInputOnDark = () => (
325
- <BackgroundColorProvider color="#333333">
326
- <DarkContainer>
327
- <ExampleContainer expanded>
328
- <Title title="Focused action" theme="dark" level={4} />
329
- <DxcTextInput label="Text input" action={action} clearable />
330
- </ExampleContainer>
331
- </DarkContainer>
332
- </BackgroundColorProvider>
333
- );
334
-
335
- const ActivedActionTextInputOnDark = () => (
336
- <BackgroundColorProvider color="#333333">
337
- <DarkContainer>
338
- <ExampleContainer pseudoState="pseudo-active" expanded>
339
- <Title title="Actived action" theme="dark" level={4} />
340
- <DxcTextInput label="Text input" action={action} clearable />
341
- </ExampleContainer>
342
- </DarkContainer>
343
- </BackgroundColorProvider>
344
- );
303
+ const AutosuggestListbox = () => {
304
+ const colorsTheme: any = useTheme();
345
305
 
346
- const ShowOptionsAutosuggestOnDark = () => (
347
- <BackgroundColorProvider color="#333333">
348
- <DarkContainer>
349
- <ExampleContainer expanded>
350
- <Title title="Show options" theme="dark" level={4} />
351
- <DxcTextInput label="Text input" suggestions={countries} clearable />
352
- </ExampleContainer>
353
- </DarkContainer>
354
- </BackgroundColorProvider>
355
- );
356
-
357
- const HoveredActionAutosuggestOnDark = () => (
358
- <BackgroundColorProvider color="#333333">
359
- <DarkContainer>
360
- <ExampleContainer expanded pseudoState="pseudo-hover">
361
- <Title title="Hovered option" theme="dark" level={4} />
362
- <DxcTextInput label="Text input" suggestions={country} clearable />
306
+ return (
307
+ <ThemeProvider theme={colorsTheme.textInput}>
308
+ <ExampleContainer>
309
+ <Title title="Autosuggest listbox" theme="light" level={2} />
310
+ <ExampleContainer>
311
+ <Title title="List dialog uses a Radix Popover to appear over elements with a certain z-index" theme="light" level={3} />
312
+ <div
313
+ style={{
314
+ display: "flex",
315
+ flexDirection: "column",
316
+ gap: "20px",
317
+ height: "150px",
318
+ width: "500px",
319
+ marginBottom: "250px",
320
+ padding: "20px",
321
+ border: "1px solid black",
322
+ borderRadius: "4px",
323
+ overflow: "auto",
324
+ zIndex: "1300",
325
+ }}
326
+ >
327
+ <DxcTextInput
328
+ label="Label"
329
+ suggestions={countries}
330
+ optional
331
+ placeholder="Choose an option"
332
+ size="fillParent"
333
+ />
334
+ <button style={{ zIndex: "1", width: "100px" }}>Submit</button>
335
+ </div>
336
+ </ExampleContainer>
337
+ <Title title="Listbox suggestion states" theme="light" level={3} />
338
+ <ExampleContainer pseudoState="pseudo-hover">
339
+ <Title title="Hovered suggestion" theme="light" level={4} />
340
+ <Suggestions
341
+ id="x"
342
+ value=""
343
+ suggestions={country}
344
+ visualFocusIndex={-1}
345
+ highlightedSuggestions={false}
346
+ searchHasErrors={false}
347
+ isSearching={false}
348
+ suggestionOnClick={() => {}}
349
+ getTextInputWidth={() => 350}
350
+ />
351
+ </ExampleContainer>
352
+ <ExampleContainer pseudoState="pseudo-active">
353
+ <Title title="Active suggestion" theme="light" level={4} />
354
+ <Suggestions
355
+ id="x"
356
+ value=""
357
+ suggestions={country}
358
+ visualFocusIndex={-1}
359
+ highlightedSuggestions={false}
360
+ searchHasErrors={false}
361
+ isSearching={false}
362
+ suggestionOnClick={(suggestion) => {}}
363
+ getTextInputWidth={() => 350}
364
+ />
365
+ </ExampleContainer>
366
+ <ExampleContainer>
367
+ <Title title="Focused suggestion" theme="light" level={4} />
368
+ <Suggestions
369
+ id="x"
370
+ value=""
371
+ suggestions={country}
372
+ visualFocusIndex={0}
373
+ highlightedSuggestions={false}
374
+ searchHasErrors={false}
375
+ isSearching={false}
376
+ suggestionOnClick={(suggestion) => {}}
377
+ getTextInputWidth={() => 350}
378
+ />
379
+ </ExampleContainer>
380
+ <ExampleContainer>
381
+ <Title title="Highlighted suggestion" theme="light" level={4} />
382
+ <Suggestions
383
+ id="x"
384
+ value="Afgh"
385
+ suggestions={country}
386
+ visualFocusIndex={-1}
387
+ highlightedSuggestions={true}
388
+ searchHasErrors={false}
389
+ isSearching={false}
390
+ suggestionOnClick={(suggestion) => {}}
391
+ getTextInputWidth={() => 350}
392
+ />
393
+ </ExampleContainer>
363
394
  </ExampleContainer>
364
- </DarkContainer>
365
- </BackgroundColorProvider>
366
- );
367
-
368
- const FocusedOptionAutosuggestOnDark = () => (
369
- <BackgroundColorProvider color="#333333">
370
- <DarkContainer>
371
- <ExampleContainer expanded>
372
- <Title title="Focused option" theme="dark" level={4} />
373
- <DxcTextInput label="Text input" suggestions={country} clearable />
395
+ <ExampleContainer>
396
+ <Title title="Autosuggest Error" theme="light" level={3} />
397
+ <Suggestions
398
+ id="x"
399
+ value=""
400
+ suggestions={country}
401
+ visualFocusIndex={-1}
402
+ highlightedSuggestions={false}
403
+ searchHasErrors={true}
404
+ isSearching={false}
405
+ suggestionOnClick={(suggestion) => {}}
406
+ getTextInputWidth={() => 350}
407
+ />
374
408
  </ExampleContainer>
375
- </DarkContainer>
376
- </BackgroundColorProvider>
377
- );
378
-
379
- const ActivedOptionAutosuggestOnDark = () => (
380
- <BackgroundColorProvider color="#333333">
381
- <DarkContainer>
382
- <ExampleContainer expanded pseudoState="pseudo-active">
383
- <Title title="Actived option" theme="dark" level={4} />
384
- <DxcTextInput label="Text input" suggestions={country} clearable />
409
+ <ExampleContainer>
410
+ <Title title="Autosuggest Searching message" theme="light" level={3} />
411
+ <Suggestions
412
+ id="x"
413
+ value=""
414
+ suggestions={country}
415
+ visualFocusIndex={-1}
416
+ highlightedSuggestions={false}
417
+ searchHasErrors={false}
418
+ isSearching={true}
419
+ suggestionOnClick={(suggestion) => {}}
420
+ getTextInputWidth={() => 350}
421
+ />
385
422
  </ExampleContainer>
386
- </DarkContainer>
387
- </BackgroundColorProvider>
388
- );
389
-
390
- export const FocusedAction = FocusedActionTextInput.bind({});
391
- FocusedAction.play = async ({ canvasElement }) => {
392
- const canvas = within(canvasElement);
393
- const action = canvas.getByRole("button");
394
- await action.focus();
395
- };
396
-
397
- export const ActivedAction = ActivedActionTextInput.bind({});
398
- ActivedAction.play = async ({ canvasElement }) => {
399
- const canvas = within(canvasElement);
400
- const action = canvas.getByRole("button");
401
- await userEvent.click(action);
402
- };
403
-
404
- export const ShowOptions = ShowOptionsAutosuggest.bind({});
405
- ShowOptions.play = async ({ canvasElement }) => {
406
- const canvas = within(canvasElement);
407
- const autosuggest = canvas.getByRole("combobox");
408
- await userEvent.click(autosuggest);
409
- };
410
-
411
- export const HoveredOption = HoveredOptionAutosuggest.bind({});
412
- HoveredOption.play = async ({ canvasElement }) => {
413
- const canvas = within(canvasElement);
414
- const autosuggest = canvas.getByRole("combobox");
415
- await userEvent.click(autosuggest);
423
+ </ThemeProvider>
424
+ );
416
425
  };
417
426
 
418
- export const FocusedOption = FocusedOptionAutosuggest.bind({});
419
- FocusedOption.play = async ({ canvasElement }) => {
420
- const canvas = within(canvasElement);
421
- const autosuggest = canvas.getByRole("combobox");
422
- await userEvent.click(autosuggest);
423
- fireEvent.keyDown(autosuggest, { key: "ArrowDown", code: "ArrowDown", keyCode: 40, charCode: 40 });
424
- };
427
+ const DarkAutosuggestListbox = () => {
428
+ const colorsTheme: any = useTheme();
425
429
 
426
- export const ActivedOption = ActivedOptionAutosuggest.bind({});
427
- ActivedOption.play = async ({ canvasElement }) => {
428
- const canvas = within(canvasElement);
429
- const autosuggest = canvas.getByRole("combobox");
430
- await userEvent.click(autosuggest);
431
- };
432
-
433
- export const FocusedActionOnDark = FocusedActionTextInputOnDark.bind({});
434
- FocusedActionOnDark.play = async ({ canvasElement }) => {
435
- const canvas = within(canvasElement);
436
- const action = canvas.getByRole("button");
437
- await action.focus();
438
- };
439
-
440
- export const ActivedActionOnDark = ActivedActionTextInputOnDark.bind({});
441
- ActivedActionOnDark.play = async ({ canvasElement }) => {
442
- const canvas = within(canvasElement);
443
- const action = canvas.getByRole("button");
444
- await userEvent.click(action);
445
- };
446
-
447
- export const ShowOptionsOnDark = ShowOptionsAutosuggestOnDark.bind({});
448
- ShowOptionsOnDark.play = async ({ canvasElement }) => {
449
- const canvas = within(canvasElement);
450
- const autosuggest = canvas.getByRole("combobox");
451
- await userEvent.click(autosuggest);
452
- };
453
-
454
- export const HoveredActionOnDark = HoveredActionAutosuggestOnDark.bind({});
455
- HoveredActionOnDark.play = async ({ canvasElement }) => {
456
- const canvas = within(canvasElement);
457
- const autosuggest = canvas.getByRole("combobox");
458
- await userEvent.click(autosuggest);
430
+ return (
431
+ <ThemeProvider theme={colorsTheme.textInput}>
432
+ <BackgroundColorProvider color="#333333">
433
+ <DarkContainer>
434
+ <Title title="Dark theme" theme="dark" level={2} />
435
+ <ExampleContainer>
436
+ <Title title="Default with opened suggestions" theme="dark" level={3} />
437
+ <DxcFlex direction="column" gap="80px">
438
+ <DxcTextInput label="Label" suggestions={countries} optional placeholder="Choose an option" />
439
+ <DxcCheckbox
440
+ label="You understand the selection and give your consent"
441
+ onChange={() => {}}
442
+ labelPosition="after"
443
+ />
444
+ <DxcButton label="Submit" onClick={() => {}} size="medium" margin={{ bottom: "xxlarge" }} />
445
+ </DxcFlex>
446
+ </ExampleContainer>
447
+ <ExampleContainer>
448
+ <Title title="Autosuggest Error" theme="dark" level={3} />
449
+ <div style={{ height: "100px" }}>
450
+ <Suggestions
451
+ id="x"
452
+ value=""
453
+ suggestions={country}
454
+ visualFocusIndex={-1}
455
+ highlightedSuggestions={false}
456
+ searchHasErrors={true}
457
+ isSearching={false}
458
+ suggestionOnClick={(suggestion) => {}}
459
+ getTextInputWidth={() => 350}
460
+ />
461
+ </div>
462
+ </ExampleContainer>
463
+ </DarkContainer>
464
+ </BackgroundColorProvider>
465
+ </ThemeProvider>
466
+ );
459
467
  };
460
468
 
461
- export const FocusedOptionOnDark = FocusedOptionAutosuggestOnDark.bind({});
462
- FocusedOptionOnDark.play = async ({ canvasElement }) => {
469
+ export const AutosuggestListboxStates = AutosuggestListbox.bind({});
470
+ AutosuggestListboxStates.play = async ({ canvasElement }) => {
463
471
  const canvas = within(canvasElement);
464
- const autosuggest = canvas.getByRole("combobox");
465
- await userEvent.click(autosuggest);
466
- fireEvent.keyDown(autosuggest, { key: "ArrowDown", code: "ArrowDown", keyCode: 40, charCode: 40 });
472
+ const select = canvas.getByRole("combobox");
473
+ await userEvent.click(select);
467
474
  };
468
475
 
469
- export const ActivedOptionOnDark = ActivedOptionAutosuggestOnDark.bind({});
470
- ActivedOptionOnDark.play = async ({ canvasElement }) => {
476
+ export const AutosuggestListboxOnDark = DarkAutosuggestListbox.bind({});
477
+ AutosuggestListboxOnDark.play = async ({ canvasElement }) => {
471
478
  const canvas = within(canvasElement);
472
- const autosuggest = canvas.getByRole("combobox");
473
- await userEvent.click(autosuggest);
479
+ const select = canvas.getByRole("combobox");
480
+ await userEvent.click(select);
474
481
  };