You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
constassignTypes=()=>{return{toFirestore(doc: NewsItemDTO): DocumentData{returndoc;},fromFirestore(snapshot: QueryDocumentSnapshot): NewsItemDTO{returnsnapshot.data()!asNewsItemDTO;},};};constNewsPage=()=>{constfirestore=useFirestore();constanimalsCollection=collection(firestore,'newsItems');constanimalsQuery=query(animalsCollection).withConverter(assignTypes());^^^convertorusedhereconst{ status, data }=useFirestoreCollectionData(animalsQuery);console.log(data);if(status==='loading'){return<span>loading...</span>;}return(<><divclassName="mx-auto lg:w-2/3 xs:w-full"><divclassName="space-y-2"><NewsItemListnews={data}/></div></div><AddNewsButton/></>);};exportdefaultNewsPage;
Steps to reproduce
Using useFirestoreCollectionData with a query that has a convertor attached results in an infinite loop of undefined. Removing the withConvertor call from the query immediately fixes the issue. The bug seems to occur whether attaching the convertor to the query or the collection.
Expected behavior
I would expect the query to succeed regardless of if a convertor is utilized or not. Currently, I can only return an untyped collection and then have to map it in an additional step. You can also force the datatype by using an as clause at the point of usage:
<NewsItemListnews={dataasNewsItemDTO[]}/>
but this also feels unnecessary.
Single documents work fine with convertors.
Actual behavior
The query loops forever, returning zero results.
The text was updated successfully, but these errors were encountered:
If I instead save off the converter to a top-level constant, which means the equality check can presumably rely on identity for the converter part, I can see the collection promise gets fulfilled and my app renders correctly.
It's something like this saved off outside of the component lifecycle, in my case at the top level of a module:
Another approach to consider is to allow users to pass in a query key override, like react-query (the lib I was coming from), if it's too difficult to track whether equality will work out from reading subtle code changes.
Version info
React: 18.2.0
Firebase: 9.13.0
ReactFire: 4.2.2
Test case
Steps to reproduce
Using
useFirestoreCollectionData
with a query that has a convertor attached results in an infinite loop of undefined. Removing thewithConvertor
call from the query immediately fixes the issue. The bug seems to occur whether attaching the convertor to the query or the collection.Expected behavior
I would expect the query to succeed regardless of if a convertor is utilized or not. Currently, I can only return an untyped collection and then have to map it in an additional step. You can also force the datatype by using an
as
clause at the point of usage:but this also feels unnecessary.
Single documents work fine with convertors.
Actual behavior
The query loops forever, returning zero results.
The text was updated successfully, but these errors were encountered: