X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/fd470d8f7838b57777492289e6e4195b6c39bd2e..c28f185b9bf6a46bf02efd4a06439d14f09d6b8b:/src/views-components/api-token/api-token.tsx diff --git a/src/views-components/api-token/api-token.tsx b/src/views-components/api-token/api-token.tsx index b78e7192..f4b50e36 100644 --- a/src/views-components/api-token/api-token.tsx +++ b/src/views-components/api-token/api-token.tsx @@ -5,13 +5,13 @@ import { RouteProps } from "react-router"; import * as React from "react"; import { connect, DispatchProp } from "react-redux"; -import { authActions, getUserDetails, saveApiToken } from "~/store/auth/auth-action"; +import { saveApiToken } from "~/store/auth/auth-action"; import { getUrlParameter } from "~/common/url"; import { AuthService } from "~/services/auth-service/auth-service"; -import { navigateToRootProject } from "~/store/navigation/navigation-action"; -import { User } from "~/models/user"; +import { navigateToRootProject, navigateToLinkAccount } from "~/store/navigation/navigation-action"; import { Config } from "~/common/config"; -import { initSessions } from "~/store/auth/auth-action-session"; +import { getAccountLinkData } from "~/store/link-account-panel/link-account-panel-actions"; +import { replace } from "react-router-redux"; interface ApiTokenProps { authService: AuthService; @@ -25,12 +25,20 @@ export const ApiToken = connect()( const search = this.props.location ? this.props.location.search : ""; const apiToken = getUrlParameter(search, 'api_token'); const loadMainApp = this.props.loadMainApp; - this.props.dispatch(saveApiToken(apiToken)); - this.props.dispatch(getUserDetails()).then((user: User) => { - this.props.dispatch(initSessions(this.props.authService, this.props.config, user)); - }).finally(() => { + this.props.dispatch(saveApiToken(apiToken)).finally(() => { + const redirectURL = this.props.authService.getTargetURL(); + if (loadMainApp) { - this.props.dispatch(navigateToRootProject); + if (redirectURL) { + this.props.authService.removeTargetURL(); + this.props.dispatch(replace(redirectURL)); + } + else if (this.props.dispatch(getAccountLinkData())) { + this.props.dispatch(navigateToLinkAccount); + } + else { + this.props.dispatch(navigateToRootProject); + } } }); }