From 5f8184f38c23d774b817f926e36be568cca3ae39 Mon Sep 17 00:00:00 2001 From: "Laurie T. Malau" Date: Wed, 1 Dec 2021 17:39:07 +0000 Subject: [PATCH] Adjust login page for prefix visit --- components/dashboard/src/App.test.ts | 18 ++++++++ components/dashboard/src/App.tsx | 2 +- components/dashboard/src/Login.tsx | 65 ++++++++++++++++++++++------ 3 files changed, 70 insertions(+), 15 deletions(-) create mode 100644 components/dashboard/src/App.test.ts diff --git a/components/dashboard/src/App.test.ts b/components/dashboard/src/App.test.ts new file mode 100644 index 00000000000000..6e0cc914ef389c --- /dev/null +++ b/components/dashboard/src/App.test.ts @@ -0,0 +1,18 @@ +/** + * Copyright (c) 2021 Gitpod GmbH. All rights reserved. + * Licensed under the GNU Affero General Public License (AGPL). + * See License-AGPL.txt in the project root for license information. + */ + +import { getURLHash } from './App' + +test('urlHash', () => { + global.window = Object.create(window); + Object.defineProperty(window, 'location', { + value: { + hash: '#https://example.org/user/repo' + } + }); + + expect(getURLHash()).toBe('https://example.org/user/repo'); +}); \ No newline at end of file diff --git a/components/dashboard/src/App.tsx b/components/dashboard/src/App.tsx index 4dad6faecd89f3..461f1894a478d7 100644 --- a/components/dashboard/src/App.tsx +++ b/components/dashboard/src/App.tsx @@ -86,7 +86,7 @@ function isWebsiteSlug(pathName: string) { return slugs.some(slug => pathName.startsWith('/' + slug + '/') || pathName === ('/' + slug)); } -function getURLHash() { +export function getURLHash() { return window.location.hash.replace(/^[#/]+/, ''); } diff --git a/components/dashboard/src/Login.tsx b/components/dashboard/src/Login.tsx index f13eb85ab158f3..7f8a45501c1a7e 100644 --- a/components/dashboard/src/Login.tsx +++ b/components/dashboard/src/Login.tsx @@ -21,6 +21,7 @@ import customize from "./images/welcome/customize.svg"; import fresh from "./images/welcome/fresh.svg"; import prebuild from "./images/welcome/prebuild.svg"; import exclamation from "./images/exclamation.svg"; +import { getURLHash } from "./App"; function Item(props: { icon: string, iconSize?: string, text: string }) { @@ -46,10 +47,23 @@ export function hasVisitedMarketingWebsiteBefore() { export function Login() { const { setUser } = useContext(UserContext); const { setTeams } = useContext(TeamsContext); - const showWelcome = !hasLoggedInBefore() && !hasVisitedMarketingWebsiteBefore(); + const urlHash = getURLHash(); + let hostFromContext: string | undefined; + let repoPathname: string | undefined; + try { + if (urlHash.length > 0) { + const url = new URL(urlHash); + hostFromContext = url.host; + repoPathname = url.pathname; + } + } catch (error) { + // Hash is not a valid URL + } - const [ authProviders, setAuthProviders ] = useState([]); - const [ errorMessage, setErrorMessage ] = useState(undefined); + const [authProviders, setAuthProviders] = useState([]); + const [errorMessage, setErrorMessage] = useState(undefined); + const [providerFromContext, setProviderFromContext] = useState(); + const showWelcome = !hasLoggedInBefore() && !hasVisitedMarketingWebsiteBefore() && !urlHash.startsWith("https://"); useEffect(() => { (async () => { @@ -57,6 +71,13 @@ export function Login() { })(); }, []) + useEffect(() => { + if (hostFromContext && authProviders) { + const providerFromContext = authProviders.find(provider => provider.host === hostFromContext); + setProviderFromContext(providerFromContext); + } + }, [authProviders]) + const authorizeSuccessful = async (payload?: string) => { updateUser().catch(console.error); @@ -70,7 +91,7 @@ export function Login() { const updateUser = async () => { await getGitpodService().reconnect(); - const [ user, teams ] = await Promise.all([ + const [user, teams] = await Promise.all([ getGitpodService().server.getLoggedInUser(), getGitpodService().server.getTeams(), ]); @@ -137,21 +158,37 @@ export function Login() {
- Gitpod's logo + Gitpod's logo + Gitpod dark theme logo
+
-

Log in{showWelcome ? '' : ' to Gitpod'}

-

ALWAYS READY-TO-CODE

+ {providerFromContext + ? <> +

Open a cloud-based development environment

+

for the repository {repoPathname?.slice(1)}

+ + : <> +

Log in{showWelcome ? '' : ' to Gitpod'}

+

ALWAYS READY-TO-CODE

+ }
+ +
- {authProviders.map(ap => { - return ( - - ); - })} + : + authProviders.map(ap => + ) + }
{errorMessage && (