@okta/odyssey-react-mui 1.13.11 → 1.14.2
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/CHANGELOG.md +25 -0
- package/dist/@types/properties.d.js +2 -0
- package/dist/@types/properties.d.js.map +1 -0
- package/dist/Accordion.js.map +1 -1
- package/dist/Autocomplete.js.map +1 -1
- package/dist/Badge.js.map +1 -1
- package/dist/Banner.js.map +1 -1
- package/dist/Box.js.map +1 -1
- package/dist/Breadcrumbs.js.map +1 -1
- package/dist/Button.js +3 -3
- package/dist/Button.js.map +1 -1
- package/dist/Callout.js.map +1 -1
- package/dist/Checkbox.js.map +1 -1
- package/dist/CheckboxGroup.js.map +1 -1
- package/dist/CircularProgress.js.map +1 -1
- package/dist/Dialog.js +8 -8
- package/dist/Dialog.js.map +1 -1
- package/dist/ErrorMessageList.js.map +1 -1
- package/dist/Field.js +1 -0
- package/dist/Field.js.map +1 -1
- package/dist/FieldComponentProps.js.map +1 -1
- package/dist/FieldError.js.map +1 -1
- package/dist/FieldHint.js.map +1 -1
- package/dist/FieldLabel.js.map +1 -1
- package/dist/Fieldset.js.map +1 -1
- package/dist/Form.js.map +1 -1
- package/dist/FormCheckedProps.js.map +1 -1
- package/dist/HintLink.js.map +1 -1
- package/dist/HtmlProps.js.map +1 -1
- package/dist/Link.js.map +1 -1
- package/dist/MenuButton.js.map +1 -1
- package/dist/MenuItem.js.map +1 -1
- package/dist/MuiPropsChild.js.map +1 -1
- package/dist/NativeSelect.js.map +1 -1
- package/dist/OdysseyProvider.js +0 -2
- package/dist/OdysseyProvider.js.map +1 -1
- package/dist/OdysseyThemeProvider.js +1 -28
- package/dist/OdysseyThemeProvider.js.map +1 -1
- package/dist/OdysseyTranslationProvider.js.map +1 -1
- package/dist/PasswordField.js.map +1 -1
- package/dist/Radio.js.map +1 -1
- package/dist/RadioGroup.js.map +1 -1
- package/dist/ScreenReaderText.js.map +1 -1
- package/dist/SearchField.js +6 -2
- package/dist/SearchField.js.map +1 -1
- package/dist/Select.js +144 -44
- package/dist/Select.js.map +1 -1
- package/dist/Status.js +6 -1
- package/dist/Status.js.map +1 -1
- package/dist/Tabs.js +1 -1
- package/dist/Tabs.js.map +1 -1
- package/dist/Tag.js.map +1 -1
- package/dist/TagList.js.map +1 -1
- package/dist/TextField.js.map +1 -1
- package/dist/Tile.js +53 -39
- package/dist/Tile.js.map +1 -1
- package/dist/Toast.js.map +1 -1
- package/dist/Tooltip.js.map +1 -1
- package/dist/Typography.js +11 -10
- package/dist/Typography.js.map +1 -1
- package/dist/createShadowRootElement.js.map +1 -1
- package/dist/getTypedObjectKeys.js.map +1 -1
- package/dist/icons.generated/AddCircle.js.map +1 -1
- package/dist/icons.generated/Apps.js.map +1 -1
- package/dist/icons.generated/ArrowBottom.js.map +1 -1
- package/dist/icons.generated/ArrowDown.js.map +1 -1
- package/dist/icons.generated/ArrowLeft.js.map +1 -1
- package/dist/icons.generated/ArrowRight.js.map +1 -1
- package/dist/icons.generated/ArrowTop.js.map +1 -1
- package/dist/icons.generated/ArrowUp.js.map +1 -1
- package/dist/icons.generated/Calendar.js.map +1 -1
- package/dist/icons.generated/Call.js.map +1 -1
- package/dist/icons.generated/Chat.js.map +1 -1
- package/dist/icons.generated/Check.js.map +1 -1
- package/dist/icons.generated/ChevronDown.js.map +1 -1
- package/dist/icons.generated/ChevronLeft.js.map +1 -1
- package/dist/icons.generated/ChevronUp.js.map +1 -1
- package/dist/icons.generated/Clock.js.map +1 -1
- package/dist/icons.generated/Close.js.map +1 -1
- package/dist/icons.generated/Copy.js.map +1 -1
- package/dist/icons.generated/Delete.js.map +1 -1
- package/dist/icons.generated/Deny.js.map +1 -1
- package/dist/icons.generated/Devices.js.map +1 -1
- package/dist/icons.generated/Directory.js.map +1 -1
- package/dist/icons.generated/Download.js.map +1 -1
- package/dist/icons.generated/Edit.js.map +1 -1
- package/dist/icons.generated/ExpandLeft.js.map +1 -1
- package/dist/icons.generated/ExpandRight.js.map +1 -1
- package/dist/icons.generated/Filter.js.map +1 -1
- package/dist/icons.generated/Folder.js.map +1 -1
- package/dist/icons.generated/Globe.js.map +1 -1
- package/dist/icons.generated/Grid.js.map +1 -1
- package/dist/icons.generated/Group.js.map +1 -1
- package/dist/icons.generated/Hide.js.map +1 -1
- package/dist/icons.generated/Home.js.map +1 -1
- package/dist/icons.generated/Link.js.map +1 -1
- package/dist/icons.generated/List.js.map +1 -1
- package/dist/icons.generated/Lock.js.map +1 -1
- package/dist/icons.generated/More.js.map +1 -1
- package/dist/icons.generated/Pause.js.map +1 -1
- package/dist/icons.generated/Refresh.js.map +1 -1
- package/dist/icons.generated/Reset.js.map +1 -1
- package/dist/icons.generated/Resume.js.map +1 -1
- package/dist/icons.generated/Search.js.map +1 -1
- package/dist/icons.generated/Server.js.map +1 -1
- package/dist/icons.generated/Settings.js.map +1 -1
- package/dist/icons.generated/Show.js.map +1 -1
- package/dist/icons.generated/Subtract.js.map +1 -1
- package/dist/icons.generated/Sync.js.map +1 -1
- package/dist/icons.generated/Unlock.js.map +1 -1
- package/dist/icons.generated/Upload.js.map +1 -1
- package/dist/icons.generated/User.js.map +1 -1
- package/dist/icons.generated/Video.js.map +1 -1
- package/dist/icons.generated/Warning.js.map +1 -1
- package/dist/icons.generated/index.js +1 -1
- package/dist/icons.generated/index.js.map +1 -1
- package/dist/index.js.map +1 -1
- package/dist/labs/DataFilters.js.map +1 -1
- package/dist/labs/DataTable.js.map +1 -1
- package/dist/labs/DatePicker.js.map +1 -1
- package/dist/labs/Drawer.js +172 -0
- package/dist/labs/Drawer.js.map +1 -0
- package/dist/labs/GroupPicker.js.map +1 -1
- package/dist/labs/PaginatedTable.js.map +1 -1
- package/dist/labs/StaticTable.js.map +1 -1
- package/dist/labs/Switch.js.map +1 -1
- package/dist/labs/VirtualizedAutocomplete.js.map +1 -1
- package/dist/labs/datePickerTheme.js.map +1 -1
- package/dist/labs/index.js +1 -0
- package/dist/labs/index.js.map +1 -1
- package/dist/labs/materialReactTableTypes.js.map +1 -1
- package/dist/properties/ts/odyssey-react-mui_cs.js +4 -2
- package/dist/properties/ts/odyssey-react-mui_cs.js.map +1 -1
- package/dist/properties/ts/odyssey-react-mui_da.js +4 -2
- package/dist/properties/ts/odyssey-react-mui_da.js.map +1 -1
- package/dist/properties/ts/odyssey-react-mui_de.js +4 -2
- package/dist/properties/ts/odyssey-react-mui_de.js.map +1 -1
- package/dist/properties/ts/odyssey-react-mui_el.js +4 -2
- package/dist/properties/ts/odyssey-react-mui_el.js.map +1 -1
- package/dist/properties/ts/odyssey-react-mui_es.js +4 -2
- package/dist/properties/ts/odyssey-react-mui_es.js.map +1 -1
- package/dist/properties/ts/odyssey-react-mui_fi.js +4 -2
- package/dist/properties/ts/odyssey-react-mui_fi.js.map +1 -1
- package/dist/properties/ts/odyssey-react-mui_fr.js +4 -2
- package/dist/properties/ts/odyssey-react-mui_fr.js.map +1 -1
- package/dist/properties/ts/odyssey-react-mui_hu.js +4 -2
- package/dist/properties/ts/odyssey-react-mui_hu.js.map +1 -1
- package/dist/properties/ts/odyssey-react-mui_id.js +4 -2
- package/dist/properties/ts/odyssey-react-mui_id.js.map +1 -1
- package/dist/properties/ts/odyssey-react-mui_it.js +4 -2
- package/dist/properties/ts/odyssey-react-mui_it.js.map +1 -1
- package/dist/properties/ts/odyssey-react-mui_ja.js +4 -2
- package/dist/properties/ts/odyssey-react-mui_ja.js.map +1 -1
- package/dist/properties/ts/odyssey-react-mui_ko.js +4 -2
- package/dist/properties/ts/odyssey-react-mui_ko.js.map +1 -1
- package/dist/properties/ts/odyssey-react-mui_ms.js +4 -2
- package/dist/properties/ts/odyssey-react-mui_ms.js.map +1 -1
- package/dist/properties/ts/odyssey-react-mui_nb.js +4 -2
- package/dist/properties/ts/odyssey-react-mui_nb.js.map +1 -1
- package/dist/properties/ts/odyssey-react-mui_nl_NL.js +4 -2
- package/dist/properties/ts/odyssey-react-mui_nl_NL.js.map +1 -1
- package/dist/properties/ts/odyssey-react-mui_pl.js +4 -2
- package/dist/properties/ts/odyssey-react-mui_pl.js.map +1 -1
- package/dist/properties/ts/odyssey-react-mui_pt_BR.js +4 -2
- package/dist/properties/ts/odyssey-react-mui_pt_BR.js.map +1 -1
- package/dist/properties/ts/odyssey-react-mui_ro.js +4 -2
- package/dist/properties/ts/odyssey-react-mui_ro.js.map +1 -1
- package/dist/properties/ts/odyssey-react-mui_ru.js +4 -2
- package/dist/properties/ts/odyssey-react-mui_ru.js.map +1 -1
- package/dist/properties/ts/odyssey-react-mui_sv.js +4 -2
- package/dist/properties/ts/odyssey-react-mui_sv.js.map +1 -1
- package/dist/properties/ts/odyssey-react-mui_th.js +4 -2
- package/dist/properties/ts/odyssey-react-mui_th.js.map +1 -1
- package/dist/properties/ts/odyssey-react-mui_tr.js +4 -2
- package/dist/properties/ts/odyssey-react-mui_tr.js.map +1 -1
- package/dist/properties/ts/odyssey-react-mui_uk.js +4 -2
- package/dist/properties/ts/odyssey-react-mui_uk.js.map +1 -1
- package/dist/properties/ts/odyssey-react-mui_vi.js +4 -2
- package/dist/properties/ts/odyssey-react-mui_vi.js.map +1 -1
- package/dist/properties/ts/odyssey-react-mui_zh_CN.js +4 -2
- package/dist/properties/ts/odyssey-react-mui_zh_CN.js.map +1 -1
- package/dist/properties/ts/odyssey-react-mui_zh_TW.js +4 -2
- package/dist/properties/ts/odyssey-react-mui_zh_TW.js.map +1 -1
- package/dist/scripts/properties-to-ts.d.ts +14 -0
- package/dist/scripts/properties-to-ts.d.ts.map +1 -0
- package/dist/src/Accordion.d.ts +2 -2
- package/dist/src/Accordion.d.ts.map +1 -1
- package/dist/src/Autocomplete.d.ts +2 -2
- package/dist/src/Autocomplete.d.ts.map +1 -1
- package/dist/src/Badge.d.ts +2 -2
- package/dist/src/Badge.d.ts.map +1 -1
- package/dist/src/Banner.d.ts +2 -2
- package/dist/src/Banner.d.ts.map +1 -1
- package/dist/src/Box.d.ts +2 -2
- package/dist/src/Box.d.ts.map +1 -1
- package/dist/src/Breadcrumbs.d.ts +3 -3
- package/dist/src/Breadcrumbs.d.ts.map +1 -1
- package/dist/src/Button.d.ts +3 -30
- package/dist/src/Button.d.ts.map +1 -1
- package/dist/src/Callout.d.ts +2 -2
- package/dist/src/Callout.d.ts.map +1 -1
- package/dist/src/Checkbox.d.ts +3 -23
- package/dist/src/Checkbox.d.ts.map +1 -1
- package/dist/src/CheckboxGroup.d.ts +2 -2
- package/dist/src/CheckboxGroup.d.ts.map +1 -1
- package/dist/src/CircularProgress.d.ts +2 -6
- package/dist/src/CircularProgress.d.ts.map +1 -1
- package/dist/src/CssBaseline.d.ts +1 -1
- package/dist/src/CssBaseline.d.ts.map +1 -1
- package/dist/src/Dialog.d.ts +5 -5
- package/dist/src/Dialog.d.ts.map +1 -1
- package/dist/src/ErrorMessageList.d.ts +1 -1
- package/dist/src/ErrorMessageList.d.ts.map +1 -1
- package/dist/src/Field.d.ts +2 -5
- package/dist/src/Field.d.ts.map +1 -1
- package/dist/src/FieldComponentProps.d.ts +7 -4
- package/dist/src/FieldComponentProps.d.ts.map +1 -1
- package/dist/src/FieldError.d.ts +2 -2
- package/dist/src/FieldError.d.ts.map +1 -1
- package/dist/src/FieldHint.d.ts +2 -2
- package/dist/src/FieldHint.d.ts.map +1 -1
- package/dist/src/FieldLabel.d.ts +2 -2
- package/dist/src/FieldLabel.d.ts.map +1 -1
- package/dist/src/Fieldset.d.ts +2 -2
- package/dist/src/Fieldset.d.ts.map +1 -1
- package/dist/src/Form.d.ts +2 -2
- package/dist/src/Form.d.ts.map +1 -1
- package/dist/src/HintLink.d.ts +1 -1
- package/dist/src/HintLink.d.ts.map +1 -1
- package/dist/src/HtmlProps.d.ts +59 -0
- package/dist/src/HtmlProps.d.ts.map +1 -1
- package/dist/src/Link.d.ts +2 -6
- package/dist/src/Link.d.ts.map +1 -1
- package/dist/src/MenuButton.d.ts +5 -23
- package/dist/src/MenuButton.d.ts.map +1 -1
- package/dist/src/MenuItem.d.ts +2 -2
- package/dist/src/MenuItem.d.ts.map +1 -1
- package/dist/src/NativeSelect.d.ts +2 -2
- package/dist/src/NativeSelect.d.ts.map +1 -1
- package/dist/src/OdysseyCacheProvider.d.ts +1 -1
- package/dist/src/OdysseyCacheProvider.d.ts.map +1 -1
- package/dist/src/OdysseyProvider.d.ts +1 -1
- package/dist/src/OdysseyProvider.d.ts.map +1 -1
- package/dist/src/OdysseyThemeProvider.d.ts +1 -3
- package/dist/src/OdysseyThemeProvider.d.ts.map +1 -1
- package/dist/src/OdysseyTranslationProvider.d.ts +2 -2
- package/dist/src/OdysseyTranslationProvider.d.ts.map +1 -1
- package/dist/src/PasswordField.d.ts +2 -2
- package/dist/src/PasswordField.d.ts.map +1 -1
- package/dist/src/Radio.d.ts +2 -2
- package/dist/src/Radio.d.ts.map +1 -1
- package/dist/src/RadioGroup.d.ts +2 -2
- package/dist/src/RadioGroup.d.ts.map +1 -1
- package/dist/src/ScreenReaderText.d.ts +2 -2
- package/dist/src/ScreenReaderText.d.ts.map +1 -1
- package/dist/src/SearchField.d.ts +11 -2
- package/dist/src/SearchField.d.ts.map +1 -1
- package/dist/src/Select.d.ts +2 -2
- package/dist/src/Select.d.ts.map +1 -1
- package/dist/src/Status.d.ts +4 -2
- package/dist/src/Status.d.ts.map +1 -1
- package/dist/src/Tabs.d.ts +2 -6
- package/dist/src/Tabs.d.ts.map +1 -1
- package/dist/src/Tag.d.ts +2 -2
- package/dist/src/Tag.d.ts.map +1 -1
- package/dist/src/TagList.d.ts +2 -2
- package/dist/src/TagList.d.ts.map +1 -1
- package/dist/src/TextField.d.ts +3 -3
- package/dist/src/TextField.d.ts.map +1 -1
- package/dist/src/Tile.d.ts +32 -11
- package/dist/src/Tile.d.ts.map +1 -1
- package/dist/src/Toast.d.ts +2 -2
- package/dist/src/Toast.d.ts.map +1 -1
- package/dist/src/ToastStack.d.ts +1 -1
- package/dist/src/ToastStack.d.ts.map +1 -1
- package/dist/src/Tooltip.d.ts +2 -2
- package/dist/src/Tooltip.d.ts.map +1 -1
- package/dist/src/Typography.d.ts +13 -25
- package/dist/src/Typography.d.ts.map +1 -1
- package/dist/src/icons.generated/Add.d.ts +1 -1
- package/dist/src/icons.generated/Add.d.ts.map +1 -1
- package/dist/src/icons.generated/AddCircle.d.ts +1 -1
- package/dist/src/icons.generated/AddCircle.d.ts.map +1 -1
- package/dist/src/icons.generated/Apps.d.ts +1 -1
- package/dist/src/icons.generated/Apps.d.ts.map +1 -1
- package/dist/src/icons.generated/ArrowBottom.d.ts +1 -1
- package/dist/src/icons.generated/ArrowBottom.d.ts.map +1 -1
- package/dist/src/icons.generated/ArrowDown.d.ts +1 -1
- package/dist/src/icons.generated/ArrowDown.d.ts.map +1 -1
- package/dist/src/icons.generated/ArrowLeft.d.ts +1 -1
- package/dist/src/icons.generated/ArrowLeft.d.ts.map +1 -1
- package/dist/src/icons.generated/ArrowLowerLeft.d.ts +1 -1
- package/dist/src/icons.generated/ArrowLowerLeft.d.ts.map +1 -1
- package/dist/src/icons.generated/ArrowLowerRight.d.ts +1 -1
- package/dist/src/icons.generated/ArrowLowerRight.d.ts.map +1 -1
- package/dist/src/icons.generated/ArrowRight.d.ts +1 -1
- package/dist/src/icons.generated/ArrowRight.d.ts.map +1 -1
- package/dist/src/icons.generated/ArrowTop.d.ts +1 -1
- package/dist/src/icons.generated/ArrowTop.d.ts.map +1 -1
- package/dist/src/icons.generated/ArrowUnsorted.d.ts +1 -1
- package/dist/src/icons.generated/ArrowUnsorted.d.ts.map +1 -1
- package/dist/src/icons.generated/ArrowUp.d.ts +1 -1
- package/dist/src/icons.generated/ArrowUp.d.ts.map +1 -1
- package/dist/src/icons.generated/ArrowUpperLeft.d.ts +1 -1
- package/dist/src/icons.generated/ArrowUpperLeft.d.ts.map +1 -1
- package/dist/src/icons.generated/ArrowUpperRight.d.ts +1 -1
- package/dist/src/icons.generated/ArrowUpperRight.d.ts.map +1 -1
- package/dist/src/icons.generated/Bug.d.ts +1 -1
- package/dist/src/icons.generated/Bug.d.ts.map +1 -1
- package/dist/src/icons.generated/Calendar.d.ts +1 -1
- package/dist/src/icons.generated/Calendar.d.ts.map +1 -1
- package/dist/src/icons.generated/Call.d.ts +1 -1
- package/dist/src/icons.generated/Call.d.ts.map +1 -1
- package/dist/src/icons.generated/Chat.d.ts +1 -1
- package/dist/src/icons.generated/Chat.d.ts.map +1 -1
- package/dist/src/icons.generated/Check.d.ts +1 -1
- package/dist/src/icons.generated/Check.d.ts.map +1 -1
- package/dist/src/icons.generated/CheckCircleFilled.d.ts +1 -1
- package/dist/src/icons.generated/CheckCircleFilled.d.ts.map +1 -1
- package/dist/src/icons.generated/ChevronDown.d.ts +1 -1
- package/dist/src/icons.generated/ChevronDown.d.ts.map +1 -1
- package/dist/src/icons.generated/ChevronLeft.d.ts +1 -1
- package/dist/src/icons.generated/ChevronLeft.d.ts.map +1 -1
- package/dist/src/icons.generated/ChevronRight.d.ts +1 -1
- package/dist/src/icons.generated/ChevronRight.d.ts.map +1 -1
- package/dist/src/icons.generated/ChevronUp.d.ts +1 -1
- package/dist/src/icons.generated/ChevronUp.d.ts.map +1 -1
- package/dist/src/icons.generated/Clock.d.ts +1 -1
- package/dist/src/icons.generated/Clock.d.ts.map +1 -1
- package/dist/src/icons.generated/Close.d.ts +1 -1
- package/dist/src/icons.generated/Close.d.ts.map +1 -1
- package/dist/src/icons.generated/CloseCircleFilled.d.ts +1 -1
- package/dist/src/icons.generated/CloseCircleFilled.d.ts.map +1 -1
- package/dist/src/icons.generated/CollapseLeft.d.ts +1 -1
- package/dist/src/icons.generated/CollapseLeft.d.ts.map +1 -1
- package/dist/src/icons.generated/CollapseRight.d.ts +1 -1
- package/dist/src/icons.generated/CollapseRight.d.ts.map +1 -1
- package/dist/src/icons.generated/Copy.d.ts +1 -1
- package/dist/src/icons.generated/Copy.d.ts.map +1 -1
- package/dist/src/icons.generated/DangerDiamond.d.ts +1 -1
- package/dist/src/icons.generated/DangerDiamond.d.ts.map +1 -1
- package/dist/src/icons.generated/DangerDiamondFilled.d.ts +1 -1
- package/dist/src/icons.generated/DangerDiamondFilled.d.ts.map +1 -1
- package/dist/src/icons.generated/Delete.d.ts +1 -1
- package/dist/src/icons.generated/Delete.d.ts.map +1 -1
- package/dist/src/icons.generated/Deny.d.ts +1 -1
- package/dist/src/icons.generated/Deny.d.ts.map +1 -1
- package/dist/src/icons.generated/Devices.d.ts +1 -1
- package/dist/src/icons.generated/Devices.d.ts.map +1 -1
- package/dist/src/icons.generated/Directory.d.ts +1 -1
- package/dist/src/icons.generated/Directory.d.ts.map +1 -1
- package/dist/src/icons.generated/Documentation.d.ts +1 -1
- package/dist/src/icons.generated/Documentation.d.ts.map +1 -1
- package/dist/src/icons.generated/Download.d.ts +1 -1
- package/dist/src/icons.generated/Download.d.ts.map +1 -1
- package/dist/src/icons.generated/DragIndicator.d.ts +1 -1
- package/dist/src/icons.generated/DragIndicator.d.ts.map +1 -1
- package/dist/src/icons.generated/Edit.d.ts +1 -1
- package/dist/src/icons.generated/Edit.d.ts.map +1 -1
- package/dist/src/icons.generated/ExpandLeft.d.ts +1 -1
- package/dist/src/icons.generated/ExpandLeft.d.ts.map +1 -1
- package/dist/src/icons.generated/ExpandRight.d.ts +1 -1
- package/dist/src/icons.generated/ExpandRight.d.ts.map +1 -1
- package/dist/src/icons.generated/ExternalLink.d.ts +1 -1
- package/dist/src/icons.generated/ExternalLink.d.ts.map +1 -1
- package/dist/src/icons.generated/Filter.d.ts +1 -1
- package/dist/src/icons.generated/Filter.d.ts.map +1 -1
- package/dist/src/icons.generated/Folder.d.ts +1 -1
- package/dist/src/icons.generated/Folder.d.ts.map +1 -1
- package/dist/src/icons.generated/Globe.d.ts +1 -1
- package/dist/src/icons.generated/Globe.d.ts.map +1 -1
- package/dist/src/icons.generated/Grid.d.ts +1 -1
- package/dist/src/icons.generated/Grid.d.ts.map +1 -1
- package/dist/src/icons.generated/Group.d.ts +1 -1
- package/dist/src/icons.generated/Group.d.ts.map +1 -1
- package/dist/src/icons.generated/Hide.d.ts +1 -1
- package/dist/src/icons.generated/Hide.d.ts.map +1 -1
- package/dist/src/icons.generated/Home.d.ts +1 -1
- package/dist/src/icons.generated/Home.d.ts.map +1 -1
- package/dist/src/icons.generated/InformationCircle.d.ts +1 -1
- package/dist/src/icons.generated/InformationCircle.d.ts.map +1 -1
- package/dist/src/icons.generated/InformationCircleFilled.d.ts +1 -1
- package/dist/src/icons.generated/InformationCircleFilled.d.ts.map +1 -1
- package/dist/src/icons.generated/Link.d.ts +1 -1
- package/dist/src/icons.generated/Link.d.ts.map +1 -1
- package/dist/src/icons.generated/List.d.ts +1 -1
- package/dist/src/icons.generated/List.d.ts.map +1 -1
- package/dist/src/icons.generated/Lock.d.ts +1 -1
- package/dist/src/icons.generated/Lock.d.ts.map +1 -1
- package/dist/src/icons.generated/More.d.ts +1 -1
- package/dist/src/icons.generated/More.d.ts.map +1 -1
- package/dist/src/icons.generated/Notification.d.ts +1 -1
- package/dist/src/icons.generated/Notification.d.ts.map +1 -1
- package/dist/src/icons.generated/Pause.d.ts +1 -1
- package/dist/src/icons.generated/Pause.d.ts.map +1 -1
- package/dist/src/icons.generated/QuestionCircle.d.ts +1 -1
- package/dist/src/icons.generated/QuestionCircle.d.ts.map +1 -1
- package/dist/src/icons.generated/QuestionCircleFilled.d.ts +1 -1
- package/dist/src/icons.generated/QuestionCircleFilled.d.ts.map +1 -1
- package/dist/src/icons.generated/Refresh.d.ts +1 -1
- package/dist/src/icons.generated/Refresh.d.ts.map +1 -1
- package/dist/src/icons.generated/Reset.d.ts +1 -1
- package/dist/src/icons.generated/Reset.d.ts.map +1 -1
- package/dist/src/icons.generated/Resume.d.ts +1 -1
- package/dist/src/icons.generated/Resume.d.ts.map +1 -1
- package/dist/src/icons.generated/Search.d.ts +1 -1
- package/dist/src/icons.generated/Search.d.ts.map +1 -1
- package/dist/src/icons.generated/Server.d.ts +1 -1
- package/dist/src/icons.generated/Server.d.ts.map +1 -1
- package/dist/src/icons.generated/Settings.d.ts +1 -1
- package/dist/src/icons.generated/Settings.d.ts.map +1 -1
- package/dist/src/icons.generated/Show.d.ts +1 -1
- package/dist/src/icons.generated/Show.d.ts.map +1 -1
- package/dist/src/icons.generated/Subtract.d.ts +1 -1
- package/dist/src/icons.generated/Subtract.d.ts.map +1 -1
- package/dist/src/icons.generated/Sync.d.ts +1 -1
- package/dist/src/icons.generated/Sync.d.ts.map +1 -1
- package/dist/src/icons.generated/Unlock.d.ts +1 -1
- package/dist/src/icons.generated/Unlock.d.ts.map +1 -1
- package/dist/src/icons.generated/Upload.d.ts +1 -1
- package/dist/src/icons.generated/Upload.d.ts.map +1 -1
- package/dist/src/icons.generated/User.d.ts +1 -1
- package/dist/src/icons.generated/User.d.ts.map +1 -1
- package/dist/src/icons.generated/Video.d.ts +1 -1
- package/dist/src/icons.generated/Video.d.ts.map +1 -1
- package/dist/src/icons.generated/Warning.d.ts +1 -1
- package/dist/src/icons.generated/Warning.d.ts.map +1 -1
- package/dist/src/icons.generated/WarningFilled.d.ts +1 -1
- package/dist/src/icons.generated/WarningFilled.d.ts.map +1 -1
- package/dist/src/icons.generated/index.d.ts +1 -1
- package/dist/src/index.d.ts.map +1 -1
- package/dist/src/labs/DataFilters.d.ts +1 -1
- package/dist/src/labs/DataFilters.d.ts.map +1 -1
- package/dist/src/labs/DataTable.d.ts +1 -1
- package/dist/src/labs/DataTable.d.ts.map +1 -1
- package/dist/src/labs/DataTablePagination.d.ts +1 -1
- package/dist/src/labs/DataTablePagination.d.ts.map +1 -1
- package/dist/src/labs/DatePicker.d.ts +1 -1
- package/dist/src/labs/DatePicker.d.ts.map +1 -1
- package/dist/src/labs/Drawer.d.ts +56 -0
- package/dist/src/labs/Drawer.d.ts.map +1 -0
- package/dist/src/labs/GroupPicker.d.ts +1 -1
- package/dist/src/labs/GroupPicker.d.ts.map +1 -1
- package/dist/src/labs/PaginatedTable.d.ts +1 -1
- package/dist/src/labs/PaginatedTable.d.ts.map +1 -1
- package/dist/src/labs/StaticTable.d.ts +1 -1
- package/dist/src/labs/StaticTable.d.ts.map +1 -1
- package/dist/src/labs/Switch.d.ts +2 -2
- package/dist/src/labs/Switch.d.ts.map +1 -1
- package/dist/src/labs/VirtualizedAutocomplete.d.ts +2 -2
- package/dist/src/labs/VirtualizedAutocomplete.d.ts.map +1 -1
- package/dist/src/labs/datePickerTheme.d.ts.map +1 -1
- package/dist/src/labs/index.d.ts +1 -0
- package/dist/src/labs/index.d.ts.map +1 -1
- package/dist/src/properties/ts/odyssey-react-mui_cs.d.ts +3 -1
- package/dist/src/properties/ts/odyssey-react-mui_cs.d.ts.map +1 -1
- package/dist/src/properties/ts/odyssey-react-mui_da.d.ts +3 -1
- package/dist/src/properties/ts/odyssey-react-mui_da.d.ts.map +1 -1
- package/dist/src/properties/ts/odyssey-react-mui_de.d.ts +3 -1
- package/dist/src/properties/ts/odyssey-react-mui_de.d.ts.map +1 -1
- package/dist/src/properties/ts/odyssey-react-mui_el.d.ts +3 -1
- package/dist/src/properties/ts/odyssey-react-mui_el.d.ts.map +1 -1
- package/dist/src/properties/ts/odyssey-react-mui_es.d.ts +3 -1
- package/dist/src/properties/ts/odyssey-react-mui_es.d.ts.map +1 -1
- package/dist/src/properties/ts/odyssey-react-mui_fi.d.ts +3 -1
- package/dist/src/properties/ts/odyssey-react-mui_fi.d.ts.map +1 -1
- package/dist/src/properties/ts/odyssey-react-mui_fr.d.ts +3 -1
- package/dist/src/properties/ts/odyssey-react-mui_fr.d.ts.map +1 -1
- package/dist/src/properties/ts/odyssey-react-mui_hu.d.ts +3 -1
- package/dist/src/properties/ts/odyssey-react-mui_hu.d.ts.map +1 -1
- package/dist/src/properties/ts/odyssey-react-mui_id.d.ts +3 -1
- package/dist/src/properties/ts/odyssey-react-mui_id.d.ts.map +1 -1
- package/dist/src/properties/ts/odyssey-react-mui_it.d.ts +3 -1
- package/dist/src/properties/ts/odyssey-react-mui_it.d.ts.map +1 -1
- package/dist/src/properties/ts/odyssey-react-mui_ja.d.ts +3 -1
- package/dist/src/properties/ts/odyssey-react-mui_ja.d.ts.map +1 -1
- package/dist/src/properties/ts/odyssey-react-mui_ko.d.ts +3 -1
- package/dist/src/properties/ts/odyssey-react-mui_ko.d.ts.map +1 -1
- package/dist/src/properties/ts/odyssey-react-mui_ms.d.ts +3 -1
- package/dist/src/properties/ts/odyssey-react-mui_ms.d.ts.map +1 -1
- package/dist/src/properties/ts/odyssey-react-mui_nb.d.ts +3 -1
- package/dist/src/properties/ts/odyssey-react-mui_nb.d.ts.map +1 -1
- package/dist/src/properties/ts/odyssey-react-mui_nl_NL.d.ts +3 -1
- package/dist/src/properties/ts/odyssey-react-mui_nl_NL.d.ts.map +1 -1
- package/dist/src/properties/ts/odyssey-react-mui_pl.d.ts +3 -1
- package/dist/src/properties/ts/odyssey-react-mui_pl.d.ts.map +1 -1
- package/dist/src/properties/ts/odyssey-react-mui_pt_BR.d.ts +3 -1
- package/dist/src/properties/ts/odyssey-react-mui_pt_BR.d.ts.map +1 -1
- package/dist/src/properties/ts/odyssey-react-mui_ro.d.ts +3 -1
- package/dist/src/properties/ts/odyssey-react-mui_ro.d.ts.map +1 -1
- package/dist/src/properties/ts/odyssey-react-mui_ru.d.ts +3 -1
- package/dist/src/properties/ts/odyssey-react-mui_ru.d.ts.map +1 -1
- package/dist/src/properties/ts/odyssey-react-mui_sv.d.ts +3 -1
- package/dist/src/properties/ts/odyssey-react-mui_sv.d.ts.map +1 -1
- package/dist/src/properties/ts/odyssey-react-mui_th.d.ts +3 -1
- package/dist/src/properties/ts/odyssey-react-mui_th.d.ts.map +1 -1
- package/dist/src/properties/ts/odyssey-react-mui_tr.d.ts +3 -1
- package/dist/src/properties/ts/odyssey-react-mui_tr.d.ts.map +1 -1
- package/dist/src/properties/ts/odyssey-react-mui_uk.d.ts +3 -1
- package/dist/src/properties/ts/odyssey-react-mui_uk.d.ts.map +1 -1
- package/dist/src/properties/ts/odyssey-react-mui_vi.d.ts +3 -1
- package/dist/src/properties/ts/odyssey-react-mui_vi.d.ts.map +1 -1
- package/dist/src/properties/ts/odyssey-react-mui_zh_CN.d.ts +3 -1
- package/dist/src/properties/ts/odyssey-react-mui_zh_CN.d.ts.map +1 -1
- package/dist/src/properties/ts/odyssey-react-mui_zh_TW.d.ts +3 -1
- package/dist/src/properties/ts/odyssey-react-mui_zh_TW.d.ts.map +1 -1
- package/dist/src/theme/components.d.ts.map +1 -1
- package/dist/theme/components.js +60 -8
- package/dist/theme/components.js.map +1 -1
- package/dist/tsconfig.production.tsbuildinfo +1 -1
- package/package.json +15 -15
- package/scripts/generateIconsIndex.ts +2 -2
- package/scripts/{properties-to-ts.js → properties-to-ts.ts} +55 -41
- package/src/@types/properties.d.ts +292 -0
- package/src/Accordion.tsx +1 -1
- package/src/Autocomplete.tsx +17 -9
- package/src/Badge.tsx +1 -1
- package/src/Banner.tsx +1 -1
- package/src/Box.tsx +2 -2
- package/src/Breadcrumbs.tsx +2 -2
- package/src/Button.tsx +26 -38
- package/src/Callout.tsx +1 -1
- package/src/Checkbox.tsx +9 -29
- package/src/CheckboxGroup.tsx +20 -5
- package/src/CircularProgress.tsx +1 -5
- package/src/Dialog.tsx +18 -17
- package/src/ErrorMessageList.tsx +1 -1
- package/src/Field.tsx +6 -9
- package/src/FieldComponentProps.ts +8 -4
- package/src/FieldError.tsx +2 -2
- package/src/FieldHint.tsx +1 -1
- package/src/FieldLabel.tsx +2 -2
- package/src/Fieldset.tsx +2 -2
- package/src/Form.tsx +1 -1
- package/src/FormCheckedProps.ts +3 -3
- package/src/HintLink.tsx +1 -1
- package/src/HtmlProps.ts +60 -0
- package/src/Link.tsx +2 -6
- package/src/MenuButton.tsx +21 -36
- package/src/MenuItem.tsx +2 -2
- package/src/MuiPropsChild.tsx +2 -2
- package/src/NativeSelect.tsx +24 -13
- package/src/OdysseyCacheProvider.test.tsx +3 -3
- package/src/OdysseyProvider.tsx +1 -3
- package/src/OdysseyThemeProvider.tsx +8 -35
- package/src/OdysseyTranslationProvider.test.tsx +6 -6
- package/src/OdysseyTranslationProvider.tsx +7 -7
- package/src/PasswordField.tsx +23 -10
- package/src/Radio.tsx +4 -4
- package/src/RadioGroup.tsx +22 -7
- package/src/ScreenReaderText.tsx +1 -1
- package/src/SearchField.tsx +25 -12
- package/src/Select.tsx +219 -77
- package/src/Status.tsx +8 -2
- package/src/Tabs.tsx +7 -11
- package/src/Tag.tsx +4 -4
- package/src/TagList.tsx +2 -2
- package/src/TextField.tsx +22 -9
- package/src/Tile.tsx +74 -43
- package/src/Toast.tsx +1 -1
- package/src/Tooltip.tsx +1 -1
- package/src/Typography.tsx +20 -28
- package/src/createShadowRootElement.ts +1 -1
- package/src/getTypedObjectKeys.ts +1 -1
- package/src/icons.generated/AddCircle.tsx +1 -1
- package/src/icons.generated/Apps.tsx +1 -1
- package/src/icons.generated/ArrowBottom.tsx +1 -1
- package/src/icons.generated/ArrowDown.tsx +1 -1
- package/src/icons.generated/ArrowLeft.tsx +1 -1
- package/src/icons.generated/ArrowRight.tsx +1 -1
- package/src/icons.generated/ArrowTop.tsx +1 -1
- package/src/icons.generated/ArrowUp.tsx +1 -1
- package/src/icons.generated/Calendar.tsx +1 -1
- package/src/icons.generated/Call.tsx +1 -1
- package/src/icons.generated/Chat.tsx +1 -1
- package/src/icons.generated/Check.tsx +1 -1
- package/src/icons.generated/ChevronDown.tsx +1 -1
- package/src/icons.generated/ChevronLeft.tsx +1 -1
- package/src/icons.generated/ChevronUp.tsx +1 -1
- package/src/icons.generated/Clock.tsx +1 -1
- package/src/icons.generated/Close.tsx +1 -1
- package/src/icons.generated/Copy.tsx +1 -1
- package/src/icons.generated/Delete.tsx +1 -1
- package/src/icons.generated/Deny.tsx +1 -1
- package/src/icons.generated/Devices.tsx +1 -1
- package/src/icons.generated/Directory.tsx +1 -1
- package/src/icons.generated/Download.tsx +1 -1
- package/src/icons.generated/Edit.tsx +1 -1
- package/src/icons.generated/ExpandLeft.tsx +1 -1
- package/src/icons.generated/ExpandRight.tsx +1 -1
- package/src/icons.generated/Filter.tsx +1 -1
- package/src/icons.generated/Folder.tsx +1 -1
- package/src/icons.generated/Globe.tsx +1 -1
- package/src/icons.generated/Grid.tsx +1 -1
- package/src/icons.generated/Group.tsx +1 -1
- package/src/icons.generated/Hide.tsx +1 -1
- package/src/icons.generated/Home.tsx +1 -1
- package/src/icons.generated/Link.tsx +1 -1
- package/src/icons.generated/List.tsx +1 -1
- package/src/icons.generated/Lock.tsx +1 -1
- package/src/icons.generated/More.tsx +1 -1
- package/src/icons.generated/Pause.tsx +1 -1
- package/src/icons.generated/Refresh.tsx +1 -1
- package/src/icons.generated/Reset.tsx +1 -1
- package/src/icons.generated/Resume.tsx +1 -1
- package/src/icons.generated/Search.tsx +1 -1
- package/src/icons.generated/Server.tsx +1 -1
- package/src/icons.generated/Settings.tsx +1 -1
- package/src/icons.generated/Show.tsx +1 -1
- package/src/icons.generated/Subtract.tsx +1 -1
- package/src/icons.generated/Sync.tsx +1 -1
- package/src/icons.generated/Unlock.tsx +1 -1
- package/src/icons.generated/Upload.tsx +1 -1
- package/src/icons.generated/User.tsx +1 -1
- package/src/icons.generated/Video.tsx +1 -1
- package/src/icons.generated/Warning.tsx +1 -1
- package/src/icons.generated/index.ts +1 -1
- package/src/index.ts +0 -1
- package/src/labs/DataFilters.tsx +36 -30
- package/src/labs/DataTable.tsx +20 -20
- package/src/labs/DatePicker.tsx +3 -1
- package/src/labs/Drawer.tsx +254 -0
- package/src/labs/GroupPicker.tsx +34 -15
- package/src/labs/PaginatedTable.tsx +12 -10
- package/src/labs/StaticTable.tsx +3 -3
- package/src/labs/Switch.tsx +5 -5
- package/src/labs/VirtualizedAutocomplete.tsx +19 -16
- package/src/labs/datePickerTheme.tsx +4 -2
- package/src/labs/index.ts +2 -0
- package/src/labs/materialReactTableTypes.tsx +1 -1
- package/src/properties/translations/odyssey-react-mui_cs.properties +3 -1
- package/src/properties/translations/odyssey-react-mui_da.properties +3 -1
- package/src/properties/translations/odyssey-react-mui_de.properties +3 -1
- package/src/properties/translations/odyssey-react-mui_el.properties +3 -1
- package/src/properties/translations/odyssey-react-mui_es.properties +3 -1
- package/src/properties/translations/odyssey-react-mui_fi.properties +3 -1
- package/src/properties/translations/odyssey-react-mui_fr.properties +3 -1
- package/src/properties/translations/odyssey-react-mui_hu.properties +3 -1
- package/src/properties/translations/odyssey-react-mui_id.properties +3 -1
- package/src/properties/translations/odyssey-react-mui_it.properties +3 -1
- package/src/properties/translations/odyssey-react-mui_ja.properties +3 -1
- package/src/properties/translations/odyssey-react-mui_ko.properties +3 -1
- package/src/properties/translations/odyssey-react-mui_ms.properties +3 -1
- package/src/properties/translations/odyssey-react-mui_nb.properties +3 -1
- package/src/properties/translations/odyssey-react-mui_nl_NL.properties +3 -1
- package/src/properties/translations/odyssey-react-mui_pl.properties +3 -1
- package/src/properties/translations/odyssey-react-mui_pt_BR.properties +3 -1
- package/src/properties/translations/odyssey-react-mui_ro.properties +3 -1
- package/src/properties/translations/odyssey-react-mui_ru.properties +3 -1
- package/src/properties/translations/odyssey-react-mui_sv.properties +3 -1
- package/src/properties/translations/odyssey-react-mui_th.properties +3 -1
- package/src/properties/translations/odyssey-react-mui_tr.properties +3 -1
- package/src/properties/translations/odyssey-react-mui_uk.properties +3 -1
- package/src/properties/translations/odyssey-react-mui_vi.properties +3 -1
- package/src/properties/translations/odyssey-react-mui_zh_CN.properties +3 -1
- package/src/properties/translations/odyssey-react-mui_zh_TW.properties +3 -1
- package/src/properties/ts/odyssey-react-mui_cs.ts +1 -1
- package/src/properties/ts/odyssey-react-mui_da.ts +1 -1
- package/src/properties/ts/odyssey-react-mui_de.ts +1 -1
- package/src/properties/ts/odyssey-react-mui_el.ts +1 -1
- package/src/properties/ts/odyssey-react-mui_es.ts +1 -1
- package/src/properties/ts/odyssey-react-mui_fi.ts +1 -1
- package/src/properties/ts/odyssey-react-mui_fr.ts +1 -1
- package/src/properties/ts/odyssey-react-mui_hu.ts +1 -1
- package/src/properties/ts/odyssey-react-mui_id.ts +1 -1
- package/src/properties/ts/odyssey-react-mui_it.ts +1 -1
- package/src/properties/ts/odyssey-react-mui_ja.ts +1 -1
- package/src/properties/ts/odyssey-react-mui_ko.ts +1 -1
- package/src/properties/ts/odyssey-react-mui_ms.ts +1 -1
- package/src/properties/ts/odyssey-react-mui_nb.ts +1 -1
- package/src/properties/ts/odyssey-react-mui_nl_NL.ts +1 -1
- package/src/properties/ts/odyssey-react-mui_pl.ts +1 -1
- package/src/properties/ts/odyssey-react-mui_pt_BR.ts +1 -1
- package/src/properties/ts/odyssey-react-mui_ro.ts +1 -1
- package/src/properties/ts/odyssey-react-mui_ru.ts +1 -1
- package/src/properties/ts/odyssey-react-mui_sv.ts +1 -1
- package/src/properties/ts/odyssey-react-mui_th.ts +1 -1
- package/src/properties/ts/odyssey-react-mui_tr.ts +1 -1
- package/src/properties/ts/odyssey-react-mui_uk.ts +1 -1
- package/src/properties/ts/odyssey-react-mui_vi.ts +1 -1
- package/src/properties/ts/odyssey-react-mui_zh_CN.ts +1 -1
- package/src/properties/ts/odyssey-react-mui_zh_TW.ts +1 -1
- package/src/theme/components.tsx +83 -16
- package/tsconfig.json +0 -3
package/src/Radio.tsx
CHANGED
|
@@ -52,7 +52,7 @@ export type RadioProps = {
|
|
|
52
52
|
*/
|
|
53
53
|
onBlur?: MuiFormControlLabelProps["onBlur"];
|
|
54
54
|
} & Pick<FieldComponentProps, "isDisabled" | "name"> &
|
|
55
|
-
HtmlProps
|
|
55
|
+
Pick<HtmlProps, "testId" | "translate">;
|
|
56
56
|
|
|
57
57
|
const Radio = ({
|
|
58
58
|
inputRef,
|
|
@@ -77,21 +77,21 @@ const Radio = ({
|
|
|
77
77
|
},
|
|
78
78
|
};
|
|
79
79
|
},
|
|
80
|
-
[]
|
|
80
|
+
[],
|
|
81
81
|
);
|
|
82
82
|
|
|
83
83
|
const onChange = useCallback<NonNullable<MuiRadioProps["onChange"]>>(
|
|
84
84
|
(event, checked) => {
|
|
85
85
|
onChangeProp?.(event, checked);
|
|
86
86
|
},
|
|
87
|
-
[onChangeProp]
|
|
87
|
+
[onChangeProp],
|
|
88
88
|
);
|
|
89
89
|
|
|
90
90
|
const onBlur = useCallback<NonNullable<MuiFormControlLabelProps["onBlur"]>>(
|
|
91
91
|
(event) => {
|
|
92
92
|
onBlurProp?.(event);
|
|
93
93
|
},
|
|
94
|
-
[onBlurProp]
|
|
94
|
+
[onBlurProp],
|
|
95
95
|
);
|
|
96
96
|
|
|
97
97
|
return (
|
package/src/RadioGroup.tsx
CHANGED
|
@@ -18,7 +18,10 @@ import { memo, ReactElement, useCallback, useRef } from "react";
|
|
|
18
18
|
|
|
19
19
|
import { Radio, RadioProps } from "./Radio";
|
|
20
20
|
import { Field } from "./Field";
|
|
21
|
-
import {
|
|
21
|
+
import {
|
|
22
|
+
FieldComponentProps,
|
|
23
|
+
FieldComponentRenderProps,
|
|
24
|
+
} from "./FieldComponentProps";
|
|
22
25
|
import type { HtmlProps } from "./HtmlProps";
|
|
23
26
|
import { getControlState, useInputValues } from "./inputUtils";
|
|
24
27
|
|
|
@@ -45,7 +48,6 @@ export type RadioGroupProps = {
|
|
|
45
48
|
value?: RadioProps["value"];
|
|
46
49
|
} & Pick<
|
|
47
50
|
FieldComponentProps,
|
|
48
|
-
| "ariaDescribedBy"
|
|
49
51
|
| "errorMessage"
|
|
50
52
|
| "errorMessageList"
|
|
51
53
|
| "hint"
|
|
@@ -54,7 +56,12 @@ export type RadioGroupProps = {
|
|
|
54
56
|
| "isDisabled"
|
|
55
57
|
| "name"
|
|
56
58
|
> &
|
|
57
|
-
HtmlProps
|
|
59
|
+
Pick<HtmlProps, "ariaDescribedBy" | "testId" | "translate">;
|
|
60
|
+
|
|
61
|
+
type FieldRenderProps = Partial<
|
|
62
|
+
Pick<FieldComponentRenderProps, "ariaDescribedBy" | "errorMessageElementId">
|
|
63
|
+
> &
|
|
64
|
+
Pick<FieldComponentRenderProps, "id" | "labelElementId">;
|
|
58
65
|
|
|
59
66
|
const RadioGroup = ({
|
|
60
67
|
ariaDescribedBy,
|
|
@@ -74,7 +81,10 @@ const RadioGroup = ({
|
|
|
74
81
|
value,
|
|
75
82
|
}: RadioGroupProps) => {
|
|
76
83
|
const controlledStateRef = useRef(
|
|
77
|
-
getControlState({
|
|
84
|
+
getControlState({
|
|
85
|
+
controlledValue: value,
|
|
86
|
+
uncontrolledValue: defaultValue,
|
|
87
|
+
}),
|
|
78
88
|
);
|
|
79
89
|
const inputValues = useInputValues({
|
|
80
90
|
defaultValue,
|
|
@@ -86,10 +96,15 @@ const RadioGroup = ({
|
|
|
86
96
|
(event, value) => {
|
|
87
97
|
onChangeProp?.(event, value);
|
|
88
98
|
},
|
|
89
|
-
[onChangeProp]
|
|
99
|
+
[onChangeProp],
|
|
90
100
|
);
|
|
91
101
|
const renderFieldComponent = useCallback(
|
|
92
|
-
({
|
|
102
|
+
({
|
|
103
|
+
ariaDescribedBy,
|
|
104
|
+
errorMessageElementId,
|
|
105
|
+
id,
|
|
106
|
+
labelElementId,
|
|
107
|
+
}: FieldRenderProps) => (
|
|
93
108
|
<MuiRadioGroup
|
|
94
109
|
{...inputValues}
|
|
95
110
|
aria-describedby={ariaDescribedBy}
|
|
@@ -104,7 +119,7 @@ const RadioGroup = ({
|
|
|
104
119
|
{children}
|
|
105
120
|
</MuiRadioGroup>
|
|
106
121
|
),
|
|
107
|
-
[children, inputValues, nameOverride, onChange, testId, translate]
|
|
122
|
+
[children, inputValues, nameOverride, onChange, testId, translate],
|
|
108
123
|
);
|
|
109
124
|
|
|
110
125
|
return (
|
package/src/ScreenReaderText.tsx
CHANGED
package/src/SearchField.tsx
CHANGED
|
@@ -24,10 +24,15 @@ import {
|
|
|
24
24
|
|
|
25
25
|
import { CloseCircleFilledIcon, SearchIcon } from "./icons.generated";
|
|
26
26
|
import { Field } from "./Field";
|
|
27
|
-
import {
|
|
27
|
+
import {
|
|
28
|
+
FieldComponentProps,
|
|
29
|
+
FieldComponentRenderProps,
|
|
30
|
+
} from "./FieldComponentProps";
|
|
28
31
|
import type { HtmlProps } from "./HtmlProps";
|
|
29
32
|
import { getControlState, useInputValues } from "./inputUtils";
|
|
30
33
|
|
|
34
|
+
export const searchVariantValues = ["outline", "filled"] as const;
|
|
35
|
+
|
|
31
36
|
export type SearchFieldProps = {
|
|
32
37
|
/**
|
|
33
38
|
* This prop helps users to fill forms faster, especially on mobile devices.
|
|
@@ -81,11 +86,15 @@ export type SearchFieldProps = {
|
|
|
81
86
|
* The value of the `input` element, to use when controlled.
|
|
82
87
|
*/
|
|
83
88
|
value?: string;
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
+
/**
|
|
90
|
+
* Whether the SearchField has a gray or white background
|
|
91
|
+
*/
|
|
92
|
+
variant?: (typeof searchVariantValues)[number];
|
|
93
|
+
} & Pick<FieldComponentProps, "id" | "isDisabled" | "name" | "isFullWidth"> &
|
|
94
|
+
Pick<HtmlProps, "ariaDescribedBy" | "testId" | "translate">;
|
|
95
|
+
|
|
96
|
+
type FieldRenderProps = Partial<Pick<HtmlProps, "ariaDescribedBy">> &
|
|
97
|
+
Pick<FieldComponentRenderProps, "id">;
|
|
89
98
|
|
|
90
99
|
const SearchField = forwardRef<HTMLInputElement, SearchFieldProps>(
|
|
91
100
|
(
|
|
@@ -108,15 +117,16 @@ const SearchField = forwardRef<HTMLInputElement, SearchFieldProps>(
|
|
|
108
117
|
testId,
|
|
109
118
|
translate,
|
|
110
119
|
value,
|
|
120
|
+
variant = "outline",
|
|
111
121
|
},
|
|
112
|
-
ref
|
|
122
|
+
ref,
|
|
113
123
|
) => {
|
|
114
124
|
const onChange: ChangeEventHandler<HTMLTextAreaElement | HTMLInputElement> =
|
|
115
125
|
useCallback(
|
|
116
126
|
(event) => {
|
|
117
127
|
onChangeProp?.(event);
|
|
118
128
|
},
|
|
119
|
-
[onChangeProp]
|
|
129
|
+
[onChangeProp],
|
|
120
130
|
);
|
|
121
131
|
|
|
122
132
|
const onClear = useCallback(() => {
|
|
@@ -127,7 +137,7 @@ const SearchField = forwardRef<HTMLInputElement, SearchFieldProps>(
|
|
|
127
137
|
getControlState({
|
|
128
138
|
controlledValue: value,
|
|
129
139
|
uncontrolledValue: defaultValue,
|
|
130
|
-
})
|
|
140
|
+
}),
|
|
131
141
|
);
|
|
132
142
|
const inputValues = useInputValues({
|
|
133
143
|
defaultValue,
|
|
@@ -136,7 +146,7 @@ const SearchField = forwardRef<HTMLInputElement, SearchFieldProps>(
|
|
|
136
146
|
});
|
|
137
147
|
|
|
138
148
|
const renderFieldComponent = useCallback(
|
|
139
|
-
({ ariaDescribedBy, id }) => (
|
|
149
|
+
({ ariaDescribedBy, id }: FieldRenderProps) => (
|
|
140
150
|
<InputBase
|
|
141
151
|
{...inputValues}
|
|
142
152
|
inputProps={{
|
|
@@ -162,6 +172,8 @@ const SearchField = forwardRef<HTMLInputElement, SearchFieldProps>(
|
|
|
162
172
|
)
|
|
163
173
|
}
|
|
164
174
|
id={id}
|
|
175
|
+
data-ods-type="search"
|
|
176
|
+
data-ods-variant={variant}
|
|
165
177
|
name={nameOverride ?? id}
|
|
166
178
|
onBlur={onBlur}
|
|
167
179
|
onChange={onChange}
|
|
@@ -193,7 +205,8 @@ const SearchField = forwardRef<HTMLInputElement, SearchFieldProps>(
|
|
|
193
205
|
tabIndex,
|
|
194
206
|
testId,
|
|
195
207
|
translate,
|
|
196
|
-
|
|
208
|
+
variant,
|
|
209
|
+
],
|
|
197
210
|
);
|
|
198
211
|
|
|
199
212
|
return (
|
|
@@ -209,7 +222,7 @@ const SearchField = forwardRef<HTMLInputElement, SearchFieldProps>(
|
|
|
209
222
|
renderFieldComponent={renderFieldComponent}
|
|
210
223
|
/>
|
|
211
224
|
);
|
|
212
|
-
}
|
|
225
|
+
},
|
|
213
226
|
);
|
|
214
227
|
|
|
215
228
|
const MemoizedSearchField = memo(SearchField);
|
package/src/Select.tsx
CHANGED
|
@@ -18,21 +18,26 @@ import {
|
|
|
18
18
|
useRef,
|
|
19
19
|
useState,
|
|
20
20
|
useImperativeHandle,
|
|
21
|
+
MouseEvent,
|
|
21
22
|
} from "react";
|
|
22
23
|
import {
|
|
23
|
-
Box,
|
|
24
|
+
Box as MuiBox,
|
|
24
25
|
Checkbox as MuiCheckbox,
|
|
25
|
-
Chip,
|
|
26
|
+
Chip as MuiChip,
|
|
26
27
|
ListItemSecondaryAction,
|
|
27
28
|
ListSubheader,
|
|
28
|
-
MenuItem,
|
|
29
|
+
MenuItem as MuiMenuItem,
|
|
29
30
|
Select as MuiSelect,
|
|
31
|
+
SelectChangeEvent,
|
|
30
32
|
} from "@mui/material";
|
|
31
33
|
import { SelectProps as MuiSelectProps } from "@mui/material";
|
|
32
34
|
|
|
33
35
|
import { Field } from "./Field";
|
|
34
|
-
import {
|
|
35
|
-
|
|
36
|
+
import {
|
|
37
|
+
FieldComponentProps,
|
|
38
|
+
FieldComponentRenderProps,
|
|
39
|
+
} from "./FieldComponentProps";
|
|
40
|
+
import { CheckIcon, CloseCircleFilledIcon } from "./icons.generated";
|
|
36
41
|
import type { HtmlProps } from "./HtmlProps";
|
|
37
42
|
import {
|
|
38
43
|
ComponentControlledState,
|
|
@@ -41,6 +46,12 @@ import {
|
|
|
41
46
|
getControlState,
|
|
42
47
|
} from "./inputUtils";
|
|
43
48
|
import { normalizedKey } from "./useNormalizedKey";
|
|
49
|
+
import styled from "@emotion/styled";
|
|
50
|
+
|
|
51
|
+
import {
|
|
52
|
+
useOdysseyDesignTokens,
|
|
53
|
+
DesignTokens,
|
|
54
|
+
} from "./OdysseyDesignTokensContext";
|
|
44
55
|
|
|
45
56
|
export type SelectOption = {
|
|
46
57
|
text: string;
|
|
@@ -48,12 +59,73 @@ export type SelectOption = {
|
|
|
48
59
|
value?: string;
|
|
49
60
|
};
|
|
50
61
|
|
|
62
|
+
const SelectContainer = styled.div`
|
|
63
|
+
position: relative;
|
|
64
|
+
width: 100%;
|
|
65
|
+
display: flex;
|
|
66
|
+
`;
|
|
67
|
+
|
|
68
|
+
const ChipsPositioningContainer = styled("div", {
|
|
69
|
+
shouldForwardProp: (prop) => prop !== "odysseyDesignTokens",
|
|
70
|
+
})<{
|
|
71
|
+
odysseyDesignTokens: DesignTokens;
|
|
72
|
+
}>`
|
|
73
|
+
display: flex;
|
|
74
|
+
align-items: center;
|
|
75
|
+
position: absolute;
|
|
76
|
+
top: ${({ odysseyDesignTokens }) => odysseyDesignTokens.Spacing0};
|
|
77
|
+
right: ${({ odysseyDesignTokens }) => odysseyDesignTokens.Spacing5};
|
|
78
|
+
bottom: ${({ odysseyDesignTokens }) => odysseyDesignTokens.Spacing0};
|
|
79
|
+
left: ${({ odysseyDesignTokens }) => odysseyDesignTokens.Spacing1};
|
|
80
|
+
margin-inline-start: ${({ odysseyDesignTokens }) =>
|
|
81
|
+
odysseyDesignTokens.BorderWidthMain};
|
|
82
|
+
opacity: 1;
|
|
83
|
+
pointer-events: none;
|
|
84
|
+
`;
|
|
85
|
+
|
|
86
|
+
const NonInteractiveIcon = styled(CloseCircleFilledIcon, {
|
|
87
|
+
shouldForwardProp: (prop) => prop !== "odysseyDesignTokens",
|
|
88
|
+
})<{
|
|
89
|
+
odysseyDesignTokens: DesignTokens;
|
|
90
|
+
}>`
|
|
91
|
+
font-size: 1em;
|
|
92
|
+
margin-inline-start: ${({ odysseyDesignTokens }) =>
|
|
93
|
+
odysseyDesignTokens.Spacing2};
|
|
94
|
+
margin-inline-end: -${({ odysseyDesignTokens }) => odysseyDesignTokens.Spacing1};
|
|
95
|
+
`;
|
|
96
|
+
|
|
97
|
+
const ChipsInnerContainer = styled(MuiBox, {
|
|
98
|
+
shouldForwardProp: (prop) =>
|
|
99
|
+
prop !== "odysseyDesignTokens" && prop !== "isInteractive",
|
|
100
|
+
})<{
|
|
101
|
+
isInteractive?: boolean;
|
|
102
|
+
odysseyDesignTokens: DesignTokens;
|
|
103
|
+
}>`
|
|
104
|
+
display: flex;
|
|
105
|
+
flex-wrap: wrap;
|
|
106
|
+
gap: ${({ odysseyDesignTokens }) => odysseyDesignTokens.Spacing1};
|
|
107
|
+
pointer-events: ${({ isInteractive }) => (isInteractive ? "auto" : "none")};
|
|
108
|
+
opacity: ${({ isInteractive }) => (isInteractive ? 1 : 0)};
|
|
109
|
+
`;
|
|
110
|
+
|
|
111
|
+
const ChipsSpacer = styled("div", {
|
|
112
|
+
shouldForwardProp: (prop) => prop !== "odysseyDesignTokens",
|
|
113
|
+
})<{
|
|
114
|
+
odysseyDesignTokens: DesignTokens;
|
|
115
|
+
}>`
|
|
116
|
+
display: inline-block;
|
|
117
|
+
border-color: transparent;
|
|
118
|
+
border-style: solid none;
|
|
119
|
+
border-width: 1px;
|
|
120
|
+
height: ${({ odysseyDesignTokens }) => odysseyDesignTokens.Spacing6};
|
|
121
|
+
`;
|
|
122
|
+
|
|
51
123
|
export type SelectValueType<HasMultipleChoices> =
|
|
52
124
|
HasMultipleChoices extends true ? string[] : string;
|
|
53
125
|
|
|
54
126
|
export type SelectProps<
|
|
55
127
|
Value extends SelectValueType<HasMultipleChoices>,
|
|
56
|
-
HasMultipleChoices extends boolean
|
|
128
|
+
HasMultipleChoices extends boolean,
|
|
57
129
|
> = {
|
|
58
130
|
/**
|
|
59
131
|
* The default value. Use when the component is not controlled.
|
|
@@ -98,7 +170,6 @@ export type SelectProps<
|
|
|
98
170
|
value?: Value;
|
|
99
171
|
} & Pick<
|
|
100
172
|
FieldComponentProps,
|
|
101
|
-
| "ariaDescribedBy"
|
|
102
173
|
| "errorMessage"
|
|
103
174
|
| "errorMessageList"
|
|
104
175
|
| "hint"
|
|
@@ -109,7 +180,12 @@ export type SelectProps<
|
|
|
109
180
|
| "isOptional"
|
|
110
181
|
| "name"
|
|
111
182
|
> &
|
|
112
|
-
HtmlProps
|
|
183
|
+
Pick<HtmlProps, "ariaDescribedBy" | "testId" | "translate">;
|
|
184
|
+
|
|
185
|
+
type SelectRenderProps = Partial<
|
|
186
|
+
Pick<FieldComponentRenderProps, "ariaDescribedBy" | "errorMessageElementId">
|
|
187
|
+
> &
|
|
188
|
+
Pick<FieldComponentRenderProps, "id" | "labelElementId">;
|
|
113
189
|
|
|
114
190
|
/**
|
|
115
191
|
* Options in Odyssey <Select> are passed as an array, which can contain any combination
|
|
@@ -129,7 +205,7 @@ export type SelectProps<
|
|
|
129
205
|
const { CONTROLLED } = ComponentControlledState;
|
|
130
206
|
const Select = <
|
|
131
207
|
Value extends SelectValueType<HasMultipleChoices>,
|
|
132
|
-
HasMultipleChoices extends boolean
|
|
208
|
+
HasMultipleChoices extends boolean,
|
|
133
209
|
>({
|
|
134
210
|
ariaDescribedBy,
|
|
135
211
|
defaultValue,
|
|
@@ -159,15 +235,19 @@ const Select = <
|
|
|
159
235
|
hasMultipleChoicesProp === undefined
|
|
160
236
|
? isMultiSelect
|
|
161
237
|
: hasMultipleChoicesProp,
|
|
162
|
-
[hasMultipleChoicesProp, isMultiSelect]
|
|
238
|
+
[hasMultipleChoicesProp, isMultiSelect],
|
|
163
239
|
);
|
|
164
240
|
const controlledStateRef = useRef(
|
|
165
|
-
getControlState({
|
|
241
|
+
getControlState({
|
|
242
|
+
controlledValue: value,
|
|
243
|
+
uncontrolledValue: defaultValue,
|
|
244
|
+
}),
|
|
166
245
|
);
|
|
167
246
|
const [internalSelectedValues, setInternalSelectedValues] = useState(
|
|
168
|
-
controlledStateRef.current === CONTROLLED ? value : defaultValue
|
|
247
|
+
controlledStateRef.current === CONTROLLED ? value : defaultValue,
|
|
169
248
|
);
|
|
170
249
|
const localInputRef = useRef<HTMLSelectElement>(null);
|
|
250
|
+
const odysseyDesignTokens = useOdysseyDesignTokens();
|
|
171
251
|
|
|
172
252
|
useImperativeHandle(
|
|
173
253
|
inputRef,
|
|
@@ -178,7 +258,7 @@ const Select = <
|
|
|
178
258
|
},
|
|
179
259
|
};
|
|
180
260
|
},
|
|
181
|
-
[]
|
|
261
|
+
[],
|
|
182
262
|
);
|
|
183
263
|
|
|
184
264
|
useEffect(() => {
|
|
@@ -200,12 +280,12 @@ const Select = <
|
|
|
200
280
|
} = event;
|
|
201
281
|
if (controlledStateRef.current !== CONTROLLED) {
|
|
202
282
|
setInternalSelectedValues(
|
|
203
|
-
(typeof value === "string" ? value.split(",") : value) as Value
|
|
283
|
+
(typeof value === "string" ? value.split(",") : value) as Value,
|
|
204
284
|
);
|
|
205
285
|
}
|
|
206
286
|
onChangeProp?.(event, child);
|
|
207
287
|
},
|
|
208
|
-
[onChangeProp]
|
|
288
|
+
[onChangeProp],
|
|
209
289
|
);
|
|
210
290
|
|
|
211
291
|
// Normalize the options array to accommodate the various
|
|
@@ -229,41 +309,85 @@ const Select = <
|
|
|
229
309
|
}
|
|
230
310
|
return { text: option, value: option, type: "option" };
|
|
231
311
|
}),
|
|
232
|
-
[options]
|
|
312
|
+
[options],
|
|
233
313
|
);
|
|
234
314
|
|
|
235
|
-
const
|
|
236
|
-
(
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
(option) => option.value === item
|
|
315
|
+
const Chips = useCallback(
|
|
316
|
+
({
|
|
317
|
+
selection,
|
|
318
|
+
isInteractive,
|
|
319
|
+
}: {
|
|
320
|
+
selection: string[];
|
|
321
|
+
isInteractive: boolean;
|
|
322
|
+
}) => {
|
|
323
|
+
const removeSelection = (itemToRemove: string) => {
|
|
324
|
+
if (Array.isArray(internalSelectedValues)) {
|
|
325
|
+
const newValue = internalSelectedValues.filter(
|
|
326
|
+
(item: string) => item !== itemToRemove,
|
|
248
327
|
);
|
|
249
328
|
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
}
|
|
329
|
+
const syntheticEvent = {
|
|
330
|
+
target: { value: newValue },
|
|
331
|
+
} as SelectChangeEvent<Value>;
|
|
253
332
|
|
|
254
|
-
|
|
255
|
-
}
|
|
256
|
-
|
|
333
|
+
onChange(syntheticEvent, null);
|
|
334
|
+
}
|
|
335
|
+
};
|
|
257
336
|
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
}
|
|
337
|
+
const stopPropagation = (event: MouseEvent<SVGSVGElement>) =>
|
|
338
|
+
event.stopPropagation();
|
|
261
339
|
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
|
|
340
|
+
return (
|
|
341
|
+
<ChipsInnerContainer
|
|
342
|
+
isInteractive={isInteractive}
|
|
343
|
+
odysseyDesignTokens={odysseyDesignTokens}
|
|
344
|
+
>
|
|
345
|
+
<ChipsSpacer odysseyDesignTokens={odysseyDesignTokens} />
|
|
346
|
+
{selection.map(
|
|
347
|
+
(item: string) =>
|
|
348
|
+
item?.length > 0 && (
|
|
349
|
+
<MuiChip
|
|
350
|
+
key={item}
|
|
351
|
+
label={
|
|
352
|
+
<>
|
|
353
|
+
{item}
|
|
354
|
+
{!isInteractive &&
|
|
355
|
+
controlledStateRef.current === CONTROLLED &&
|
|
356
|
+
hasMultipleChoices && (
|
|
357
|
+
<NonInteractiveIcon
|
|
358
|
+
odysseyDesignTokens={odysseyDesignTokens}
|
|
359
|
+
/>
|
|
360
|
+
)}
|
|
361
|
+
</>
|
|
362
|
+
}
|
|
363
|
+
tabIndex={-1}
|
|
364
|
+
onDelete={
|
|
365
|
+
isInteractive && controlledStateRef.current === CONTROLLED
|
|
366
|
+
? () => removeSelection(item)
|
|
367
|
+
: undefined
|
|
368
|
+
}
|
|
369
|
+
deleteIcon={
|
|
370
|
+
<CloseCircleFilledIcon
|
|
371
|
+
sx={{ pointerEvents: "auto" }}
|
|
372
|
+
// We need to stop event propagation on mouse down to prevent the deletion
|
|
373
|
+
// from being blocked by the Select list opening, and also ensure that
|
|
374
|
+
// the pointerEvent is registered even when the parent's are not
|
|
375
|
+
onMouseDown={stopPropagation}
|
|
376
|
+
/>
|
|
377
|
+
}
|
|
378
|
+
/>
|
|
379
|
+
),
|
|
380
|
+
)}
|
|
381
|
+
</ChipsInnerContainer>
|
|
382
|
+
);
|
|
265
383
|
},
|
|
266
|
-
[
|
|
384
|
+
[
|
|
385
|
+
controlledStateRef,
|
|
386
|
+
hasMultipleChoices,
|
|
387
|
+
internalSelectedValues,
|
|
388
|
+
odysseyDesignTokens,
|
|
389
|
+
onChange,
|
|
390
|
+
],
|
|
267
391
|
);
|
|
268
392
|
|
|
269
393
|
// Convert the options into the ReactNode children
|
|
@@ -272,21 +396,22 @@ const Select = <
|
|
|
272
396
|
() =>
|
|
273
397
|
normalizedOptions.map((option, index) => {
|
|
274
398
|
if (option.type === "heading") {
|
|
275
|
-
return
|
|
399
|
+
return (
|
|
400
|
+
<ListSubheader key={option.text}> {option.text} </ListSubheader>
|
|
401
|
+
);
|
|
276
402
|
}
|
|
403
|
+
|
|
404
|
+
const isSelected = hasMultipleChoices
|
|
405
|
+
? internalSelectedValues?.includes(option.value)
|
|
406
|
+
: internalSelectedValues === option.value;
|
|
407
|
+
|
|
277
408
|
return (
|
|
278
|
-
<
|
|
409
|
+
<MuiMenuItem
|
|
279
410
|
key={normalizedKey(option.text, index.toString())}
|
|
280
411
|
value={option.value}
|
|
412
|
+
selected={isSelected}
|
|
281
413
|
>
|
|
282
|
-
{hasMultipleChoices &&
|
|
283
|
-
<MuiCheckbox
|
|
284
|
-
checked={
|
|
285
|
-
option.value !== undefined &&
|
|
286
|
-
internalSelectedValues?.includes(option.value)
|
|
287
|
-
}
|
|
288
|
-
/>
|
|
289
|
-
)}
|
|
414
|
+
{hasMultipleChoices && <MuiCheckbox checked={isSelected} />}
|
|
290
415
|
{option.text}
|
|
291
416
|
{!hasMultipleChoices &&
|
|
292
417
|
(internalSelectedValues?.includes(option.value) ||
|
|
@@ -295,48 +420,65 @@ const Select = <
|
|
|
295
420
|
<CheckIcon />
|
|
296
421
|
</ListItemSecondaryAction>
|
|
297
422
|
)}
|
|
298
|
-
</
|
|
423
|
+
</MuiMenuItem>
|
|
299
424
|
);
|
|
300
425
|
}),
|
|
301
|
-
[hasMultipleChoices, normalizedOptions, internalSelectedValues]
|
|
426
|
+
[hasMultipleChoices, normalizedOptions, internalSelectedValues],
|
|
427
|
+
);
|
|
428
|
+
|
|
429
|
+
const renderValue = useCallback(
|
|
430
|
+
(value: Value) =>
|
|
431
|
+
Array.isArray(value) && <Chips selection={value} isInteractive={false} />,
|
|
432
|
+
[Chips],
|
|
302
433
|
);
|
|
303
434
|
|
|
304
435
|
const renderFieldComponent = useCallback(
|
|
305
|
-
({
|
|
306
|
-
|
|
307
|
-
|
|
308
|
-
|
|
309
|
-
|
|
310
|
-
|
|
311
|
-
|
|
312
|
-
|
|
313
|
-
inputValues
|
|
314
|
-
|
|
315
|
-
|
|
316
|
-
|
|
317
|
-
|
|
318
|
-
|
|
319
|
-
|
|
320
|
-
|
|
321
|
-
|
|
322
|
-
|
|
323
|
-
|
|
324
|
-
|
|
325
|
-
|
|
326
|
-
|
|
436
|
+
({
|
|
437
|
+
ariaDescribedBy,
|
|
438
|
+
errorMessageElementId,
|
|
439
|
+
id,
|
|
440
|
+
labelElementId,
|
|
441
|
+
}: SelectRenderProps) => (
|
|
442
|
+
<SelectContainer>
|
|
443
|
+
<MuiSelect
|
|
444
|
+
{...inputValues}
|
|
445
|
+
aria-describedby={ariaDescribedBy}
|
|
446
|
+
aria-errormessage={errorMessageElementId}
|
|
447
|
+
children={children}
|
|
448
|
+
id={id}
|
|
449
|
+
inputProps={{ "data-se": testId }}
|
|
450
|
+
inputRef={localInputRef}
|
|
451
|
+
labelId={labelElementId}
|
|
452
|
+
multiple={hasMultipleChoices}
|
|
453
|
+
name={nameOverride ?? id}
|
|
454
|
+
onBlur={onBlur}
|
|
455
|
+
onChange={onChange}
|
|
456
|
+
onFocus={onFocus}
|
|
457
|
+
renderValue={hasMultipleChoices ? renderValue : undefined}
|
|
458
|
+
translate={translate}
|
|
459
|
+
/>
|
|
460
|
+
{hasMultipleChoices && Array.isArray(value) && (
|
|
461
|
+
<ChipsPositioningContainer odysseyDesignTokens={odysseyDesignTokens}>
|
|
462
|
+
<Chips selection={value} isInteractive={true} />
|
|
463
|
+
</ChipsPositioningContainer>
|
|
464
|
+
)}
|
|
465
|
+
</SelectContainer>
|
|
327
466
|
),
|
|
328
467
|
[
|
|
329
468
|
children,
|
|
469
|
+
Chips,
|
|
330
470
|
inputValues,
|
|
331
471
|
hasMultipleChoices,
|
|
332
472
|
nameOverride,
|
|
473
|
+
odysseyDesignTokens,
|
|
333
474
|
onBlur,
|
|
334
475
|
onChange,
|
|
335
476
|
onFocus,
|
|
336
477
|
renderValue,
|
|
337
478
|
testId,
|
|
338
479
|
translate,
|
|
339
|
-
|
|
480
|
+
value,
|
|
481
|
+
],
|
|
340
482
|
);
|
|
341
483
|
|
|
342
484
|
return (
|
package/src/Status.tsx
CHANGED
|
@@ -10,6 +10,7 @@
|
|
|
10
10
|
* See the License for the specific language governing permissions and limitations under the License.
|
|
11
11
|
*/
|
|
12
12
|
|
|
13
|
+
import { memo } from "react";
|
|
13
14
|
import { Chip } from "@mui/material";
|
|
14
15
|
|
|
15
16
|
import { useMuiProps } from "./MuiPropsContext";
|
|
@@ -31,9 +32,9 @@ export type StatusProps = {
|
|
|
31
32
|
* Determine the color and icon of the Status
|
|
32
33
|
*/
|
|
33
34
|
severity: (typeof statusSeverityValues)[number];
|
|
34
|
-
} & HtmlProps
|
|
35
|
+
} & Pick<HtmlProps, "testId" | "translate">;
|
|
35
36
|
|
|
36
|
-
|
|
37
|
+
const Status = ({ label, severity, testId, translate }: StatusProps) => {
|
|
37
38
|
const muiProps = useMuiProps();
|
|
38
39
|
|
|
39
40
|
return (
|
|
@@ -47,3 +48,8 @@ export const Status = ({ label, severity, testId, translate }: StatusProps) => {
|
|
|
47
48
|
/>
|
|
48
49
|
);
|
|
49
50
|
};
|
|
51
|
+
|
|
52
|
+
const MemoizedStatus = memo(Status);
|
|
53
|
+
MemoizedStatus.displayName = "Status";
|
|
54
|
+
|
|
55
|
+
export { MemoizedStatus as Status };
|