Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Firestore unsubscribe from useEffect

I'm trying to use useEffect to stop listening to Firebase Firestore collection changes.

I can get Firebase data, But I can't access this unsubscribe();

How can i fix this?


  let unsbscribe;

  async function getFirebaseData() {
      unsbscribe = db.collection('room')
          .where('joinUser', 'array-contains-any', [10])
          .onSnapshot((res) => {
            // do something...
          });


  useEffect(() => {
    getFirebaseData();
    return () => {
      unsbscribe(); // throws an error that unsubscribe is not a function.
    };
  }, []);

like image 873
Rick Avatar asked Oct 26 '25 01:10

Rick


2 Answers

You can unsubscribe it from inside the useEffect hook in this way:

useEffect(() => {
    const unsubscribe = db.collection('room')
        .where('joinUser', 'array-contains-any', [10])
        .onSnapshot((res) => {
            // do something...
        });
    return () => unsubscribe()
}, []);
like image 96
Shahnawaz Hossan Avatar answered Oct 28 '25 16:10

Shahnawaz Hossan


Try to return just unsubscribe

 let unsbscribe;

  async function getFirebaseData() {
      unsbscribe = db.collection('room')
          .where('joinUser', 'array-contains-any', [10])
          .onSnapshot((res) => {
            // do something...
          });


  useEffect(() => {
    getFirebaseData();
    return unsubscribe
  }, []);
like image 44
Jackmekiss Avatar answered Oct 28 '25 15:10

Jackmekiss