Skip to content

Commit

Permalink
Merge pull request #21 from jphacks/feat/signin-button
Browse files Browse the repository at this point in the history
サインインボタン
  • Loading branch information
Inlet-back authored Oct 26, 2024
2 parents d3c3149 + 55cc14a commit bbac81e
Show file tree
Hide file tree
Showing 4 changed files with 103 additions and 0 deletions.
2 changes: 2 additions & 0 deletions task_yell/.gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -34,3 +34,5 @@ yarn-error.log*
# typescript
*.tsbuildinfo
next-env.d.ts

certificates
1 change: 1 addition & 0 deletions task_yell/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@
"private": true,
"scripts": {
"dev": "next dev",
"dev-https": "next dev --experimental-https",
"build": "next build",
"start": "next start",
"lint": "next lint"
Expand Down
69 changes: 69 additions & 0 deletions task_yell/src/components/sign-in-button.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,69 @@
"use client";

import { onAuthStateChanged } from "@/firebase/auth";
import { auth } from "@/firebase/client-app";
import { GoogleAuthProvider, signInWithPopup, type User } from "firebase/auth";
import { useRouter } from "next/navigation";
import { useCallback, useEffect, useState } from "react";

function useUserSession() {
// The initialUser comes from the server via a server component
const [user, setUser] = useState<User | null>();
const router = useRouter();

// Register the service worker that sends auth state back to server
// The service worker is built with npm run build-service-worker
// useEffect(() => {
// if ("serviceWorker" in navigator) {
// const serializedFirebaseConfig = encodeURIComponent(JSON.stringify(firebaseConfig));
// const serviceWorkerUrl = `/auth-service-worker.js?firebaseConfig=${serializedFirebaseConfig}`

// navigator.serviceWorker
// .register(serviceWorkerUrl)
// .then((registration) => console.log("scope is: ", registration.scope));
// }
// }, []);

useEffect(() => {
const unsubscribe = onAuthStateChanged((authUser) => {
setUser(authUser)
})

return () => unsubscribe()
// eslint-disable-next-line react-hooks/exhaustive-deps
}, []);

useEffect(() => {
onAuthStateChanged((authUser) => {
if (user === undefined) return

// refresh when user changed to ease testing
if (user?.email !== authUser?.email) {
router.refresh()
}
})
// eslint-disable-next-line react-hooks/exhaustive-deps
}, [user, router.refresh])

return user;
}

export function SignInButton() {
const user = useUserSession();
const handleSignIn = useCallback(async () => {
const provider = new GoogleAuthProvider();
await signInWithPopup(auth, provider);
}, []);
const handleSignOut = useCallback(async () => {
console.log("signing out")
await auth.signOut();
}, []);

return !user ?
(<button type="button" onClick={handleSignIn} >
サインイン
</button>) : (<button type="button" onClick={handleSignOut}>
サインアウト
</button>
)
}
31 changes: 31 additions & 0 deletions task_yell/src/firebase/auth.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
import {
GoogleAuthProvider,
signInWithPopup,
onAuthStateChanged as _onAuthStateChanged,
} from "firebase/auth";

import { auth } from "@/firebase/client-app";

export type NextOrObserveUser = Parameters<typeof _onAuthStateChanged>[1];

export function onAuthStateChanged(cb: NextOrObserveUser) {
return _onAuthStateChanged(auth, cb);
}

export async function signInWithGoogle() {
const provider = new GoogleAuthProvider();

try {
await signInWithPopup(auth, provider);
} catch (error) {
console.error("Error signing in with Google", error);
}
}

export async function signOut() {
try {
return auth.signOut();
} catch (error) {
console.error("Error signing out with Google", error);
}
}

0 comments on commit bbac81e

Please sign in to comment.