angularfire: Angular Standalone (v16.2.0) & Angular Fire (v7.6.1) - error on calling `collection` function
Version info
Angular:
Angular CLI: 16.2.0
Node: 18.17.0
Package Manager: npm 9.8.1
OS: darwin x64
Angular: 16.2.2
... animations, common, compiler, compiler-cli, core, forms
... platform-browser, platform-browser-dynamic, router
Package Version
---------------------------------------------------------
@angular-devkit/architect 0.1602.0
@angular-devkit/build-angular 16.2.0
@angular-devkit/core 16.2.0
@angular-devkit/schematics 16.2.0
@angular/cli 16.2.0
@angular/fire 7.6.1
@schematics/angular 16.2.0
rxjs 7.8.1
typescript 5.1.6
zone.js 0.13.1
Firebase:
npm list firebase
website@0.0.1/Volumes/Develop/GitHub/*****/website
└─ firebase@9.23.0
AngularFire:
> npm list @angular/fire
website@0.0.1 /Volumes/Develop/GitHub/*****/website
└── @angular/fire@7.6.1
How to reproduce these conditions
> npx @angular/cli@latest new website --routing --standalone
> ng add @angular/fire
Steps to set up and reproduce
In app.config.ts:
...
provideFirebaseApp(() => initializeApp(environment.firebase)),
provideFirestore(() => getFirestore()),
provideAuth(() => getAuth()),
)
...
In component:
...
firestore: Firestore = inject(Firestore)
items$: Observable<any[]> | undefined
ngOnInit() {
const aCollection = collection(this.firestore, 'faqs')
this.items$ = collectionData(aCollection) as Observable<any[]>
}
...
Debug output
** Errors in the JavaScript console **
ERROR FirebaseError:
Expected first argument to collection() to be a
CollectionReference, a DocumentReference or FirebaseFirestore
console.log(this.firestore)
{
"app": {
"_isDeleted": false,
"_options": {
"projectId": "*****",
"appId": "*****",
"storageBucket": "*****",
"apiKey": "*****",
"authDomain": "*****",
"messagingSenderId": "*****",
"measurementId": "*****"
},
"_config": {
"name": "[DEFAULT]",
"automaticDataCollectionEnabled": false
},
"_name": "[DEFAULT]",
"_automaticDataCollectionEnabled": false,
"_container": {
"name": "[DEFAULT]",
"providers": {}
}
},
"databaseId": {
"projectId": "*****",
"database": "(default)"
},
"settings": {
"host": "firestore.googleapis.com",
"ssl": true,
"ignoreUndefinedProperties": false,
"cacheSizeBytes": 41943040,
"experimentalForceLongPolling": false,
"experimentalAutoDetectLongPolling": true,
"experimentalLongPollingOptions": {},
"useFetchStreams": true
}
}
Expected behavior
Get a result from firestore
Actual behavior
Error in console
About this issue
- Original URL
- State: open
- Created 10 months ago
- Reactions: 6
- Comments: 46 (2 by maintainers)
Just ran into the same issue after following the instructions in the Quickstart But I guess it’s due to the version mismatch you mentioned
I am using “@angular/fire”: “^7.6.1”, “firebase”: “^10.3.0”, “@angular/core”: “^16.2.0”,
this setup worked for me
I was able to get it working by deleting the package-lock.json file and the node_modules directory. Then, I installed the following versions:
It’s now working for Angular 15, 16, and Ionic 7."
I use npm And I also think that the problem is with rxfire v6.0.4.
You have to remove the ^ in front of the version of rxfire in your package.json The ^ allows the package-manager to install the newest version for the given major version (= last two numbers can be changed) Using ~ would only allow changes to the minor version (= last number can be changed) But we don’t want any change.
I think reopening the ticket would be good, since more people will run into this problem, until there is a new version of angular/fire, which supports firebase v10
@oluijks @jits I have also ran into this issue now - we can possibly open this issue again. I found the only change necessary to fix the issue was to change where collection is imported from.
Importing like this results in the console error mentioned above:
Changing the imports to this fixes the console error and data is fetched like expected:
I guess there is an issue with collection when it is imported from @angular/fire/firestore
Just as a side note - the same outcome happens when I am on the following two sets of package versions so it seems to still be an issue in the lastest canary version as well as the latest release version:
and
@oluijks – what are your import statements?
This may be relevant: https://stackoverflow.com/a/69048162/238287
One thing I’ve noticed: it’s important to always import functions from
'@angular/fire/firestore'
and not from rxfire or the Firebase JS SDK directly, otherwise weird things happen.@jits RxFire’s
collection()
function was named well before the version 9 SDK and we didn’t want to cause a breaking change.I just published a version of RxFire
6.0.5
that fixes the dependency range for the Firebase SDK. I also pushed a new canary of AngularFire. Can someone try the latest canary after deleting all node modules and trying again?Same issue with Angular 16.2.0 and Firebase v10+, solved with “@angular/fire”: “^7.6.1”, “firebase”: “^9.23.0”, “rxfire”: “6.0.3”
I can confirm the issue. What worked for me was:
Any other configuration throws build or runtime errors.
Reopening this issue
@timlouw I can confirm that importing
collection
fromfirebase/firestore
fixes the mentioned FirebaseError. I’m not sure if this will raise other issues though…@jits Ok to open up this issue again now we know a bit more? I think the angularfire team has enough info to look at this issue…
I just followed the official AngularFire Quickstart, but as soon as I installed AngularFire (using npm), the app can not compile anymore :
Generic type 'AggregateQuerySnapshot<T>' requires 1 type argument(s).
Few weeks earlier, I could install AngularFire but I got the following error :
Expected first argument to collection() to be a CollectionReference, a DocumentReference or FirebaseFirestore
What I understrand in this topic, is that these errors come from an incompatibility between AngularFire and the new major version Firebase 10. Am I correct ?
I’m also understranding that the AngularFire team is aware and working on a fix?
I was using yarn to install the packages previously and doesn’t matter the combination of versions of angular fire and firebase, the issue persisted.
Now I did an npm install and everything works
I have faced the same issue, tried to install different version of AngularFire, Rxfire and Firebase, yet getting errors.
I tried the canary build the results are same as before.data:image/s3,"s3://crabby-images/c28a0/c28a084fdf4c455ea22da87e42878460d1774832" alt="Screenshot 2023-09-04 at 7 09 51 AM"
My angular fire version
thanks for your comments guys and fixes… 3 days I m turning this problem in EVERY directions 😃
My apologies, you are correct @jits @Tucaen - I double checked the versions installed in the package-lock.
@jits Will do. I’ll close it for now and again, thanks for the help.