[ARVADOS-WORKBENCH2] updated: 2.1.0-138-gf657dca6
Git user
git at public.arvados.org
Wed Jan 13 12:58:07 UTC 2021
Summary of changes:
src/views-components/api-token/api-token.tsx | 43 ++++++++++++++++------------
1 file changed, 24 insertions(+), 19 deletions(-)
via f657dca6334ce910559100ba99666a95cfbc7236 (commit)
from f3834ab9fef93773ad3f2063b38468b2fed51325 (commit)
Those revisions listed above that are new to this repository have
not appeared on any other notification email; so we list those
revisions in full, below.
commit f657dca6334ce910559100ba99666a95cfbc7236
Author: Daniel Kutyła <daniel.kutyla at contractors.roche.com>
Date: Wed Jan 13 13:57:18 2021 +0100
17231: Moved redirect code to other lifecycle method
Arvados-DCO-1.1-Signed-off-by: Daniel Kutyła <daniel.kutyla at contractors.roche.com>
diff --git a/src/views-components/api-token/api-token.tsx b/src/views-components/api-token/api-token.tsx
index 548dfe77..97d3fc40 100644
--- a/src/views-components/api-token/api-token.tsx
+++ b/src/views-components/api-token/api-token.tsx
@@ -4,6 +4,7 @@
import { RouteProps } from "react-router";
import * as React from "react";
+import { RootState } from "~/store/store";
import { connect, DispatchProp } from "react-redux";
import { saveApiToken } from "~/store/auth/auth-action";
import { getUrlParameter } from "~/common/url";
@@ -12,38 +13,42 @@ import { navigateToRootProject, navigateToLinkAccount } from "~/store/navigation
import { Config } from "~/common/config";
import { getAccountLinkData } from "~/store/link-account-panel/link-account-panel-actions";
import { replace } from "react-router-redux";
+import { User } from "~/models/user";
interface ApiTokenProps {
authService: AuthService;
config: Config;
loadMainApp: boolean;
+ user?: User;
}
-export const ApiToken = connect()(
+export const ApiToken = connect((state: RootState) => ({
+ user: state.auth.user,
+}), null)(
class extends React.Component<ApiTokenProps & RouteProps & DispatchProp<any>, {}> {
componentDidMount() {
const search = this.props.location ? this.props.location.search : "";
const apiToken = getUrlParameter(search, 'api_token');
- const loadMainApp = this.props.loadMainApp;
- this.props.dispatch<any>(saveApiToken(apiToken)).finally(() => {
- const redirectURL = this.props.authService.getTargetURL();
+ this.props.dispatch<any>(saveApiToken(apiToken));
+ }
+
+ componentDidUpdate() {
+ const redirectURL = this.props.authService.getTargetURL();
- setTimeout(() => {
- if (loadMainApp) {
- 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);
- }
- }
- }, 0);
- });
+ if (this.props.loadMainApp && this.props.user) {
+ 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);
+ }
+ }
}
+
render() {
return <div />;
}
-----------------------------------------------------------------------
hooks/post-receive
--
More information about the arvados-commits
mailing list