Ich habe keine Proben gefunden. Ist es möglich, die FirebaseUI mit AngularFire2 zu verwenden? AFAIK die Benutzeroberfläche ist nicht Teil von AngularFire2.Verwenden FirebaseUI mit AngularFire2
Antwort
Es gibt tatsächlich keine direkte Integration zwischen FirebaseUI (für das Web) und AngularFire2.
AngularFire2 verfügt über integrierte Anmeldeelemente, die in die untergeordnete Anmeldefunktion des Firebase Authentication JavaScript SDK integriert sind. Mehr dazu finden Sie unter AngularFire2 documentation on user authentication.
Aber da sowohl AngularFire2 als auch FirebaseUI-Web auf dem Firebase Authentication JavaScript SDK basieren, funktionieren sie wahrscheinlich auch gut zusammen. Wenn Sie start a sign-in flow from FirebaseUI, wird es am Ende trigger an onAuthStateChanged()
event auf der SDK-Ebene. Das ist die same event that AngularFire2 listens to, um ihr eigenes Ereignis onAuth()
auszulösen.
Ja, AngularFire und FirebaseUI können zusammenarbeiten. Sie müssen:
1: Import FirebaseUI und geben ihm den Zugang zu Feuerbasis (zB vor Bootstrap)
import * as firebase from 'firebase/app'
// Attach firebase to window so FirebaseUI can access it
(<any>window).firebase = firebase
// Import FirebaseUI standalone (as its npm.js file causes double firebase code)
import 'firebaseui/dist/firebaseui' // Imports for side effects only
// Declare `window.firebaseui` that the above import creates
declare global {
const firebaseui
}
Why you can't just import * as firebaseui
like you do with firebase
2: Init FirebaseUI in einem Dienst (so dass es passiert nur einmal) und übergeben Sie die von AngularFire erstellte Authentifizierungsinstanz.
constructor(private af_auth: AngularFireAuth){
this.fui_auth = new firebaseui.auth.AuthUI(this.af_auth.auth)
}
3: Übertragen Sie die Benutzeroberfläche in einer Komponente
@Component({
'selector': 'app-signin',
'template': '', // Populated by `fui_auth.start()`
})
export class SigninComp {
constructor(private user: UserService){}
ngOnInit(){
// Show Firebase UI auth widget
this.user.fui_auth.start('app-signin', {config...}})
}
}
Es gibt auch a module available, aber es leidet zur Zeit von this issue
- 1. Verwenden von "Firebase" mit AngularFire2 v4
- 2. FirebaseUI-Android mit Google Anmelden
- 3. Ausgabe mit FirebaseUI und FirebaseRecyclerAdapater
- 4. FirebaseUI NoSuchMethodException:
- 5. iOS FirebaseUI mit benutzerdefiniertem UITableViewCell
- 6. Mehrere Authentifizierungsmethoden mit AngularFire2
- 7. hostedDomain mit Angularfire2
- 8. Angular2 mit angularfire2
- 9. FirebaseUI im Fragment
- 10. Ionic Firebase App mit AngularFire2
- 11. FirebaseUI Login-Orientierung
- 12. ionische 3 mit geofire angularfire2
- 13. Laden von Bildern mit FirebaseUI und Speicherreferenzen
- 14. FirebaseUI Auth Clang Fehler mit TwitterKit
- 15. FirebaseUI - erhalten zufällige Liste mit FirebaseRecyclerAdapter
- 16. FirebaseUI für iOS populateCellWithBlock Fehler
- 17. AngularFire2 AuthCredentials
- 18. Überprüfung Authentifizierungsstatus mit AngularFire2 v4
- 19. FirebaseUI Auth stürzt auf Android
- 20. Persist angemeldet Benutzer mit angularfire2 mit Cookies
- 21. AngularFire2 Abfrage nach Kindobjekt
- 22. Get FirebaseListObservable mit Parameter (AngularFire2, Angular 2)
- 23. Abfrage beobachtbar und angularfire2
- 24. eckige angularfire2 einfache Join
- 25. FirebaseUI und Firebase, was ist der Unterschied?
- 26. Kann nicht die Titelleiste der Authorization Aktivität mit FirebaseUI
- 27. AngularFire2 - Verwenden des Zugriffstokens von Google Auth für Google-APIs
- 28. Angularfire2 benutzerdefinierte Authentifizierung
- 29. AngularFire2 - Abonnement-Abfrage
- 30. Firebase-Speicher und angularfire2
Ein echtes Arbeits Beispiel hierfür wäre wirklich schön. Es gibt https://github.com/RaphaelJenni/FirebaseUIAngularIntegration, aber es funktioniert nicht für mich. 'FirebaseError: Firebase: Es wurde keine Firebase-App '[DEFAULT]' erstellt - rufen Sie Firebase App.initializeApp() (app/no-app) auf." – Splaktar
Es scheint, als ob ein doppelter Aufruf von 'firebase.initializeApp (firebaseConfig) 'erforderlich ist zusätzlich zum Aufruf von 'AngularFireModule.initializeApp (fireBaseConfig)' in 'app.module.ts'. – Splaktar