firebaseui-angular-i18n
Version:
[](https://badge.fury.io/js/firebaseui-angular-i18n)
136 lines • 18.5 kB
JavaScript
import { Component, EventEmitter, Inject, Input, Optional, Output } from '@angular/core';
import 'firebase/compat/auth';
import * as i0 from "@angular/core";
import * as i1 from "@angular/fire/compat/auth";
import * as i2 from "./firebaseui-angular-library.service";
export class FirebaseuiAngularLibraryComponent {
constructor(angularFireAuth, _firebaseUiConfig, _firebaseUiConfig_Feature, ngZone, firebaseUIService) {
this.angularFireAuth = angularFireAuth;
this._firebaseUiConfig = _firebaseUiConfig;
this._firebaseUiConfig_Feature = _firebaseUiConfig_Feature;
this.ngZone = ngZone;
this.firebaseUIService = firebaseUIService;
this.signInSuccessWithAuthResultCallback = new EventEmitter(); // tslint:disable-line
this.signInFailureCallback = new EventEmitter(); // tslint:disable-line
this.uiShownCallback = new EventEmitter(); // tslint:disable-line
this.firebaseUISubscription = this.firebaseUIService.getFirebaseUiObservable().subscribe((fireUIInstance) => {
this.firebaseUIPopup(fireUIInstance);
});
}
async ngOnChanges(changes) {
await this.firebaseUIService.setLanguage(changes.language.currentValue);
}
get firebaseUiConfig() {
return {
...this._firebaseUiConfig,
...this._firebaseUiConfig_Feature
};
}
ngOnInit() {
this.subscription = this.angularFireAuth.authState.subscribe((value) => {
if ((value && value.isAnonymous) || !value) {
if (this.firebaseUiConfig.signInOptions.length !== 0) {
// initialization of ngOnChanges occurs only when language value is accepted as @input. fire manually if it is not
if (!this.language) {
this.firebaseUIService.setLanguage('en');
}
}
else {
throw new Error('There must be at least one AuthProvider.');
}
}
});
}
ngOnDestroy() {
if (!!this.subscription) {
this.subscription.unsubscribe();
}
if (!!this.firebaseUISubscription) {
this.firebaseUISubscription.unsubscribe();
}
}
getUIAuthConfig() {
if (!this.firebaseUiConfig.callbacks) {
this._firebaseUiConfig[FirebaseuiAngularLibraryComponent.COMPUTED_CALLBACKS] = true;
this._firebaseUiConfig.callbacks = this.getCallbacks();
}
return this.firebaseUiConfig;
}
firebaseUIPopup(firebaseUiInstance) {
const uiAuthConfig = this.getUIAuthConfig();
// Check if callbacks got computed to reset them again after providing the to firebaseui.
// Necessary for allowing updating the firebaseui config during runtime.
let resetCallbacks = false;
if (uiAuthConfig[FirebaseuiAngularLibraryComponent.COMPUTED_CALLBACKS]) {
resetCallbacks = true;
delete uiAuthConfig[FirebaseuiAngularLibraryComponent.COMPUTED_CALLBACKS];
}
delete uiAuthConfig.language;
// show the firebaseui
firebaseUiInstance.start('#firebaseui-auth-container', uiAuthConfig);
if (resetCallbacks) {
this._firebaseUiConfig.callbacks = null;
}
}
getCallbacks() {
const signInSuccessWithAuthResultCallback = (authResult, redirectUrl) => {
this.ngZone.run(() => {
this.signInSuccessWithAuthResultCallback.emit({
authResult,
redirectUrl
});
});
return this.firebaseUiConfig.signInSuccessUrl;
};
const signInFailureCallback = (error) => {
this.ngZone.run(() => {
this.signInFailureCallback.emit({
code: error.code,
credential: error.credential
});
});
return Promise.reject();
};
const uiShownCallback = () => {
this.ngZone.run(() => {
this.uiShownCallback.emit();
});
};
return {
signInSuccessWithAuthResult: signInSuccessWithAuthResultCallback,
signInFailure: signInFailureCallback,
uiShown: uiShownCallback
};
}
}
FirebaseuiAngularLibraryComponent.COMPUTED_CALLBACKS = 'COMPUTED_CALLBACKS';
FirebaseuiAngularLibraryComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.2", ngImport: i0, type: FirebaseuiAngularLibraryComponent, deps: [{ token: i1.AngularFireAuth }, { token: 'firebaseUIAuthConfig' }, { token: 'firebaseUIAuthConfigFeature' }, { token: i0.NgZone }, { token: i2.FirebaseuiAngularLibraryService }], target: i0.ɵɵFactoryTarget.Component });
FirebaseuiAngularLibraryComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.2", type: FirebaseuiAngularLibraryComponent, selector: "firebase-ui", inputs: { language: "language" }, outputs: { signInSuccessWithAuthResultCallback: "signInSuccessWithAuthResult", signInFailureCallback: "signInFailure", uiShownCallback: "uiShown" }, usesOnChanges: true, ngImport: i0, template: '<div id="firebaseui-auth-container"></div>', isInline: true });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.2", ngImport: i0, type: FirebaseuiAngularLibraryComponent, decorators: [{
type: Component,
args: [{
selector: 'firebase-ui',
template: '<div id="firebaseui-auth-container"></div>'
}]
}], ctorParameters: function () { return [{ type: i1.AngularFireAuth }, { type: undefined, decorators: [{
type: Inject,
args: ['firebaseUIAuthConfig']
}] }, { type: undefined, decorators: [{
type: Inject,
args: ['firebaseUIAuthConfigFeature']
}] }, { type: i0.NgZone }, { type: i2.FirebaseuiAngularLibraryService }]; }, propDecorators: { language: [{
type: Optional
}, {
type: Input,
args: ["language"]
}], signInSuccessWithAuthResultCallback: [{
type: Output,
args: ['signInSuccessWithAuthResult']
}], signInFailureCallback: [{
type: Output,
args: ['signInFailure']
}], uiShownCallback: [{
type: Output,
args: ['uiShown']
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"firebaseui-angular-library.component.js","sourceRoot":"","sources":["../../../../projects/firebaseui-angular-library/src/lib/firebaseui-angular-library.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Inject, Input, NgZone, OnChanges, OnDestroy, OnInit, Optional, Output, SimpleChanges } from '@angular/core';\nimport { AngularFireAuth } from '@angular/fire/compat/auth';\nimport firebase from 'firebase/compat/app';\nimport 'firebase/compat/auth';\nimport * as firebaseui from 'firebaseui';\nimport { Subscription } from 'rxjs';\nimport {\n  ExtendedFirebaseUIAuthConfig,\n  FirebaseUISignInFailure,\n  FirebaseUISignInSuccessWithAuthResult\n} from './firebaseui-angular-library.helper';\nimport { FirebaseuiAngularLibraryService } from './firebaseui-angular-library.service';\n\nimport User = firebase.User;\nimport UserCredential = firebase.auth.UserCredential;\nimport AuthUI = firebaseui.auth.AuthUI;\n\n\n@Component({\n  selector: 'firebase-ui',\n  template: '<div id=\"firebaseui-auth-container\"></div>'\n})\nexport class FirebaseuiAngularLibraryComponent implements OnInit, OnDestroy, OnChanges {\n  private static readonly COMPUTED_CALLBACKS = 'COMPUTED_CALLBACKS';\n  private firebaseUISubscription: Subscription;\n\n  @Optional() @Input(\"language\") language: string;\n\n  @Output('signInSuccessWithAuthResult') signInSuccessWithAuthResultCallback: EventEmitter<FirebaseUISignInSuccessWithAuthResult> = new EventEmitter(); // tslint:disable-line\n  @Output('signInFailure') signInFailureCallback: EventEmitter<FirebaseUISignInFailure> = new EventEmitter(); // tslint:disable-line\n  @Output('uiShown') uiShownCallback: EventEmitter<void> = new EventEmitter(); // tslint:disable-line\n\n  private subscription: Subscription;\n\n  constructor(private angularFireAuth: AngularFireAuth,\n    @Inject('firebaseUIAuthConfig') private _firebaseUiConfig: ExtendedFirebaseUIAuthConfig,\n    @Inject('firebaseUIAuthConfigFeature') private _firebaseUiConfig_Feature: ExtendedFirebaseUIAuthConfig,\n    private ngZone: NgZone,\n    private firebaseUIService: FirebaseuiAngularLibraryService) {\n    this.firebaseUISubscription = this.firebaseUIService.getFirebaseUiObservable().subscribe((fireUIInstance: AuthUI) => {\n      this.firebaseUIPopup(fireUIInstance);\n    });\n  }\n\n  async ngOnChanges(changes: SimpleChanges) {\n    await this.firebaseUIService.setLanguage(changes.language.currentValue);\n  }\n\n  get firebaseUiConfig(): ExtendedFirebaseUIAuthConfig {\n    return {\n      ...this._firebaseUiConfig,\n      ...this._firebaseUiConfig_Feature\n    };\n  }\n\n  ngOnInit(): void {\n    this.subscription = this.angularFireAuth.authState.subscribe((value: User) => {\n      if ((value && value.isAnonymous) || !value) {\n        if (this.firebaseUiConfig.signInOptions.length !== 0) {\n          // initialization of ngOnChanges occurs only when language value is accepted as @input. fire manually if it is not\n          if (!this.language) {\n            this.firebaseUIService.setLanguage('en');\n          }\n        } else {\n          throw new Error('There must be at least one AuthProvider.');\n        }\n      }\n    });\n  }\n\n  ngOnDestroy(): void {\n    if (!!this.subscription) {\n      this.subscription.unsubscribe();\n    }\n    if (!!this.firebaseUISubscription) {\n      this.firebaseUISubscription.unsubscribe();\n    }\n  }\n\n  private getUIAuthConfig(): ExtendedFirebaseUIAuthConfig {\n    if (!this.firebaseUiConfig.callbacks) {\n      this._firebaseUiConfig[FirebaseuiAngularLibraryComponent.COMPUTED_CALLBACKS] = true;\n      this._firebaseUiConfig.callbacks = this.getCallbacks();\n    }\n    return this.firebaseUiConfig;\n  }\n\n  private firebaseUIPopup(firebaseUiInstance: AuthUI) {\n    const uiAuthConfig = this.getUIAuthConfig();\n\n    // Check if callbacks got computed to reset them again after providing the to firebaseui.\n    // Necessary for allowing updating the firebaseui config during runtime.\n    let resetCallbacks = false;\n    if (uiAuthConfig[FirebaseuiAngularLibraryComponent.COMPUTED_CALLBACKS]) {\n      resetCallbacks = true;\n      delete uiAuthConfig[FirebaseuiAngularLibraryComponent.COMPUTED_CALLBACKS];\n    }\n\n    delete uiAuthConfig.language;\n\n    // show the firebaseui\n    firebaseUiInstance.start('#firebaseui-auth-container', uiAuthConfig);\n\n    if (resetCallbacks) {\n      this._firebaseUiConfig.callbacks = null;\n    }\n  }\n\n  private getCallbacks(): any { // firebaseui.Callbacks\n    const signInSuccessWithAuthResultCallback = (authResult: UserCredential, redirectUrl: string) => {\n      this.ngZone.run(() => {\n        this.signInSuccessWithAuthResultCallback.emit({\n          authResult,\n          redirectUrl\n        });\n      });\n      return this.firebaseUiConfig.signInSuccessUrl;\n    };\n\n    const signInFailureCallback = (error: firebaseui.auth.AuthUIError) => {\n      this.ngZone.run(() => {\n        this.signInFailureCallback.emit({\n          code: error.code,\n          credential: error.credential\n        });\n      });\n      return Promise.reject();\n    };\n\n    const uiShownCallback = () => {\n      this.ngZone.run(() => {\n        this.uiShownCallback.emit();\n      });\n    };\n\n    return {\n      signInSuccessWithAuthResult: signInSuccessWithAuthResultCallback,\n      signInFailure: signInFailureCallback,\n      uiShown: uiShownCallback\n    };\n  }\n}\n"]}