Description
Version info
- Angular: 13.0.3
- Firebase: 9.6.0 (released last week)
- AngularFire: 7.2.0 (with rxfire 6.0.3)
- FirebaseUI: 6.0.0 (with firebaseui-angular 6.1.0)
How to reproduce these conditions
Added and configured Firebase App Check following the documentation. In app.module.ts
:
provideAppCheck(() => initializeAppCheck(getApp(),
{ provider: new ReCaptchaV3Provider(recaptcha3SiteKey), isTokenAutoRefreshEnabled: true })),
Error in production build: (ng build --configuration=production
deployed on Firebase Hosting)
Error: reCAPTCHA placeholder element must be empty
which then causes: @firebase/firestore: Could not reach Cloud Firestore backend.
Why this happens?
According to an old Stackoverflow question, it might be because "You are loading the google recaptcha library twice."
Network tab
Indeed, looking at the Network tab, recaptcha__en.js
is loaded twice.
Could the second recaptcha be loaded by something else?
I initially suspected FirebaseUI is loading the second recaptcha.
However, commenting out provideAppCheck()
in app.module.ts
then checking the network tab shows 0 instances of recaptcha__en.js
, leading to the conclusion that both were loaded through provideAppCheck()
.
Summary
provideAppCheck()
seems to load recaptcha library twice, causing a console error and disrupting Firestore completely.