@databiosphere/findable-ui 19.0.0 → 20.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.release-please-manifest.json +1 -1
- package/CHANGELOG.md +11 -0
- package/lib/components/Authentication/components/SessionController/components/GoogleSessionController/SessionController.d.ts +2 -0
- package/lib/components/Authentication/components/SessionController/components/GoogleSessionController/SessionController.js +29 -0
- package/lib/components/Authentication/components/SessionController/components/GoogleSessionController/types.d.ts +6 -0
- package/lib/components/Authentication/components/SessionController/components/GoogleSessionController/types.js +1 -0
- package/lib/components/Authentication/components/SessionController/components/NextSessionController/SessionController.d.ts +2 -0
- package/lib/components/Authentication/components/SessionController/components/NextSessionController/SessionController.js +17 -0
- package/lib/components/Authentication/components/SessionController/components/NextSessionController/constants.d.ts +5 -0
- package/lib/components/Authentication/components/SessionController/components/NextSessionController/constants.js +12 -0
- package/lib/components/Authentication/components/SessionController/components/NextSessionController/types.d.ts +4 -0
- package/lib/components/Authentication/components/SessionController/components/NextSessionController/types.js +1 -0
- package/lib/components/Authentication/components/SessionController/components/NextSessionController/utils.d.ts +15 -0
- package/lib/components/Authentication/components/SessionController/components/NextSessionController/utils.js +53 -0
- package/lib/components/ComponentCreator/ComponentCreator.js +2 -3
- package/lib/components/Export/components/ExportToTerra/components/TerraSetUpForm/components/FormStep/components/AcceptTerraTOS/acceptTerraTOS.js +2 -2
- package/lib/components/Export/components/ExportToTerra/components/TerraSetUpForm/components/NIHAccountExpiryWarning/nihAccountExpiryWarning.js +1 -1
- package/lib/components/Export/components/ExportToTerra/components/TerraSetUpForm/terraSetUpForm.js +8 -3
- package/lib/components/Layout/components/Header/components/Content/components/Actions/components/Authentication/authentication.d.ts +2 -1
- package/lib/components/Layout/components/Header/components/Content/components/Actions/components/Authentication/authentication.js +17 -14
- package/lib/components/Layout/components/Header/components/Content/components/Actions/components/Authentication/components/AuthenticationMenu/authenticationMenu.d.ts +3 -4
- package/lib/components/Layout/components/Header/components/Content/components/Actions/components/Authentication/components/AuthenticationMenu/authenticationMenu.js +15 -24
- package/lib/components/Layout/components/Header/components/Content/components/Actions/components/Authentication/components/AuthenticationMenu/authenticationMenu.styles.d.ts +1 -1
- package/lib/components/Layout/components/Header/components/Content/components/Actions/components/Authentication/components/AuthenticationMenu/authenticationMenu.styles.js +2 -2
- package/lib/components/Layout/components/Header/components/Content/components/Actions/components/Authentication/components/AuthenticationMenu/constants.d.ts +2 -0
- package/lib/components/Layout/components/Header/components/Content/components/Actions/components/Authentication/components/AuthenticationMenu/constants.js +14 -0
- package/lib/components/Layout/components/Header/components/Content/components/Actions/components/Authentication/components/Button/button.styles.js +3 -2
- package/lib/components/Layout/components/Header/header.js +1 -1
- package/lib/components/Login/components/Button/button.d.ts +2 -0
- package/lib/components/Login/components/Button/button.js +6 -0
- package/lib/components/Login/components/Button/button.styles.d.ts +5 -0
- package/lib/components/Login/components/Button/button.styles.js +11 -0
- package/lib/components/Login/components/Button/constants.d.ts +2 -0
- package/lib/components/Login/components/Button/constants.js +6 -0
- package/lib/components/Login/components/Button/types.d.ts +3 -0
- package/lib/components/Login/components/Button/types.js +1 -0
- package/lib/components/Login/login.d.ts +2 -9
- package/lib/components/Login/login.js +9 -10
- package/lib/components/Login/types.d.ts +10 -0
- package/lib/components/Login/types.js +1 -0
- package/lib/components/common/Banner/components/SessionTimeout/sessionTimeout.js +1 -1
- package/lib/components/common/CustomIcon/common/entities.d.ts +1 -4
- package/lib/components/common/CustomIcon/components/GoogleIcon/googleIcon.d.ts +2 -2
- package/lib/components/common/CustomIcon/components/GoogleIcon/googleIcon.js +1 -1
- package/lib/config/entities.d.ts +22 -23
- package/lib/hooks/authentication/auth/useAuthReducer.d.ts +2 -0
- package/lib/hooks/authentication/auth/useAuthReducer.js +8 -0
- package/lib/hooks/authentication/authentication/useAuthenticationReducer.d.ts +2 -0
- package/lib/hooks/authentication/authentication/useAuthenticationReducer.js +8 -0
- package/lib/hooks/authentication/config/useAuthenticationConfig.d.ts +6 -0
- package/lib/hooks/authentication/config/useAuthenticationConfig.js +9 -0
- package/lib/hooks/authentication/credentials/useCredentialsReducer.d.ts +2 -0
- package/lib/hooks/authentication/credentials/useCredentialsReducer.js +7 -0
- package/lib/hooks/authentication/profile/types.d.ts +5 -0
- package/lib/hooks/authentication/profile/types.js +1 -0
- package/lib/hooks/authentication/profile/useProfile.d.ts +6 -0
- package/lib/hooks/authentication/profile/useProfile.js +15 -0
- package/lib/hooks/authentication/providers/types.d.ts +6 -0
- package/lib/hooks/authentication/providers/types.js +1 -0
- package/lib/hooks/authentication/providers/useProviders.d.ts +6 -0
- package/lib/hooks/authentication/providers/useProviders.js +14 -0
- package/lib/hooks/authentication/session/useSessionActive.d.ts +12 -0
- package/lib/hooks/authentication/session/useSessionActive.js +36 -0
- package/lib/hooks/authentication/session/useSessionCallbackUrl.d.ts +4 -0
- package/lib/hooks/authentication/session/useSessionCallbackUrl.js +20 -0
- package/lib/hooks/authentication/session/useSessionIdleTimer.d.ts +6 -0
- package/lib/hooks/authentication/session/useSessionIdleTimer.js +8 -0
- package/lib/hooks/{useSessionTimeout.js → authentication/session/useSessionTimeout.js} +2 -2
- package/lib/hooks/{useAuthentication → authentication/terra}/useAuthenticationForm.d.ts +0 -1
- package/lib/hooks/{useAuthentication → authentication/terra}/useAuthenticationForm.js +6 -9
- package/lib/hooks/{useAuthentication → authentication/terra}/useAuthenticationNIHExpiry.js +3 -4
- package/lib/hooks/authentication/token/types.d.ts +4 -0
- package/lib/hooks/authentication/token/types.js +1 -0
- package/lib/hooks/authentication/token/useToken.d.ts +2 -0
- package/lib/hooks/authentication/token/useToken.js +5 -0
- package/lib/hooks/authentication/token/useTokenReducer.d.ts +7 -0
- package/lib/hooks/authentication/token/useTokenReducer.js +12 -0
- package/lib/hooks/useEntityList.js +2 -2
- package/lib/hooks/useFetchEntity.js +4 -3
- package/lib/hooks/useFileManifest/useFetchFilesFacets.js +2 -3
- package/lib/hooks/useFileManifest/useFetchSummary.js +2 -3
- package/lib/hooks/useRequestFileLocation.js +2 -3
- package/lib/hooks/useRouteHistory.d.ts +14 -0
- package/lib/hooks/useRouteHistory.js +40 -0
- package/lib/hooks/useRouteRoot.d.ts +1 -0
- package/lib/hooks/useRouteRoot.js +8 -0
- package/lib/hooks/useSummary.js +3 -3
- package/lib/providers/authentication/auth/actions.d.ts +8 -0
- package/lib/providers/authentication/auth/actions.js +12 -0
- package/lib/providers/authentication/auth/constants.d.ts +2 -0
- package/lib/providers/authentication/auth/constants.js +5 -0
- package/lib/providers/authentication/auth/context.d.ts +2 -0
- package/lib/providers/authentication/auth/context.js +7 -0
- package/lib/providers/authentication/auth/dispatch.d.ts +23 -0
- package/lib/providers/authentication/auth/dispatch.js +43 -0
- package/lib/providers/authentication/auth/hook.d.ts +6 -0
- package/lib/providers/authentication/auth/hook.js +9 -0
- package/lib/providers/authentication/auth/reducer.d.ts +8 -0
- package/lib/providers/authentication/auth/reducer.js +24 -0
- package/lib/providers/authentication/auth/types.d.ts +48 -0
- package/lib/providers/authentication/auth/types.js +11 -0
- package/lib/providers/authentication/authentication/actions.d.ts +8 -0
- package/lib/providers/authentication/authentication/actions.js +12 -0
- package/lib/providers/authentication/authentication/constants.d.ts +2 -0
- package/lib/providers/authentication/authentication/constants.js +5 -0
- package/lib/providers/authentication/authentication/context.d.ts +2 -0
- package/lib/providers/authentication/authentication/context.js +6 -0
- package/lib/providers/authentication/authentication/dispatch.d.ts +22 -0
- package/lib/providers/authentication/authentication/dispatch.js +42 -0
- package/lib/providers/authentication/authentication/hook.d.ts +6 -0
- package/lib/providers/authentication/authentication/hook.js +9 -0
- package/lib/providers/authentication/authentication/reducer.d.ts +9 -0
- package/lib/providers/authentication/authentication/reducer.js +25 -0
- package/lib/providers/authentication/authentication/types.d.ts +47 -0
- package/lib/providers/authentication/authentication/types.js +11 -0
- package/lib/providers/authentication/authentication/utils.d.ts +12 -0
- package/lib/providers/authentication/authentication/utils.js +18 -0
- package/lib/providers/authentication/common/types.d.ts +1 -0
- package/lib/providers/authentication/common/types.js +1 -0
- package/lib/providers/authentication/common/utils.d.ts +6 -0
- package/lib/providers/authentication/common/utils.js +11 -0
- package/lib/providers/authentication/credentials/actions.d.ts +8 -0
- package/lib/providers/authentication/credentials/actions.js +12 -0
- package/lib/providers/authentication/credentials/constants.d.ts +2 -0
- package/lib/providers/authentication/credentials/constants.js +3 -0
- package/lib/providers/authentication/credentials/context.d.ts +2 -0
- package/lib/providers/authentication/credentials/context.js +6 -0
- package/lib/providers/authentication/credentials/dispatch.d.ts +12 -0
- package/lib/providers/authentication/credentials/dispatch.js +22 -0
- package/lib/providers/authentication/credentials/hook.d.ts +6 -0
- package/lib/providers/authentication/credentials/hook.js +9 -0
- package/lib/providers/authentication/credentials/reducer.d.ts +8 -0
- package/lib/providers/authentication/credentials/reducer.js +22 -0
- package/lib/providers/authentication/credentials/types.d.ts +24 -0
- package/lib/providers/authentication/credentials/types.js +5 -0
- package/lib/providers/authentication/terra/context.d.ts +2 -0
- package/lib/providers/authentication/terra/context.js +7 -0
- package/lib/providers/authentication/terra/hook.d.ts +6 -0
- package/lib/providers/authentication/terra/hook.js +9 -0
- package/lib/{hooks/useAuthentication → providers/authentication/terra/hooks}/common/constants.d.ts +2 -0
- package/lib/{hooks/useAuthentication → providers/authentication/terra/hooks}/common/constants.js +7 -0
- package/lib/{hooks/useAuthentication → providers/authentication/terra/hooks}/common/entities.d.ts +3 -7
- package/lib/{hooks/useAuthentication → providers/authentication/terra/hooks}/common/entities.js +1 -5
- package/lib/providers/authentication/terra/hooks/useFetchProfiles.d.ts +13 -0
- package/lib/providers/authentication/terra/hooks/useFetchProfiles.js +31 -0
- package/lib/{hooks/useAuthentication → providers/authentication/terra/hooks}/useFetchTerraNIHProfile.js +11 -6
- package/lib/{hooks/useAuthentication → providers/authentication/terra/hooks}/useFetchTerraProfile.js +11 -6
- package/lib/{hooks/useAuthentication → providers/authentication/terra/hooks}/useFetchTerraTermsOfService.js +11 -6
- package/lib/providers/authentication/terra/hooks/utils.d.ts +16 -0
- package/lib/providers/authentication/terra/hooks/utils.js +19 -0
- package/lib/providers/authentication/terra/provider.d.ts +2 -0
- package/lib/providers/authentication/terra/provider.js +42 -0
- package/lib/providers/authentication/terra/types.d.ts +20 -0
- package/lib/providers/authentication/terra/types.js +6 -0
- package/lib/providers/authentication/terra/utils.d.ts +19 -0
- package/lib/providers/authentication/terra/utils.js +36 -0
- package/lib/providers/authentication/token/constants.d.ts +2 -0
- package/lib/providers/authentication/token/constants.js +4 -0
- package/lib/providers/authentication/token/dispatch.d.ts +12 -0
- package/lib/providers/authentication/token/dispatch.js +22 -0
- package/lib/providers/authentication/token/reducer.d.ts +8 -0
- package/lib/providers/authentication/token/reducer.js +22 -0
- package/lib/providers/authentication/token/types.d.ts +28 -0
- package/lib/providers/authentication/token/types.js +5 -0
- package/lib/providers/exploreState.js +3 -5
- package/lib/providers/googleSignInAuthentication/common/types.d.ts +17 -0
- package/lib/providers/googleSignInAuthentication/common/types.js +1 -0
- package/lib/providers/googleSignInAuthentication/constants.d.ts +4 -0
- package/lib/providers/googleSignInAuthentication/constants.js +12 -0
- package/lib/providers/googleSignInAuthentication/hooks/useGoogleSignInService.d.ts +3 -0
- package/lib/providers/googleSignInAuthentication/hooks/useGoogleSignInService.js +36 -0
- package/lib/providers/googleSignInAuthentication/profile/types.d.ts +14 -0
- package/lib/providers/googleSignInAuthentication/profile/types.js +1 -0
- package/lib/providers/googleSignInAuthentication/profile/utils.d.ts +8 -0
- package/lib/providers/googleSignInAuthentication/profile/utils.js +25 -0
- package/lib/providers/googleSignInAuthentication/provider.d.ts +2 -0
- package/lib/providers/googleSignInAuthentication/provider.js +40 -0
- package/lib/providers/googleSignInAuthentication/service/constants.d.ts +4 -0
- package/lib/providers/googleSignInAuthentication/service/constants.js +9 -0
- package/lib/providers/googleSignInAuthentication/service/service.d.ts +6 -0
- package/lib/providers/googleSignInAuthentication/service/service.js +43 -0
- package/lib/providers/googleSignInAuthentication/types.d.ts +6 -0
- package/lib/providers/googleSignInAuthentication/types.js +1 -0
- package/lib/providers/nextAuthAuthentication/hooks/useNextAuthService.d.ts +2 -0
- package/lib/providers/nextAuthAuthentication/hooks/useNextAuthService.js +14 -0
- package/lib/providers/nextAuthAuthentication/provider.d.ts +2 -0
- package/lib/providers/nextAuthAuthentication/provider.js +30 -0
- package/lib/providers/nextAuthAuthentication/service/service.d.ts +6 -0
- package/lib/providers/nextAuthAuthentication/service/service.js +12 -0
- package/lib/providers/nextAuthAuthentication/types.d.ts +8 -0
- package/lib/providers/nextAuthAuthentication/types.js +1 -0
- package/lib/routes/constants.d.ts +3 -0
- package/lib/routes/constants.js +3 -0
- package/lib/styles/common/mui/button.d.ts +3 -0
- package/lib/styles/common/mui/button.js +17 -0
- package/lib/styles/common/mui/paper.d.ts +2 -0
- package/lib/styles/common/mui/paper.js +9 -0
- package/lib/styles/common/mui/popover.d.ts +3 -0
- package/lib/styles/common/mui/popover.js +10 -0
- package/lib/theme/common/entities.d.ts +6 -0
- package/lib/theme/common/entities.js +1 -0
- package/lib/views/LoginView/loginView.d.ts +5 -1
- package/lib/views/LoginView/loginView.js +6 -4
- package/package.json +3 -2
- package/src/components/Authentication/components/SessionController/components/GoogleSessionController/SessionController.tsx +38 -0
- package/src/components/Authentication/components/SessionController/components/GoogleSessionController/types.ts +7 -0
- package/src/components/Authentication/components/SessionController/components/NextSessionController/SessionController.tsx +23 -0
- package/src/components/Authentication/components/SessionController/components/NextSessionController/constants.ts +21 -0
- package/src/components/Authentication/components/SessionController/components/NextSessionController/types.ts +5 -0
- package/src/components/Authentication/components/SessionController/components/NextSessionController/utils.ts +74 -0
- package/src/components/ComponentCreator/ComponentCreator.tsx +4 -3
- package/src/components/Export/components/ExportToTerra/components/TerraSetUpForm/components/FormStep/components/AcceptTerraTOS/acceptTerraTOS.tsx +4 -4
- package/src/components/Export/components/ExportToTerra/components/TerraSetUpForm/components/NIHAccountExpiryWarning/nihAccountExpiryWarning.tsx +1 -1
- package/src/components/Export/components/ExportToTerra/components/TerraSetUpForm/terraSetUpForm.tsx +9 -6
- package/src/components/Layout/components/Header/components/Content/components/Actions/components/Authentication/authentication.tsx +27 -25
- package/src/components/Layout/components/Header/components/Content/components/Actions/components/Authentication/components/AuthenticationMenu/authenticationMenu.styles.ts +2 -2
- package/src/components/Layout/components/Header/components/Content/components/Actions/components/Authentication/components/AuthenticationMenu/authenticationMenu.tsx +18 -42
- package/src/components/Layout/components/Header/components/Content/components/Actions/components/Authentication/components/AuthenticationMenu/constants.ts +19 -0
- package/src/components/Layout/components/Header/components/Content/components/Actions/components/Authentication/components/Button/button.styles.ts +3 -2
- package/src/components/Layout/components/Header/header.tsx +1 -1
- package/src/components/Login/components/Button/button.styles.ts +12 -0
- package/src/components/Login/components/Button/button.tsx +8 -0
- package/src/components/Login/components/Button/constants.ts +8 -0
- package/src/components/Login/components/Button/types.ts +4 -0
- package/src/components/Login/login.tsx +28 -28
- package/src/components/Login/types.ts +11 -0
- package/src/components/common/Banner/components/SessionTimeout/sessionTimeout.tsx +1 -1
- package/src/components/common/CustomIcon/common/entities.ts +1 -4
- package/src/components/common/CustomIcon/components/GoogleIcon/googleIcon.tsx +3 -4
- package/src/config/entities.ts +20 -25
- package/src/hooks/authentication/auth/useAuthReducer.ts +16 -0
- package/src/hooks/authentication/authentication/useAuthenticationReducer.ts +16 -0
- package/src/hooks/authentication/config/useAuthenticationConfig.ts +13 -0
- package/src/hooks/authentication/credentials/useCredentialsReducer.ts +13 -0
- package/src/hooks/authentication/profile/types.ts +9 -0
- package/src/hooks/authentication/profile/useProfile.ts +21 -0
- package/src/hooks/authentication/providers/types.ts +7 -0
- package/src/hooks/authentication/providers/useProviders.ts +23 -0
- package/src/hooks/authentication/session/useSessionActive.ts +51 -0
- package/src/hooks/authentication/session/useSessionCallbackUrl.ts +25 -0
- package/src/hooks/authentication/session/useSessionIdleTimer.ts +10 -0
- package/src/hooks/{useSessionTimeout.ts → authentication/session/useSessionTimeout.ts} +2 -2
- package/src/hooks/{useAuthentication → authentication/terra}/useAuthenticationForm.ts +8 -13
- package/src/hooks/{useAuthentication → authentication/terra}/useAuthenticationNIHExpiry.ts +3 -4
- package/src/hooks/authentication/token/types.ts +5 -0
- package/src/hooks/authentication/token/useToken.ts +9 -0
- package/src/hooks/authentication/token/useTokenReducer.ts +19 -0
- package/src/hooks/useEntityList.ts +2 -2
- package/src/hooks/useFetchEntity.tsx +3 -3
- package/src/hooks/useFileManifest/useFetchFilesFacets.ts +2 -3
- package/src/hooks/useFileManifest/useFetchSummary.ts +2 -3
- package/src/hooks/useRequestFileLocation.ts +2 -3
- package/src/hooks/useRouteHistory.ts +65 -0
- package/src/hooks/useRouteRoot.ts +11 -0
- package/src/hooks/useSummary.ts +3 -3
- package/src/providers/authentication/auth/actions.ts +17 -0
- package/src/providers/authentication/auth/constants.ts +6 -0
- package/src/providers/authentication/auth/context.ts +9 -0
- package/src/providers/authentication/auth/dispatch.ts +58 -0
- package/src/providers/authentication/auth/hook.ts +11 -0
- package/src/providers/authentication/auth/reducer.ts +25 -0
- package/src/providers/authentication/auth/types.ts +63 -0
- package/src/providers/authentication/authentication/actions.ts +17 -0
- package/src/providers/authentication/authentication/constants.ts +6 -0
- package/src/providers/authentication/authentication/context.ts +8 -0
- package/src/providers/authentication/authentication/dispatch.ts +55 -0
- package/src/providers/authentication/authentication/hook.ts +11 -0
- package/src/providers/authentication/authentication/reducer.ts +34 -0
- package/src/providers/authentication/authentication/types.ts +64 -0
- package/src/providers/authentication/authentication/utils.ts +25 -0
- package/src/providers/authentication/common/types.ts +1 -0
- package/src/providers/authentication/common/utils.ts +11 -0
- package/src/providers/authentication/credentials/actions.ts +17 -0
- package/src/providers/authentication/credentials/constants.ts +5 -0
- package/src/providers/authentication/credentials/context.ts +8 -0
- package/src/providers/authentication/credentials/dispatch.ts +31 -0
- package/src/providers/authentication/credentials/hook.ts +11 -0
- package/src/providers/authentication/credentials/reducer.ts +30 -0
- package/src/providers/authentication/credentials/types.ts +33 -0
- package/src/providers/authentication/terra/context.ts +16 -0
- package/src/providers/authentication/terra/hook.ts +11 -0
- package/src/{hooks/useAuthentication → providers/authentication/terra/hooks}/common/constants.ts +9 -0
- package/src/{hooks/useAuthentication → providers/authentication/terra/hooks}/common/entities.ts +1 -7
- package/src/providers/authentication/terra/hooks/useFetchProfiles.ts +61 -0
- package/src/{hooks/useAuthentication → providers/authentication/terra/hooks}/useFetchTerraNIHProfile.ts +18 -7
- package/src/{hooks/useAuthentication → providers/authentication/terra/hooks}/useFetchTerraProfile.ts +18 -7
- package/src/{hooks/useAuthentication → providers/authentication/terra/hooks}/useFetchTerraTermsOfService.ts +18 -7
- package/src/providers/authentication/terra/hooks/utils.ts +29 -0
- package/src/providers/authentication/terra/provider.tsx +60 -0
- package/src/providers/authentication/terra/types.ts +23 -0
- package/src/providers/authentication/terra/utils.ts +49 -0
- package/src/providers/authentication/token/constants.ts +6 -0
- package/src/providers/authentication/token/dispatch.ts +29 -0
- package/src/providers/authentication/token/reducer.ts +26 -0
- package/src/providers/authentication/token/types.ts +36 -0
- package/src/providers/exploreState.tsx +3 -4
- package/src/providers/googleSignInAuthentication/common/types.ts +28 -0
- package/src/providers/googleSignInAuthentication/constants.ts +17 -0
- package/src/providers/googleSignInAuthentication/hooks/useGoogleSignInService.ts +53 -0
- package/src/providers/googleSignInAuthentication/profile/types.ts +15 -0
- package/src/providers/googleSignInAuthentication/profile/utils.ts +29 -0
- package/src/providers/googleSignInAuthentication/provider.tsx +53 -0
- package/src/providers/googleSignInAuthentication/service/constants.ts +16 -0
- package/src/providers/googleSignInAuthentication/service/service.ts +68 -0
- package/src/providers/googleSignInAuthentication/types.ts +7 -0
- package/src/providers/nextAuthAuthentication/hooks/useNextAuthService.ts +26 -0
- package/src/providers/nextAuthAuthentication/provider.tsx +42 -0
- package/src/providers/nextAuthAuthentication/service/service.ts +14 -0
- package/src/providers/nextAuthAuthentication/types.ts +9 -0
- package/src/routes/constants.ts +3 -0
- package/src/styles/common/mui/button.ts +20 -0
- package/src/styles/common/mui/paper.ts +11 -0
- package/src/styles/common/mui/popover.ts +19 -0
- package/src/theme/common/entities.ts +7 -0
- package/src/views/LoginView/loginView.tsx +15 -9
- package/tests/getProfileStatus.test.ts +290 -0
- package/tests/terraProfileProvider.test.tsx +121 -0
- package/tests/transformRoute.test.ts +21 -0
- package/tests/useRouteHistory.test.ts +97 -0
- package/tests/useSessionActive.test.ts +107 -0
- package/lib/components/Layout/components/Header/components/Content/components/Actions/components/Authentication/components/AuthenticationMenu/authenticationMenu.stories.d.ts +0 -5
- package/lib/components/Layout/components/Header/components/Content/components/Actions/components/Authentication/components/AuthenticationMenu/authenticationMenu.stories.js +0 -29
- package/lib/components/Login/login.stories.d.ts +0 -6
- package/lib/components/Login/login.stories.js +0 -31
- package/lib/components/common/Button/components/LoginButton/loginButton.d.ts +0 -3
- package/lib/components/common/Button/components/LoginButton/loginButton.js +0 -6
- package/lib/components/common/Button/components/LoginButton/loginButton.styles.d.ts +0 -7
- package/lib/components/common/Button/components/LoginButton/loginButton.styles.js +0 -11
- package/lib/hooks/useAuthentication/useAuthentication.d.ts +0 -6
- package/lib/hooks/useAuthentication/useAuthentication.js +0 -9
- package/lib/hooks/useAuthentication/useAuthenticationComplete.d.ts +0 -6
- package/lib/hooks/useAuthentication/useAuthenticationComplete.js +0 -55
- package/lib/hooks/useAuthentication/useAuthenticationStatus.d.ts +0 -20
- package/lib/hooks/useAuthentication/useAuthenticationStatus.js +0 -32
- package/lib/hooks/useAuthentication/useFetchGoogleProfile.d.ts +0 -21
- package/lib/hooks/useAuthentication/useFetchGoogleProfile.js +0 -41
- package/lib/hooks/useAuthentication/useTokenClient.d.ts +0 -11
- package/lib/hooks/useAuthentication/useTokenClient.js +0 -29
- package/lib/hooks/useAuthenticationConfig.d.ts +0 -6
- package/lib/hooks/useAuthenticationConfig.js +0 -14
- package/lib/providers/authentication.d.ts +0 -51
- package/lib/providers/authentication.js +0 -110
- package/src/components/Layout/components/Header/components/Content/components/Actions/components/Authentication/components/AuthenticationMenu/authenticationMenu.stories.tsx +0 -35
- package/src/components/Login/login.stories.tsx +0 -43
- package/src/components/common/Button/components/LoginButton/loginButton.styles.ts +0 -13
- package/src/components/common/Button/components/LoginButton/loginButton.tsx +0 -16
- package/src/hooks/useAuthentication/useAuthentication.tsx +0 -10
- package/src/hooks/useAuthentication/useAuthenticationComplete.ts +0 -66
- package/src/hooks/useAuthentication/useAuthenticationStatus.ts +0 -49
- package/src/hooks/useAuthentication/useFetchGoogleProfile.ts +0 -68
- package/src/hooks/useAuthentication/useTokenClient.ts +0 -54
- package/src/hooks/useAuthenticationConfig.ts +0 -18
- package/src/providers/authentication.tsx +0 -181
- package/tests/authentication.test.ts +0 -142
- package/tests/useAuthenticationStatus.test.ts +0 -155
- /package/lib/hooks/{useSessionTimeout.d.ts → authentication/session/useSessionTimeout.d.ts} +0 -0
- /package/lib/hooks/{useAuthentication → authentication/terra}/useAuthenticationNIHExpiry.d.ts +0 -0
- /package/lib/{hooks/useAuthentication → providers/authentication/terra/hooks}/common/utils.d.ts +0 -0
- /package/lib/{hooks/useAuthentication → providers/authentication/terra/hooks}/common/utils.js +0 -0
- /package/lib/{hooks/useAuthentication → providers/authentication/terra/hooks}/useFetchTerraNIHProfile.d.ts +0 -0
- /package/lib/{hooks/useAuthentication → providers/authentication/terra/hooks}/useFetchTerraProfile.d.ts +0 -0
- /package/lib/{hooks/useAuthentication → providers/authentication/terra/hooks}/useFetchTerraTermsOfService.d.ts +0 -0
- /package/src/{hooks/useAuthentication → providers/authentication/terra/hooks}/common/utils.ts +0 -0
package/CHANGELOG.md
CHANGED
|
@@ -1,5 +1,16 @@
|
|
|
1
1
|
# Changelog
|
|
2
2
|
|
|
3
|
+
## [20.0.0](https://github.com/DataBiosphere/findable-ui/compare/v19.0.0...v20.0.0) (2025-01-06)
|
|
4
|
+
|
|
5
|
+
|
|
6
|
+
### ⚠ BREAKING CHANGES
|
|
7
|
+
|
|
8
|
+
* remove terra functionality from authprovider into its own provider ([#178](https://github.com/DataBiosphere/findable-ui/issues/178)) (#240)
|
|
9
|
+
|
|
10
|
+
### Features
|
|
11
|
+
|
|
12
|
+
* remove terra functionality from authprovider into its own provider ([#178](https://github.com/DataBiosphere/findable-ui/issues/178)) ([#240](https://github.com/DataBiosphere/findable-ui/issues/240)) ([18b0ea8](https://github.com/DataBiosphere/findable-ui/commit/18b0ea875b0096a76e968f8578769f62fbab8804))
|
|
13
|
+
|
|
3
14
|
## [19.0.0](https://github.com/DataBiosphere/findable-ui/compare/v18.0.0...v19.0.0) (2025-01-03)
|
|
4
15
|
|
|
5
16
|
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import React, { Fragment, useEffect } from "react";
|
|
2
|
+
import { authComplete } from "../../../../../../providers/authentication/auth/dispatch";
|
|
3
|
+
import { useAuth } from "../../../../../../providers/authentication/auth/hook";
|
|
4
|
+
import { authenticationComplete } from "../../../../../../providers/authentication/authentication/dispatch";
|
|
5
|
+
import { useAuthentication } from "../../../../../../providers/authentication/authentication/hook";
|
|
6
|
+
import { updateCredentials } from "../../../../../../providers/authentication/credentials/dispatch";
|
|
7
|
+
import { useCredentials } from "../../../../../../providers/authentication/credentials/hook";
|
|
8
|
+
export function SessionController({ children, token, }) {
|
|
9
|
+
const { authDispatch } = useAuth();
|
|
10
|
+
const { authenticationDispatch, authenticationState: { profile }, } = useAuthentication();
|
|
11
|
+
const { credentialsDispatch } = useCredentials();
|
|
12
|
+
useEffect(() => {
|
|
13
|
+
// Dispatch only when profile is available:
|
|
14
|
+
// - Login errors are managed by the login service.
|
|
15
|
+
// - Logout operations handle resetting credentials, authentication and auth state.
|
|
16
|
+
if (!profile)
|
|
17
|
+
return;
|
|
18
|
+
credentialsDispatch?.(updateCredentials(token)); // Release credentials.
|
|
19
|
+
authenticationDispatch?.(authenticationComplete()); // Authentication `status` is "SETTLED".
|
|
20
|
+
authDispatch?.(authComplete({ isAuthenticated: true })); // Auth `status` is "SETTLED", and `isAuthenticated` is "true".
|
|
21
|
+
}, [
|
|
22
|
+
authDispatch,
|
|
23
|
+
authenticationDispatch,
|
|
24
|
+
credentialsDispatch,
|
|
25
|
+
profile,
|
|
26
|
+
token,
|
|
27
|
+
]);
|
|
28
|
+
return React.createElement(Fragment, null, children);
|
|
29
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { useSession } from "next-auth/react";
|
|
2
|
+
import React, { Fragment, useEffect } from "react";
|
|
3
|
+
import { updateAuthState } from "../../../../../../providers/authentication/auth/dispatch";
|
|
4
|
+
import { useAuth } from "../../../../../../providers/authentication/auth/hook";
|
|
5
|
+
import { updateAuthentication } from "../../../../../../providers/authentication/authentication/dispatch";
|
|
6
|
+
import { useAuthentication } from "../../../../../../providers/authentication/authentication/hook";
|
|
7
|
+
import { mapAuth, mapAuthentication } from "./utils";
|
|
8
|
+
export function SessionController({ children, }) {
|
|
9
|
+
const { authDispatch } = useAuth();
|
|
10
|
+
const { authenticationDispatch } = useAuthentication();
|
|
11
|
+
const session = useSession();
|
|
12
|
+
useEffect(() => {
|
|
13
|
+
authDispatch?.(updateAuthState(mapAuth(session)));
|
|
14
|
+
authenticationDispatch?.(updateAuthentication(mapAuthentication(session)));
|
|
15
|
+
}, [authDispatch, authenticationDispatch, session]);
|
|
16
|
+
return React.createElement(Fragment, null, children);
|
|
17
|
+
}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import { SessionContextValue } from "next-auth/react";
|
|
2
|
+
import { AUTH_STATUS } from "../../../../../../providers/authentication/auth/types";
|
|
3
|
+
import { AUTHENTICATION_STATUS } from "../../../../../../providers/authentication/authentication/types";
|
|
4
|
+
export declare const AUTH_STATUS_MAP: Record<SessionContextValue["status"], AUTH_STATUS>;
|
|
5
|
+
export declare const AUTHENTICATION_STATUS_MAP: Record<SessionContextValue["status"], AUTHENTICATION_STATUS>;
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { AUTH_STATUS } from "../../../../../../providers/authentication/auth/types";
|
|
2
|
+
import { AUTHENTICATION_STATUS } from "../../../../../../providers/authentication/authentication/types";
|
|
3
|
+
export const AUTH_STATUS_MAP = {
|
|
4
|
+
authenticated: AUTH_STATUS.SETTLED,
|
|
5
|
+
loading: AUTH_STATUS.PENDING,
|
|
6
|
+
unauthenticated: AUTH_STATUS.SETTLED,
|
|
7
|
+
};
|
|
8
|
+
export const AUTHENTICATION_STATUS_MAP = {
|
|
9
|
+
authenticated: AUTHENTICATION_STATUS.SETTLED,
|
|
10
|
+
loading: AUTHENTICATION_STATUS.PENDING,
|
|
11
|
+
unauthenticated: AUTHENTICATION_STATUS.SETTLED,
|
|
12
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { SessionContextValue } from "next-auth/react";
|
|
2
|
+
import { UpdateAuthStatePayload } from "../../../../../../providers/authentication/auth/types";
|
|
3
|
+
import { UpdateAuthenticationPayload } from "../../../../../../providers/authentication/authentication/types";
|
|
4
|
+
/**
|
|
5
|
+
* Returns the auth state from the session context.
|
|
6
|
+
* @param session - Session context value.
|
|
7
|
+
* @returns auth state.
|
|
8
|
+
*/
|
|
9
|
+
export declare function mapAuth(session: SessionContextValue): UpdateAuthStatePayload;
|
|
10
|
+
/**
|
|
11
|
+
* Returns the authentication profile and status from the session context.
|
|
12
|
+
* @param session - Session context value.
|
|
13
|
+
* @returns authentication profile and status.
|
|
14
|
+
*/
|
|
15
|
+
export declare function mapAuthentication(session: SessionContextValue): UpdateAuthenticationPayload;
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
import { AUTH_STATUS, } from "../../../../../../providers/authentication/auth/types";
|
|
2
|
+
import { AUTHENTICATION_STATUS, } from "../../../../../../providers/authentication/authentication/types";
|
|
3
|
+
import { AUTH_STATUS_MAP, AUTHENTICATION_STATUS_MAP } from "./constants";
|
|
4
|
+
/**
|
|
5
|
+
* Returns the auth state from the session context.
|
|
6
|
+
* @param session - Session context value.
|
|
7
|
+
* @returns auth state.
|
|
8
|
+
*/
|
|
9
|
+
export function mapAuth(session) {
|
|
10
|
+
return {
|
|
11
|
+
isAuthenticated: session.status === "authenticated",
|
|
12
|
+
status: mapStatus(session.status, AUTH_STATUS_MAP, AUTH_STATUS.SETTLED),
|
|
13
|
+
};
|
|
14
|
+
}
|
|
15
|
+
/**
|
|
16
|
+
* Returns the authentication profile and status from the session context.
|
|
17
|
+
* @param session - Session context value.
|
|
18
|
+
* @returns authentication profile and status.
|
|
19
|
+
*/
|
|
20
|
+
export function mapAuthentication(session) {
|
|
21
|
+
return {
|
|
22
|
+
profile: mapProfile(session.data),
|
|
23
|
+
status: mapStatus(session.status, AUTHENTICATION_STATUS_MAP, AUTHENTICATION_STATUS.SETTLED),
|
|
24
|
+
};
|
|
25
|
+
}
|
|
26
|
+
/**
|
|
27
|
+
* Maps the session data to a user profile.
|
|
28
|
+
* @param sessionData - Session data.
|
|
29
|
+
* @returns user profile.
|
|
30
|
+
*/
|
|
31
|
+
function mapProfile(sessionData) {
|
|
32
|
+
if (!sessionData)
|
|
33
|
+
return;
|
|
34
|
+
const { user } = sessionData;
|
|
35
|
+
if (!user)
|
|
36
|
+
return;
|
|
37
|
+
const { email, image, name } = user;
|
|
38
|
+
return {
|
|
39
|
+
email: email || "",
|
|
40
|
+
image: image || "",
|
|
41
|
+
name: name || "",
|
|
42
|
+
};
|
|
43
|
+
}
|
|
44
|
+
/**
|
|
45
|
+
* Returns the auth or authentication status <S> based on the session status.
|
|
46
|
+
* @param status - Session status.
|
|
47
|
+
* @param statusBySessionStatus - Map of session status to auth or authentication status.
|
|
48
|
+
* @param defaultStatus - Default auth or authentication status.
|
|
49
|
+
* @returns auth or authentication status.
|
|
50
|
+
*/
|
|
51
|
+
function mapStatus(status, statusBySessionStatus, defaultStatus) {
|
|
52
|
+
return statusBySessionStatus[status] || defaultStatus;
|
|
53
|
+
}
|
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
import React from "react";
|
|
2
|
-
import { useAuthentication } from "../../hooks/useAuthentication/useAuthentication";
|
|
3
2
|
import { useConfig } from "../../hooks/useConfig";
|
|
4
3
|
import { useExploreState } from "../../hooks/useExploreState";
|
|
5
4
|
import { useFileManifestState } from "../../hooks/useFileManifestState";
|
|
6
5
|
import { useSystemStatus } from "../../hooks/useSystemStatus";
|
|
6
|
+
import { useAuth } from "../../providers/authentication/auth/hook";
|
|
7
7
|
/**
|
|
8
8
|
* ComponentCreator uses React API to create components based on the component configs, instead of using JSX.
|
|
9
9
|
* That way we can continue to create UI components without having to worry about if they should be able to transform model data into props.
|
|
@@ -15,7 +15,7 @@ import { useSystemStatus } from "../../hooks/useSystemStatus";
|
|
|
15
15
|
* @returns A set of React components.
|
|
16
16
|
*/
|
|
17
17
|
export const ComponentCreator = ({ components, response, viewContext, }) => {
|
|
18
|
-
const {
|
|
18
|
+
const { authState: { isAuthenticated }, } = useAuth();
|
|
19
19
|
const { config, entityConfig } = useConfig();
|
|
20
20
|
const { exploreState } = useExploreState();
|
|
21
21
|
const { fileManifestState } = useFileManifestState();
|
|
@@ -30,7 +30,6 @@ export const ComponentCreator = ({ components, response, viewContext, }) => {
|
|
|
30
30
|
? c.viewBuilder(response, {
|
|
31
31
|
...viewContext,
|
|
32
32
|
authState: {
|
|
33
|
-
authenticationStatus,
|
|
34
33
|
isAuthenticated,
|
|
35
34
|
},
|
|
36
35
|
entityConfig,
|
|
@@ -1,13 +1,13 @@
|
|
|
1
1
|
import React from "react";
|
|
2
|
-
import { useAuthentication } from "../../../../../../../../../../hooks/useAuthentication/useAuthentication";
|
|
3
2
|
import { useConfig } from "../../../../../../../../../../hooks/useConfig";
|
|
3
|
+
import { useTerraProfile } from "../../../../../../../../../../providers/authentication/terra/hook";
|
|
4
4
|
import { ButtonPrimary } from "../../../../../../../../../common/Button/components/ButtonPrimary/buttonPrimary";
|
|
5
5
|
import { ANCHOR_TARGET, REL_ATTRIBUTE, } from "../../../../../../../../../Links/common/entities";
|
|
6
6
|
import { FormStep } from "../../formStep";
|
|
7
7
|
export const AcceptTerraTOS = ({ active, completed, step, }) => {
|
|
8
8
|
const { config } = useConfig();
|
|
9
9
|
const { exportToTerraUrl } = config;
|
|
10
|
-
const { terraProfileLoginStatus } =
|
|
10
|
+
const { terraProfileLoginStatus } = useTerraProfile();
|
|
11
11
|
const isTOSAccepted = isTermsOfServiceAccepted(terraProfileLoginStatus);
|
|
12
12
|
const onOpenTerra = () => {
|
|
13
13
|
if (exportToTerraUrl) {
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import React from "react";
|
|
2
|
-
import { expireTimeInSeconds, useAuthenticationNIHExpiry, } from "../../../../../../../../hooks/
|
|
2
|
+
import { expireTimeInSeconds, useAuthenticationNIHExpiry, } from "../../../../../../../../hooks/authentication/terra/useAuthenticationNIHExpiry";
|
|
3
3
|
import { Alert } from "../../../../../../../common/Alert/alert";
|
|
4
4
|
import { ALERT_PROPS } from "../../../../../../../common/Alert/constants";
|
|
5
5
|
import { FluidPaper } from "../../../../../../../common/Paper/paper.styles";
|
package/lib/components/Export/components/ExportToTerra/components/TerraSetUpForm/terraSetUpForm.js
CHANGED
|
@@ -1,6 +1,8 @@
|
|
|
1
1
|
import { Typography } from "@mui/material";
|
|
2
2
|
import React from "react";
|
|
3
|
-
import { ONBOARDING_STEP, useAuthenticationForm, } from "../../../../../../hooks/
|
|
3
|
+
import { ONBOARDING_STEP, useAuthenticationForm, } from "../../../../../../hooks/authentication/terra/useAuthenticationForm";
|
|
4
|
+
import { useAuth } from "../../../../../../providers/authentication/auth/hook";
|
|
5
|
+
import { AUTH_STATUS } from "../../../../../../providers/authentication/auth/types";
|
|
4
6
|
import { TEXT_BODY_400_2_LINES } from "../../../../../../theme/common/typography";
|
|
5
7
|
import { FluidPaper, GridPaper, } from "../../../../../common/Paper/paper.styles";
|
|
6
8
|
import { SectionTitle } from "../../../../../common/Section/components/SectionTitle/sectionTitle";
|
|
@@ -9,8 +11,11 @@ import { ConnectTerraToNIHAccount } from "./components/FormStep/components/Conne
|
|
|
9
11
|
import { CreateTerraAccount } from "./components/FormStep/components/CreateTerraAccount/createTerraAccount";
|
|
10
12
|
import { Section, SectionContent } from "./terraSetUpForm.styles";
|
|
11
13
|
export const TerraSetUpForm = () => {
|
|
12
|
-
const {
|
|
13
|
-
|
|
14
|
+
const { authState: { isAuthenticated, status }, } = useAuth();
|
|
15
|
+
const { isComplete, onboardingStatusByStep } = useAuthenticationForm();
|
|
16
|
+
if (!isAuthenticated)
|
|
17
|
+
return null;
|
|
18
|
+
if (status === AUTH_STATUS.PENDING)
|
|
14
19
|
return null;
|
|
15
20
|
return isComplete ? null : (React.createElement(FluidPaper, null,
|
|
16
21
|
React.createElement(GridPaper, null,
|
|
@@ -9,9 +9,10 @@ export declare const Authentication: ({ authenticationEnabled, Button, closeMenu
|
|
|
9
9
|
/**
|
|
10
10
|
* Renders authentication button.
|
|
11
11
|
* @param props - Button props.
|
|
12
|
+
* @param pathname - Pathname.
|
|
12
13
|
* @returns button.
|
|
13
14
|
*/
|
|
14
|
-
export declare function renderButton(props: MButtonProps): JSX.Element;
|
|
15
|
+
export declare function renderButton(props: MButtonProps, pathname: string): JSX.Element;
|
|
15
16
|
/**
|
|
16
17
|
* Renders authentication icon button.
|
|
17
18
|
* @param props - Button props.
|
|
@@ -1,30 +1,33 @@
|
|
|
1
1
|
import LoginRoundedIcon from "@mui/icons-material/LoginRounded";
|
|
2
|
-
import { IconButton as MIconButton, } from "@mui/material";
|
|
3
|
-
import
|
|
4
|
-
import React
|
|
5
|
-
import {
|
|
2
|
+
import { IconButton as MIconButton, Skeleton, } from "@mui/material";
|
|
3
|
+
import Router from "next/router";
|
|
4
|
+
import React from "react";
|
|
5
|
+
import { useProfile } from "../../../../../../../../../../hooks/authentication/profile/useProfile";
|
|
6
|
+
import { ROUTE } from "../../../../../../../../../../routes/constants";
|
|
7
|
+
import { isNavigationLinkSelected } from "../../../Navigation/common/utils";
|
|
6
8
|
import { AuthenticationMenu } from "./components/AuthenticationMenu/authenticationMenu";
|
|
7
9
|
import { StyledButton } from "./components/Button/button.styles";
|
|
8
10
|
export const Authentication = ({ authenticationEnabled, Button, closeMenu, }) => {
|
|
9
|
-
const {
|
|
10
|
-
const router = useRouter();
|
|
11
|
-
const onLogout = useCallback(() => {
|
|
12
|
-
location.href = router.basePath;
|
|
13
|
-
}, [router]);
|
|
11
|
+
const { isLoading, profile } = useProfile();
|
|
14
12
|
if (!authenticationEnabled)
|
|
15
13
|
return null;
|
|
16
|
-
|
|
17
|
-
|
|
14
|
+
if (isLoading)
|
|
15
|
+
return React.createElement(Skeleton, { height: 32, variant: "circular", width: 32 });
|
|
16
|
+
if (profile)
|
|
17
|
+
return React.createElement(AuthenticationMenu, { profile: profile });
|
|
18
|
+
return (React.createElement(Button, { onClick: async () => {
|
|
19
|
+
await Router.push(ROUTE.LOGIN);
|
|
18
20
|
closeMenu();
|
|
19
|
-
} }))
|
|
21
|
+
} }));
|
|
20
22
|
};
|
|
21
23
|
/**
|
|
22
24
|
* Renders authentication button.
|
|
23
25
|
* @param props - Button props.
|
|
26
|
+
* @param pathname - Pathname.
|
|
24
27
|
* @returns button.
|
|
25
28
|
*/
|
|
26
|
-
export function renderButton(props) {
|
|
27
|
-
return (React.createElement(StyledButton, { startIcon: React.createElement(LoginRoundedIcon, null), variant: "nav", ...props }, "Sign in"));
|
|
29
|
+
export function renderButton(props, pathname) {
|
|
30
|
+
return (React.createElement(StyledButton, { startIcon: React.createElement(LoginRoundedIcon, null), variant: isNavigationLinkSelected(pathname, [ROUTE.LOGIN]) ? "activeNav" : "nav", ...props }, "Sign in"));
|
|
28
31
|
}
|
|
29
32
|
/**
|
|
30
33
|
* Renders authentication icon button.
|
|
@@ -1,6 +1,5 @@
|
|
|
1
|
-
import { UserProfile } from "../../../../../../../../../../../../
|
|
1
|
+
import { UserProfile } from "../../../../../../../../../../../../providers/authentication/authentication/types";
|
|
2
2
|
export interface AuthenticationMenuProps {
|
|
3
|
-
|
|
4
|
-
userProfile: UserProfile;
|
|
3
|
+
profile: UserProfile;
|
|
5
4
|
}
|
|
6
|
-
export declare const AuthenticationMenu: ({
|
|
5
|
+
export declare const AuthenticationMenu: ({ profile, }: AuthenticationMenuProps) => JSX.Element;
|
|
@@ -1,30 +1,21 @@
|
|
|
1
1
|
import { MenuItem } from "@mui/material";
|
|
2
|
-
import React, {
|
|
3
|
-
import {
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
};
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
React.createElement(UserIcon, { onClick: onOpenMenu },
|
|
15
|
-
React.createElement(Avatar, { alt: `${userProfile.given_name} ${userProfile.family_name}`, src: userProfile.picture })),
|
|
16
|
-
React.createElement(Menu, { anchorEl: anchorEl, anchorOrigin: { horizontal: "right", vertical: "bottom" }, autoFocus: false, onClose: onCloseMenu, open: open, slotProps: { paper: { variant: "menu" } }, transformOrigin: {
|
|
17
|
-
horizontal: "right",
|
|
18
|
-
vertical: "top",
|
|
19
|
-
} },
|
|
2
|
+
import React, { Fragment } from "react";
|
|
3
|
+
import { useAuth } from "../../../../../../../../../../../../providers/authentication/auth/hook";
|
|
4
|
+
import { useMenu } from "../../../../../../../../../../../common/Menu/hooks/useMenu";
|
|
5
|
+
import { AuthenticationMenu as Menu, StyledAvatar, UserIcon, UserNames, UserSummary, } from "./authenticationMenu.styles";
|
|
6
|
+
import { MENU_PROPS } from "./constants";
|
|
7
|
+
export const AuthenticationMenu = ({ profile, }) => {
|
|
8
|
+
const { service: { requestLogout } = {} } = useAuth();
|
|
9
|
+
const { anchorEl, onClose, onOpen, open } = useMenu();
|
|
10
|
+
return (React.createElement(Fragment, null,
|
|
11
|
+
React.createElement(UserIcon, { onClick: onOpen },
|
|
12
|
+
React.createElement(StyledAvatar, { alt: profile.name, src: profile.image })),
|
|
13
|
+
React.createElement(Menu, { ...MENU_PROPS, anchorEl: anchorEl, onClose: onClose, open: open },
|
|
20
14
|
React.createElement(UserSummary, null,
|
|
21
15
|
"You are signed in as:",
|
|
22
|
-
React.createElement(UserNames, { noWrap: true },
|
|
23
|
-
userProfile.given_name,
|
|
24
|
-
" ",
|
|
25
|
-
userProfile.family_name)),
|
|
16
|
+
React.createElement(UserNames, { noWrap: true }, profile.name)),
|
|
26
17
|
React.createElement(MenuItem, { onClick: () => {
|
|
27
|
-
|
|
28
|
-
|
|
18
|
+
requestLogout?.();
|
|
19
|
+
onClose();
|
|
29
20
|
} }, "Logout"))));
|
|
30
21
|
};
|
|
@@ -16,7 +16,7 @@ export declare const UserNames: import("@emotion/styled").StyledComponent<import
|
|
|
16
16
|
}, "fontSize" | "fontWeight" | "lineHeight" | "letterSpacing" | "textTransform" | "p" | "style" | "className" | "classes" | "color" | "children" | "border" | "borderTop" | "borderRight" | "borderBottom" | "borderLeft" | "borderColor" | "borderRadius" | "display" | "displayPrint" | "overflow" | "textOverflow" | "visibility" | "whiteSpace" | "flexBasis" | "flexDirection" | "flexWrap" | "justifyContent" | "alignItems" | "alignContent" | "order" | "flex" | "flexGrow" | "flexShrink" | "alignSelf" | "justifyItems" | "justifySelf" | "gap" | "columnGap" | "rowGap" | "gridColumn" | "gridRow" | "gridAutoFlow" | "gridAutoColumns" | "gridAutoRows" | "gridTemplateColumns" | "gridTemplateRows" | "gridTemplateAreas" | "gridArea" | "bgcolor" | "zIndex" | "position" | "top" | "right" | "bottom" | "left" | "boxShadow" | "width" | "maxWidth" | "minWidth" | "height" | "maxHeight" | "minHeight" | "boxSizing" | "m" | "mt" | "mr" | "mb" | "ml" | "mx" | "my" | "pt" | "pr" | "pb" | "pl" | "px" | "py" | "margin" | "marginTop" | "marginRight" | "marginBottom" | "marginLeft" | "marginX" | "marginY" | "marginInline" | "marginInlineStart" | "marginInlineEnd" | "marginBlock" | "marginBlockStart" | "marginBlockEnd" | "padding" | "paddingTop" | "paddingRight" | "paddingBottom" | "paddingLeft" | "paddingX" | "paddingY" | "paddingInline" | "paddingInlineStart" | "paddingInlineEnd" | "paddingBlock" | "paddingBlockStart" | "paddingBlockEnd" | "typography" | "fontFamily" | "fontStyle" | "textAlign" | "align" | "gutterBottom" | "noWrap" | "paragraph" | "sx" | "variant" | "variantMapping"> & {
|
|
17
17
|
theme?: import("@emotion/react").Theme;
|
|
18
18
|
}, {}, {}>;
|
|
19
|
-
export declare const
|
|
19
|
+
export declare const StyledAvatar: import("@emotion/styled").StyledComponent<import("@mui/material").AvatarOwnProps & import("@mui/material").AvatarSlotsAndSlotProps & import("@mui/material/OverridableComponent").CommonProps & Omit<Omit<import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLDivElement>, HTMLDivElement>, "ref"> & {
|
|
20
20
|
ref?: ((instance: HTMLDivElement | null) => void | import("react").DO_NOT_USE_OR_YOU_WILL_BE_FIRED_CALLBACK_REF_RETURN_VALUES[keyof import("react").DO_NOT_USE_OR_YOU_WILL_BE_FIRED_CALLBACK_REF_RETURN_VALUES]) | import("react").RefObject<HTMLDivElement> | null | undefined;
|
|
21
21
|
}, "style" | "className" | "classes" | "children" | "sx" | "variant" | "alt" | "src" | "sizes" | "srcSet" | "slotProps" | "slots" | "imgProps"> & {
|
|
22
22
|
theme?: import("@emotion/react").Theme;
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import styled from "@emotion/styled";
|
|
2
|
-
import { Avatar
|
|
2
|
+
import { Avatar, IconButton as MIconButton, Menu as MMenu, MenuItem, Typography, } from "@mui/material";
|
|
3
3
|
export const AuthenticationMenu = styled(MMenu) `
|
|
4
4
|
margin: 4px 0;
|
|
5
5
|
`;
|
|
@@ -22,7 +22,7 @@ export const UserNames = styled(Typography) `
|
|
|
22
22
|
font-weight: 500;
|
|
23
23
|
max-width: 200px;
|
|
24
24
|
`;
|
|
25
|
-
export const
|
|
25
|
+
export const StyledAvatar = styled(Avatar) `
|
|
26
26
|
height: 32px;
|
|
27
27
|
width: 32px;
|
|
28
28
|
`;
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { VARIANT } from "../../../../../../../../../../../../styles/common/mui/paper";
|
|
2
|
+
import { POPOVER_ORIGIN_HORIZONTAL, POPOVER_ORIGIN_VERTICAL, } from "../../../../../../../../../../../../styles/common/mui/popover";
|
|
3
|
+
export const MENU_PROPS = {
|
|
4
|
+
anchorOrigin: {
|
|
5
|
+
horizontal: POPOVER_ORIGIN_HORIZONTAL.RIGHT,
|
|
6
|
+
vertical: POPOVER_ORIGIN_VERTICAL.BOTTOM,
|
|
7
|
+
},
|
|
8
|
+
autoFocus: false,
|
|
9
|
+
slotProps: { paper: { variant: VARIANT.MENU } },
|
|
10
|
+
transformOrigin: {
|
|
11
|
+
horizontal: POPOVER_ORIGIN_HORIZONTAL.RIGHT,
|
|
12
|
+
vertical: POPOVER_ORIGIN_VERTICAL.TOP,
|
|
13
|
+
},
|
|
14
|
+
};
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import styled from "@emotion/styled";
|
|
2
|
-
import { Button
|
|
3
|
-
export const StyledButton = styled(
|
|
2
|
+
import { Button } from "@mui/material";
|
|
3
|
+
export const StyledButton = styled(Button) `
|
|
4
|
+
&.MuiButton-activeNav,
|
|
4
5
|
&.MuiButton-nav {
|
|
5
6
|
padding: 6px 12px;
|
|
6
7
|
}
|
|
@@ -49,7 +49,7 @@ export const Header = ({ ...headerProps }) => {
|
|
|
49
49
|
: renderSearchButton(props), closeMenu: onClose, searchEnabled: searchEnabled, searchURL: searchURL }),
|
|
50
50
|
React.createElement(Authentication, { Button: ({ ...props }) => isIn.isMenuIn
|
|
51
51
|
? renderAuthenticationIconButton(props)
|
|
52
|
-
: renderAuthenticationButton(props), authenticationEnabled: authenticationEnabled, closeMenu: onClose }),
|
|
52
|
+
: renderAuthenticationButton(props, pathname), authenticationEnabled: authenticationEnabled, closeMenu: onClose }),
|
|
53
53
|
actions,
|
|
54
54
|
React.createElement(Menu, { ...navigationProps, closeMenu: onClose, isMenuIn: isIn.isMenuIn, open: open, openMenu: onOpen }))))))));
|
|
55
55
|
};
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import { StyledButton } from "./button.styles";
|
|
3
|
+
import { BUTTON_PROPS } from "./constants";
|
|
4
|
+
export const Button = ({ className, ...props }) => {
|
|
5
|
+
return React.createElement(StyledButton, { className: className, ...BUTTON_PROPS, ...props });
|
|
6
|
+
};
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
export declare const StyledButton: import("@emotion/styled").StyledComponent<import("@mui/material").ButtonOwnProps & Omit<import("@mui/material").ButtonBaseOwnProps, "classes"> & import("@mui/material/OverridableComponent").CommonProps & Omit<Omit<import("react").DetailedHTMLProps<import("react").ButtonHTMLAttributes<HTMLButtonElement>, HTMLButtonElement>, "ref"> & {
|
|
2
|
+
ref?: ((instance: HTMLButtonElement | null) => void | import("react").DO_NOT_USE_OR_YOU_WILL_BE_FIRED_CALLBACK_REF_RETURN_VALUES[keyof import("react").DO_NOT_USE_OR_YOU_WILL_BE_FIRED_CALLBACK_REF_RETURN_VALUES]) | import("react").RefObject<HTMLButtonElement> | null | undefined;
|
|
3
|
+
}, "style" | "className" | "classes" | "tabIndex" | "color" | "children" | "sx" | "variant" | "disabled" | "href" | "action" | "size" | "centerRipple" | "disableRipple" | "disableTouchRipple" | "focusRipple" | "focusVisibleClassName" | "LinkComponent" | "onFocusVisible" | "TouchRippleProps" | "touchRippleRef" | "fullWidth" | "disableElevation" | "disableFocusRipple" | "endIcon" | "startIcon"> & {
|
|
4
|
+
theme?: import("@emotion/react").Theme;
|
|
5
|
+
}, {}, {}>;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -1,9 +1,2 @@
|
|
|
1
|
-
import {
|
|
2
|
-
export
|
|
3
|
-
isGoogle?: boolean;
|
|
4
|
-
termsOfService?: ReactNode;
|
|
5
|
-
text?: ReactNode;
|
|
6
|
-
title: string;
|
|
7
|
-
warning?: ReactNode;
|
|
8
|
-
}
|
|
9
|
-
export declare const Login: ({ isGoogle, termsOfService, text, title, warning, }: LoginProps) => JSX.Element;
|
|
1
|
+
import { Props } from "./types";
|
|
2
|
+
export declare const Login: <P>({ providers, termsOfService, text, title, warning, }: Props<P>) => JSX.Element;
|
|
@@ -1,27 +1,26 @@
|
|
|
1
1
|
import { Checkbox, Typography } from "@mui/material";
|
|
2
|
-
import React, { useState } from "react";
|
|
3
|
-
import {
|
|
4
|
-
import { LoginButton } from "../common/Button/components/LoginButton/loginButton";
|
|
2
|
+
import React, { useCallback, useState } from "react";
|
|
3
|
+
import { useAuth } from "../../providers/authentication/auth/hook";
|
|
5
4
|
import { CheckedIcon } from "../common/CustomIcon/components/CheckedIcon/checkedIcon";
|
|
6
|
-
import { GoogleIcon } from "../common/CustomIcon/components/GoogleIcon/googleIcon";
|
|
7
5
|
import { UncheckedErrorIcon } from "../common/CustomIcon/components/UncheckedErrorIcon/uncheckedErrorIcon";
|
|
8
6
|
import { UncheckedIcon } from "../common/CustomIcon/components/UncheckedIcon/uncheckedIcon";
|
|
9
7
|
import { RoundedPaper } from "../common/Paper/paper.styles";
|
|
10
8
|
import { SectionContent } from "../common/Section/section.styles";
|
|
9
|
+
import { Button } from "./components/Button/button";
|
|
11
10
|
import { LoginAgreement, LoginSection, LoginSectionActions, LoginText, LoginWarning, LoginWrapper, TermsOfService, } from "./login.styles";
|
|
12
|
-
export const Login = ({
|
|
13
|
-
const {
|
|
11
|
+
export const Login = ({ providers = [], termsOfService, text, title, warning, }) => {
|
|
12
|
+
const { service: { requestLogin } = {} } = useAuth();
|
|
14
13
|
const [isError, setIsError] = useState(false);
|
|
15
14
|
const [isInAgreement, setIsInAgreement] = useState(!termsOfService);
|
|
16
15
|
// Authenticates the user, if the user has agreed to the terms of service.
|
|
17
16
|
// If the terms of service are not accepted, set the terms of service error state to true.
|
|
18
|
-
const
|
|
17
|
+
const onLogin = useCallback((providerId) => {
|
|
19
18
|
if (!isInAgreement) {
|
|
20
19
|
setIsError(true);
|
|
21
20
|
return;
|
|
22
21
|
}
|
|
23
|
-
|
|
24
|
-
};
|
|
22
|
+
requestLogin?.(providerId);
|
|
23
|
+
}, [isInAgreement, requestLogin]);
|
|
25
24
|
// Callback fired when the checkbox value is changed.
|
|
26
25
|
// Clears the terms of service error state and sets state isInAgreement with checkbox selected value.
|
|
27
26
|
const handleChange = (changeEvent) => {
|
|
@@ -38,6 +37,6 @@ export const Login = ({ isGoogle = false, termsOfService, text, title, warning,
|
|
|
38
37
|
termsOfService && (React.createElement(LoginAgreement, null,
|
|
39
38
|
React.createElement(Checkbox, { checkedIcon: React.createElement(CheckedIcon, null), icon: isError ? React.createElement(UncheckedErrorIcon, null) : React.createElement(UncheckedIcon, null), onChange: handleChange }),
|
|
40
39
|
React.createElement(TermsOfService, null, termsOfService))),
|
|
41
|
-
|
|
40
|
+
providers?.map((provider) => (React.createElement(Button, { key: provider.id, endIcon: "icon" in provider && provider.icon, onClick: () => onLogin(provider.id) }, provider.name)))))),
|
|
42
41
|
warning && React.createElement(LoginWarning, null, warning)));
|
|
43
42
|
};
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { ClientSafeProvider } from "next-auth/react";
|
|
2
|
+
import { ReactNode } from "react";
|
|
3
|
+
import { OAuthProvider } from "../../config/entities";
|
|
4
|
+
export interface Props<P> {
|
|
5
|
+
providers?: ClientSafeProvider[] | OAuthProvider<P>[];
|
|
6
|
+
termsOfService?: ReactNode;
|
|
7
|
+
text?: ReactNode;
|
|
8
|
+
title: string;
|
|
9
|
+
warning?: ReactNode;
|
|
10
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { Fade } from "@mui/material";
|
|
2
2
|
import React from "react";
|
|
3
|
-
import { useSessionTimeout } from "../../../../../hooks/useSessionTimeout";
|
|
3
|
+
import { useSessionTimeout } from "../../../../../hooks/authentication/session/useSessionTimeout";
|
|
4
4
|
import { Banner } from "../../banner";
|
|
5
5
|
export const SessionTimeout = ({ children, className, content, ...props }) => {
|
|
6
6
|
const { clearSessionTimeout, isSessionTimeout } = useSessionTimeout();
|