質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.49%
Firebase

Firebaseは、Googleが提供するBasSサービスの一つ。リアルタイム通知可能、並びにアクセス制御ができるオブジェクトデータベース機能を備えます。さらに認証機能、アプリケーションのログ解析機能などの利用も可能です。

Firebase Authentication

Firebase Authenticationは、Firebaseを利用したユーザーの認証機能です。バックエンドサービス、SDK、アプリでのユーザー認証に使用できるUIライブラリが用意されています。

Cloud Firestore

Cloud Firestore は、自動スケーリングと高性能を実現し、アプリケーション開発を簡素化するように構築された NoSQLドキュメントデータベースです。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

React.js

Reactは、アプリケーションのインターフェースを構築するためのオープンソースJavaScriptライブラリです。

Q&A

解決済

1回答

661閲覧

React, firebaseのアプリでログイン後にFirestoreをstateとして読み込む方法

退会済みユーザー

退会済みユーザー

総合スコア0

Firebase

Firebaseは、Googleが提供するBasSサービスの一つ。リアルタイム通知可能、並びにアクセス制御ができるオブジェクトデータベース機能を備えます。さらに認証機能、アプリケーションのログ解析機能などの利用も可能です。

Firebase Authentication

Firebase Authenticationは、Firebaseを利用したユーザーの認証機能です。バックエンドサービス、SDK、アプリでのユーザー認証に使用できるUIライブラリが用意されています。

Cloud Firestore

Cloud Firestore は、自動スケーリングと高性能を実現し、アプリケーション開発を簡素化するように構築された NoSQLドキュメントデータベースです。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

React.js

Reactは、アプリケーションのインターフェースを構築するためのオープンソースJavaScriptライブラリです。

0グッド

0クリップ

投稿2020/01/15 03:39

前提

React, Firebase, react-router, react-firebase-hooksを用いてログインしたユーザーが記事を投稿、閲覧できるSPAを作成しています。
Reduxなどは使用していません。

ログインしたユーザーのみが記事一覧をFirestoreから取得することができる仕様です。

最上位コンポーネントのApp.jsxに認証情報userとFirestoreから取得した記事一覧データpostsをstateとして保持し、下位コンポーネントにpropsとして渡すことで記事の表示などを行っています。

ユーザーがログインしていない状態の場合はpostsはパーミッションエラーで取得できないためundefinedとなります。
非ログインユーザーアクセスを試みた際は、ログインページにリダイレクトしてログインを促すような実装です。

実現したいこと

現状、ログインページでログインを行いuserステートが更新されたあとも、postsがログイン前のundefinedのままとなってしまい、記事が取得できない問題があります。

ブラウザの更新を行うと再度postsの読み込みが走るためuserpostsが揃い記事表示できるようにはなるのですが、「ユーザーログインが行われたタイミングでpostsを読み込み直す」ような実装をどのように行えばよいかがわかりません。

設計自体を変えたほうがいい場合は、どのように設計すべきかをご教授いただけると幸いです。

該当のソースコード

  • App.jsx

jsx

1const App = () => { 2 const [user, userLoading] = useAuthState(firebase.auth()); 3 const [posts, postsLoading, postsError] = useCollectionData( 4 firestore.collection('post').orderBy('postTime', 'desc'), 5 ); 6 7 return ( 8 <> 9 {userLoading || postsLoading ? ( 10 <p>please wait ...</p> 11 ) : ( 12 <MuiThemeProvider theme={theme}> 13 <GlobalStyle /> 14 <BrowserRouter> 15 <Header user={user} /> 16 <Content> 17 <Router user={user} posts={posts} /> 18 </Content> 19 </BrowserRouter> 20 </MuiThemeProvider> 21 )} 22 </> 23 ); 24};

試したこと

  • App.jsx

jsx

1const App = () => { 2 // 省略 3 4 if (user && postsError) { 5 ... // ログインできているのにposts読み込みが失敗しているときの再読み込み処理を書こうと考えましたが、どう書けばよいのか思いつきませんでした…… 6 } 7 8 // 省略 9};

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

こちら自己解決しました!

App.jsxにはuserのみを持たせ、ログイン有無で下位コンポーネントの出し分けを行い、
ログイン時に表示する下位コンポーネントにpostを持たせることで解決しました。

  • App.jsx

jsx

1const App = () => { 2 const [user, userLoading] = useAuthState(firebase.auth()); 3 if (user) { 4 return <AuthorizedPage user={user} userLoading={userLoading} />; 5 } 6 7 return <UnAuthorizedPage userLoading={userLoading} />; 8};
  • AuthorizedPage.jsx

jsx

1const AuthorizedPage = props => { 2 const { user, userLoading } = props; 3 const [posts, postsLoading] = useCollectionData( 4 firestore.collection('post').orderBy('postTime', 'desc'), 5 ); 6 7 return ( 8 <> 9 {userLoading || postsLoading ? ( 10 <p>please wait ...</p> 11 ) : ( 12 <MuiThemeProvider theme={theme}> 13 <GlobalStyle /> 14 <BrowserRouter> 15 <Header user={user} /> 16 <Content> 17 <Router user={user} posts={posts} /> 18 </Content> 19 </BrowserRouter> 20 </MuiThemeProvider> 21 )} 22 </> 23 ); 24};

投稿2020/01/16 08:51

退会済みユーザー

退会済みユーザー

総合スコア0

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.49%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問