UNPKG

angularx-social-login

Version:

Social login and authentication module for Angular 4 / 5. Supports authentication with Google and Facebook. Can be extended to other providers also.

166 lines (125 loc) 3.84 kB
# Angular 8 Social Login Social login and authentication module for Angular 8 (supports Angular 4+). Supports authentication with **Google** and **Facebook**. Can be extended to other providers also. Check out the [demo](https://abacritt.github.io/angularx-social-login/). ## Getting started ### Install via npm ```sh npm install --save angularx-social-login ``` ### Import the module In your `AppModule`, import the `SocialLoginModule` ```javascript import { SocialLoginModule, AuthServiceConfig } from "angularx-social-login"; import { GoogleLoginProvider, FacebookLoginProvider } from "angularx-social-login"; let config = new AuthServiceConfig([ { id: GoogleLoginProvider.PROVIDER_ID, provider: new GoogleLoginProvider("Google-OAuth-Client-Id") }, { id: FacebookLoginProvider.PROVIDER_ID, provider: new FacebookLoginProvider("Facebook-App-Id") } ]); export function provideConfig() { return config; } @NgModule({ declarations: [ ... ], imports: [ ... SocialLoginModule ], providers: [ { provide: AuthServiceConfig, useFactory: provideConfig } ], bootstrap: [...] }) export class AppModule { } ``` ### Sign in and out users ```javascript import { AuthService } from "angularx-social-login"; import { FacebookLoginProvider, GoogleLoginProvider } from "angularx-social-login"; @Component({ selector: 'app-demo', templateUrl: './demo.component.html', styleUrls: ['./demo.component.css'] }) export class DemoComponent implements OnInit { constructor(private authService: AuthService) { } signInWithGoogle(): void { this.authService.signIn(GoogleLoginProvider.PROVIDER_ID); } signInWithFB(): void { this.authService.signIn(FacebookLoginProvider.PROVIDER_ID); } signOut(): void { this.authService.signOut(); } } ``` ### Subscribe to the authentication state You are notified when user logs in or logs out. You receive a `SocialUser` object when the user logs in and a `null` when the user logs out. `SocialUser` object contains basic user information such as name, email, photo URL, etc. ```javascript import { AuthService } from "angularx-social-login"; import { SocialUser } from "angularx-social-login"; @Component({ selector: 'app-demo', templateUrl: './demo.component.html', styleUrls: ['./demo.component.css'] }) export class DemoComponent implements OnInit { private user: SocialUser; private loggedIn: boolean; constructor(private authService: AuthService) { } ngOnInit() { this.authService.authState.subscribe((user) => { this.user = user; this.loggedIn = (user != null); }); } } ``` ### Display the user information ```html <img src="{{ user.photoUrl }}"> <div> <h4>{{ user.name }}</h4> <p>{{ user.email }}</p> </div> ``` ## Specifying custom scope ```javascript const fbLoginOptions: LoginOpt = { scope: 'pages_messaging,pages_messaging_subscriptions,email,pages_show_list,manage_pages', return_scopes: true, enable_profile_selector: true }; // https://developers.facebook.com/docs/reference/javascript/FB.login/v2.11 const googleLoginOptions: LoginOpt = { scope: 'profile email' }; // https://developers.google.com/api-client-library/javascript/reference/referencedocs#gapiauth2clientconfig let config = new AuthServiceConfig([ { id: GoogleLoginProvider.PROVIDER_ID, provider: new GoogleLoginProvider("Google-OAuth-Client-Id", googleLoginOptions) }, { id: FacebookLoginProvider.PROVIDER_ID, provider: new FacebookLoginProvider("Facebook-App-Id", fbLoginOptions) } ]); ``` ## Building with AoT If you are facing issue in building your app with AoT, check [this document](https://github.com/abacritt/angularx-social-login/blob/master/README-AOT.md). ## Running the demo app ```sh cd demo npm install ng serve ```