@okta/odyssey-react-mui 1.32.0 → 1.32.4
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/cjs/theme/components.cjs +6 -0
- package/dist/cjs/theme/components.cjs.map +1 -1
- package/dist/cjs/ui-shell/SideNav/SideNav.cjs +2 -1
- package/dist/cjs/ui-shell/SideNav/SideNav.cjs.map +1 -1
- package/dist/cjs/ui-shell/SideNav/SideNavItemContent.cjs +36 -11
- package/dist/cjs/ui-shell/SideNav/SideNavItemContent.cjs.map +1 -1
- package/dist/cjs/ui-shell/SideNav/SideNavItemLinkContent.cjs +3 -1
- package/dist/cjs/ui-shell/SideNav/SideNavItemLinkContent.cjs.map +1 -1
- package/dist/cjs/ui-shell/SideNav/SideNavLogo.cjs +14 -2
- package/dist/cjs/ui-shell/SideNav/SideNavLogo.cjs.map +1 -1
- package/dist/cjs/ui-shell/SideNav/SideNavToggleButton.cjs +1 -1
- package/dist/cjs/ui-shell/SideNav/SideNavToggleButton.cjs.map +1 -1
- package/dist/cjs/ui-shell/SideNav/types.cjs.map +1 -1
- package/dist/cjs/ui-shell/UiShellContent.cjs +48 -32
- package/dist/cjs/ui-shell/UiShellContent.cjs.map +1 -1
- package/dist/cjs/ui-shell/index.cjs +9 -1
- package/dist/cjs/ui-shell/index.cjs.map +1 -1
- package/dist/cjs/useContrastMode.cjs +1 -1
- package/dist/cjs/useContrastMode.cjs.map +1 -1
- package/dist/esm/theme/components.js +6 -0
- package/dist/esm/theme/components.js.map +1 -1
- package/dist/esm/ui-shell/SideNav/SideNav.js +2 -1
- package/dist/esm/ui-shell/SideNav/SideNav.js.map +1 -1
- package/dist/esm/ui-shell/SideNav/SideNavItemContent.js +37 -12
- package/dist/esm/ui-shell/SideNav/SideNavItemContent.js.map +1 -1
- package/dist/esm/ui-shell/SideNav/SideNavItemLinkContent.js +3 -1
- package/dist/esm/ui-shell/SideNav/SideNavItemLinkContent.js.map +1 -1
- package/dist/esm/ui-shell/SideNav/SideNavLogo.js +14 -2
- package/dist/esm/ui-shell/SideNav/SideNavLogo.js.map +1 -1
- package/dist/esm/ui-shell/SideNav/SideNavToggleButton.js +1 -1
- package/dist/esm/ui-shell/SideNav/SideNavToggleButton.js.map +1 -1
- package/dist/esm/ui-shell/SideNav/types.js.map +1 -1
- package/dist/esm/ui-shell/UiShellContent.js +45 -31
- package/dist/esm/ui-shell/UiShellContent.js.map +1 -1
- package/dist/esm/ui-shell/index.js +1 -0
- package/dist/esm/ui-shell/index.js.map +1 -1
- package/dist/esm/useContrastMode.js +2 -2
- package/dist/esm/useContrastMode.js.map +1 -1
- package/dist/index.cjs +1 -1
- package/dist/index.mjs +1 -1
- package/dist/index.scss +1 -1
- package/dist/tsconfig.production.tsbuildinfo +1 -1
- package/dist/types/theme/components.d.ts.map +1 -1
- package/dist/types/ui-shell/SideNav/SideNav.d.ts.map +1 -1
- package/dist/types/ui-shell/SideNav/SideNavItemContent.d.ts +9 -7
- package/dist/types/ui-shell/SideNav/SideNavItemContent.d.ts.map +1 -1
- package/dist/types/ui-shell/SideNav/SideNavItemLinkContent.d.ts +1 -1
- package/dist/types/ui-shell/SideNav/SideNavItemLinkContent.d.ts.map +1 -1
- package/dist/types/ui-shell/SideNav/SideNavLogo.d.ts.map +1 -1
- package/dist/types/ui-shell/SideNav/types.d.ts +5 -1
- package/dist/types/ui-shell/SideNav/types.d.ts.map +1 -1
- package/dist/types/ui-shell/UiShellContent.d.ts +8 -2
- package/dist/types/ui-shell/UiShellContent.d.ts.map +1 -1
- package/dist/types/ui-shell/index.d.ts +1 -1
- package/dist/types/ui-shell/index.d.ts.map +1 -1
- package/package.json +4 -4
- package/.browserslistrc +0 -1
- package/.svgrrc.cjs +0 -13
- package/CHANGELOG.md +0 -1490
- package/babel.config.cjs +0 -112
- package/i18n.config.json +0 -10
- package/scripts/generateIconsIndex.ts +0 -49
- package/scripts/generateTestSelectorsJson.ts +0 -33
- package/scripts/properties-to-ts.ts +0 -111
- package/src/@types/i18next.d.ts +0 -24
- package/src/@types/properties.d.ts +0 -292
- package/src/@types/react-augment.d.ts +0 -22
- package/src/Accordion.tsx +0 -117
- package/src/Autocomplete.tsx +0 -321
- package/src/Badge.tsx +0 -112
- package/src/Banner.tsx +0 -112
- package/src/Box.tsx +0 -44
- package/src/Breadcrumbs.tsx +0 -221
- package/src/Buttons/BaseButton.tsx +0 -250
- package/src/Buttons/BaseMenuButton.tsx +0 -342
- package/src/Buttons/Button.tsx +0 -30
- package/src/Buttons/ButtonContext.tsx +0 -23
- package/src/Buttons/MenuButton.tsx +0 -33
- package/src/Buttons/MenuContext.ts +0 -25
- package/src/Buttons/MenuItem.tsx +0 -103
- package/src/Buttons/index.ts +0 -25
- package/src/Callout.tsx +0 -176
- package/src/Card.tsx +0 -186
- package/src/Checkbox.tsx +0 -261
- package/src/CheckboxGroup.tsx +0 -127
- package/src/CircularProgress.tsx +0 -42
- package/src/CssBaseline.tsx +0 -20
- package/src/DataTable/DataTable.tsx +0 -968
- package/src/DataTable/DataTableRowActions.tsx +0 -132
- package/src/DataTable/DataTableSettings.tsx +0 -136
- package/src/DataTable/constants.ts +0 -13
- package/src/DataTable/index.tsx +0 -28
- package/src/DataTable/reorderDataRowsLocally.tsx +0 -48
- package/src/DataTable/useRowReordering.tsx +0 -232
- package/src/DataTable/useScrollIndication.tsx +0 -125
- package/src/DatePickers/DateField.tsx +0 -267
- package/src/DatePickers/DateFieldActionBar.tsx +0 -65
- package/src/DatePickers/DateFieldLocalizationProvider.tsx +0 -46
- package/src/DatePickers/DatePicker.test.tsx +0 -66
- package/src/DatePickers/DatePicker.tsx +0 -299
- package/src/DatePickers/DatePicker.types.d.ts +0 -14
- package/src/DatePickers/TimeZonePicker.tsx +0 -59
- package/src/DatePickers/datePickerTheme.tsx +0 -377
- package/src/DatePickers/index.ts +0 -15
- package/src/DatePickers/useDateFieldsTranslations.ts +0 -94
- package/src/DatePickers/useOdysseyDateFields.ts +0 -303
- package/src/Dialog.tsx +0 -178
- package/src/Drawer.tsx +0 -255
- package/src/EmptyState.tsx +0 -79
- package/src/ErrorMessageList.tsx +0 -56
- package/src/Field.tsx +0 -189
- package/src/FieldComponentProps.ts +0 -66
- package/src/FieldError.tsx +0 -59
- package/src/FieldHint.tsx +0 -72
- package/src/FieldLabel.tsx +0 -67
- package/src/Fieldset.tsx +0 -116
- package/src/FieldsetContext.tsx +0 -23
- package/src/FileUploader/FileUploadIllustration.tsx +0 -66
- package/src/FileUploader/FileUploadPreview.tsx +0 -151
- package/src/FileUploader/FileUploader.tsx +0 -311
- package/src/FileUploader/index.ts +0 -13
- package/src/Form.tsx +0 -185
- package/src/FormCheckedProps.ts +0 -59
- package/src/HintLink.tsx +0 -28
- package/src/HtmlProps.ts +0 -112
- package/src/IconWithTooltip.tsx +0 -90
- package/src/Link.tsx +0 -115
- package/src/MuiPropsChild.tsx +0 -42
- package/src/MuiPropsContext.ts +0 -18
- package/src/NativeSelect.tsx +0 -249
- package/src/NullElement.tsx +0 -13
- package/src/OdysseyCacheProvider.test.tsx +0 -39
- package/src/OdysseyCacheProvider.tsx +0 -86
- package/src/OdysseyDesignTokensContext.tsx +0 -23
- package/src/OdysseyProvider.tsx +0 -92
- package/src/OdysseyThemeProvider.test.tsx +0 -211
- package/src/OdysseyThemeProvider.tsx +0 -109
- package/src/OdysseyTranslationProvider.test.tsx +0 -95
- package/src/OdysseyTranslationProvider.tsx +0 -77
- package/src/OdysseyTranslationProvider.types.ts +0 -47
- package/src/Pagination/Pagination.test.tsx +0 -327
- package/src/Pagination/Pagination.tsx +0 -417
- package/src/Pagination/constants.ts +0 -13
- package/src/Pagination/index.ts +0 -15
- package/src/Pagination/usePagination.ts +0 -45
- package/src/PasswordField.tsx +0 -253
- package/src/Radio.tsx +0 -199
- package/src/RadioGroup.tsx +0 -164
- package/src/ScreenReaderText.tsx +0 -53
- package/src/SearchField.tsx +0 -240
- package/src/Select.tsx +0 -576
- package/src/Stack.tsx +0 -56
- package/src/Status.tsx +0 -67
- package/src/Surface.tsx +0 -61
- package/src/SvgIcon.ts +0 -22
- package/src/Switch.tsx +0 -425
- package/src/Tabs.tsx +0 -259
- package/src/Tag.tsx +0 -317
- package/src/TagList.tsx +0 -55
- package/src/TagListContext.tsx +0 -23
- package/src/TextField.tsx +0 -298
- package/src/Toast.tsx +0 -151
- package/src/ToastStack.tsx +0 -43
- package/src/Tooltip.tsx +0 -61
- package/src/Typography.test.tsx +0 -26
- package/src/Typography.tsx +0 -474
- package/src/createContrastColors.ts +0 -112
- package/src/createUniqueAlphabeticalId.test.ts +0 -22
- package/src/createUniqueAlphabeticalId.ts +0 -17
- package/src/createUniqueId.test.ts +0 -22
- package/src/createUniqueId.ts +0 -17
- package/src/getTypedObjectKeys.ts +0 -15
- package/src/hexToRgb.ts +0 -40
- package/src/i18n.ts +0 -110
- package/src/icons.generated/Add.tsx +0 -44
- package/src/icons.generated/AddCircle.tsx +0 -46
- package/src/icons.generated/Apps.tsx +0 -44
- package/src/icons.generated/ArrowBottom.tsx +0 -46
- package/src/icons.generated/ArrowDown.tsx +0 -46
- package/src/icons.generated/ArrowLeft.tsx +0 -46
- package/src/icons.generated/ArrowLowerLeft.tsx +0 -46
- package/src/icons.generated/ArrowLowerRight.tsx +0 -46
- package/src/icons.generated/ArrowRight.tsx +0 -46
- package/src/icons.generated/ArrowTop.tsx +0 -46
- package/src/icons.generated/ArrowUnsorted.tsx +0 -46
- package/src/icons.generated/ArrowUp.tsx +0 -46
- package/src/icons.generated/ArrowUpperLeft.tsx +0 -46
- package/src/icons.generated/ArrowUpperRight.tsx +0 -46
- package/src/icons.generated/Bug.tsx +0 -44
- package/src/icons.generated/Calendar.tsx +0 -46
- package/src/icons.generated/Call.tsx +0 -44
- package/src/icons.generated/Chat.tsx +0 -44
- package/src/icons.generated/Check.tsx +0 -44
- package/src/icons.generated/CheckCircleFilled.tsx +0 -47
- package/src/icons.generated/ChevronDown.tsx +0 -46
- package/src/icons.generated/ChevronLeft.tsx +0 -46
- package/src/icons.generated/ChevronRight.tsx +0 -46
- package/src/icons.generated/ChevronUp.tsx +0 -46
- package/src/icons.generated/Clock.tsx +0 -44
- package/src/icons.generated/Close.tsx +0 -44
- package/src/icons.generated/CloseCircleFilled.tsx +0 -47
- package/src/icons.generated/CollapseLeft.tsx +0 -46
- package/src/icons.generated/CollapseRight.tsx +0 -46
- package/src/icons.generated/Copy.tsx +0 -44
- package/src/icons.generated/Custom.tsx +0 -50
- package/src/icons.generated/DangerDiamond.tsx +0 -46
- package/src/icons.generated/DangerDiamondFilled.tsx +0 -47
- package/src/icons.generated/Delete.tsx +0 -44
- package/src/icons.generated/Deny.tsx +0 -44
- package/src/icons.generated/Devices.tsx +0 -46
- package/src/icons.generated/Directory.tsx +0 -46
- package/src/icons.generated/Documentation.tsx +0 -46
- package/src/icons.generated/Download.tsx +0 -46
- package/src/icons.generated/DragIndicator.tsx +0 -46
- package/src/icons.generated/Duo.tsx +0 -62
- package/src/icons.generated/Edit.tsx +0 -44
- package/src/icons.generated/Email.tsx +0 -49
- package/src/icons.generated/ExpandLeft.tsx +0 -46
- package/src/icons.generated/ExpandRight.tsx +0 -46
- package/src/icons.generated/ExternalLink.tsx +0 -44
- package/src/icons.generated/Fido2.tsx +0 -72
- package/src/icons.generated/Filter.tsx +0 -44
- package/src/icons.generated/Folder.tsx +0 -44
- package/src/icons.generated/Globe.tsx +0 -44
- package/src/icons.generated/GoogleAuth.tsx +0 -70
- package/src/icons.generated/Grid.tsx +0 -47
- package/src/icons.generated/Group.tsx +0 -44
- package/src/icons.generated/Hide.tsx +0 -44
- package/src/icons.generated/Home.tsx +0 -44
- package/src/icons.generated/Idp.tsx +0 -54
- package/src/icons.generated/InformationCircle.tsx +0 -47
- package/src/icons.generated/InformationCircleFilled.tsx +0 -47
- package/src/icons.generated/Link.tsx +0 -44
- package/src/icons.generated/List.tsx +0 -44
- package/src/icons.generated/Lock.tsx +0 -44
- package/src/icons.generated/More.tsx +0 -44
- package/src/icons.generated/Notification.tsx +0 -46
- package/src/icons.generated/OktaVerify.tsx +0 -46
- package/src/icons.generated/OnPremMfa.tsx +0 -52
- package/src/icons.generated/OneTimePassword.tsx +0 -65
- package/src/icons.generated/Password.tsx +0 -80
- package/src/icons.generated/Pause.tsx +0 -44
- package/src/icons.generated/QuestionCircle.tsx +0 -46
- package/src/icons.generated/QuestionCircleFilled.tsx +0 -47
- package/src/icons.generated/Refresh.tsx +0 -46
- package/src/icons.generated/Reset.tsx +0 -44
- package/src/icons.generated/Resume.tsx +0 -44
- package/src/icons.generated/Search.tsx +0 -44
- package/src/icons.generated/SecurityQuestion.tsx +0 -51
- package/src/icons.generated/Server.tsx +0 -44
- package/src/icons.generated/Settings.tsx +0 -46
- package/src/icons.generated/Show.tsx +0 -44
- package/src/icons.generated/SmartCard.tsx +0 -65
- package/src/icons.generated/Sms.tsx +0 -55
- package/src/icons.generated/Subtract.tsx +0 -46
- package/src/icons.generated/SymantecVip.tsx +0 -52
- package/src/icons.generated/Sync.tsx +0 -44
- package/src/icons.generated/ThumbsDown.tsx +0 -46
- package/src/icons.generated/ThumbsUp.tsx +0 -46
- package/src/icons.generated/Unlock.tsx +0 -44
- package/src/icons.generated/Upload.tsx +0 -44
- package/src/icons.generated/User.tsx +0 -44
- package/src/icons.generated/Video.tsx +0 -44
- package/src/icons.generated/VoiceCall.tsx +0 -62
- package/src/icons.generated/Warning.tsx +0 -46
- package/src/icons.generated/WarningFilled.tsx +0 -46
- package/src/icons.generated/Yubikey.tsx +0 -44
- package/src/icons.generated/index.ts +0 -107
- package/src/index.ts +0 -118
- package/src/inputUtils.ts +0 -80
- package/src/labs/AppTile.tsx +0 -421
- package/src/labs/DataFilters.tsx +0 -871
- package/src/labs/DataTable.tsx +0 -877
- package/src/labs/DataTablePagination.tsx +0 -88
- package/src/labs/DataView/BulkActionsMenu.tsx +0 -98
- package/src/labs/DataView/CardLayoutContent.tsx +0 -272
- package/src/labs/DataView/DataCard.tsx +0 -357
- package/src/labs/DataView/DataTable.tsx +0 -128
- package/src/labs/DataView/DataView.test.tsx +0 -1168
- package/src/labs/DataView/DataView.tsx +0 -504
- package/src/labs/DataView/DetailPanel.tsx +0 -31
- package/src/labs/DataView/LayoutSwitcher.tsx +0 -72
- package/src/labs/DataView/RowActions.tsx +0 -125
- package/src/labs/DataView/TableLayoutContent.tsx +0 -500
- package/src/labs/DataView/TableSettings.tsx +0 -144
- package/src/labs/DataView/componentTypes.ts +0 -129
- package/src/labs/DataView/constants.tsx +0 -28
- package/src/labs/DataView/dataTypes.ts +0 -83
- package/src/labs/DataView/fetchData.ts +0 -49
- package/src/labs/DataView/index.ts +0 -19
- package/src/labs/DataView/tableConstants.tsx +0 -137
- package/src/labs/DataView/testSupportData.tsx +0 -301
- package/src/labs/DataView/useFilterConversion.ts +0 -88
- package/src/labs/DatePickers/DateTimeField.tsx +0 -267
- package/src/labs/DatePickers/DateTimePicker.test.tsx +0 -70
- package/src/labs/DatePickers/DateTimePicker.tsx +0 -303
- package/src/labs/DatePickers/dateTimePickerTheme.ts +0 -216
- package/src/labs/DatePickers/index.ts +0 -13
- package/src/labs/GroupPicker.tsx +0 -261
- package/src/labs/OdysseyPickers/ComposablePicker.test.tsx +0 -32
- package/src/labs/OdysseyPickers/ComposablePicker.tsx +0 -188
- package/src/labs/OdysseyPickers/Picker.tsx +0 -381
- package/src/labs/OdysseyPickers/PickerVirtualizationListBox.tsx +0 -192
- package/src/labs/OdysseyPickers/PickerWithOptionAdornment.tsx +0 -429
- package/src/labs/OdysseyPickers/index.ts +0 -15
- package/src/labs/PageTemplate/Layout.tsx +0 -85
- package/src/labs/PageTemplate/PageTemplate.tsx +0 -234
- package/src/labs/PageTemplate/index.ts +0 -14
- package/src/labs/PaginatedTable.tsx +0 -290
- package/src/labs/README.md +0 -46
- package/src/labs/StaticTable.tsx +0 -131
- package/src/labs/UserProfile.tsx +0 -104
- package/src/labs/UserProfileMenuButton.tsx +0 -86
- package/src/labs/index.ts +0 -47
- package/src/labs/materialReactTableTypes.tsx +0 -19
- package/src/properties/odyssey-react-mui.properties +0 -140
- package/src/properties/translations/odyssey-react-mui_cs.properties +0 -140
- package/src/properties/translations/odyssey-react-mui_da.properties +0 -140
- package/src/properties/translations/odyssey-react-mui_de.properties +0 -140
- package/src/properties/translations/odyssey-react-mui_el.properties +0 -140
- package/src/properties/translations/odyssey-react-mui_es.properties +0 -140
- package/src/properties/translations/odyssey-react-mui_fi.properties +0 -140
- package/src/properties/translations/odyssey-react-mui_fr.properties +0 -140
- package/src/properties/translations/odyssey-react-mui_ht.properties +0 -140
- package/src/properties/translations/odyssey-react-mui_hu.properties +0 -140
- package/src/properties/translations/odyssey-react-mui_id.properties +0 -140
- package/src/properties/translations/odyssey-react-mui_it.properties +0 -140
- package/src/properties/translations/odyssey-react-mui_ja.properties +0 -140
- package/src/properties/translations/odyssey-react-mui_ko.properties +0 -140
- package/src/properties/translations/odyssey-react-mui_ms.properties +0 -140
- package/src/properties/translations/odyssey-react-mui_nb.properties +0 -140
- package/src/properties/translations/odyssey-react-mui_nl_NL.properties +0 -140
- package/src/properties/translations/odyssey-react-mui_ok_PL.properties +0 -126
- package/src/properties/translations/odyssey-react-mui_ok_SK.properties +0 -126
- package/src/properties/translations/odyssey-react-mui_pl.properties +0 -140
- package/src/properties/translations/odyssey-react-mui_pt_BR.properties +0 -140
- package/src/properties/translations/odyssey-react-mui_ro.properties +0 -140
- package/src/properties/translations/odyssey-react-mui_ru.properties +0 -140
- package/src/properties/translations/odyssey-react-mui_sv.properties +0 -140
- package/src/properties/translations/odyssey-react-mui_th.properties +0 -140
- package/src/properties/translations/odyssey-react-mui_tr.properties +0 -140
- package/src/properties/translations/odyssey-react-mui_uk.properties +0 -140
- package/src/properties/translations/odyssey-react-mui_vi.properties +0 -140
- package/src/properties/translations/odyssey-react-mui_zh_CN.properties +0 -140
- package/src/properties/translations/odyssey-react-mui_zh_TW.properties +0 -140
- package/src/properties/ts/odyssey-react-mui.ts +0 -1
- package/src/properties/ts/odyssey-react-mui_cs.ts +0 -1
- package/src/properties/ts/odyssey-react-mui_da.ts +0 -1
- package/src/properties/ts/odyssey-react-mui_de.ts +0 -1
- package/src/properties/ts/odyssey-react-mui_el.ts +0 -1
- package/src/properties/ts/odyssey-react-mui_es.ts +0 -1
- package/src/properties/ts/odyssey-react-mui_fi.ts +0 -1
- package/src/properties/ts/odyssey-react-mui_fr.ts +0 -1
- package/src/properties/ts/odyssey-react-mui_ht.ts +0 -1
- package/src/properties/ts/odyssey-react-mui_hu.ts +0 -1
- package/src/properties/ts/odyssey-react-mui_id.ts +0 -1
- package/src/properties/ts/odyssey-react-mui_it.ts +0 -1
- package/src/properties/ts/odyssey-react-mui_ja.ts +0 -1
- package/src/properties/ts/odyssey-react-mui_ko.ts +0 -1
- package/src/properties/ts/odyssey-react-mui_ms.ts +0 -1
- package/src/properties/ts/odyssey-react-mui_nb.ts +0 -1
- package/src/properties/ts/odyssey-react-mui_nl_NL.ts +0 -1
- package/src/properties/ts/odyssey-react-mui_ok_PL.ts +0 -1
- package/src/properties/ts/odyssey-react-mui_ok_SK.ts +0 -1
- package/src/properties/ts/odyssey-react-mui_pl.ts +0 -1
- package/src/properties/ts/odyssey-react-mui_pt_BR.ts +0 -1
- package/src/properties/ts/odyssey-react-mui_ro.ts +0 -1
- package/src/properties/ts/odyssey-react-mui_ru.ts +0 -1
- package/src/properties/ts/odyssey-react-mui_sv.ts +0 -1
- package/src/properties/ts/odyssey-react-mui_th.ts +0 -1
- package/src/properties/ts/odyssey-react-mui_tr.ts +0 -1
- package/src/properties/ts/odyssey-react-mui_uk.ts +0 -1
- package/src/properties/ts/odyssey-react-mui_vi.ts +0 -1
- package/src/properties/ts/odyssey-react-mui_zh_CN.ts +0 -1
- package/src/properties/ts/odyssey-react-mui_zh_TW.ts +0 -1
- package/src/remUtils.ts +0 -27
- package/src/shadow-dom/index.ts +0 -13
- package/src/shadow-dom/shadow-dom.test.ts +0 -24
- package/src/shadow-dom/shadow-dom.ts +0 -54
- package/src/test-selectors/getByQuerySelector.ts +0 -176
- package/src/test-selectors/getComputedAccessibleErrorMessageText.ts +0 -52
- package/src/test-selectors/getComputedAccessibleText.ts +0 -36
- package/src/test-selectors/index.ts +0 -15
- package/src/test-selectors/interpolateString.ts +0 -41
- package/src/test-selectors/linkedHtmlSelectors.ts +0 -73
- package/src/test-selectors/queryOdysseySelector.ts +0 -36
- package/src/test-selectors/querySelector.ts +0 -249
- package/src/test-selectors/sanityChecks.ts +0 -53
- package/src/test-selectors/testSelector.ts +0 -143
- package/src/theme/components.tsx +0 -3275
- package/src/theme/components.types.ts +0 -111
- package/src/theme/createOdysseyMuiTheme.ts +0 -54
- package/src/theme/index.ts +0 -13
- package/src/theme/mixins.ts +0 -29
- package/src/theme/mixins.types.ts +0 -31
- package/src/theme/palette.ts +0 -112
- package/src/theme/palette.types.ts +0 -24
- package/src/theme/shape.ts +0 -31
- package/src/theme/spacing.ts +0 -34
- package/src/theme/theme.ts +0 -13
- package/src/theme/typography.ts +0 -137
- package/src/theme/typography.types.ts +0 -41
- package/src/theme/useContrastMode.test.tsx +0 -504
- package/src/ui-shell/AppSwitcher/AppSwitcher.tsx +0 -94
- package/src/ui-shell/AppSwitcher/AppSwitcherApp.tsx +0 -146
- package/src/ui-shell/AppSwitcher/OktaAura.tsx +0 -50
- package/src/ui-shell/AppSwitcher/index.ts +0 -13
- package/src/ui-shell/SideNav/CollapseIcon.tsx +0 -34
- package/src/ui-shell/SideNav/HandleIcon.tsx +0 -35
- package/src/ui-shell/SideNav/NavAccordion.tsx +0 -243
- package/src/ui-shell/SideNav/OktaLogo.tsx +0 -34
- package/src/ui-shell/SideNav/SideNav.test.tsx +0 -326
- package/src/ui-shell/SideNav/SideNav.tsx +0 -810
- package/src/ui-shell/SideNav/SideNavFooterContent.tsx +0 -85
- package/src/ui-shell/SideNav/SideNavHeader.tsx +0 -134
- package/src/ui-shell/SideNav/SideNavItemContent.tsx +0 -402
- package/src/ui-shell/SideNav/SideNavItemContentContext.tsx +0 -29
- package/src/ui-shell/SideNav/SideNavItemLinkContent.tsx +0 -90
- package/src/ui-shell/SideNav/SideNavLogo.tsx +0 -65
- package/src/ui-shell/SideNav/SideNavToggleButton.tsx +0 -272
- package/src/ui-shell/SideNav/SortableList/SortableItem.tsx +0 -237
- package/src/ui-shell/SideNav/SortableList/SortableList.tsx +0 -132
- package/src/ui-shell/SideNav/SortableList/SortableOverlay.tsx +0 -34
- package/src/ui-shell/SideNav/index.ts +0 -16
- package/src/ui-shell/SideNav/types.ts +0 -224
- package/src/ui-shell/TopNav/TopNav.tsx +0 -109
- package/src/ui-shell/TopNav/TopNavLinksList.tsx +0 -68
- package/src/ui-shell/TopNav/TopNavListItem.tsx +0 -209
- package/src/ui-shell/TopNav/index.ts +0 -13
- package/src/ui-shell/UiShell.test.tsx +0 -366
- package/src/ui-shell/UiShell.tsx +0 -153
- package/src/ui-shell/UiShellContent.tsx +0 -350
- package/src/ui-shell/UiShellProvider.tsx +0 -103
- package/src/ui-shell/bufferLatest.test.ts +0 -79
- package/src/ui-shell/bufferLatest.ts +0 -64
- package/src/ui-shell/createMessageBus.test.ts +0 -115
- package/src/ui-shell/createMessageBus.ts +0 -53
- package/src/ui-shell/createStore.test.ts +0 -103
- package/src/ui-shell/createStore.ts +0 -37
- package/src/ui-shell/index.ts +0 -21
- package/src/ui-shell/renderUiShell.test.tsx +0 -203
- package/src/ui-shell/renderUiShell.tsx +0 -158
- package/src/ui-shell/useHasUiShell.ts +0 -25
- package/src/ui-shell/useScrollState.ts +0 -59
- package/src/useAutocomplete.tsx +0 -184
- package/src/useContrastMode.tsx +0 -143
- package/src/useNormalizedKey.ts +0 -17
- package/src/useUniqueAlphabeticalId.ts +0 -21
- package/src/useUniqueId.ts +0 -21
- package/src/web-component/createReactRootElements.test.ts +0 -40
- package/src/web-component/createReactRootElements.ts +0 -39
- package/src/web-component/index.ts +0 -13
- package/src/web-component/renderReactInWebComponent.test.tsx +0 -128
- package/src/web-component/renderReactInWebComponent.ts +0 -135
- package/tsconfig.json +0 -16
- package/tsconfig.production.json +0 -13
- package/vitest.config.ts +0 -36
- package/vitest.setup.ts +0 -32
|
@@ -1,417 +0,0 @@
|
|
|
1
|
-
/*!
|
|
2
|
-
* Copyright (c) 2023-present, Okta, Inc. and/or its affiliates. All rights reserved.
|
|
3
|
-
* The Okta software accompanied by this notice is provided pursuant to the Apache License, Version 2.0 (the "License.")
|
|
4
|
-
*
|
|
5
|
-
* You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0.
|
|
6
|
-
* Unless required by applicable law or agreed to in writing, software
|
|
7
|
-
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
8
|
-
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
9
|
-
*
|
|
10
|
-
* See the License for the specific language governing permissions and limitations under the License.
|
|
11
|
-
*/
|
|
12
|
-
|
|
13
|
-
import styled from "@emotion/styled";
|
|
14
|
-
import { InputBase } from "@mui/material";
|
|
15
|
-
import { memo, useCallback, useEffect, useMemo, useRef, useState } from "react";
|
|
16
|
-
import { useTranslation } from "react-i18next";
|
|
17
|
-
|
|
18
|
-
import { Box } from "../Box.js";
|
|
19
|
-
import { Button } from "../Buttons/index.js";
|
|
20
|
-
import { paginationTypeValues } from "./constants.js";
|
|
21
|
-
import { ArrowLeftIcon, ArrowRightIcon } from "../icons.generated/index.js";
|
|
22
|
-
import {
|
|
23
|
-
DesignTokens,
|
|
24
|
-
useOdysseyDesignTokens,
|
|
25
|
-
} from "../OdysseyDesignTokensContext.js";
|
|
26
|
-
import { usePagination } from "./usePagination.js";
|
|
27
|
-
import { Paragraph } from "../Typography.js";
|
|
28
|
-
|
|
29
|
-
const PaginationContainer = styled("nav")({
|
|
30
|
-
display: "flex",
|
|
31
|
-
justifyContent: "space-between",
|
|
32
|
-
});
|
|
33
|
-
|
|
34
|
-
const PaginationSegment = styled("div", {
|
|
35
|
-
shouldForwardProp: (prop) => prop !== "odysseyDesignTokens",
|
|
36
|
-
})<{ odysseyDesignTokens: DesignTokens }>(({ odysseyDesignTokens }) => ({
|
|
37
|
-
display: "flex",
|
|
38
|
-
alignItems: "center",
|
|
39
|
-
gap: odysseyDesignTokens.Spacing4,
|
|
40
|
-
"& > div": {
|
|
41
|
-
display: "flex",
|
|
42
|
-
alignItems: "center",
|
|
43
|
-
gap: odysseyDesignTokens.Spacing2,
|
|
44
|
-
},
|
|
45
|
-
}));
|
|
46
|
-
|
|
47
|
-
const PaginationInput = styled(InputBase, {
|
|
48
|
-
shouldForwardProp: (prop) => prop !== "odysseyDesignTokens",
|
|
49
|
-
})<{ odysseyDesignTokens: DesignTokens }>(({ odysseyDesignTokens }) => ({
|
|
50
|
-
borderColor: odysseyDesignTokens.HueNeutral200,
|
|
51
|
-
borderRadius: odysseyDesignTokens.BorderRadiusTight,
|
|
52
|
-
height: odysseyDesignTokens.Spacing6,
|
|
53
|
-
width: "4.5714285714rem", // This is a hardcoded value, keep as string
|
|
54
|
-
"&:hover": {
|
|
55
|
-
borderColor: odysseyDesignTokens.HueNeutral400,
|
|
56
|
-
},
|
|
57
|
-
"&.Mui-focused:hover": {
|
|
58
|
-
borderColor: odysseyDesignTokens.PalettePrimaryMain,
|
|
59
|
-
},
|
|
60
|
-
}));
|
|
61
|
-
|
|
62
|
-
const PaginationButtonContainer = styled("div")({
|
|
63
|
-
"& > *": {
|
|
64
|
-
marginInlineStart: `0 !important`,
|
|
65
|
-
},
|
|
66
|
-
});
|
|
67
|
-
|
|
68
|
-
export type PaginationProps = {
|
|
69
|
-
/**
|
|
70
|
-
* The labeled rendered for the current page index
|
|
71
|
-
*/
|
|
72
|
-
currentPageLabel?: string;
|
|
73
|
-
/**
|
|
74
|
-
* The number of items currently visible on the page
|
|
75
|
-
*/
|
|
76
|
-
currentRowsCount?: number;
|
|
77
|
-
/**
|
|
78
|
-
* If true, the page input will be visible and the user can directly manipulate which page
|
|
79
|
-
* is visible.
|
|
80
|
-
*/
|
|
81
|
-
hasPageInput?: boolean;
|
|
82
|
-
/**
|
|
83
|
-
* If true, the row count input will be visible and the user can directly manipulate how many rows
|
|
84
|
-
* are visible.
|
|
85
|
-
*/
|
|
86
|
-
hasRowCountInput?: boolean;
|
|
87
|
-
/**
|
|
88
|
-
* If true, the "X - X of total X" label will be visible
|
|
89
|
-
*/
|
|
90
|
-
hasRowCountLabel?: boolean;
|
|
91
|
-
/**
|
|
92
|
-
* If true, the pagination controls will be disabled
|
|
93
|
-
*/
|
|
94
|
-
isDisabled?: boolean;
|
|
95
|
-
/**
|
|
96
|
-
* If true, the next or Show More button will be disabled
|
|
97
|
-
*/
|
|
98
|
-
isMoreDisabled?: boolean;
|
|
99
|
-
/**
|
|
100
|
-
* The current page last row index
|
|
101
|
-
*/
|
|
102
|
-
lastRow?: number;
|
|
103
|
-
/**
|
|
104
|
-
* If the pagination is of "loadMore" variant, then this is the the load more label
|
|
105
|
-
*/
|
|
106
|
-
loadMoreLabel?: string;
|
|
107
|
-
/**
|
|
108
|
-
* The max page
|
|
109
|
-
*/
|
|
110
|
-
maxPageIndex?: number;
|
|
111
|
-
/**
|
|
112
|
-
* The max rows per page
|
|
113
|
-
*/
|
|
114
|
-
maxPageSize?: number;
|
|
115
|
-
/**
|
|
116
|
-
* The label for the next control
|
|
117
|
-
*/
|
|
118
|
-
nextLabel?: string;
|
|
119
|
-
/**
|
|
120
|
-
* Page index and page size setter
|
|
121
|
-
*/
|
|
122
|
-
onPaginationChange: ({
|
|
123
|
-
pageIndex,
|
|
124
|
-
pageSize,
|
|
125
|
-
}: {
|
|
126
|
-
pageIndex: number;
|
|
127
|
-
pageSize: number;
|
|
128
|
-
}) => void;
|
|
129
|
-
/**
|
|
130
|
-
* The current page index
|
|
131
|
-
*/
|
|
132
|
-
pageIndex: number;
|
|
133
|
-
/**
|
|
134
|
-
* The current page size
|
|
135
|
-
*/
|
|
136
|
-
pageSize: number;
|
|
137
|
-
/**
|
|
138
|
-
* The label for the previous control
|
|
139
|
-
*/
|
|
140
|
-
previousLabel?: string;
|
|
141
|
-
/**
|
|
142
|
-
* The label that shows how many results are rendered per page
|
|
143
|
-
*/
|
|
144
|
-
rowsPerPageLabel?: string;
|
|
145
|
-
/**
|
|
146
|
-
* Total rows count
|
|
147
|
-
*/
|
|
148
|
-
totalRows?: number;
|
|
149
|
-
/**
|
|
150
|
-
* The type of pagination controls shown. Defaults to next/prev buttons, but can be
|
|
151
|
-
* set to a simple "Load more" button by setting to "loadMore".
|
|
152
|
-
*/
|
|
153
|
-
variant?: (typeof paginationTypeValues)[number];
|
|
154
|
-
};
|
|
155
|
-
|
|
156
|
-
const Pagination = ({
|
|
157
|
-
currentPageLabel: currentPageLabelProp,
|
|
158
|
-
currentRowsCount,
|
|
159
|
-
hasPageInput = true,
|
|
160
|
-
hasRowCountInput = true,
|
|
161
|
-
hasRowCountLabel = true,
|
|
162
|
-
isDisabled,
|
|
163
|
-
isMoreDisabled,
|
|
164
|
-
lastRow,
|
|
165
|
-
loadMoreLabel: loadMoreLabelProp,
|
|
166
|
-
maxPageIndex,
|
|
167
|
-
maxPageSize,
|
|
168
|
-
nextLabel: nextLabelProp,
|
|
169
|
-
onPaginationChange: onPaginationChangeProp,
|
|
170
|
-
pageIndex,
|
|
171
|
-
pageSize,
|
|
172
|
-
previousLabel: previousLabelProp,
|
|
173
|
-
rowsPerPageLabel: rowsPerPageLabelProp,
|
|
174
|
-
totalRows,
|
|
175
|
-
variant,
|
|
176
|
-
}: PaginationProps) => {
|
|
177
|
-
const odysseyDesignTokens = useOdysseyDesignTokens();
|
|
178
|
-
const { t } = useTranslation();
|
|
179
|
-
|
|
180
|
-
const [page, setPage] = useState<number>(pageIndex);
|
|
181
|
-
const [rowsPerPage, setRowsPerPage] = useState<number>(pageSize);
|
|
182
|
-
const initialRowsPerPage = useRef<number>(pageSize);
|
|
183
|
-
|
|
184
|
-
const currentPageLabel = currentPageLabelProp ?? t("pagination.page");
|
|
185
|
-
const loadMoreLabel = loadMoreLabelProp ?? t("pagination.loadmore");
|
|
186
|
-
const nextLabel = nextLabelProp ?? t("pagination.next");
|
|
187
|
-
const previousLabel = previousLabelProp ?? t("pagination.previous");
|
|
188
|
-
const rowsPerPageLabel = rowsPerPageLabelProp ?? t("pagination.rowsperpage");
|
|
189
|
-
|
|
190
|
-
useEffect(() => {
|
|
191
|
-
setPage(pageIndex);
|
|
192
|
-
setRowsPerPage(pageSize);
|
|
193
|
-
}, [pageIndex, pageSize]);
|
|
194
|
-
|
|
195
|
-
const onPaginationChange = useCallback(
|
|
196
|
-
({ pageIndex, pageSize }: { pageIndex: number; pageSize: number }) => {
|
|
197
|
-
onPaginationChangeProp({ pageIndex, pageSize });
|
|
198
|
-
},
|
|
199
|
-
[onPaginationChangeProp],
|
|
200
|
-
);
|
|
201
|
-
|
|
202
|
-
const { totalRowsLabel } = usePagination({
|
|
203
|
-
pageIndex,
|
|
204
|
-
pageSize,
|
|
205
|
-
currentRowsCount: currentRowsCount || pageSize,
|
|
206
|
-
totalRows,
|
|
207
|
-
});
|
|
208
|
-
|
|
209
|
-
const handlePaginationChange = useCallback(() => {
|
|
210
|
-
let updatedPage = page;
|
|
211
|
-
let updatedRowsPerPage = rowsPerPage;
|
|
212
|
-
|
|
213
|
-
if (totalRows) {
|
|
214
|
-
const maxPageIndex = Math.ceil(totalRows / updatedRowsPerPage);
|
|
215
|
-
|
|
216
|
-
// Ensure rowsPerPage does not exceed totalRows
|
|
217
|
-
if (updatedRowsPerPage > totalRows) {
|
|
218
|
-
updatedRowsPerPage = totalRows;
|
|
219
|
-
}
|
|
220
|
-
|
|
221
|
-
// Ensure page is within valid range
|
|
222
|
-
if (updatedPage > maxPageIndex) {
|
|
223
|
-
updatedPage = maxPageIndex;
|
|
224
|
-
} else if (updatedPage < 1) {
|
|
225
|
-
updatedPage = 1;
|
|
226
|
-
}
|
|
227
|
-
}
|
|
228
|
-
|
|
229
|
-
console.log({
|
|
230
|
-
page,
|
|
231
|
-
updatedPage,
|
|
232
|
-
rowsPerPage,
|
|
233
|
-
updatedRowsPerPage,
|
|
234
|
-
});
|
|
235
|
-
|
|
236
|
-
onPaginationChange({
|
|
237
|
-
pageIndex: updatedPage,
|
|
238
|
-
pageSize: updatedRowsPerPage,
|
|
239
|
-
});
|
|
240
|
-
}, [page, rowsPerPage, onPaginationChange, totalRows]);
|
|
241
|
-
|
|
242
|
-
// The following handlers use React.KeyboardEvent (rather than just KeyboardEvent) becuase React.KeyboardEvent
|
|
243
|
-
// is generic, while plain KeyboardEvent is not. We need this generic so we can specify the HTMLInputElement,
|
|
244
|
-
// which allows us to use currentTarget.value
|
|
245
|
-
const handlePageSubmit = useCallback(
|
|
246
|
-
(event: React.KeyboardEvent<HTMLInputElement | HTMLTextAreaElement>) => {
|
|
247
|
-
if (event.key === "Enter") {
|
|
248
|
-
onPaginationChange({
|
|
249
|
-
pageIndex: parseInt(event.currentTarget.value),
|
|
250
|
-
pageSize: rowsPerPage,
|
|
251
|
-
});
|
|
252
|
-
}
|
|
253
|
-
},
|
|
254
|
-
[rowsPerPage, onPaginationChange],
|
|
255
|
-
);
|
|
256
|
-
|
|
257
|
-
const handleRowsPerPageSubmit = useCallback(
|
|
258
|
-
(event: React.KeyboardEvent<HTMLInputElement | HTMLTextAreaElement>) => {
|
|
259
|
-
if (event.key === "Enter") {
|
|
260
|
-
onPaginationChange({
|
|
261
|
-
pageIndex: page,
|
|
262
|
-
pageSize: parseInt(event.currentTarget.value),
|
|
263
|
-
});
|
|
264
|
-
}
|
|
265
|
-
},
|
|
266
|
-
[page, onPaginationChange],
|
|
267
|
-
);
|
|
268
|
-
|
|
269
|
-
const setPageFromEvent = useCallback(
|
|
270
|
-
(event: React.ChangeEvent<HTMLInputElement>) => {
|
|
271
|
-
const value = maxPageIndex
|
|
272
|
-
? Math.min(parseInt(event.target.value), maxPageIndex)
|
|
273
|
-
: parseInt(event.target.value);
|
|
274
|
-
setPage(value);
|
|
275
|
-
},
|
|
276
|
-
[setPage, maxPageIndex],
|
|
277
|
-
);
|
|
278
|
-
|
|
279
|
-
const setRowsPerPageFromEvent = useCallback(
|
|
280
|
-
(event: React.ChangeEvent<HTMLInputElement>) => {
|
|
281
|
-
const value = maxPageSize
|
|
282
|
-
? Math.min(parseInt(event.target.value), maxPageSize)
|
|
283
|
-
: parseInt(event.target.value);
|
|
284
|
-
|
|
285
|
-
// Ensure the value can't be less than 1
|
|
286
|
-
setRowsPerPage(Math.max(1, value));
|
|
287
|
-
},
|
|
288
|
-
[setRowsPerPage, maxPageSize],
|
|
289
|
-
);
|
|
290
|
-
|
|
291
|
-
const handleLoadMore = useCallback(() => {
|
|
292
|
-
onPaginationChange({
|
|
293
|
-
pageIndex: 1,
|
|
294
|
-
pageSize: rowsPerPage + initialRowsPerPage.current,
|
|
295
|
-
});
|
|
296
|
-
}, [rowsPerPage, onPaginationChange]);
|
|
297
|
-
|
|
298
|
-
const handleNextButton = useCallback(() => {
|
|
299
|
-
onPaginationChange({ pageIndex: page + 1, pageSize: rowsPerPage });
|
|
300
|
-
}, [onPaginationChange, page, rowsPerPage]);
|
|
301
|
-
|
|
302
|
-
const handlePreviousButton = useCallback(() => {
|
|
303
|
-
onPaginationChange({ pageIndex: page - 1, pageSize: rowsPerPage });
|
|
304
|
-
}, [onPaginationChange, page, rowsPerPage]);
|
|
305
|
-
|
|
306
|
-
const loadMoreIsDisabled = useMemo(() => {
|
|
307
|
-
return isMoreDisabled || (totalRows ? rowsPerPage >= totalRows : false);
|
|
308
|
-
}, [isMoreDisabled, rowsPerPage, totalRows]);
|
|
309
|
-
|
|
310
|
-
const nextButtonDisabled = useMemo(
|
|
311
|
-
() =>
|
|
312
|
-
isMoreDisabled ||
|
|
313
|
-
(lastRow && (totalRows ? lastRow >= totalRows : false)) ||
|
|
314
|
-
isDisabled,
|
|
315
|
-
[isMoreDisabled, totalRows, lastRow, isDisabled],
|
|
316
|
-
);
|
|
317
|
-
|
|
318
|
-
const previousButtonDisabled = useMemo(
|
|
319
|
-
() => pageIndex <= 1 || isDisabled,
|
|
320
|
-
[pageIndex, isDisabled],
|
|
321
|
-
);
|
|
322
|
-
|
|
323
|
-
const rowsPerPageInputProps = useMemo(
|
|
324
|
-
() => ({
|
|
325
|
-
"aria-label": rowsPerPageLabel,
|
|
326
|
-
max: maxPageSize || totalRows,
|
|
327
|
-
}),
|
|
328
|
-
[maxPageSize, rowsPerPageLabel, totalRows],
|
|
329
|
-
);
|
|
330
|
-
|
|
331
|
-
const currentPageInputProps = useMemo(
|
|
332
|
-
() => ({
|
|
333
|
-
"aria-label": currentPageLabel,
|
|
334
|
-
max: maxPageIndex,
|
|
335
|
-
}),
|
|
336
|
-
[currentPageLabel, maxPageIndex],
|
|
337
|
-
);
|
|
338
|
-
|
|
339
|
-
return variant === "paged" ? (
|
|
340
|
-
<PaginationContainer aria-label={t("pagination.label")}>
|
|
341
|
-
<PaginationSegment odysseyDesignTokens={odysseyDesignTokens}>
|
|
342
|
-
{hasRowCountInput && (
|
|
343
|
-
<Box>
|
|
344
|
-
<Paragraph component="span" color="textSecondary">
|
|
345
|
-
{rowsPerPageLabel}
|
|
346
|
-
</Paragraph>
|
|
347
|
-
<PaginationInput
|
|
348
|
-
odysseyDesignTokens={odysseyDesignTokens}
|
|
349
|
-
type="number"
|
|
350
|
-
value={rowsPerPage}
|
|
351
|
-
onChange={setRowsPerPageFromEvent}
|
|
352
|
-
onBlur={handlePaginationChange}
|
|
353
|
-
onKeyDown={handleRowsPerPageSubmit}
|
|
354
|
-
disabled={isDisabled}
|
|
355
|
-
inputProps={rowsPerPageInputProps}
|
|
356
|
-
/>
|
|
357
|
-
</Box>
|
|
358
|
-
)}
|
|
359
|
-
{hasRowCountLabel && (
|
|
360
|
-
<Paragraph component="span" color="textSecondary">
|
|
361
|
-
{totalRowsLabel}
|
|
362
|
-
</Paragraph>
|
|
363
|
-
)}
|
|
364
|
-
</PaginationSegment>
|
|
365
|
-
|
|
366
|
-
<PaginationSegment odysseyDesignTokens={odysseyDesignTokens}>
|
|
367
|
-
{totalRows && hasPageInput && (
|
|
368
|
-
<Box>
|
|
369
|
-
<Paragraph component="span" color="textSecondary">
|
|
370
|
-
{currentPageLabel}
|
|
371
|
-
</Paragraph>
|
|
372
|
-
<PaginationInput
|
|
373
|
-
odysseyDesignTokens={odysseyDesignTokens}
|
|
374
|
-
type="number"
|
|
375
|
-
value={page}
|
|
376
|
-
onChange={setPageFromEvent}
|
|
377
|
-
onBlur={handlePaginationChange}
|
|
378
|
-
onKeyDown={handlePageSubmit}
|
|
379
|
-
disabled={isDisabled}
|
|
380
|
-
inputProps={currentPageInputProps}
|
|
381
|
-
/>
|
|
382
|
-
</Box>
|
|
383
|
-
)}
|
|
384
|
-
<PaginationButtonContainer>
|
|
385
|
-
<Button
|
|
386
|
-
startIcon={<ArrowLeftIcon />}
|
|
387
|
-
variant="floating"
|
|
388
|
-
size="small"
|
|
389
|
-
ariaLabel={previousLabel}
|
|
390
|
-
onClick={handlePreviousButton}
|
|
391
|
-
isDisabled={previousButtonDisabled}
|
|
392
|
-
/>
|
|
393
|
-
<Button
|
|
394
|
-
endIcon={<ArrowRightIcon />}
|
|
395
|
-
variant="floating"
|
|
396
|
-
size="small"
|
|
397
|
-
ariaLabel={nextLabel}
|
|
398
|
-
onClick={handleNextButton}
|
|
399
|
-
isDisabled={nextButtonDisabled}
|
|
400
|
-
/>
|
|
401
|
-
</PaginationButtonContainer>
|
|
402
|
-
</PaginationSegment>
|
|
403
|
-
</PaginationContainer>
|
|
404
|
-
) : (
|
|
405
|
-
<Button
|
|
406
|
-
variant="secondary"
|
|
407
|
-
label={loadMoreLabel}
|
|
408
|
-
onClick={handleLoadMore}
|
|
409
|
-
isDisabled={loadMoreIsDisabled}
|
|
410
|
-
/>
|
|
411
|
-
);
|
|
412
|
-
};
|
|
413
|
-
|
|
414
|
-
const MemoizedPagination = memo(Pagination);
|
|
415
|
-
MemoizedPagination.displayName = "Pagination";
|
|
416
|
-
|
|
417
|
-
export { MemoizedPagination as Pagination };
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
/*!
|
|
2
|
-
* Copyright (c) 2023-present, Okta, Inc. and/or its affiliates. All rights reserved.
|
|
3
|
-
* The Okta software accompanied by this notice is provided pursuant to the Apache License, Version 2.0 (the "License.")
|
|
4
|
-
*
|
|
5
|
-
* You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0.
|
|
6
|
-
* Unless required by applicable law or agreed to in writing, software
|
|
7
|
-
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
8
|
-
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
9
|
-
*
|
|
10
|
-
* See the License for the specific language governing permissions and limitations under the License.
|
|
11
|
-
*/
|
|
12
|
-
|
|
13
|
-
export const paginationTypeValues = ["paged", "loadMore"] as const;
|
package/src/Pagination/index.ts
DELETED
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
/*!
|
|
2
|
-
* Copyright (c) 2023-present, Okta, Inc. and/or its affiliates. All rights reserved.
|
|
3
|
-
* The Okta software accompanied by this notice is provided pursuant to the Apache License, Version 2.0 (the "License.")
|
|
4
|
-
*
|
|
5
|
-
* You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0.
|
|
6
|
-
* Unless required by applicable law or agreed to in writing, software
|
|
7
|
-
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
8
|
-
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
9
|
-
*
|
|
10
|
-
* See the License for the specific language governing permissions and limitations under the License.
|
|
11
|
-
*/
|
|
12
|
-
|
|
13
|
-
export { paginationTypeValues } from "./constants.js";
|
|
14
|
-
export * from "./Pagination.js";
|
|
15
|
-
export { usePagination } from "./usePagination.js";
|
|
@@ -1,45 +0,0 @@
|
|
|
1
|
-
/*!
|
|
2
|
-
* Copyright (c) 2023-present, Okta, Inc. and/or its affiliates. All rights reserved.
|
|
3
|
-
* The Okta software accompanied by this notice is provided pursuant to the Apache License, Version 2.0 (the "License.")
|
|
4
|
-
*
|
|
5
|
-
* You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0.
|
|
6
|
-
* Unless required by applicable law or agreed to in writing, software
|
|
7
|
-
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
8
|
-
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
9
|
-
*
|
|
10
|
-
* See the License for the specific language governing permissions and limitations under the License.
|
|
11
|
-
*/
|
|
12
|
-
|
|
13
|
-
import { useTranslation } from "react-i18next";
|
|
14
|
-
import { useMemo } from "react";
|
|
15
|
-
|
|
16
|
-
type UsePaginationType = {
|
|
17
|
-
currentRowsCount: number;
|
|
18
|
-
pageIndex: number;
|
|
19
|
-
pageSize: number;
|
|
20
|
-
totalRows?: number;
|
|
21
|
-
};
|
|
22
|
-
|
|
23
|
-
export const usePagination = ({
|
|
24
|
-
currentRowsCount,
|
|
25
|
-
pageIndex,
|
|
26
|
-
pageSize,
|
|
27
|
-
totalRows,
|
|
28
|
-
}: UsePaginationType) => {
|
|
29
|
-
const { t } = useTranslation();
|
|
30
|
-
|
|
31
|
-
return useMemo(() => {
|
|
32
|
-
const firstRow = pageSize * (pageIndex - 1) + 1;
|
|
33
|
-
const lastRow = firstRow + (currentRowsCount - 1);
|
|
34
|
-
|
|
35
|
-
const totalRowsLabel = totalRows
|
|
36
|
-
? t("pagination.rowswithtotal", { firstRow, lastRow, totalRows })
|
|
37
|
-
: t("pagination.rowswithouttotal", { firstRow, lastRow });
|
|
38
|
-
|
|
39
|
-
return {
|
|
40
|
-
firstRow,
|
|
41
|
-
lastRow,
|
|
42
|
-
totalRowsLabel,
|
|
43
|
-
};
|
|
44
|
-
}, [currentRowsCount, pageIndex, pageSize, totalRows, t]);
|
|
45
|
-
};
|