@arbor-education/design-system.components 0.1.2 → 0.1.3

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 (148) hide show
  1. package/.changeset/neat-experts-repair.md +2 -0
  2. package/.changeset/slick-places-grin.md +5 -0
  3. package/.changeset/sunny-cars-sell.md +2 -0
  4. package/.changeset/tough-facts-check.md +5 -0
  5. package/.changeset/true-rats-add.md +5 -0
  6. package/.github/workflows/chromatic.yml +2 -1
  7. package/.github/workflows/release.yml +124 -0
  8. package/CHANGELOG.md +0 -1
  9. package/bin/createComponent.sh +39 -9
  10. package/dist/components/dropdown/Dropdown.d.ts +1 -0
  11. package/dist/components/dropdown/Dropdown.d.ts.map +1 -1
  12. package/dist/components/dropdown/DropdownContent.d.ts +1 -0
  13. package/dist/components/dropdown/DropdownContent.d.ts.map +1 -1
  14. package/dist/components/dropdown/DropdownContent.js +3 -2
  15. package/dist/components/dropdown/DropdownContent.js.map +1 -1
  16. package/dist/components/formField/FormField.d.ts +8 -0
  17. package/dist/components/formField/FormField.d.ts.map +1 -1
  18. package/dist/components/formField/FormField.js +3 -1
  19. package/dist/components/formField/FormField.js.map +1 -1
  20. package/dist/components/formField/FormField.stories.d.ts.map +1 -1
  21. package/dist/components/formField/FormField.stories.js +5 -0
  22. package/dist/components/formField/FormField.stories.js.map +1 -1
  23. package/dist/components/formField/FormField.test.js +11 -1
  24. package/dist/components/formField/FormField.test.js.map +1 -1
  25. package/dist/components/formField/inputs/colourPickerDropdown/ColourPickerDropdown.d.ts +12 -0
  26. package/dist/components/formField/inputs/colourPickerDropdown/ColourPickerDropdown.d.ts.map +1 -0
  27. package/dist/components/formField/inputs/colourPickerDropdown/ColourPickerDropdown.js +17 -0
  28. package/dist/components/formField/inputs/colourPickerDropdown/ColourPickerDropdown.js.map +1 -0
  29. package/dist/components/formField/inputs/colourPickerDropdown/ColourPickerDropdown.stories.d.ts +10 -0
  30. package/dist/components/formField/inputs/colourPickerDropdown/ColourPickerDropdown.stories.d.ts.map +1 -0
  31. package/dist/components/formField/inputs/colourPickerDropdown/ColourPickerDropdown.stories.js +24 -0
  32. package/dist/components/formField/inputs/colourPickerDropdown/ColourPickerDropdown.stories.js.map +1 -0
  33. package/dist/components/formField/inputs/colourPickerDropdown/ColourPickerDropdown.test.d.ts +2 -0
  34. package/dist/components/formField/inputs/colourPickerDropdown/ColourPickerDropdown.test.d.ts.map +1 -0
  35. package/dist/components/formField/inputs/colourPickerDropdown/ColourPickerDropdown.test.js +88 -0
  36. package/dist/components/formField/inputs/colourPickerDropdown/ColourPickerDropdown.test.js.map +1 -0
  37. package/dist/components/formField/inputs/dropdown/Dropdown.d.ts +11 -0
  38. package/dist/components/formField/inputs/dropdown/Dropdown.d.ts.map +1 -0
  39. package/dist/components/formField/inputs/dropdown/Dropdown.js +43 -0
  40. package/dist/components/formField/inputs/dropdown/Dropdown.js.map +1 -0
  41. package/dist/components/formField/inputs/dropdown/Dropdown.stories.d.ts +161 -0
  42. package/dist/components/formField/inputs/dropdown/Dropdown.stories.d.ts.map +1 -0
  43. package/dist/components/formField/inputs/dropdown/Dropdown.stories.js +172 -0
  44. package/dist/components/formField/inputs/dropdown/Dropdown.stories.js.map +1 -0
  45. package/dist/components/formField/inputs/dropdown/Dropdown.test.d.ts +2 -0
  46. package/dist/components/formField/inputs/dropdown/Dropdown.test.d.ts.map +1 -0
  47. package/dist/components/formField/inputs/dropdown/Dropdown.test.js +93 -0
  48. package/dist/components/formField/inputs/dropdown/Dropdown.test.js.map +1 -0
  49. package/dist/components/formField/inputs/dropdown/buttons/dropdownButton/DropdownButton.d.ts +11 -0
  50. package/dist/components/formField/inputs/dropdown/buttons/dropdownButton/DropdownButton.d.ts.map +1 -0
  51. package/dist/components/formField/inputs/dropdown/buttons/dropdownButton/DropdownButton.js +15 -0
  52. package/dist/components/formField/inputs/dropdown/buttons/dropdownButton/DropdownButton.js.map +1 -0
  53. package/dist/components/formField/inputs/dropdown/items/DropdownItemRenderer.d.ts +10 -0
  54. package/dist/components/formField/inputs/dropdown/items/DropdownItemRenderer.d.ts.map +1 -0
  55. package/dist/components/formField/inputs/dropdown/items/DropdownItemRenderer.js +12 -0
  56. package/dist/components/formField/inputs/dropdown/items/DropdownItemRenderer.js.map +1 -0
  57. package/dist/components/formField/inputs/dropdown/items/dropdownItem/DropdownItem.d.ts +9 -0
  58. package/dist/components/formField/inputs/dropdown/items/dropdownItem/DropdownItem.d.ts.map +1 -0
  59. package/dist/components/formField/inputs/dropdown/items/dropdownItem/DropdownItem.js +17 -0
  60. package/dist/components/formField/inputs/dropdown/items/dropdownItem/DropdownItem.js.map +1 -0
  61. package/dist/components/formField/inputs/dropdown/items/dropdownMultiLineItem/DropdownMultiLineItem.d.ts +7 -0
  62. package/dist/components/formField/inputs/dropdown/items/dropdownMultiLineItem/DropdownMultiLineItem.d.ts.map +1 -0
  63. package/dist/components/formField/inputs/dropdown/items/dropdownMultiLineItem/DropdownMultiLineItem.js +16 -0
  64. package/dist/components/formField/inputs/dropdown/items/dropdownMultiLineItem/DropdownMultiLineItem.js.map +1 -0
  65. package/dist/components/formField/inputs/dropdown/wrapper/DropdownWrapper.d.ts +16 -0
  66. package/dist/components/formField/inputs/dropdown/wrapper/DropdownWrapper.d.ts.map +1 -0
  67. package/dist/components/formField/inputs/dropdown/wrapper/DropdownWrapper.js +73 -0
  68. package/dist/components/formField/inputs/dropdown/wrapper/DropdownWrapper.js.map +1 -0
  69. package/dist/components/formField/inputs/selectDropdown/SelectDropdown.d.ts +10 -6
  70. package/dist/components/formField/inputs/selectDropdown/SelectDropdown.d.ts.map +1 -1
  71. package/dist/components/formField/inputs/selectDropdown/SelectDropdown.js +10 -6
  72. package/dist/components/formField/inputs/selectDropdown/SelectDropdown.js.map +1 -1
  73. package/dist/components/formField/inputs/selectDropdown/SelectDropdown.test.js +1 -1
  74. package/dist/components/formField/inputs/selectDropdown/SelectDropdown.test.js.map +1 -1
  75. package/dist/components/heading/HeadingInnerContainer.d.ts +5 -0
  76. package/dist/components/heading/HeadingInnerContainer.d.ts.map +1 -0
  77. package/dist/components/heading/HeadingInnerContainer.js +7 -0
  78. package/dist/components/heading/HeadingInnerContainer.js.map +1 -0
  79. package/dist/components/icon/Icon.d.ts +0 -1
  80. package/dist/components/icon/Icon.d.ts.map +1 -1
  81. package/dist/components/icon/Icon.js +1 -1
  82. package/dist/components/icon/Icon.js.map +1 -1
  83. package/dist/components/searchBar/SearchBar.d.ts +8 -0
  84. package/dist/components/searchBar/SearchBar.d.ts.map +1 -0
  85. package/dist/components/searchBar/SearchBar.js +38 -0
  86. package/dist/components/searchBar/SearchBar.js.map +1 -0
  87. package/dist/components/searchBar/SearchBar.test.d.ts +2 -0
  88. package/dist/components/searchBar/SearchBar.test.d.ts.map +1 -0
  89. package/dist/components/searchBar/SearchBar.test.js +36 -0
  90. package/dist/components/searchBar/SearchBar.test.js.map +1 -0
  91. package/dist/components/slideover/Slideover.d.ts +1 -0
  92. package/dist/components/slideover/Slideover.d.ts.map +1 -1
  93. package/dist/components/slideover/Slideover.js +2 -2
  94. package/dist/components/slideover/Slideover.js.map +1 -1
  95. package/dist/components/table/HideColumnsDropdown.d.ts +9 -0
  96. package/dist/components/table/HideColumnsDropdown.d.ts.map +1 -0
  97. package/dist/components/table/HideColumnsDropdown.js +33 -0
  98. package/dist/components/table/HideColumnsDropdown.js.map +1 -0
  99. package/dist/components/table/Table.d.ts +14 -0
  100. package/dist/components/table/Table.d.ts.map +1 -1
  101. package/dist/components/table/Table.js +8 -3
  102. package/dist/components/table/Table.js.map +1 -1
  103. package/dist/components/table/Table.stories.d.ts +3 -0
  104. package/dist/components/table/Table.stories.d.ts.map +1 -1
  105. package/dist/components/table/Table.stories.js +53 -1
  106. package/dist/components/table/Table.stories.js.map +1 -1
  107. package/dist/components/table/Table.test.js +132 -0
  108. package/dist/components/table/Table.test.js.map +1 -1
  109. package/dist/components/table/TableHeader.d.ts +3 -0
  110. package/dist/components/table/TableHeader.d.ts.map +1 -1
  111. package/dist/components/table/TableHeader.js +4 -3
  112. package/dist/components/table/TableHeader.js.map +1 -1
  113. package/dist/index.css +93 -1
  114. package/dist/index.css.map +1 -1
  115. package/dist/index.d.ts +1 -0
  116. package/dist/index.d.ts.map +1 -1
  117. package/dist/index.js +1 -0
  118. package/dist/index.js.map +1 -1
  119. package/dist/tailwind.css +229 -0
  120. package/package.json +2 -1
  121. package/src/components/dropdown/DropdownContent.tsx +4 -2
  122. package/src/components/formField/FormField.stories.tsx +17 -0
  123. package/src/components/formField/FormField.test.tsx +13 -1
  124. package/src/components/formField/FormField.tsx +10 -0
  125. package/src/components/formField/inputs/colourPickerDropdown/ColourPickerDropdown.stories.tsx +29 -0
  126. package/src/components/formField/inputs/colourPickerDropdown/ColourPickerDropdown.test.tsx +121 -0
  127. package/src/components/formField/inputs/colourPickerDropdown/ColourPickerDropdown.tsx +53 -0
  128. package/src/components/formField/inputs/colourPickerDropdown/colourPickerDropdown.scss +12 -0
  129. package/src/components/formField/inputs/selectDropdown/SelectDropdown.test.tsx +1 -1
  130. package/src/components/formField/inputs/selectDropdown/SelectDropdown.tsx +55 -41
  131. package/src/components/heading/heading.scss +1 -0
  132. package/src/components/icon/Icon.tsx +1 -2
  133. package/src/components/searchBar/SearchBar.test.tsx +40 -0
  134. package/src/components/searchBar/SearchBar.tsx +97 -0
  135. package/src/components/searchBar/searchBar.scss +69 -0
  136. package/src/components/slideover/Slideover.tsx +10 -5
  137. package/src/components/table/HideColumnsDropdown.tsx +57 -0
  138. package/src/components/table/Table.stories.tsx +96 -2
  139. package/src/components/table/Table.test.tsx +240 -0
  140. package/src/components/table/Table.tsx +10 -1
  141. package/src/components/table/TableHeader.tsx +8 -0
  142. package/src/components/table/table.scss +22 -0
  143. package/src/index.scss +24 -22
  144. package/src/index.ts +1 -0
  145. package/.github/workflows/changeset-version.yml +0 -39
  146. package/.github/workflows/merge-version-packages-pr.yml +0 -31
  147. package/.github/workflows/production-build.yml +0 -130
  148. package/release/design-system.components.tgz +0 -0
@@ -0,0 +1,88 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { describe, expect, test, vi } from 'vitest';
3
+ import { render, screen } from '@testing-library/react';
4
+ import userEvent from '@testing-library/user-event';
5
+ import '@testing-library/jest-dom/vitest';
6
+ import { ColourPickerDropdown } from './ColourPickerDropdown';
7
+ // Mock the Sketch component from @uiw/react-color
8
+ vi.mock('@uiw/react-color', () => ({
9
+ Sketch: ({ onChange, color }) => {
10
+ return (_jsx("div", { "data-testid": "sketch-color-picker", "data-color": color, children: _jsx("button", { "data-testid": "color-change-button", onClick: () => {
11
+ onChange({ hex: '#ff0000' });
12
+ }, children: "Change Color" }) }));
13
+ },
14
+ }));
15
+ describe('ColourPickerDropdown component', () => {
16
+ test('renders the component', () => {
17
+ const onChange = vi.fn();
18
+ render(_jsx(ColourPickerDropdown, { onChange: onChange }));
19
+ expect(screen.getByText('Toggle colour picker.')).toBeInTheDocument();
20
+ });
21
+ test('respects the disabled prop', () => {
22
+ const onChange = vi.fn();
23
+ render(_jsx(ColourPickerDropdown, { onChange: onChange, disabled: true }));
24
+ expect(screen.getByRole('button')).toBeDisabled();
25
+ });
26
+ test('uses default value when no value prop is provided', () => {
27
+ const onChange = vi.fn();
28
+ render(_jsx(ColourPickerDropdown, { onChange: onChange }));
29
+ const defaultValue = '#3cad51';
30
+ const preview = screen.getByRole('button').querySelector('.ds-colour-picker-dropdown__preview');
31
+ expect(preview).toHaveStyle({ backgroundColor: defaultValue });
32
+ expect(screen.getByText(`current colour: ${defaultValue}`)).toBeInTheDocument();
33
+ });
34
+ test('uses provided value prop', () => {
35
+ const onChange = vi.fn();
36
+ const passedValue = '#ff0000';
37
+ render(_jsx(ColourPickerDropdown, { value: passedValue, onChange: onChange }));
38
+ const preview = screen.getByRole('button').querySelector('.ds-colour-picker-dropdown__preview');
39
+ expect(preview).toHaveStyle({ backgroundColor: passedValue });
40
+ expect(screen.getByText(`current colour: ${passedValue}`)).toBeInTheDocument();
41
+ });
42
+ test('updates preview color when value prop changes', () => {
43
+ const onChange = vi.fn();
44
+ const firstValue = '#ff0000';
45
+ const secondValue = '#0000ff';
46
+ const { rerender } = render(_jsx(ColourPickerDropdown, { value: firstValue, onChange: onChange }));
47
+ let preview = screen.getByRole('button').querySelector('.ds-colour-picker-dropdown__preview');
48
+ expect(preview).toHaveStyle({ backgroundColor: firstValue });
49
+ expect(screen.getByText(`current colour: ${firstValue}`)).toBeInTheDocument();
50
+ rerender(_jsx(ColourPickerDropdown, { value: secondValue, onChange: onChange }));
51
+ preview = screen.getByRole('button').querySelector('.ds-colour-picker-dropdown__preview');
52
+ expect(preview).toHaveStyle({ backgroundColor: secondValue });
53
+ expect(screen.getByText(`current colour: ${secondValue}`)).toBeInTheDocument();
54
+ });
55
+ test('calls onChange when color is changed', async () => {
56
+ const onChange = vi.fn();
57
+ render(_jsx(ColourPickerDropdown, { onChange: onChange }));
58
+ const trigger = screen.getByRole('button');
59
+ await userEvent.click(trigger);
60
+ const colorPicker = await screen.findByTestId('sketch-color-picker');
61
+ expect(colorPicker).toBeInTheDocument();
62
+ const changeButton = screen.getByTestId('color-change-button');
63
+ await userEvent.click(changeButton);
64
+ expect(onChange).toHaveBeenCalledWith(expect.objectContaining({ hex: '#ff0000' }));
65
+ });
66
+ test('updates preview color when color is changed', async () => {
67
+ const onChange = vi.fn();
68
+ render(_jsx(ColourPickerDropdown, { onChange: onChange }));
69
+ const trigger = screen.getByRole('button');
70
+ await userEvent.click(trigger);
71
+ await screen.findByTestId('sketch-color-picker');
72
+ const changeButton = screen.getByTestId('color-change-button');
73
+ await userEvent.click(changeButton);
74
+ const currentColour = screen.getByText('current colour: #ff0000');
75
+ expect(currentColour).toBeInTheDocument();
76
+ expect(currentColour.parentElement).toHaveStyle({ backgroundColor: '#ff0000' });
77
+ });
78
+ test('renders color picker with correct initial color', async () => {
79
+ const onChange = vi.fn();
80
+ render(_jsx(ColourPickerDropdown, { value: "#00ff00", onChange: onChange }));
81
+ expect(screen.getByText('current colour: #00ff00')).toBeInTheDocument();
82
+ const trigger = screen.getByRole('button');
83
+ await userEvent.click(trigger);
84
+ const colorPicker = await screen.findByTestId('sketch-color-picker');
85
+ expect(colorPicker).toHaveAttribute('data-color', '#00ff00');
86
+ });
87
+ });
88
+ //# sourceMappingURL=ColourPickerDropdown.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ColourPickerDropdown.test.js","sourceRoot":"","sources":["../../../../../src/components/formField/inputs/colourPickerDropdown/ColourPickerDropdown.test.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,11 @@
1
+ import { type DropdownOptionsProps } from '../../../formField/inputs/dropdown/items/DropdownItemRenderer';
2
+ export type DropdownInputProps = {
3
+ placeholder?: string;
4
+ options: DropdownOptionsProps[];
5
+ multiple?: boolean;
6
+ disabled?: boolean;
7
+ errorText?: string;
8
+ onSelectionChange: (value: string[]) => void;
9
+ };
10
+ export declare const Dropdown: (props: DropdownInputProps) => import("react/jsx-runtime").JSX.Element;
11
+ //# sourceMappingURL=Dropdown.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Dropdown.d.ts","sourceRoot":"","sources":["../../../../../src/components/formField/inputs/dropdown/Dropdown.tsx"],"names":[],"mappings":"AAEA,OAAO,EAEL,KAAK,oBAAoB,EAC1B,MAAM,iEAAiE,CAAC;AAEzE,MAAM,MAAM,kBAAkB,GAAG;IAC/B,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,OAAO,EAAE,oBAAoB,EAAE,CAAC;IAChC,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,iBAAiB,EAAE,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,IAAI,CAAC;CAC9C,CAAC;AAEF,eAAO,MAAM,QAAQ,GAAI,OAAO,kBAAkB,4CAiEjD,CAAC"}
@@ -0,0 +1,43 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { useEffect, useState } from 'react';
3
+ import { DropdownWrapper } from '../../../formField/inputs/dropdown/wrapper/DropdownWrapper';
4
+ import { DropdownItemRenderer, } from '../../../formField/inputs/dropdown/items/DropdownItemRenderer';
5
+ export const Dropdown = (props) => {
6
+ const { options, disabled, multiple, placeholder, errorText, onSelectionChange } = props;
7
+ const [selectedValues, setSelectedValues] = useState([]);
8
+ const [renderedSelectContent, setRenderedSelectContent] = useState('');
9
+ useEffect(() => {
10
+ onSelectionChange(selectedValues);
11
+ if (selectedValues.length === 0) {
12
+ setRenderedSelectContent(placeholder ?? 'Select');
13
+ }
14
+ else if (selectedValues.length === 1) {
15
+ const selectedLabel = options.find(option => option.value === selectedValues[0])?.label;
16
+ if (selectedLabel)
17
+ setRenderedSelectContent(selectedLabel);
18
+ }
19
+ else {
20
+ setRenderedSelectContent(placeholder ?? `Select (${selectedValues.length})`);
21
+ }
22
+ }, [selectedValues, options, placeholder, onSelectionChange]);
23
+ // Flatten grouped options into a single array with headers
24
+ const UNGROUPED_KEY = 'Ungrouped';
25
+ const groupedOptions = options.reduce((acc, option) => {
26
+ const key = option.group ?? UNGROUPED_KEY;
27
+ if (!acc[key])
28
+ acc[key] = [];
29
+ acc[key].push(option);
30
+ return acc;
31
+ }, {});
32
+ const flatOptions = [];
33
+ Object.entries(groupedOptions).forEach(([groupName, groupItems]) => {
34
+ if (Object.keys(groupedOptions).length > 1) {
35
+ flatOptions.push({ headerLabel: groupName });
36
+ }
37
+ flatOptions.push(...groupItems);
38
+ });
39
+ return (_jsx(DropdownWrapper, { placeholder: renderedSelectContent, multiple: multiple, errorText: errorText, onSelectionChange: (value) => setSelectedValues(value), disabled: disabled, children: flatOptions.map(item => 'headerLabel' in item
40
+ ? (_jsx("h3", { className: "ds-dropdown-wrapper--items--header", children: item.headerLabel }, `${item.headerLabel}-header`))
41
+ : (_jsx(DropdownItemRenderer, { value: item.value, header: item.header, label: item.label, icon: item.icon }, item.value))) }));
42
+ };
43
+ //# sourceMappingURL=Dropdown.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Dropdown.js","sourceRoot":"","sources":["../../../../../src/components/formField/inputs/dropdown/Dropdown.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,161 @@
1
+ import type { Meta } from '@storybook/react-vite';
2
+ import { Dropdown } from './Dropdown';
3
+ declare const meta: Meta<typeof Dropdown>;
4
+ export declare const Default: {
5
+ args: {
6
+ title: string;
7
+ options: {
8
+ label: string;
9
+ value: string;
10
+ }[];
11
+ multiple: boolean;
12
+ onSelectionChange: (value: string[]) => void;
13
+ };
14
+ };
15
+ export declare const WithIcon: {
16
+ args: {
17
+ title: string;
18
+ options: {
19
+ label: string;
20
+ value: string;
21
+ icon: string;
22
+ }[];
23
+ multiple: boolean;
24
+ onSelectionChange: (value: string[]) => void;
25
+ };
26
+ };
27
+ export declare const DefaultWithGroups: {
28
+ args: {
29
+ title: string;
30
+ multiple: boolean;
31
+ options: ({
32
+ label: string;
33
+ value: string;
34
+ group: string;
35
+ } | {
36
+ label: string;
37
+ value: string;
38
+ group?: undefined;
39
+ })[];
40
+ onSelectionChange: (value: string[]) => void;
41
+ };
42
+ };
43
+ export declare const DefaultMultiSelect: {
44
+ args: {
45
+ title: string;
46
+ options: {
47
+ label: string;
48
+ value: string;
49
+ }[];
50
+ multiple: boolean;
51
+ onSelectionChange: (value: string[]) => void;
52
+ };
53
+ };
54
+ export declare const Placeholder: {
55
+ args: {
56
+ placeholder: string;
57
+ title: string;
58
+ options: {
59
+ label: string;
60
+ value: string;
61
+ }[];
62
+ onSelectionChange: (value: string[]) => void;
63
+ };
64
+ };
65
+ export declare const EmptyPlaceHolder: {
66
+ args: {
67
+ placeholder: string;
68
+ options: {
69
+ label: string;
70
+ value: string;
71
+ }[];
72
+ disabled: boolean;
73
+ onSelectionChange: (value: string[]) => void;
74
+ };
75
+ };
76
+ export declare const WithError: {
77
+ args: {
78
+ title: string;
79
+ options: {
80
+ label: string;
81
+ value: string;
82
+ }[];
83
+ disabled: boolean;
84
+ errorText: string;
85
+ onSelectionChange: (value: string[]) => void;
86
+ };
87
+ };
88
+ export declare const Disabled: {
89
+ args: {
90
+ title: string;
91
+ options: {
92
+ label: string;
93
+ value: string;
94
+ }[];
95
+ disabled: boolean;
96
+ onSelectionChange: (value: string[]) => void;
97
+ };
98
+ };
99
+ export declare const WithGroups: {
100
+ args: {
101
+ title: string;
102
+ options: ({
103
+ label: string;
104
+ value: string;
105
+ group: string;
106
+ } | {
107
+ label: string;
108
+ value: string;
109
+ group?: undefined;
110
+ })[];
111
+ onSelectionChange: (value: string[]) => void;
112
+ };
113
+ };
114
+ export declare const MultilineItems: {
115
+ args: {
116
+ title: string;
117
+ options: {
118
+ label: string;
119
+ value: string;
120
+ header: string;
121
+ }[];
122
+ onSelectionChange: (value: string[]) => void;
123
+ };
124
+ };
125
+ export declare const MultilineItemsGrouped: {
126
+ args: {
127
+ title: string;
128
+ options: ({
129
+ label: string;
130
+ value: string;
131
+ header: string;
132
+ group?: undefined;
133
+ } | {
134
+ label: string;
135
+ value: string;
136
+ header: string;
137
+ group: string;
138
+ })[];
139
+ onSelectionChange: (value: string[]) => void;
140
+ };
141
+ };
142
+ export declare const MultilineItemsGroupedMultiSelect: {
143
+ args: {
144
+ title: string;
145
+ multiple: boolean;
146
+ options: ({
147
+ label: string;
148
+ value: string;
149
+ header: string;
150
+ group: string;
151
+ } | {
152
+ label: string;
153
+ value: string;
154
+ header: string;
155
+ group?: undefined;
156
+ })[];
157
+ onSelectionChange: (value: string[]) => void;
158
+ };
159
+ };
160
+ export default meta;
161
+ //# sourceMappingURL=Dropdown.stories.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Dropdown.stories.d.ts","sourceRoot":"","sources":["../../../../../src/components/formField/inputs/dropdown/Dropdown.stories.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,uBAAuB,CAAC;AAClD,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAEtC,QAAA,MAAM,IAAI,EAAE,IAAI,CAAC,OAAO,QAAQ,CAG/B,CAAC;AAEF,eAAO,MAAM,OAAO;;;;;;;;mCASW,MAAM,EAAE;;CAEtC,CAAC;AAEF,eAAO,MAAM,QAAQ;;;;;;;;;mCASU,MAAM,EAAE;;CAEtC,CAAC;AAEF,eAAO,MAAM,iBAAiB;;;;;;;;;;;;;mCAeC,MAAM,EAAE;;CAEtC,CAAC;AAEF,eAAO,MAAM,kBAAkB;;;;;;;;mCASA,MAAM,EAAE;;CAEtC,CAAC;AAEF,eAAO,MAAM,WAAW;;;;;;;;mCASO,MAAM,EAAE;;CAEtC,CAAC;AAEF,eAAO,MAAM,gBAAgB;;;;;;;;mCASE,MAAM,EAAE;;CAEtC,CAAC;AAEF,eAAO,MAAM,SAAS;;;;;;;;;mCAUS,MAAM,EAAE;;CAEtC,CAAC;AAEF,eAAO,MAAM,QAAQ;;;;;;;;mCASU,MAAM,EAAE;;CAEtC,CAAC;AAEF,eAAO,MAAM,UAAU;;;;;;;;;;;;mCAYQ,MAAM,EAAE;;CAEtC,CAAC;AAEF,eAAO,MAAM,cAAc;;;;;;;;mCASI,MAAM,EAAE;;CAEtC,CAAC;AAEF,eAAO,MAAM,qBAAqB;;;;;;;;;;;;;;mCAcH,MAAM,EAAE;;CAEtC,CAAC;AAEF,eAAO,MAAM,gCAAgC;;;;;;;;;;;;;;;mCAed,MAAM,EAAE;;CAEtC,CAAC;AACF,eAAe,IAAI,CAAC"}
@@ -0,0 +1,172 @@
1
+ import { Dropdown } from './Dropdown';
2
+ const meta = {
3
+ title: 'Components/Dropdown',
4
+ component: Dropdown,
5
+ };
6
+ export const Default = {
7
+ args: {
8
+ title: 'titleValue',
9
+ options: [
10
+ { label: 'Option 1', value: 'option1' },
11
+ { label: 'Option 2', value: 'option2' },
12
+ { label: 'Option 3', value: 'option3' },
13
+ ],
14
+ multiple: false,
15
+ onSelectionChange: (value) => { console.log(value); },
16
+ },
17
+ };
18
+ export const WithIcon = {
19
+ args: {
20
+ title: 'titleValue',
21
+ options: [
22
+ { label: 'Option 1', value: 'option1', icon: '3-dot' },
23
+ { label: 'Option 2', value: 'option2', icon: 'user' },
24
+ { label: 'Option 3', value: 'option3', icon: 'chart-spline' },
25
+ ],
26
+ multiple: true,
27
+ onSelectionChange: (value) => { console.log(value); },
28
+ },
29
+ };
30
+ export const DefaultWithGroups = {
31
+ args: {
32
+ title: 'titleValue',
33
+ multiple: true,
34
+ options: [
35
+ { label: 'Option 5', value: 'option5', group: 'Group 1' },
36
+ { label: 'Option 6', value: 'option6', group: 'Group 1' },
37
+ { label: 'Option 7', value: 'option7', group: 'Group 2' },
38
+ { label: 'Option 8', value: 'option8', group: 'Group 2' },
39
+ { label: 'Option 1', value: 'option1' },
40
+ { label: 'Option 2', value: 'option2' },
41
+ { label: 'Option 3', value: 'option3' },
42
+ { label: 'Option 4', value: 'option4' },
43
+ { label: 'Option 9', value: 'option9' },
44
+ ],
45
+ onSelectionChange: (value) => { console.log(value); },
46
+ },
47
+ };
48
+ export const DefaultMultiSelect = {
49
+ args: {
50
+ title: 'titleValue',
51
+ options: [
52
+ { label: 'Option 1', value: 'option1' },
53
+ { label: 'Option 2', value: 'option2' },
54
+ { label: 'Option 3', value: 'option3' },
55
+ ],
56
+ multiple: true,
57
+ onSelectionChange: (value) => { console.log(value); },
58
+ },
59
+ };
60
+ export const Placeholder = {
61
+ args: {
62
+ placeholder: 'placeholder',
63
+ title: 'titleValue',
64
+ options: [
65
+ { label: 'Option 1', value: 'option1' },
66
+ { label: 'Option 2', value: 'option2' },
67
+ { label: 'Option 3', value: 'option3' },
68
+ ],
69
+ onSelectionChange: (value) => { console.log(value); },
70
+ },
71
+ };
72
+ export const EmptyPlaceHolder = {
73
+ args: {
74
+ placeholder: '',
75
+ options: [
76
+ { label: 'Option 1', value: 'option1' },
77
+ { label: 'Option 2', value: 'option2' },
78
+ { label: 'Option 3', value: 'option3' },
79
+ ],
80
+ disabled: false,
81
+ onSelectionChange: (value) => { console.log(value); },
82
+ },
83
+ };
84
+ export const WithError = {
85
+ args: {
86
+ title: 'titleValue',
87
+ options: [
88
+ { label: 'Option 1', value: 'option1' },
89
+ { label: 'Option 2', value: 'option2' },
90
+ { label: 'Option 3', value: 'option3' },
91
+ ],
92
+ disabled: false,
93
+ errorText: 'This field is required',
94
+ onSelectionChange: (value) => { console.log(value); },
95
+ },
96
+ };
97
+ export const Disabled = {
98
+ args: {
99
+ title: 'titleValue',
100
+ options: [
101
+ { label: 'Option 1', value: 'option1' },
102
+ { label: 'Option 2', value: 'option2' },
103
+ { label: 'Option 3', value: 'option3' },
104
+ ],
105
+ disabled: true,
106
+ onSelectionChange: (value) => { console.log(value); },
107
+ },
108
+ };
109
+ export const WithGroups = {
110
+ args: {
111
+ title: 'titleValue',
112
+ options: [
113
+ { label: 'Option 1', value: 'option1', group: 'Group 1' },
114
+ { label: 'Option 2', value: 'option2', group: 'Group 1' },
115
+ { label: 'Option 4', value: 'option4', group: 'Group 2' },
116
+ { label: 'Option 5', value: 'option5', group: 'Group 2' },
117
+ { label: 'Option 3', value: 'option3' },
118
+ { label: 'Option 6', value: 'option6' },
119
+ { label: 'Option 7', value: 'option7' },
120
+ ],
121
+ onSelectionChange: (value) => { console.log(value); },
122
+ },
123
+ };
124
+ export const MultilineItems = {
125
+ args: {
126
+ title: 'titleValue',
127
+ options: [
128
+ { label: 'Option 1', value: 'option1', header: 'header1' },
129
+ { label: 'Option 2', value: 'option2', header: 'header2' },
130
+ { label: 'Option 3', value: 'option3', header: 'header3' },
131
+ { label: 'Option 4', value: 'option4', header: 'header4' },
132
+ ],
133
+ onSelectionChange: (value) => { console.log(value); },
134
+ },
135
+ };
136
+ export const MultilineItemsGrouped = {
137
+ args: {
138
+ title: 'titleValue',
139
+ options: [
140
+ { label: 'Option 1', value: 'option1', header: 'header1' },
141
+ { label: 'Option 2', value: 'option2', header: 'header2' },
142
+ { label: 'Option 3', value: 'option3', header: 'header3' },
143
+ { label: 'Option 4', value: 'option4', header: 'header4' },
144
+ { label: 'Option 5', value: 'option5', header: 'header5', group: 'Group 1' },
145
+ { label: 'Option 6', value: 'option6', header: 'header6', group: 'Group 1' },
146
+ { label: 'Option 7', value: 'option7', header: 'header7', group: 'Group 2' },
147
+ { label: 'Option 8', value: 'option8', header: 'header8', group: 'Group 2' },
148
+ { label: 'Option 9', value: 'option9', header: 'header9' },
149
+ ],
150
+ onSelectionChange: (value) => { console.log(value); },
151
+ },
152
+ };
153
+ export const MultilineItemsGroupedMultiSelect = {
154
+ args: {
155
+ title: 'titleValue',
156
+ multiple: true,
157
+ options: [
158
+ { label: 'Option 5', value: 'option5', header: 'header5', group: 'Group 1' },
159
+ { label: 'Option 6', value: 'option6', header: 'header6', group: 'Group 1' },
160
+ { label: 'Option 7', value: 'option7', header: 'header7', group: 'Group 2' },
161
+ { label: 'Option 8', value: 'option8', header: 'header8', group: 'Group 2' },
162
+ { label: 'Option 1', value: 'option1', header: 'header1' },
163
+ { label: 'Option 2', value: 'option2', header: 'header2' },
164
+ { label: 'Option 3', value: 'option3', header: 'header3' },
165
+ { label: 'Option 4', value: 'option4', header: 'header4' },
166
+ { label: 'Option 9', value: 'option9', header: 'header9' },
167
+ ],
168
+ onSelectionChange: (value) => { console.log(value); },
169
+ },
170
+ };
171
+ export default meta;
172
+ //# sourceMappingURL=Dropdown.stories.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Dropdown.stories.js","sourceRoot":"","sources":["../../../../../src/components/formField/inputs/dropdown/Dropdown.stories.tsx"],"names":[],"mappings":"AACA,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAEtC,MAAM,IAAI,GAA0B;IAClC,KAAK,EAAE,qBAAqB;IAC5B,SAAS,EAAE,QAAQ;CACpB,CAAC;AAEF,MAAM,CAAC,MAAM,OAAO,GAAG;IACrB,IAAI,EAAE;QACJ,KAAK,EAAE,YAAY;QACnB,OAAO,EAAE;YACP,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE;YACvC,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE;YACvC,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE;SACxC;QACD,QAAQ,EAAE,KAAK;QACf,iBAAiB,EAAE,CAAC,KAAe,EAAE,EAAE,GAAG,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;KAChE;CACF,CAAC;AAEF,MAAM,CAAC,MAAM,QAAQ,GAAG;IACtB,IAAI,EAAE;QACJ,KAAK,EAAE,YAAY;QACnB,OAAO,EAAE;YACP,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE,IAAI,EAAE,OAAO,EAAE;YACtD,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE,IAAI,EAAE,MAAM,EAAE;YACrD,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE,IAAI,EAAE,cAAc,EAAE;SAC9D;QACD,QAAQ,EAAE,IAAI;QACd,iBAAiB,EAAE,CAAC,KAAe,EAAE,EAAE,GAAG,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;KAChE;CACF,CAAC;AAEF,MAAM,CAAC,MAAM,iBAAiB,GAAG;IAC/B,IAAI,EAAE;QACJ,KAAK,EAAE,YAAY;QACnB,QAAQ,EAAE,IAAI;QACd,OAAO,EAAE;YACP,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE,KAAK,EAAE,SAAS,EAAE;YACzD,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE,KAAK,EAAE,SAAS,EAAE;YACzD,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE,KAAK,EAAE,SAAS,EAAE;YACzD,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE,KAAK,EAAE,SAAS,EAAE;YACzD,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE;YACvC,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE;YACvC,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE;YACvC,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE;YACvC,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE;SACxC;QACD,iBAAiB,EAAE,CAAC,KAAe,EAAE,EAAE,GAAG,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;KAChE;CACF,CAAC;AAEF,MAAM,CAAC,MAAM,kBAAkB,GAAG;IAChC,IAAI,EAAE;QACJ,KAAK,EAAE,YAAY;QACnB,OAAO,EAAE;YACP,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE;YACvC,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE;YACvC,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE;SACxC;QACD,QAAQ,EAAE,IAAI;QACd,iBAAiB,EAAE,CAAC,KAAe,EAAE,EAAE,GAAG,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;KAChE;CACF,CAAC;AAEF,MAAM,CAAC,MAAM,WAAW,GAAG;IACzB,IAAI,EAAE;QACJ,WAAW,EAAE,aAAa;QAC1B,KAAK,EAAE,YAAY;QACnB,OAAO,EAAE;YACP,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE;YACvC,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE;YACvC,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE;SACxC;QACD,iBAAiB,EAAE,CAAC,KAAe,EAAE,EAAE,GAAG,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;KAChE;CACF,CAAC;AAEF,MAAM,CAAC,MAAM,gBAAgB,GAAG;IAC9B,IAAI,EAAE;QACJ,WAAW,EAAE,EAAE;QACf,OAAO,EAAE;YACP,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE;YACvC,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE;YACvC,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE;SACxC;QACD,QAAQ,EAAE,KAAK;QACf,iBAAiB,EAAE,CAAC,KAAe,EAAE,EAAE,GAAG,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;KAChE;CACF,CAAC;AAEF,MAAM,CAAC,MAAM,SAAS,GAAG;IACvB,IAAI,EAAE;QACJ,KAAK,EAAE,YAAY;QACnB,OAAO,EAAE;YACP,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE;YACvC,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE;YACvC,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE;SACxC;QACD,QAAQ,EAAE,KAAK;QACf,SAAS,EAAE,wBAAwB;QACnC,iBAAiB,EAAE,CAAC,KAAe,EAAE,EAAE,GAAG,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;KAChE;CACF,CAAC;AAEF,MAAM,CAAC,MAAM,QAAQ,GAAG;IACtB,IAAI,EAAE;QACJ,KAAK,EAAE,YAAY;QACnB,OAAO,EAAE;YACP,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE;YACvC,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE;YACvC,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE;SACxC;QACD,QAAQ,EAAE,IAAI;QACd,iBAAiB,EAAE,CAAC,KAAe,EAAE,EAAE,GAAG,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;KAChE;CACF,CAAC;AAEF,MAAM,CAAC,MAAM,UAAU,GAAG;IACxB,IAAI,EAAE;QACJ,KAAK,EAAE,YAAY;QACnB,OAAO,EAAE;YACP,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE,KAAK,EAAE,SAAS,EAAE;YACzD,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE,KAAK,EAAE,SAAS,EAAE;YACzD,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE,KAAK,EAAE,SAAS,EAAE;YACzD,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE,KAAK,EAAE,SAAS,EAAE;YACzD,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE;YACvC,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE;YACvC,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE;SACxC;QACD,iBAAiB,EAAE,CAAC,KAAe,EAAE,EAAE,GAAG,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;KAChE;CACF,CAAC;AAEF,MAAM,CAAC,MAAM,cAAc,GAAG;IAC5B,IAAI,EAAE;QACJ,KAAK,EAAE,YAAY;QACnB,OAAO,EAAE;YACP,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE;YAC1D,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE;YAC1D,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE;YAC1D,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE;SAC3D;QACD,iBAAiB,EAAE,CAAC,KAAe,EAAE,EAAE,GAAG,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;KAChE;CACF,CAAC;AAEF,MAAM,CAAC,MAAM,qBAAqB,GAAG;IACnC,IAAI,EAAE;QACJ,KAAK,EAAE,YAAY;QACnB,OAAO,EAAE;YACP,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE;YAC1D,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE;YAC1D,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE;YAC1D,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE;YAC1D,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE,KAAK,EAAE,SAAS,EAAE;YAC5E,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE,KAAK,EAAE,SAAS,EAAE;YAC5E,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE,KAAK,EAAE,SAAS,EAAE;YAC5E,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE,KAAK,EAAE,SAAS,EAAE;YAC5E,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE;SAC3D;QACD,iBAAiB,EAAE,CAAC,KAAe,EAAE,EAAE,GAAG,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;KAChE;CACF,CAAC;AAEF,MAAM,CAAC,MAAM,gCAAgC,GAAG;IAC9C,IAAI,EAAE;QACJ,KAAK,EAAE,YAAY;QACnB,QAAQ,EAAE,IAAI;QACd,OAAO,EAAE;YACP,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE,KAAK,EAAE,SAAS,EAAE;YAC5E,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE,KAAK,EAAE,SAAS,EAAE;YAC5E,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE,KAAK,EAAE,SAAS,EAAE;YAC5E,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE,KAAK,EAAE,SAAS,EAAE;YAC5E,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE;YAC1D,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE;YAC1D,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE;YAC1D,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE;YAC1D,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE;SAC3D;QACD,iBAAiB,EAAE,CAAC,KAAe,EAAE,EAAE,GAAG,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;KAChE;CACF,CAAC;AACF,eAAe,IAAI,CAAC"}
@@ -0,0 +1,2 @@
1
+ import '@testing-library/jest-dom/vitest';
2
+ //# sourceMappingURL=Dropdown.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Dropdown.test.d.ts","sourceRoot":"","sources":["../../../../../src/components/formField/inputs/dropdown/Dropdown.test.tsx"],"names":[],"mappings":"AAGA,OAAO,kCAAkC,CAAC"}
@@ -0,0 +1,93 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { describe, expect, test, vi } from 'vitest';
3
+ import { render, screen } from '@testing-library/react';
4
+ import userEvent from '@testing-library/user-event';
5
+ import '@testing-library/jest-dom/vitest';
6
+ import { Dropdown } from './Dropdown';
7
+ describe('Dropdown component', () => {
8
+ test('renders with default placeholder', () => {
9
+ render(_jsx(Dropdown, { onSelectionChange: vi.fn(), disabled: false, options: [{ label: 'Label 1', value: 'label1' }] }));
10
+ expect(screen.getByText('Select')).toBeInTheDocument();
11
+ });
12
+ test('renders custom placeholder', () => {
13
+ render(_jsx(Dropdown, { onSelectionChange: vi.fn(), placeholder: "Hello I'm a Dropdown!", disabled: false, options: [{ label: 'Label 1', value: 'label1' }] }));
14
+ expect(screen.getByText("Hello I'm a Dropdown!")).toBeInTheDocument();
15
+ });
16
+ test('click opens options', async () => {
17
+ render(_jsx(Dropdown, { onSelectionChange: vi.fn(), placeholder: "Hello I'm a Dropdown!", disabled: false, options: [{ label: 'Label 1', value: 'label1' }] }));
18
+ await userEvent.click(screen.getByText("Hello I'm a Dropdown!"));
19
+ expect(await screen.findByText('Label 1')).toBeInTheDocument();
20
+ });
21
+ test('does not open options when disabled', async () => {
22
+ render(_jsx(Dropdown, { onSelectionChange: vi.fn(), placeholder: "Disabled Dropdown", disabled: true, options: [{ label: 'Label 1', value: 'label1' }] }));
23
+ await userEvent.click(screen.getByText('Disabled Dropdown'));
24
+ expect(screen.queryByText('Label 1')).toBeNull();
25
+ });
26
+ test('clicking option triggers onSelectionChange', async () => {
27
+ const onSelectionChange = vi.fn();
28
+ render(_jsx(Dropdown, { onSelectionChange: onSelectionChange, placeholder: "Hello I'm a Dropdown!", disabled: false, options: [{ label: 'Label 1', value: 'label1' }] }));
29
+ await userEvent.click(screen.getByText("Hello I'm a Dropdown!"));
30
+ const option = await screen.findByText('Label 1');
31
+ await userEvent.click(option);
32
+ expect(onSelectionChange).toHaveBeenCalledWith(['label1']);
33
+ });
34
+ test('renders multiple options (Default story)', async () => {
35
+ render(_jsx(Dropdown, { options: [
36
+ { label: 'Option 1', value: 'option1' },
37
+ { label: 'Option 2', value: 'option2' },
38
+ { label: 'Option 3', value: 'option3' },
39
+ ], onSelectionChange: vi.fn() }));
40
+ await userEvent.click(screen.getByText('Select'));
41
+ expect(await screen.findByText('Option 1')).toBeInTheDocument();
42
+ expect(screen.getByText('Option 2')).toBeInTheDocument();
43
+ expect(screen.getByText('Option 3')).toBeInTheDocument();
44
+ });
45
+ test('renders icons (WithIcon story)', async () => {
46
+ render(_jsx(Dropdown, { options: [
47
+ { label: 'Option 1', value: 'option1', icon: '3-dot' },
48
+ { label: 'Option 2', value: 'option2', icon: 'user' },
49
+ ], multiple: true, onSelectionChange: vi.fn() }));
50
+ await userEvent.click(screen.getByText('Select'));
51
+ expect(await screen.findByText('Option 1')).toBeInTheDocument();
52
+ expect(screen.getByText('Option 2')).toBeInTheDocument();
53
+ });
54
+ test('supports multi-select (DefaultMultiSelect story)', async () => {
55
+ const onSelectionChange = vi.fn();
56
+ render(_jsx(Dropdown, { multiple: true, options: [
57
+ { label: 'Option 1', value: 'option1' },
58
+ { label: 'Option 2', value: 'option2' },
59
+ ], onSelectionChange: onSelectionChange }));
60
+ await userEvent.click(screen.getByText('Select'));
61
+ const option1 = await screen.findByText('Option 1');
62
+ const option2 = screen.getByText('Option 2');
63
+ await userEvent.click(option1);
64
+ await userEvent.click(option2);
65
+ expect(onSelectionChange).toHaveBeenCalledWith(['option1', 'option2']);
66
+ });
67
+ test('applies error class when errorText is provided', () => {
68
+ render(_jsx(Dropdown, { onSelectionChange: vi.fn(), placeholder: "Select", disabled: false, errorText: "Something went wrong", options: [{ label: 'Label 1', value: 'label1' }] }));
69
+ const selectElement = screen.getByRole('button');
70
+ expect(selectElement).toHaveClass('ds-button--error');
71
+ });
72
+ test('renders grouped options (WithGroups story)', async () => {
73
+ render(_jsx(Dropdown, { options: [
74
+ { label: 'Option 1', value: 'option1', group: 'Group 1' },
75
+ { label: 'Option 2', value: 'option2', group: 'Group 1' },
76
+ { label: 'Option 3', value: 'option3' },
77
+ ], onSelectionChange: vi.fn() }));
78
+ await userEvent.click(screen.getByText('Select'));
79
+ expect(await screen.findByText('Group 1')).toBeInTheDocument();
80
+ expect(screen.getByText('Option 1')).toBeInTheDocument();
81
+ expect(screen.getByText('Option 3')).toBeInTheDocument();
82
+ });
83
+ test('renders multiline items (MultilineItems story)', async () => {
84
+ render(_jsx(Dropdown, { options: [
85
+ { label: 'Option 1', value: 'option1', header: 'header1' },
86
+ { label: 'Option 2', value: 'option2', header: 'header2' },
87
+ ], onSelectionChange: vi.fn() }));
88
+ await userEvent.click(screen.getByText('Select'));
89
+ expect(await screen.findByText('Option 1')).toBeInTheDocument();
90
+ expect(screen.getByText('header1')).toBeInTheDocument();
91
+ });
92
+ });
93
+ //# sourceMappingURL=Dropdown.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Dropdown.test.js","sourceRoot":"","sources":["../../../../../src/components/formField/inputs/dropdown/Dropdown.test.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,11 @@
1
+ import React from 'react';
2
+ type DropdownButtonProps = {
3
+ label: string;
4
+ disabled?: boolean;
5
+ error?: boolean;
6
+ pressed?: boolean;
7
+ onClick?: (e: React.MouseEvent<HTMLButtonElement>) => void;
8
+ };
9
+ export declare const DropdownButton: React.FC<DropdownButtonProps>;
10
+ export {};
11
+ //# sourceMappingURL=DropdownButton.d.ts.map