From 896b41a39215567ea5897bbd7a5e3fd5be562747 Mon Sep 17 00:00:00 2001 From: Maina Wycliffe Date: Fri, 17 Nov 2023 19:22:35 +0300 Subject: [PATCH] fix: separate the oidc login controls from email password fix: fix sign in with microsoft not working --- src/components/ory/ui/Flow.tsx | 118 +++++++++++++++------- src/components/ory/ui/NodeInputButton.tsx | 1 + src/components/ory/ui/NodeInputSubmit.tsx | 14 ++- 3 files changed, 94 insertions(+), 39 deletions(-) diff --git a/src/components/ory/ui/Flow.tsx b/src/components/ory/ui/Flow.tsx index 3c34712efa..dd1f524d40 100644 --- a/src/components/ory/ui/Flow.tsx +++ b/src/components/ory/ui/Flow.tsx @@ -11,7 +11,11 @@ import { UpdateVerificationFlowBody as SubmitSelfServiceVerificationFlowBody, UiNode } from "@ory/client"; -import { getNodeId, isUiNodeInputAttributes } from "@ory/integrations/ui"; +import { + filterNodesByGroups, + getNodeId, + isUiNodeInputAttributes +} from "@ory/integrations/ui"; import { Component, FormEvent } from "react"; import FormSkeletonLoader from "../../SkeletonLoader/FormSkeletonLoader"; @@ -158,40 +162,84 @@ export class Flow extends Component, State> { } return ( -
- {!hideGlobalMessages ? : null} - {nodes.map((node, k) => { - const id = getNodeId(node) as keyof Values; - return ( - - new Promise((resolve) => { - this.setState( - (state) => ({ - ...state, - values: { - ...state.values, - [getNodeId(node)]: value - } - }), - resolve - ); - }) - } - /> - ); - })} - +
+
+ {!hideGlobalMessages ? ( + + ) : null} + {filterNodesByGroups({ + nodes: nodes, + groups: ["default", "password"] + }).map((node, k) => { + const id = getNodeId(node) as keyof Values; + return ( + + new Promise((resolve) => { + this.setState( + (state) => ({ + ...state, + values: { + ...state.values, + [getNodeId(node)]: value + } + }), + resolve + ); + }) + } + /> + ); + })} + + +
+ +
+
+ {filterNodesByGroups({ + nodes: nodes, + groups: ["oidc"], + withoutDefaultGroup: true + }).map((node, k) => { + const id = getNodeId(node) as keyof Values; + return ( + + new Promise((resolve) => { + this.setState( + (state) => ({ + ...state, + values: { + ...state.values, + [getNodeId(node)]: value + } + }), + resolve + ); + }) + } + /> + ); + })} +
+
+
); } } diff --git a/src/components/ory/ui/NodeInputButton.tsx b/src/components/ory/ui/NodeInputButton.tsx index a91d00ee19..e298363193 100644 --- a/src/components/ory/ui/NodeInputButton.tsx +++ b/src/components/ory/ui/NodeInputButton.tsx @@ -36,6 +36,7 @@ export function NodeInputButton({ }} value={attributes.value || ""} disabled={attributes.disabled || disabled} + type="button" > {getNodeLabel(node)} diff --git a/src/components/ory/ui/NodeInputSubmit.tsx b/src/components/ory/ui/NodeInputSubmit.tsx index 4061f8f630..dd3e60b580 100644 --- a/src/components/ory/ui/NodeInputSubmit.tsx +++ b/src/components/ory/ui/NodeInputSubmit.tsx @@ -13,12 +13,18 @@ export function NodeInputSubmit({