Merge branch '18874-merge-wb2'
[arvados.git] / services / workbench2 / src / store / link-account-panel / link-account-panel-reducer.ts
diff --git a/services/workbench2/src/store/link-account-panel/link-account-panel-reducer.ts b/services/workbench2/src/store/link-account-panel/link-account-panel-reducer.ts
new file mode 100644 (file)
index 0000000..15d0781
--- /dev/null
@@ -0,0 +1,86 @@
+// Copyright (C) The Arvados Authors. All rights reserved.
+//
+// SPDX-License-Identifier: AGPL-3.0
+
+import { linkAccountPanelActions, LinkAccountPanelAction } from "store/link-account-panel/link-account-panel-actions";
+import { UserResource } from "models/user";
+
+export enum LinkAccountPanelStatus {
+    NONE,
+    INITIAL,
+    HAS_SESSION_DATA,
+    LINKING,
+    ERROR
+}
+
+export enum LinkAccountPanelError {
+    NONE,
+    INACTIVE,
+    NON_ADMIN,
+    SAME_USER
+}
+
+export enum OriginatingUser {
+    NONE,
+    TARGET_USER,
+    USER_TO_LINK
+}
+
+export interface LinkAccountPanelState {
+    selectedCluster: string | undefined;
+    originatingUser: OriginatingUser | undefined;
+    targetUser: UserResource | undefined;
+    targetUserToken: string | undefined;
+    userToLink: UserResource | undefined;
+    userToLinkToken: string | undefined;
+    status: LinkAccountPanelStatus;
+    error: LinkAccountPanelError;
+    isProcessing: boolean;
+}
+
+const initialState = {
+    selectedCluster: undefined,
+    originatingUser: OriginatingUser.NONE,
+    targetUser: undefined,
+    targetUserToken: undefined,
+    userToLink: undefined,
+    userToLinkToken: undefined,
+    isProcessing: false,
+    status: LinkAccountPanelStatus.NONE,
+    error: LinkAccountPanelError.NONE
+};
+
+export const linkAccountPanelReducer = (state: LinkAccountPanelState = initialState, action: LinkAccountPanelAction) =>
+    linkAccountPanelActions.match(action, {
+        default: () => state,
+        LINK_INIT: ({ targetUser }) => ({
+            ...state,
+            targetUser, targetUserToken: undefined,
+            userToLink: undefined, userToLinkToken: undefined,
+            status: LinkAccountPanelStatus.INITIAL, error: LinkAccountPanelError.NONE, originatingUser: OriginatingUser.NONE
+        }),
+        LINK_LOAD: ({ originatingUser, userToLink, targetUser, targetUserToken, userToLinkToken}) => ({
+            ...state,
+            originatingUser,
+            targetUser, targetUserToken,
+            userToLink, userToLinkToken,
+            status: LinkAccountPanelStatus.LINKING, error: LinkAccountPanelError.NONE
+        }),
+        LINK_INVALID: ({ originatingUser, targetUser, userToLink, error }) => ({
+            ...state,
+            originatingUser,
+            targetUser, targetUserToken: undefined,
+            userToLink, userToLinkToken: undefined,
+            error, status: LinkAccountPanelStatus.ERROR
+        }),
+        SET_SELECTED_CLUSTER: ({ selectedCluster }) => ({
+            ...state, selectedCluster
+        }),
+        SET_IS_PROCESSING: ({ isProcessing }) =>({
+            ...state,
+            isProcessing
+        }),
+        HAS_SESSION_DATA: () => ({
+            ...state, status: LinkAccountPanelStatus.HAS_SESSION_DATA
+        })
+    });
\ No newline at end of file