From eaec46a67b8d15900e0c2fbf19829de75df59795 Mon Sep 17 00:00:00 2001 From: Andrey Antukh Date: Fri, 13 Dec 2024 10:22:40 +0100 Subject: [PATCH] :bug: Fix incorrect team invitation redirect after login --- frontend/src/app/main/data/auth.cljs | 36 +++++++++++++----------- frontend/src/app/main/ui/auth/login.cljs | 11 ++------ 2 files changed, 21 insertions(+), 26 deletions(-) diff --git a/frontend/src/app/main/data/auth.cljs b/frontend/src/app/main/data/auth.cljs index c1ba640b5..740946b24 100644 --- a/frontend/src/app/main/data/auth.cljs +++ b/frontend/src/app/main/data/auth.cljs @@ -39,24 +39,26 @@ accepting invitation, or third party auth signup or singin." [{:keys [props] :as profile}] (letfn [(get-redirect-events [teams] - (if-let [redirect-href (:login-redirect storage/session)] - (binding [storage/*sync* true] - (swap! storage/session dissoc :login-redirect) - (if (= redirect-href (rt/get-current-href)) - (rx/of (rt/reload true)) - (rx/of (rt/nav-raw :href redirect-href)))) - (if-let [file-id (get props :welcome-file-id)] - (rx/of (dcm/go-to-workspace - :file-id file-id - :team-id (:default-team-id profile)) - (dp/update-profile-props {:welcome-file-id nil})) + (if-let [token (:invitation-token profile)] + (rx/of (rt/nav :auth-verify-token {:token token})) + (if-let [redirect-href (:login-redirect storage/session)] + (binding [storage/*sync* true] + (swap! storage/session dissoc :login-redirect) + (if (= redirect-href (rt/get-current-href)) + (rx/of (rt/reload true)) + (rx/of (rt/nav-raw :href redirect-href)))) + (if-let [file-id (get props :welcome-file-id)] + (rx/of (dcm/go-to-workspace + :file-id file-id + :team-id (:default-team-id profile)) + (dp/update-profile-props {:welcome-file-id nil})) - (let [teams (into #{} (map :id) teams) - team-id (dtm/get-last-team-id) - team-id (if (and team-id (contains? teams team-id)) - team-id - (:default-team-id profile))] - (rx/of (dcm/go-to-dashboard-recent {:team-id team-id}))))))] + (let [teams (into #{} (map :id) teams) + team-id (dtm/get-last-team-id) + team-id (if (and team-id (contains? teams team-id)) + team-id + (:default-team-id profile))] + (rx/of (dcm/go-to-dashboard-recent {:team-id team-id})))))))] (ptk/reify ::logged-in ev/Event diff --git a/frontend/src/app/main/ui/auth/login.cljs b/frontend/src/app/main/ui/auth/login.cljs index e30b25957..10bf80d3b 100644 --- a/frontend/src/app/main/ui/auth/login.cljs +++ b/frontend/src/app/main/ui/auth/login.cljs @@ -120,17 +120,10 @@ :else (reset! error (tr "errors.generic"))))) - on-success-default - (mf/use-fn - (fn [data] - (when-let [token (:invitation-token data)] - (st/emit! (rt/nav :auth-verify-token {:token token}))))) - on-success (fn [data] - (if (nil? on-success-callback) - (on-success-default data) - (on-success-callback))) + (when (fn? on-success-callback) + (on-success-callback data))) on-submit (mf/use-callback