@ultraviolet/ui 2.0.0-beta.8 → 2.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/components/Alert/index.cjs +5 -5
- package/dist/components/Avatar/index.cjs +117 -37
- package/dist/components/Avatar/index.d.ts +3 -43
- package/dist/components/Avatar/index.js +119 -39
- package/dist/components/{AvatarV2 → Avatar}/types.d.ts +1 -1
- package/dist/components/Badge/index.cjs +3 -3
- package/dist/components/Banner/index.cjs +3 -3
- package/dist/components/BarChart/index.cjs +2 -2
- package/dist/components/BarStack/index.cjs +2 -2
- package/dist/components/Bullet/index.cjs +2 -6
- package/dist/components/Bullet/index.d.ts +1 -3
- package/dist/components/Bullet/index.js +3 -7
- package/dist/components/Button/index.cjs +16 -10
- package/dist/components/Button/index.d.ts +6 -0
- package/dist/components/Button/index.js +11 -5
- package/dist/components/Card/index.cjs +6 -7
- package/dist/components/Card/index.d.ts +0 -4
- package/dist/components/Card/index.js +4 -5
- package/dist/components/Carousel/index.cjs +5 -5
- package/dist/components/Checkbox/index.cjs +41 -59
- package/dist/components/Checkbox/index.d.ts +0 -8
- package/dist/components/Checkbox/index.js +27 -45
- package/dist/components/CheckboxGroup/index.cjs +9 -8
- package/dist/components/CheckboxGroup/index.d.ts +3 -3
- package/dist/components/CheckboxGroup/index.js +5 -4
- package/dist/components/Chip/ChipContext.cjs +2 -2
- package/dist/components/Chip/ChipIcon.cjs +2 -2
- package/dist/components/Chip/index.cjs +10 -10
- package/dist/components/Chip/index.d.ts +2 -2
- package/dist/components/Chip/index.js +1 -1
- package/dist/components/CopyButton/index.cjs +1 -2
- package/dist/components/CopyButton/index.d.ts +1 -5
- package/dist/components/CopyButton/index.js +1 -2
- package/dist/components/DateInput/Context.cjs +2 -2
- package/dist/components/DateInput/components/CalendarContent.cjs +2 -2
- package/dist/components/DateInput/components/CalendarDaily.cjs +5 -5
- package/dist/components/DateInput/components/CalendarDaily.js +2 -2
- package/dist/components/DateInput/components/CalendarMonthly.cjs +3 -3
- package/dist/components/DateInput/components/Popup.cjs +3 -3
- package/dist/components/DateInput/helpers.cjs +20 -0
- package/dist/components/DateInput/helpers.d.ts +2 -0
- package/dist/components/DateInput/helpers.js +20 -0
- package/dist/components/DateInput/index.cjs +42 -31
- package/dist/components/DateInput/index.js +30 -19
- package/dist/components/Dialog/Context.cjs +3 -3
- package/dist/components/Dialog/index.cjs +4 -4
- package/dist/components/Dialog/index.d.ts +9 -4
- package/dist/components/Dialog/index.js +2 -2
- package/dist/components/Drawer/index.cjs +44 -22
- package/dist/components/Drawer/index.d.ts +14 -2
- package/dist/components/Drawer/index.js +44 -22
- package/dist/components/Expandable/index.cjs +18 -9
- package/dist/components/Expandable/index.js +12 -3
- package/dist/components/ExpandableCard/index.cjs +14 -14
- package/dist/components/GlobalAlert/index.cjs +2 -2
- package/dist/components/InfiniteScroll/index.cjs +7 -7
- package/dist/components/LineChart/CustomLegend.cjs +9 -9
- package/dist/components/LineChart/CustomLegend.js +9 -9
- package/dist/components/LineChart/index.cjs +3 -3
- package/dist/components/Link/index.cjs +20 -36
- package/dist/components/Link/index.d.ts +2 -11
- package/dist/components/Link/index.js +14 -30
- package/dist/components/List/Cell.cjs +4 -17
- package/dist/components/List/Cell.d.ts +0 -6
- package/dist/components/List/Cell.js +2 -15
- package/dist/components/List/HeaderCell.cjs +3 -3
- package/dist/components/List/HeaderCell.js +4 -4
- package/dist/components/List/HeaderRow.cjs +2 -4
- package/dist/components/List/HeaderRow.js +2 -4
- package/dist/components/List/ListContext.cjs +23 -23
- package/dist/components/List/Row.cjs +55 -34
- package/dist/components/List/Row.d.ts +8 -1
- package/dist/components/List/Row.js +43 -22
- package/dist/components/List/SelectBar.cjs +2 -2
- package/dist/components/List/index.cjs +12 -11
- package/dist/components/List/index.d.ts +3 -1
- package/dist/components/List/index.js +6 -5
- package/dist/components/Menu/MenuContent.cjs +222 -0
- package/dist/components/{MenuV2 → Menu}/MenuContent.d.ts +3 -4
- package/dist/components/Menu/MenuContent.js +220 -0
- package/dist/components/Menu/MenuProvider.cjs +42 -0
- package/dist/components/Menu/MenuProvider.d.ts +24 -0
- package/dist/components/Menu/MenuProvider.js +42 -0
- package/dist/components/Menu/components/Group.cjs +34 -0
- package/dist/components/{MenuV2 → Menu}/components/Group.d.ts +1 -1
- package/dist/components/Menu/components/Group.js +32 -0
- package/dist/components/Menu/components/Item.cjs +172 -0
- package/dist/components/{MenuV2 → Menu}/components/Item.d.ts +4 -0
- package/dist/components/Menu/components/Item.js +171 -0
- package/dist/components/{MenuV2 → Menu}/constants.cjs +0 -1
- package/dist/components/{MenuV2 → Menu}/constants.js +0 -1
- package/dist/components/Menu/helpers.cjs +48 -0
- package/dist/components/{MenuV2 → Menu}/helpers.d.ts +2 -1
- package/dist/components/Menu/helpers.js +48 -0
- package/dist/components/Menu/index.cjs +13 -109
- package/dist/components/Menu/index.d.ts +62 -35
- package/dist/components/Menu/index.js +14 -108
- package/dist/components/{MenuV2 → Menu}/types.d.ts +3 -11
- package/dist/components/Modal/ModalContent.cjs +2 -8
- package/dist/components/Modal/ModalContent.d.ts +1 -2
- package/dist/components/Modal/ModalContent.js +2 -8
- package/dist/components/Modal/ModalProvider.cjs +8 -8
- package/dist/components/Modal/components/Dialog.cjs +21 -23
- package/dist/components/Modal/components/Dialog.d.ts +1 -1
- package/dist/components/Modal/components/Dialog.js +6 -8
- package/dist/components/Modal/components/Disclosure.cjs +10 -13
- package/dist/components/Modal/components/Disclosure.d.ts +1 -1
- package/dist/components/Modal/components/Disclosure.js +6 -9
- package/dist/components/Modal/index.cjs +13 -15
- package/dist/components/Modal/index.d.ts +1 -18
- package/dist/components/Modal/index.js +7 -9
- package/dist/components/Modal/types.d.ts +2 -16
- package/dist/components/NumberInput/index.cjs +194 -194
- package/dist/components/NumberInput/index.d.ts +30 -33
- package/dist/components/NumberInput/index.js +190 -190
- package/dist/components/Pagination/PaginationButtons.cjs +5 -5
- package/dist/components/Pagination/PerPage.cjs +3 -3
- package/dist/components/Pagination/PerPage.js +3 -3
- package/dist/components/Pagination/index.cjs +4 -4
- package/dist/components/PieChart/index.cjs +5 -5
- package/dist/components/Popover/index.cjs +10 -10
- package/dist/components/Popover/index.d.ts +4 -2
- package/dist/components/Popover/index.js +2 -2
- package/dist/components/Popup/helpers.cjs +41 -1
- package/dist/components/Popup/helpers.d.ts +1 -1
- package/dist/components/Popup/helpers.js +41 -1
- package/dist/components/Popup/index.cjs +34 -38
- package/dist/components/Popup/index.js +8 -12
- package/dist/components/Radio/index.cjs +3 -3
- package/dist/components/Radio/index.d.ts +9 -9
- package/dist/components/RadioGroup/index.cjs +6 -7
- package/dist/components/RadioGroup/index.d.ts +3 -8
- package/dist/components/RadioGroup/index.js +2 -3
- package/dist/components/Row/index.cjs +18 -6
- package/dist/components/Row/index.d.ts +5 -5
- package/dist/components/Row/index.js +18 -6
- package/dist/components/SearchInput/Key.cjs +2 -2
- package/dist/components/SearchInput/index.cjs +26 -26
- package/dist/components/SearchInput/index.d.ts +1 -1
- package/dist/components/SearchInput/index.js +7 -7
- package/dist/components/SearchInput/types.d.ts +3 -3
- package/dist/components/SelectInput/Dropdown.cjs +477 -0
- package/dist/components/SelectInput/Dropdown.js +475 -0
- package/dist/components/SelectInput/DropdownOption.cjs +91 -0
- package/dist/components/SelectInput/DropdownOption.js +89 -0
- package/dist/components/SelectInput/SearchBarDropdown.cjs +129 -0
- package/dist/components/SelectInput/SearchBarDropdown.js +127 -0
- package/dist/components/SelectInput/SelectBar.cjs +364 -0
- package/dist/components/SelectInput/SelectBar.js +362 -0
- package/dist/components/{SelectInputV2 → SelectInput}/SelectInputProvider.cjs +22 -22
- package/dist/components/{SelectInputV2 → SelectInput}/SelectInputProvider.d.ts +2 -1
- package/dist/components/{SelectInputV2 → SelectInput}/SelectInputProvider.js +8 -8
- package/dist/components/SelectInput/index.cjs +68 -496
- package/dist/components/SelectInput/index.d.ts +119 -63
- package/dist/components/SelectInput/index.js +68 -494
- package/dist/components/SelectableCard/index.cjs +13 -13
- package/dist/components/SelectableCardGroup/index.cjs +5 -5
- package/dist/components/SelectableCardGroup/index.d.ts +1 -1
- package/dist/components/SelectableCardGroup/index.js +1 -1
- package/dist/components/SelectableCardOptionGroup/Provider.cjs +3 -3
- package/dist/components/SelectableCardOptionGroup/Provider.d.ts +2 -2
- package/dist/components/SelectableCardOptionGroup/components/Option.cjs +11 -11
- package/dist/components/SelectableCardOptionGroup/components/Option.d.ts +5 -5
- package/dist/components/SelectableCardOptionGroup/components/Option.js +9 -9
- package/dist/components/SelectableCardOptionGroup/index.cjs +2 -2
- package/dist/components/SelectableCardOptionGroup/index.d.ts +3 -3
- package/dist/components/Separator/index.cjs +8 -9
- package/dist/components/Separator/index.d.ts +1 -5
- package/dist/components/Separator/index.js +8 -9
- package/dist/components/Skeleton/Block.cjs +2 -2
- package/dist/components/Skeleton/Slider.cjs +3 -3
- package/dist/components/Skeleton/Slider.js +3 -3
- package/dist/components/Slider/components/DoubleSlider.cjs +20 -20
- package/dist/components/Slider/components/DoubleSlider.js +7 -7
- package/dist/components/Slider/components/SingleSlider.cjs +24 -24
- package/dist/components/Slider/components/SingleSlider.js +7 -7
- package/dist/components/Slider/index.cjs +2 -2
- package/dist/components/Slider/styles.d.ts +35 -24
- package/dist/components/Snippet/index.cjs +3 -3
- package/dist/components/Stack/index.cjs +31 -11
- package/dist/components/Stack/index.d.ts +9 -9
- package/dist/components/Stack/index.js +31 -11
- package/dist/components/StepList/index.cjs +3 -3
- package/dist/components/StepList/index.js +3 -3
- package/dist/components/Stepper/Step.cjs +10 -14
- package/dist/components/Stepper/Step.js +6 -10
- package/dist/components/Stepper/StepperProvider.cjs +7 -7
- package/dist/components/Stepper/index.cjs +11 -14
- package/dist/components/Stepper/index.js +4 -7
- package/dist/components/SwitchButton/FocusOverlay.cjs +12 -20
- package/dist/components/SwitchButton/FocusOverlay.d.ts +5 -5
- package/dist/components/SwitchButton/FocusOverlay.js +12 -20
- package/dist/components/SwitchButton/Option.cjs +82 -0
- package/dist/components/SwitchButton/Option.d.ts +10 -0
- package/dist/components/SwitchButton/Option.js +80 -0
- package/dist/components/SwitchButton/SwitchButtonContext.cjs +13 -0
- package/dist/components/SwitchButton/SwitchButtonContext.d.ts +19 -0
- package/dist/components/SwitchButton/SwitchButtonContext.js +13 -0
- package/dist/components/SwitchButton/constant.cjs +4 -0
- package/dist/components/SwitchButton/constant.d.ts +1 -0
- package/dist/components/SwitchButton/constant.js +4 -0
- package/dist/components/SwitchButton/index.cjs +82 -48
- package/dist/components/SwitchButton/index.d.ts +14 -13
- package/dist/components/SwitchButton/index.js +81 -47
- package/dist/components/Table/HeaderCell.cjs +5 -5
- package/dist/components/Table/HeaderCell.js +6 -6
- package/dist/components/Table/Row.cjs +10 -10
- package/dist/components/Table/SelectBar.cjs +2 -2
- package/dist/components/Table/TableContext.cjs +5 -5
- package/dist/components/Table/index.cjs +10 -10
- package/dist/components/Table/index.js +2 -2
- package/dist/components/Tabs/Tab.cjs +3 -3
- package/dist/components/Tabs/TabMenu.cjs +7 -7
- package/dist/components/Tabs/TabMenu.d.ts +3 -3
- package/dist/components/Tabs/TabMenu.js +5 -5
- package/dist/components/Tabs/TabMenuItem.cjs +5 -5
- package/dist/components/Tabs/TabMenuItem.d.ts +1 -0
- package/dist/components/Tabs/TabMenuItem.js +3 -3
- package/dist/components/Tabs/TabsContext.cjs +3 -3
- package/dist/components/Tabs/index.cjs +14 -14
- package/dist/components/Tabs/index.d.ts +4 -3
- package/dist/components/Tabs/index.js +3 -3
- package/dist/components/Tag/index.cjs +2 -2
- package/dist/components/TagInput/index.cjs +14 -16
- package/dist/components/TagInput/index.d.ts +1 -17
- package/dist/components/TagInput/index.js +7 -9
- package/dist/components/TagList/index.cjs +13 -13
- package/dist/components/Text/index.cjs +4 -6
- package/dist/components/Text/index.d.ts +2 -6
- package/dist/components/Text/index.js +2 -4
- package/dist/components/TextArea/index.cjs +13 -13
- package/dist/components/TextArea/index.js +4 -4
- package/dist/components/TextInput/index.cjs +179 -343
- package/dist/components/TextInput/index.d.ts +74 -68
- package/dist/components/TextInput/index.js +177 -340
- package/dist/components/TimeInput/index.cjs +320 -23
- package/dist/components/TimeInput/index.d.ts +44 -20
- package/dist/components/TimeInput/index.js +320 -25
- package/dist/components/Toaster/index.cjs +2 -10
- package/dist/components/Toaster/index.d.ts +0 -4
- package/dist/components/Toaster/index.js +2 -10
- package/dist/components/Toggle/index.cjs +6 -6
- package/dist/components/ToggleGroup/index.cjs +5 -5
- package/dist/components/ToggleGroup/index.d.ts +1 -1
- package/dist/components/ToggleGroup/index.js +1 -1
- package/dist/components/Tooltip/index.cjs +3 -3
- package/dist/components/Tooltip/index.d.ts +36 -4
- package/dist/components/Tooltip/index.js +1 -1
- package/dist/components/UnitInput/index.cjs +33 -50
- package/dist/components/UnitInput/index.d.ts +8 -7
- package/dist/components/UnitInput/index.js +28 -45
- package/dist/components/VerificationCode/index.cjs +5 -5
- package/dist/components/index.d.ts +2 -9
- package/dist/hooks/useIsOverflowing.cjs +3 -3
- package/dist/index.cjs +143 -159
- package/dist/index.d.ts +2 -2
- package/dist/index.js +4 -20
- package/dist/theme/index.d.ts +2 -7
- package/package.json +9 -13
- package/dist/components/AvatarV2/index.cjs +0 -139
- package/dist/components/AvatarV2/index.d.ts +0 -5
- package/dist/components/AvatarV2/index.js +0 -137
- package/dist/components/Menu/Item.cjs +0 -93
- package/dist/components/Menu/Item.d.ts +0 -15
- package/dist/components/Menu/Item.js +0 -92
- package/dist/components/MenuV2/MenuContent.cjs +0 -163
- package/dist/components/MenuV2/MenuContent.js +0 -161
- package/dist/components/MenuV2/MenuProvider.cjs +0 -31
- package/dist/components/MenuV2/MenuProvider.d.ts +0 -14
- package/dist/components/MenuV2/MenuProvider.js +0 -31
- package/dist/components/MenuV2/components/Group.cjs +0 -34
- package/dist/components/MenuV2/components/Group.js +0 -32
- package/dist/components/MenuV2/components/Item.cjs +0 -134
- package/dist/components/MenuV2/components/Item.js +0 -133
- package/dist/components/MenuV2/helpers.cjs +0 -26
- package/dist/components/MenuV2/helpers.js +0 -26
- package/dist/components/MenuV2/index.cjs +0 -20
- package/dist/components/MenuV2/index.d.ts +0 -76
- package/dist/components/MenuV2/index.js +0 -20
- package/dist/components/NumberInput/helpers.cjs +0 -10
- package/dist/components/NumberInput/helpers.d.ts +0 -4
- package/dist/components/NumberInput/helpers.js +0 -10
- package/dist/components/NumberInputV2/index.cjs +0 -262
- package/dist/components/NumberInputV2/index.d.ts +0 -38
- package/dist/components/NumberInputV2/index.js +0 -260
- package/dist/components/PasswordStrengthMeter/index.cjs +0 -98
- package/dist/components/PasswordStrengthMeter/index.d.ts +0 -39
- package/dist/components/PasswordStrengthMeter/index.js +0 -96
- package/dist/components/SelectInputV2/Dropdown.cjs +0 -477
- package/dist/components/SelectInputV2/Dropdown.js +0 -475
- package/dist/components/SelectInputV2/DropdownOption.cjs +0 -91
- package/dist/components/SelectInputV2/DropdownOption.js +0 -89
- package/dist/components/SelectInputV2/SearchBarDropdown.cjs +0 -129
- package/dist/components/SelectInputV2/SearchBarDropdown.js +0 -127
- package/dist/components/SelectInputV2/SelectBar.cjs +0 -364
- package/dist/components/SelectInputV2/SelectBar.js +0 -362
- package/dist/components/SelectInputV2/index.cjs +0 -91
- package/dist/components/SelectInputV2/index.d.ts +0 -126
- package/dist/components/SelectInputV2/index.js +0 -89
- package/dist/components/TextInputV2/index.cjs +0 -223
- package/dist/components/TextInputV2/index.d.ts +0 -81
- package/dist/components/TextInputV2/index.js +0 -221
- package/dist/components/TimeInputV2/index.cjs +0 -326
- package/dist/components/TimeInputV2/index.d.ts +0 -49
- package/dist/components/TimeInputV2/index.js +0 -324
- package/dist/helpers/isJSON.cjs +0 -10
- package/dist/helpers/isJSON.js +0 -11
- package/dist/theme/ThemeRegistry.cjs +0 -56
- package/dist/theme/ThemeRegistry.d.ts +0 -12
- package/dist/theme/ThemeRegistry.js +0 -55
- /package/dist/components/{AvatarV2 → Avatar}/constants.cjs +0 -0
- /package/dist/components/{AvatarV2 → Avatar}/constants.d.ts +0 -0
- /package/dist/components/{AvatarV2 → Avatar}/constants.js +0 -0
- /package/dist/components/{MenuV2 → Menu}/constants.d.ts +0 -0
- /package/dist/components/{SelectInputV2 → SelectInput}/Dropdown.d.ts +0 -0
- /package/dist/components/{SelectInputV2 → SelectInput}/DropdownOption.d.ts +0 -0
- /package/dist/components/{SelectInputV2 → SelectInput}/SearchBarDropdown.d.ts +0 -0
- /package/dist/components/{SelectInputV2 → SelectInput}/SelectBar.d.ts +0 -0
- /package/dist/components/{SelectInputV2 → SelectInput}/findOptionInOptions.cjs +0 -0
- /package/dist/components/{SelectInputV2 → SelectInput}/findOptionInOptions.d.ts +0 -0
- /package/dist/components/{SelectInputV2 → SelectInput}/findOptionInOptions.js +0 -0
- /package/dist/components/{SelectInputV2 → SelectInput}/types.cjs +0 -0
- /package/dist/components/{SelectInputV2 → SelectInput}/types.d.ts +0 -0
- /package/dist/components/{SelectInputV2 → SelectInput}/types.js +0 -0
- /package/dist/components/{TimeInputV2 → TimeInput}/constants.cjs +0 -0
- /package/dist/components/{TimeInputV2 → TimeInput}/constants.d.ts +0 -0
- /package/dist/components/{TimeInputV2 → TimeInput}/constants.js +0 -0
- /package/dist/components/{TimeInputV2 → TimeInput}/helpers.cjs +0 -0
- /package/dist/components/{TimeInputV2 → TimeInput}/helpers.d.ts +0 -0
- /package/dist/components/{TimeInputV2 → TimeInput}/helpers.js +0 -0
|
@@ -2,8 +2,8 @@
|
|
|
2
2
|
"use strict";
|
|
3
3
|
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
4
4
|
const jsxRuntime = require("@emotion/react/jsx-runtime");
|
|
5
|
-
const
|
|
6
|
-
const SelectInputContext =
|
|
5
|
+
const react = require("react");
|
|
6
|
+
const SelectInputContext = react.createContext({
|
|
7
7
|
options: [],
|
|
8
8
|
multiselect: false,
|
|
9
9
|
onSearch: () => {
|
|
@@ -30,7 +30,7 @@ const SelectInputContext = React.createContext({
|
|
|
30
30
|
onChange: () => {
|
|
31
31
|
}
|
|
32
32
|
});
|
|
33
|
-
const useSelectInput = () =>
|
|
33
|
+
const useSelectInput = () => react.useContext(SelectInputContext);
|
|
34
34
|
const SelectInputProvider = ({
|
|
35
35
|
options,
|
|
36
36
|
multiselect,
|
|
@@ -40,9 +40,10 @@ const SelectInputProvider = ({
|
|
|
40
40
|
numberOfOptions,
|
|
41
41
|
children,
|
|
42
42
|
onChange,
|
|
43
|
-
refSelect
|
|
43
|
+
refSelect,
|
|
44
|
+
onOpen
|
|
44
45
|
}) => {
|
|
45
|
-
const currentValue =
|
|
46
|
+
const currentValue = react.useMemo(() => {
|
|
46
47
|
if (value) {
|
|
47
48
|
if (Array.isArray(value)) {
|
|
48
49
|
return value;
|
|
@@ -51,32 +52,31 @@ const SelectInputProvider = ({
|
|
|
51
52
|
}
|
|
52
53
|
return [];
|
|
53
54
|
}, [value]);
|
|
54
|
-
const selectedGroups =
|
|
55
|
+
const selectedGroups = react.useMemo(() => {
|
|
55
56
|
if (Array.isArray(options)) {
|
|
56
57
|
return [];
|
|
57
58
|
}
|
|
58
59
|
return Object.keys(options).filter((group) => options[group].every((groupOption) => currentValue.includes(groupOption.value)));
|
|
59
60
|
}, [currentValue, options]);
|
|
60
|
-
const [displayedOptions, setDisplayedOptions] =
|
|
61
|
-
const [isDropdownVisible, setIsDropdownVisible] =
|
|
62
|
-
const [searchInput, setSearchInput] =
|
|
63
|
-
const handleDropDownVisible =
|
|
61
|
+
const [displayedOptions, setDisplayedOptions] = react.useState(options);
|
|
62
|
+
const [isDropdownVisible, setIsDropdownVisible] = react.useState(false);
|
|
63
|
+
const [searchInput, setSearchInput] = react.useState("");
|
|
64
|
+
const handleDropDownVisible = react.useCallback((newValue) => {
|
|
65
|
+
setIsDropdownVisible(newValue);
|
|
64
66
|
if (newValue) {
|
|
65
|
-
|
|
66
|
-
}
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
refSelect.current?.focus();
|
|
70
|
-
}
|
|
67
|
+
onOpen?.();
|
|
68
|
+
}
|
|
69
|
+
if (!newValue && refSelect) {
|
|
70
|
+
refSelect.current?.focus();
|
|
71
71
|
}
|
|
72
|
-
}, [refSelect]);
|
|
73
|
-
const allValues =
|
|
72
|
+
}, [refSelect, onOpen]);
|
|
73
|
+
const allValues = react.useMemo(() => {
|
|
74
74
|
if (!Array.isArray(options)) {
|
|
75
75
|
return Object.keys(options).flatMap((group) => options[group].filter((option) => !option.disabled));
|
|
76
76
|
}
|
|
77
77
|
return options;
|
|
78
78
|
}, [options]);
|
|
79
|
-
const allGroups =
|
|
79
|
+
const allGroups = react.useMemo(() => {
|
|
80
80
|
if (!Array.isArray(options)) {
|
|
81
81
|
return Object.keys(options);
|
|
82
82
|
}
|
|
@@ -162,19 +162,19 @@ const SelectInputProvider = ({
|
|
|
162
162
|
return state;
|
|
163
163
|
}
|
|
164
164
|
};
|
|
165
|
-
const [selectedData, setSelectedData] =
|
|
165
|
+
const [selectedData, setSelectedData] = react.useReducer(reducer, {
|
|
166
166
|
selectedValues: currentValue,
|
|
167
167
|
allSelected: false,
|
|
168
168
|
selectedGroups
|
|
169
169
|
});
|
|
170
|
-
|
|
170
|
+
react.useEffect(() => {
|
|
171
171
|
setSelectedData({
|
|
172
172
|
type: "reset",
|
|
173
173
|
selectedGroups,
|
|
174
174
|
selectedValues: currentValue
|
|
175
175
|
});
|
|
176
176
|
}, [currentValue, selectedGroups]);
|
|
177
|
-
const providerValue =
|
|
177
|
+
const providerValue = react.useMemo(() => ({
|
|
178
178
|
onSearch: setDisplayedOptions,
|
|
179
179
|
isDropdownVisible,
|
|
180
180
|
setIsDropdownVisible: handleDropDownVisible,
|
|
@@ -37,6 +37,7 @@ type SelectInputProviderProps<IsMulti extends boolean> = {
|
|
|
37
37
|
multiselect: IsMulti;
|
|
38
38
|
refSelect?: RefObject<HTMLDivElement | null>;
|
|
39
39
|
onChange?: IsMulti extends true ? (value: string[]) => void : (value: string) => void;
|
|
40
|
+
onOpen?: () => void;
|
|
40
41
|
};
|
|
41
|
-
export declare const SelectInputProvider: <T extends boolean>({ options, multiselect, selectAll, value, selectAllGroup, numberOfOptions, children, onChange, refSelect, }: SelectInputProviderProps<T>) => import("@emotion/react/jsx-runtime").JSX.Element;
|
|
42
|
+
export declare const SelectInputProvider: <T extends boolean>({ options, multiselect, selectAll, value, selectAllGroup, numberOfOptions, children, onChange, refSelect, onOpen, }: SelectInputProviderProps<T>) => import("@emotion/react/jsx-runtime").JSX.Element;
|
|
42
43
|
export {};
|
|
@@ -38,7 +38,8 @@ const SelectInputProvider = ({
|
|
|
38
38
|
numberOfOptions,
|
|
39
39
|
children,
|
|
40
40
|
onChange,
|
|
41
|
-
refSelect
|
|
41
|
+
refSelect,
|
|
42
|
+
onOpen
|
|
42
43
|
}) => {
|
|
43
44
|
const currentValue = useMemo(() => {
|
|
44
45
|
if (value) {
|
|
@@ -59,15 +60,14 @@ const SelectInputProvider = ({
|
|
|
59
60
|
const [isDropdownVisible, setIsDropdownVisible] = useState(false);
|
|
60
61
|
const [searchInput, setSearchInput] = useState("");
|
|
61
62
|
const handleDropDownVisible = useCallback((newValue) => {
|
|
63
|
+
setIsDropdownVisible(newValue);
|
|
62
64
|
if (newValue) {
|
|
63
|
-
|
|
64
|
-
}
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
refSelect.current?.focus();
|
|
68
|
-
}
|
|
65
|
+
onOpen?.();
|
|
66
|
+
}
|
|
67
|
+
if (!newValue && refSelect) {
|
|
68
|
+
refSelect.current?.focus();
|
|
69
69
|
}
|
|
70
|
-
}, [refSelect]);
|
|
70
|
+
}, [refSelect, onOpen]);
|
|
71
71
|
const allValues = useMemo(() => {
|
|
72
72
|
if (!Array.isArray(options)) {
|
|
73
73
|
return Object.keys(options).flatMap((group) => options[group].filter((option) => !option.disabled));
|