diff --git a/package-lock.json b/package-lock.json index c32293f9..3ec07985 100644 --- a/package-lock.json +++ b/package-lock.json @@ -11,6 +11,7 @@ "@emotion/react": "^11.13.0", "@emotion/styled": "^11.13.0", "@fortawesome/fontawesome-svg-core": "^6.6.0", + "@fortawesome/free-brands-svg-icons": "^6.6.0", "@fortawesome/free-solid-svg-icons": "^6.6.0", "@fortawesome/react-fontawesome": "^0.2.2", "@mui/icons-material": "^5.16.5", @@ -963,6 +964,17 @@ "node": ">=6" } }, + "node_modules/@fortawesome/free-brands-svg-icons": { + "version": "6.6.0", + "resolved": "https://registry.npmjs.org/@fortawesome/free-brands-svg-icons/-/free-brands-svg-icons-6.6.0.tgz", + "integrity": "sha512-1MPD8lMNW/earme4OQi1IFHtmHUwAKgghXlNwWi9GO7QkTfD+IIaYpIai4m2YJEzqfEji3jFHX1DZI5pbY/biQ==", + "dependencies": { + "@fortawesome/fontawesome-common-types": "6.6.0" + }, + "engines": { + "node": ">=6" + } + }, "node_modules/@fortawesome/free-solid-svg-icons": { "version": "6.6.0", "resolved": "https://registry.npmjs.org/@fortawesome/free-solid-svg-icons/-/free-solid-svg-icons-6.6.0.tgz", diff --git a/package.json b/package.json index bea2a467..24eea081 100644 --- a/package.json +++ b/package.json @@ -18,6 +18,7 @@ "@emotion/react": "^11.13.0", "@emotion/styled": "^11.13.0", "@fortawesome/fontawesome-svg-core": "^6.6.0", + "@fortawesome/free-brands-svg-icons": "^6.6.0", "@fortawesome/free-solid-svg-icons": "^6.6.0", "@fortawesome/react-fontawesome": "^0.2.2", "@mui/icons-material": "^5.16.5", diff --git a/src/app/api/auth/[...nextauth]/route.ts b/src/app/api/auth/[...nextauth]/route.ts index 1d38a1d9..85cc4d25 100644 --- a/src/app/api/auth/[...nextauth]/route.ts +++ b/src/app/api/auth/[...nextauth]/route.ts @@ -1,3 +1,3 @@ -import { auth } from "@/composition" +import { authHandlers } from "@/composition" -export const { GET, POST } = auth.handlers +export const { GET, POST } = authHandlers diff --git a/src/app/auth/signin/page.tsx b/src/app/auth/signin/page.tsx new file mode 100644 index 00000000..97e53ae0 --- /dev/null +++ b/src/app/auth/signin/page.tsx @@ -0,0 +1,127 @@ +import Image from "next/image" +import Link from "next/link" +import { Box, Button, Stack, Typography } from "@mui/material" +import { signIn } from "@/composition" +import { env } from "@/common" +import { FontAwesomeIcon } from "@fortawesome/react-fontawesome" +import { faGithub } from "@fortawesome/free-brands-svg-icons" +import SignInTexts from "@/features/auth/view/SignInTexts" + +const SITE_NAME = env.getOrThrow("NEXT_PUBLIC_SHAPE_DOCS_TITLE") +const HELP_URL = env.get("NEXT_PUBLIC_SHAPE_DOCS_HELP_URL") + +export default async function SignInPage() { + return ( + + + + + ) +} + +const InfoColumn = () => { + return ( + + + + ) +} + +const SignInColumn = () => { + const title = `Get started with ${SITE_NAME}` + return ( + + + + + {`${SITE_NAME} + + + {title} + + + {title} + + + + + +