@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.
- package/.changeset/neat-experts-repair.md +2 -0
- package/.changeset/slick-places-grin.md +5 -0
- package/.changeset/sunny-cars-sell.md +2 -0
- package/.changeset/tough-facts-check.md +5 -0
- package/.changeset/true-rats-add.md +5 -0
- package/.github/workflows/chromatic.yml +2 -1
- package/.github/workflows/release.yml +124 -0
- package/CHANGELOG.md +0 -1
- package/bin/createComponent.sh +39 -9
- package/dist/components/dropdown/Dropdown.d.ts +1 -0
- package/dist/components/dropdown/Dropdown.d.ts.map +1 -1
- package/dist/components/dropdown/DropdownContent.d.ts +1 -0
- package/dist/components/dropdown/DropdownContent.d.ts.map +1 -1
- package/dist/components/dropdown/DropdownContent.js +3 -2
- package/dist/components/dropdown/DropdownContent.js.map +1 -1
- package/dist/components/formField/FormField.d.ts +8 -0
- package/dist/components/formField/FormField.d.ts.map +1 -1
- package/dist/components/formField/FormField.js +3 -1
- package/dist/components/formField/FormField.js.map +1 -1
- package/dist/components/formField/FormField.stories.d.ts.map +1 -1
- package/dist/components/formField/FormField.stories.js +5 -0
- package/dist/components/formField/FormField.stories.js.map +1 -1
- package/dist/components/formField/FormField.test.js +11 -1
- package/dist/components/formField/FormField.test.js.map +1 -1
- package/dist/components/formField/inputs/colourPickerDropdown/ColourPickerDropdown.d.ts +12 -0
- package/dist/components/formField/inputs/colourPickerDropdown/ColourPickerDropdown.d.ts.map +1 -0
- package/dist/components/formField/inputs/colourPickerDropdown/ColourPickerDropdown.js +17 -0
- package/dist/components/formField/inputs/colourPickerDropdown/ColourPickerDropdown.js.map +1 -0
- package/dist/components/formField/inputs/colourPickerDropdown/ColourPickerDropdown.stories.d.ts +10 -0
- package/dist/components/formField/inputs/colourPickerDropdown/ColourPickerDropdown.stories.d.ts.map +1 -0
- package/dist/components/formField/inputs/colourPickerDropdown/ColourPickerDropdown.stories.js +24 -0
- package/dist/components/formField/inputs/colourPickerDropdown/ColourPickerDropdown.stories.js.map +1 -0
- package/dist/components/formField/inputs/colourPickerDropdown/ColourPickerDropdown.test.d.ts +2 -0
- package/dist/components/formField/inputs/colourPickerDropdown/ColourPickerDropdown.test.d.ts.map +1 -0
- package/dist/components/formField/inputs/colourPickerDropdown/ColourPickerDropdown.test.js +88 -0
- package/dist/components/formField/inputs/colourPickerDropdown/ColourPickerDropdown.test.js.map +1 -0
- package/dist/components/formField/inputs/dropdown/Dropdown.d.ts +11 -0
- package/dist/components/formField/inputs/dropdown/Dropdown.d.ts.map +1 -0
- package/dist/components/formField/inputs/dropdown/Dropdown.js +43 -0
- package/dist/components/formField/inputs/dropdown/Dropdown.js.map +1 -0
- package/dist/components/formField/inputs/dropdown/Dropdown.stories.d.ts +161 -0
- package/dist/components/formField/inputs/dropdown/Dropdown.stories.d.ts.map +1 -0
- package/dist/components/formField/inputs/dropdown/Dropdown.stories.js +172 -0
- package/dist/components/formField/inputs/dropdown/Dropdown.stories.js.map +1 -0
- package/dist/components/formField/inputs/dropdown/Dropdown.test.d.ts +2 -0
- package/dist/components/formField/inputs/dropdown/Dropdown.test.d.ts.map +1 -0
- package/dist/components/formField/inputs/dropdown/Dropdown.test.js +93 -0
- package/dist/components/formField/inputs/dropdown/Dropdown.test.js.map +1 -0
- package/dist/components/formField/inputs/dropdown/buttons/dropdownButton/DropdownButton.d.ts +11 -0
- package/dist/components/formField/inputs/dropdown/buttons/dropdownButton/DropdownButton.d.ts.map +1 -0
- package/dist/components/formField/inputs/dropdown/buttons/dropdownButton/DropdownButton.js +15 -0
- package/dist/components/formField/inputs/dropdown/buttons/dropdownButton/DropdownButton.js.map +1 -0
- package/dist/components/formField/inputs/dropdown/items/DropdownItemRenderer.d.ts +10 -0
- package/dist/components/formField/inputs/dropdown/items/DropdownItemRenderer.d.ts.map +1 -0
- package/dist/components/formField/inputs/dropdown/items/DropdownItemRenderer.js +12 -0
- package/dist/components/formField/inputs/dropdown/items/DropdownItemRenderer.js.map +1 -0
- package/dist/components/formField/inputs/dropdown/items/dropdownItem/DropdownItem.d.ts +9 -0
- package/dist/components/formField/inputs/dropdown/items/dropdownItem/DropdownItem.d.ts.map +1 -0
- package/dist/components/formField/inputs/dropdown/items/dropdownItem/DropdownItem.js +17 -0
- package/dist/components/formField/inputs/dropdown/items/dropdownItem/DropdownItem.js.map +1 -0
- package/dist/components/formField/inputs/dropdown/items/dropdownMultiLineItem/DropdownMultiLineItem.d.ts +7 -0
- package/dist/components/formField/inputs/dropdown/items/dropdownMultiLineItem/DropdownMultiLineItem.d.ts.map +1 -0
- package/dist/components/formField/inputs/dropdown/items/dropdownMultiLineItem/DropdownMultiLineItem.js +16 -0
- package/dist/components/formField/inputs/dropdown/items/dropdownMultiLineItem/DropdownMultiLineItem.js.map +1 -0
- package/dist/components/formField/inputs/dropdown/wrapper/DropdownWrapper.d.ts +16 -0
- package/dist/components/formField/inputs/dropdown/wrapper/DropdownWrapper.d.ts.map +1 -0
- package/dist/components/formField/inputs/dropdown/wrapper/DropdownWrapper.js +73 -0
- package/dist/components/formField/inputs/dropdown/wrapper/DropdownWrapper.js.map +1 -0
- package/dist/components/formField/inputs/selectDropdown/SelectDropdown.d.ts +10 -6
- package/dist/components/formField/inputs/selectDropdown/SelectDropdown.d.ts.map +1 -1
- package/dist/components/formField/inputs/selectDropdown/SelectDropdown.js +10 -6
- package/dist/components/formField/inputs/selectDropdown/SelectDropdown.js.map +1 -1
- package/dist/components/formField/inputs/selectDropdown/SelectDropdown.test.js +1 -1
- package/dist/components/formField/inputs/selectDropdown/SelectDropdown.test.js.map +1 -1
- package/dist/components/heading/HeadingInnerContainer.d.ts +5 -0
- package/dist/components/heading/HeadingInnerContainer.d.ts.map +1 -0
- package/dist/components/heading/HeadingInnerContainer.js +7 -0
- package/dist/components/heading/HeadingInnerContainer.js.map +1 -0
- package/dist/components/icon/Icon.d.ts +0 -1
- package/dist/components/icon/Icon.d.ts.map +1 -1
- package/dist/components/icon/Icon.js +1 -1
- package/dist/components/icon/Icon.js.map +1 -1
- package/dist/components/searchBar/SearchBar.d.ts +8 -0
- package/dist/components/searchBar/SearchBar.d.ts.map +1 -0
- package/dist/components/searchBar/SearchBar.js +38 -0
- package/dist/components/searchBar/SearchBar.js.map +1 -0
- package/dist/components/searchBar/SearchBar.test.d.ts +2 -0
- package/dist/components/searchBar/SearchBar.test.d.ts.map +1 -0
- package/dist/components/searchBar/SearchBar.test.js +36 -0
- package/dist/components/searchBar/SearchBar.test.js.map +1 -0
- package/dist/components/slideover/Slideover.d.ts +1 -0
- package/dist/components/slideover/Slideover.d.ts.map +1 -1
- package/dist/components/slideover/Slideover.js +2 -2
- package/dist/components/slideover/Slideover.js.map +1 -1
- package/dist/components/table/HideColumnsDropdown.d.ts +9 -0
- package/dist/components/table/HideColumnsDropdown.d.ts.map +1 -0
- package/dist/components/table/HideColumnsDropdown.js +33 -0
- package/dist/components/table/HideColumnsDropdown.js.map +1 -0
- package/dist/components/table/Table.d.ts +14 -0
- package/dist/components/table/Table.d.ts.map +1 -1
- package/dist/components/table/Table.js +8 -3
- package/dist/components/table/Table.js.map +1 -1
- package/dist/components/table/Table.stories.d.ts +3 -0
- package/dist/components/table/Table.stories.d.ts.map +1 -1
- package/dist/components/table/Table.stories.js +53 -1
- package/dist/components/table/Table.stories.js.map +1 -1
- package/dist/components/table/Table.test.js +132 -0
- package/dist/components/table/Table.test.js.map +1 -1
- package/dist/components/table/TableHeader.d.ts +3 -0
- package/dist/components/table/TableHeader.d.ts.map +1 -1
- package/dist/components/table/TableHeader.js +4 -3
- package/dist/components/table/TableHeader.js.map +1 -1
- package/dist/index.css +93 -1
- package/dist/index.css.map +1 -1
- package/dist/index.d.ts +1 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +1 -0
- package/dist/index.js.map +1 -1
- package/dist/tailwind.css +229 -0
- package/package.json +2 -1
- package/src/components/dropdown/DropdownContent.tsx +4 -2
- package/src/components/formField/FormField.stories.tsx +17 -0
- package/src/components/formField/FormField.test.tsx +13 -1
- package/src/components/formField/FormField.tsx +10 -0
- package/src/components/formField/inputs/colourPickerDropdown/ColourPickerDropdown.stories.tsx +29 -0
- package/src/components/formField/inputs/colourPickerDropdown/ColourPickerDropdown.test.tsx +121 -0
- package/src/components/formField/inputs/colourPickerDropdown/ColourPickerDropdown.tsx +53 -0
- package/src/components/formField/inputs/colourPickerDropdown/colourPickerDropdown.scss +12 -0
- package/src/components/formField/inputs/selectDropdown/SelectDropdown.test.tsx +1 -1
- package/src/components/formField/inputs/selectDropdown/SelectDropdown.tsx +55 -41
- package/src/components/heading/heading.scss +1 -0
- package/src/components/icon/Icon.tsx +1 -2
- package/src/components/searchBar/SearchBar.test.tsx +40 -0
- package/src/components/searchBar/SearchBar.tsx +97 -0
- package/src/components/searchBar/searchBar.scss +69 -0
- package/src/components/slideover/Slideover.tsx +10 -5
- package/src/components/table/HideColumnsDropdown.tsx +57 -0
- package/src/components/table/Table.stories.tsx +96 -2
- package/src/components/table/Table.test.tsx +240 -0
- package/src/components/table/Table.tsx +10 -1
- package/src/components/table/TableHeader.tsx +8 -0
- package/src/components/table/table.scss +22 -0
- package/src/index.scss +24 -22
- package/src/index.ts +1 -0
- package/.github/workflows/changeset-version.yml +0 -39
- package/.github/workflows/merge-version-packages-pr.yml +0 -31
- package/.github/workflows/production-build.yml +0 -130
- 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
|
package/dist/components/formField/inputs/colourPickerDropdown/ColourPickerDropdown.test.js.map
ADDED
|
@@ -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":"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"}
|
|
@@ -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
|