verben-authentication-ui 0.3.8 → 0.3.9

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (25) hide show
  1. package/esm2022/lib/components/auth-callback/auth-callback.component.mjs +48 -0
  2. package/esm2022/lib/components/auth-callback/auth-callback.module.mjs +18 -0
  3. package/esm2022/lib/components/o-auth/o-auth.component.mjs +53 -81
  4. package/esm2022/lib/components/sign-in/sign-in.component.mjs +103 -35
  5. package/esm2022/lib/components/sign-up/sign-up.component.mjs +1 -1
  6. package/esm2022/lib/components/user-management/user-management.component.mjs +2 -2
  7. package/esm2022/lib/components/user-request/user-request.component.mjs +58 -61
  8. package/esm2022/lib/components/user-request-approval/user-request-approval.component.mjs +2 -2
  9. package/esm2022/lib/models/UserRequest.mjs +1 -1
  10. package/esm2022/lib/models/log-in.mjs +1 -1
  11. package/esm2022/lib/models/oauth-response.mjs +2 -0
  12. package/esm2022/lib/services/http-web-request.service.mjs +1 -2
  13. package/esm2022/public-api.mjs +3 -1
  14. package/fesm2022/verben-authentication-ui.mjs +271 -174
  15. package/fesm2022/verben-authentication-ui.mjs.map +1 -1
  16. package/lib/components/auth-callback/auth-callback.component.d.ts +17 -0
  17. package/lib/components/auth-callback/auth-callback.module.d.ts +8 -0
  18. package/lib/components/o-auth/o-auth.component.d.ts +10 -18
  19. package/lib/components/sign-in/sign-in.component.d.ts +17 -5
  20. package/lib/components/user-request/user-request.component.d.ts +6 -5
  21. package/lib/models/UserRequest.d.ts +2 -0
  22. package/lib/models/log-in.d.ts +1 -0
  23. package/lib/models/oauth-response.d.ts +6 -0
  24. package/package.json +1 -1
  25. package/public-api.d.ts +2 -0
@@ -0,0 +1,48 @@
1
+ import { Component, Input } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ import * as i1 from "@angular/router";
4
+ export class AuthCallbackComponent {
5
+ router;
6
+ code = '';
7
+ previousUrl = '';
8
+ redirectText;
9
+ width = 40;
10
+ height = 40;
11
+ color = 'black';
12
+ constructor(router) {
13
+ this.router = router;
14
+ }
15
+ ngOnInit() {
16
+ this.handleRedirect();
17
+ }
18
+ handleRedirect() {
19
+ const params = new URLSearchParams(window.location.search);
20
+ const code = params.get('code');
21
+ const stateParam = params.get('state');
22
+ if (code && stateParam) {
23
+ try {
24
+ const state = JSON.parse(decodeURIComponent(stateParam));
25
+ const returnTo = state.returnTo || '/';
26
+ this.router.navigate([returnTo], { queryParams: { code } });
27
+ }
28
+ catch (e) {
29
+ const msg = e;
30
+ }
31
+ }
32
+ }
33
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AuthCallbackComponent, deps: [{ token: i1.Router }], target: i0.ɵɵFactoryTarget.Component });
34
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: AuthCallbackComponent, selector: "verben-auth-callback", inputs: { redirectText: "redirectText", width: "width", height: "height", color: "color" }, ngImport: i0, template: "<section class=\"wrapper\"> \n <div class=\"flexWrapper\"> \n <p class=\"{{redirectText}}\">Redirecting ...</p>\n <div class=\"loader\"></div>\n </div>\n</section>", styles: [".wrapper{width:100%;min-height:100%;display:flex;align-items:center;justify-content:center}.flexWrapper{display:flex;align-items:center;justify-content:center}.loader{border:2px solid white;border-radius:50%;border-top:2px solid black;width:40px;height:40px;-webkit-animation:spin 2s linear infinite;animation:spin 2s linear infinite}@-webkit-keyframes spin{0%{-webkit-transform:rotate(0deg)}to{-webkit-transform:rotate(360deg)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}\n"] });
35
+ }
36
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AuthCallbackComponent, decorators: [{
37
+ type: Component,
38
+ args: [{ selector: 'verben-auth-callback', template: "<section class=\"wrapper\"> \n <div class=\"flexWrapper\"> \n <p class=\"{{redirectText}}\">Redirecting ...</p>\n <div class=\"loader\"></div>\n </div>\n</section>", styles: [".wrapper{width:100%;min-height:100%;display:flex;align-items:center;justify-content:center}.flexWrapper{display:flex;align-items:center;justify-content:center}.loader{border:2px solid white;border-radius:50%;border-top:2px solid black;width:40px;height:40px;-webkit-animation:spin 2s linear infinite;animation:spin 2s linear infinite}@-webkit-keyframes spin{0%{-webkit-transform:rotate(0deg)}to{-webkit-transform:rotate(360deg)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}\n"] }]
39
+ }], ctorParameters: () => [{ type: i1.Router }], propDecorators: { redirectText: [{
40
+ type: Input
41
+ }], width: [{
42
+ type: Input
43
+ }], height: [{
44
+ type: Input
45
+ }], color: [{
46
+ type: Input
47
+ }] } });
48
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0aC1jYWxsYmFjay5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy92ZXJiZW4tYXV0aGVudGljYXRpb24tdWkvc3JjL2xpYi9jb21wb25lbnRzL2F1dGgtY2FsbGJhY2svYXV0aC1jYWxsYmFjay5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy92ZXJiZW4tYXV0aGVudGljYXRpb24tdWkvc3JjL2xpYi9jb21wb25lbnRzL2F1dGgtY2FsbGJhY2svYXV0aC1jYWxsYmFjay5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBVSxNQUFNLGVBQWUsQ0FBQzs7O0FBUXpELE1BQU0sT0FBTyxxQkFBcUI7SUFTWjtJQVJwQixJQUFJLEdBQVcsRUFBRSxDQUFDO0lBQ2xCLFdBQVcsR0FBVyxFQUFFLENBQUM7SUFDaEIsWUFBWSxDQUFTO0lBQ3JCLEtBQUssR0FBVSxFQUFFLENBQUM7SUFDbEIsTUFBTSxHQUFVLEVBQUUsQ0FBQztJQUNuQixLQUFLLEdBQVUsT0FBTyxDQUFDO0lBR2hDLFlBQW9CLE1BQWM7UUFBZCxXQUFNLEdBQU4sTUFBTSxDQUFRO0lBQUcsQ0FBQztJQUV0QyxRQUFRO1FBQ04sSUFBSSxDQUFDLGNBQWMsRUFBRSxDQUFDO0lBQ3hCLENBQUM7SUFFRCxjQUFjO1FBQ1osTUFBTSxNQUFNLEdBQUcsSUFBSSxlQUFlLENBQUMsTUFBTSxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUMzRCxNQUFNLElBQUksR0FBRyxNQUFNLENBQUMsR0FBRyxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQ2hDLE1BQU0sVUFBVSxHQUFHLE1BQU0sQ0FBQyxHQUFHLENBQUMsT0FBTyxDQUFDLENBQUM7UUFFdkMsSUFBSSxJQUFJLElBQUksVUFBVSxFQUFFLENBQUM7WUFDdkIsSUFBSSxDQUFDO2dCQUNILE1BQU0sS0FBSyxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsa0JBQWtCLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQztnQkFDekQsTUFBTSxRQUFRLEdBQUcsS0FBSyxDQUFDLFFBQVEsSUFBSSxHQUFHLENBQUM7Z0JBQ3ZDLElBQUksQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLENBQUMsUUFBUSxDQUFDLEVBQUUsRUFBRSxXQUFXLEVBQUUsRUFBRSxJQUFJLEVBQUUsRUFBRSxDQUFDLENBQUM7WUFDOUQsQ0FBQztZQUFDLE9BQU8sQ0FBQyxFQUFFLENBQUM7Z0JBQ1osTUFBTSxHQUFHLEdBQUcsQ0FBQyxDQUFBO1lBQ2QsQ0FBQztRQUNILENBQUM7SUFDSCxDQUFDO3dHQTdCVSxxQkFBcUI7NEZBQXJCLHFCQUFxQix3SkNSbEMseUxBS1U7OzRGREdHLHFCQUFxQjtrQkFMakMsU0FBUzsrQkFDRSxzQkFBc0I7MkVBT3ZCLFlBQVk7c0JBQXBCLEtBQUs7Z0JBQ0csS0FBSztzQkFBYixLQUFLO2dCQUNHLE1BQU07c0JBQWQsS0FBSztnQkFDRyxLQUFLO3NCQUFiLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEFjdGl2YXRlZFJvdXRlLCBSb3V0ZXIgfSBmcm9tICdAYW5ndWxhci9yb3V0ZXInO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICd2ZXJiZW4tYXV0aC1jYWxsYmFjaycsXG4gIHRlbXBsYXRlVXJsOiAnLi9hdXRoLWNhbGxiYWNrLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmw6ICcuL2F1dGgtY2FsbGJhY2suY29tcG9uZW50LmNzcydcbn0pXG5leHBvcnQgY2xhc3MgQXV0aENhbGxiYWNrQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcbiAgY29kZTogc3RyaW5nID0gJyc7XG4gIHByZXZpb3VzVXJsOiBzdHJpbmcgPSAnJztcbiAgQElucHV0KCkgcmVkaXJlY3RUZXh0PzpzdHJpbmc7XG4gIEBJbnB1dCgpIHdpZHRoOm51bWJlciA9IDQwO1xuICBASW5wdXQoKSBoZWlnaHQ6bnVtYmVyID0gNDA7XG4gIEBJbnB1dCgpIGNvbG9yOnN0cmluZyA9ICdibGFjayc7XG4gIFxuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgcm91dGVyOiBSb3V0ZXIpIHt9XG5cbiAgbmdPbkluaXQoKSB7XG4gICAgdGhpcy5oYW5kbGVSZWRpcmVjdCgpO1xuICB9XG5cbiAgaGFuZGxlUmVkaXJlY3QoKSB7XG4gICAgY29uc3QgcGFyYW1zID0gbmV3IFVSTFNlYXJjaFBhcmFtcyh3aW5kb3cubG9jYXRpb24uc2VhcmNoKTtcbiAgICBjb25zdCBjb2RlID0gcGFyYW1zLmdldCgnY29kZScpO1xuICAgIGNvbnN0IHN0YXRlUGFyYW0gPSBwYXJhbXMuZ2V0KCdzdGF0ZScpO1xuXG4gICAgaWYgKGNvZGUgJiYgc3RhdGVQYXJhbSkge1xuICAgICAgdHJ5IHtcbiAgICAgICAgY29uc3Qgc3RhdGUgPSBKU09OLnBhcnNlKGRlY29kZVVSSUNvbXBvbmVudChzdGF0ZVBhcmFtKSk7XG4gICAgICAgIGNvbnN0IHJldHVyblRvID0gc3RhdGUucmV0dXJuVG8gfHwgJy8nO1xuICAgICAgICB0aGlzLnJvdXRlci5uYXZpZ2F0ZShbcmV0dXJuVG9dLCB7IHF1ZXJ5UGFyYW1zOiB7IGNvZGUgfSB9KTtcbiAgICAgIH0gY2F0Y2ggKGUpIHtcbiAgICAgICBjb25zdCBtc2cgPSBlXG4gICAgICB9XG4gICAgfVxuICB9XG59XG4iLCI8c2VjdGlvbiBjbGFzcz1cIndyYXBwZXJcIj4gXG4gICAgPGRpdiBjbGFzcz1cImZsZXhXcmFwcGVyXCI+IFxuICAgICAgICA8cCBjbGFzcz1cInt7cmVkaXJlY3RUZXh0fX1cIj5SZWRpcmVjdGluZyAuLi48L3A+XG4gICAgICAgIDxkaXYgY2xhc3M9XCJsb2FkZXJcIj48L2Rpdj5cbiAgICA8L2Rpdj5cbjwvc2VjdGlvbj4iXX0=
@@ -0,0 +1,18 @@
1
+ import { NgModule } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import { AuthCallbackComponent } from './auth-callback.component';
4
+ import * as i0 from "@angular/core";
5
+ export class AuthCallbackModule {
6
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AuthCallbackModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
7
+ static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.13", ngImport: i0, type: AuthCallbackModule, declarations: [AuthCallbackComponent], imports: [CommonModule], exports: [AuthCallbackComponent] });
8
+ static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AuthCallbackModule, imports: [CommonModule] });
9
+ }
10
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AuthCallbackModule, decorators: [{
11
+ type: NgModule,
12
+ args: [{
13
+ declarations: [AuthCallbackComponent],
14
+ imports: [CommonModule],
15
+ exports: [AuthCallbackComponent]
16
+ }]
17
+ }] });
18
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0aC1jYWxsYmFjay5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy92ZXJiZW4tYXV0aGVudGljYXRpb24tdWkvc3JjL2xpYi9jb21wb25lbnRzL2F1dGgtY2FsbGJhY2svYXV0aC1jYWxsYmFjay5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sMkJBQTJCLENBQUM7O0FBT2xFLE1BQU0sT0FBTyxrQkFBa0I7d0dBQWxCLGtCQUFrQjt5R0FBbEIsa0JBQWtCLGlCQUpkLHFCQUFxQixhQUMxQixZQUFZLGFBQ1oscUJBQXFCO3lHQUVwQixrQkFBa0IsWUFIbkIsWUFBWTs7NEZBR1gsa0JBQWtCO2tCQUw5QixRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRSxDQUFDLHFCQUFxQixDQUFDO29CQUNyQyxPQUFPLEVBQUUsQ0FBQyxZQUFZLENBQUM7b0JBQ3ZCLE9BQU8sRUFBRSxDQUFDLHFCQUFxQixDQUFDO2lCQUNqQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgQXV0aENhbGxiYWNrQ29tcG9uZW50IH0gZnJvbSAnLi9hdXRoLWNhbGxiYWNrLmNvbXBvbmVudCc7XG5cbkBOZ01vZHVsZSh7XG4gIGRlY2xhcmF0aW9uczogW0F1dGhDYWxsYmFja0NvbXBvbmVudF0sXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGVdLFxuICBleHBvcnRzOiBbQXV0aENhbGxiYWNrQ29tcG9uZW50XVxufSlcbmV4cG9ydCBjbGFzcyBBdXRoQ2FsbGJhY2tNb2R1bGUge30iXX0=
@@ -1,79 +1,41 @@
1
1
  import { Component, EventEmitter, Input, Output } from '@angular/core';
2
2
  import { MechanismType } from '../../models/auth-mechanism';
3
- import { ErrorResponse } from '../../models/ErrorResponse';
4
3
  import * as i0 from "@angular/core";
5
4
  import * as i1 from "@angular/router";
6
5
  import * as i2 from "../../services/http-web-request.service";
7
6
  import * as i3 from "../../services/util.service";
8
- import * as i4 from "../../services/environment.service";
9
- import * as i5 from "@angular/common";
10
- import * as i6 from "verben-ng-ui";
7
+ import * as i4 from "@angular/common";
8
+ import * as i5 from "verben-ng-ui";
11
9
  export class OAuthComponent {
12
10
  route;
13
11
  server;
14
12
  utilService;
15
- envSvc;
16
- clientId = 'YOUR_CLIENT_ID_FROM_BACKEND';
13
+ router;
17
14
  showGoogle = false;
18
15
  showMicrosoft = false;
19
16
  showApple = false;
20
17
  authMechanisms = null;
21
- redirectUri = 'http://localhost:4200/documentation/login';
22
- apiKey;
23
18
  microsoftClick = new EventEmitter();
24
- onSubmitGoogleAuth = new EventEmitter();
25
19
  googleClick = new EventEmitter();
26
20
  appleClick = new EventEmitter();
27
- code = '';
28
- googleRedirectUrl = '';
29
- constructor(route, server, utilService, envSvc) {
21
+ page = '';
22
+ constructor(route, server, utilService, router) {
30
23
  this.route = route;
31
24
  this.server = server;
32
25
  this.utilService = utilService;
33
- this.envSvc = envSvc;
26
+ this.router = router;
34
27
  }
35
28
  ngOnInit() {
29
+ this.loadPage();
36
30
  this.loadGoogleScript();
37
- this.route.queryParams.subscribe(params => {
38
- this.code = params['code'];
39
- });
40
- if (this.code) {
41
- console.log('Code from URL:', this.code);
42
- this.verifyUserDetails();
43
- }
44
31
  if (this.authMechanisms !== null) {
45
- this.showMicrosoft = this.authMechanisms.some(item => item.AuthMechanism.includes(MechanismType.MicrosoftAD));
46
- this.showGoogle = this.authMechanisms.some(item => item.AuthMechanism.includes(MechanismType.Google));
47
- if (this.showGoogle) {
48
- const data = this.authMechanisms.find(item => item.AuthMechanism.includes(MechanismType.Google));
49
- this.clientId = data?.ClientId;
50
- this.googleRedirectUrl = data?.RedirectUri;
51
- }
52
- this.showApple = this.authMechanisms.some(item => item.AuthMechanism.includes(MechanismType.Apple));
32
+ this.authMechanisms = this.authMechanisms.filter((item) => item.AuthMechanism !== MechanismType.InApp);
53
33
  }
54
34
  }
55
- async verifyUserDetails() {
56
- if (this.authMechanisms !== null && this.apiKey) {
57
- const data = this.authMechanisms.find(item => item.AuthMechanism.includes(MechanismType.Google));
58
- const payload = {
59
- AuthCode: this.code,
60
- APIKey: this.apiKey,
61
- AuthMechanism: data.AuthMechanism
62
- };
63
- this.utilService.sendBI(true);
64
- const res = await this.server.post(`Authentication/GetUserDetails`, payload);
65
- this.utilService.sendBI(false);
66
- if (res instanceof ErrorResponse) {
67
- this.onSubmitGoogleAuth.emit(res);
68
- }
69
- else {
70
- var result = res;
71
- this.onSubmitGoogleAuth.emit(result);
72
- }
73
- }
35
+ loadPage() {
36
+ this.page = this.router.url;
74
37
  }
75
38
  loadGoogleScript() {
76
- console.log('checking here');
77
39
  if (!document.getElementById('google-jssdk')) {
78
40
  const script = document.createElement('script');
79
41
  script.src = 'https://accounts.google.com/gsi/client';
@@ -85,53 +47,63 @@ export class OAuthComponent {
85
47
  document.head.appendChild(script);
86
48
  }
87
49
  }
88
- oAuthWithMicrosoft() {
89
- this.microsoftClick.emit();
90
- }
91
- oAuthWithGoogle() {
92
- const redirectUri = encodeURIComponent(this.redirectUri);
50
+ oAuthWithGoogle(data) {
51
+ const redirectUri = encodeURIComponent(data.RedirectUri);
93
52
  const scope = encodeURIComponent('openid email profile');
94
53
  const responseType = 'code';
95
- const authUrl = `https://accounts.google.com/o/oauth2/v2/auth?client_id=${this.clientId}&redirect_uri=${redirectUri}&response_type=${responseType}&scope=${scope}`;
96
- window.location.href = authUrl; // Redirects the current window
97
- }
98
- exchangeCodeForToken(authCode) {
99
- console.log('Exchanging code for token:', authCode);
100
- // this.http.post('/api/auth/google/token', { code: authCode }).subscribe({
101
- // next: (response) => {
102
- // console.log('Token received:', response);
103
- // // Handle successful login (store token, etc.)
104
- // },
105
- // error: (err) => {
106
- // console.error('Error exchanging code for token:', err);
107
- // }
108
- // });
109
- }
110
- handleCredentialResponse(response) {
111
- console.log('Encoded JWT ID token:', response.credential);
54
+ const state = encodeURIComponent(JSON.stringify({ returnTo: this.page }));
55
+ const authUrl = `https://accounts.google.com/o/oauth2/v2/auth?client_id=${data.ClientId}&redirect_uri=${redirectUri}&response_type=${responseType}&scope=${scope}&state=${state}`;
56
+ window.location.href = authUrl;
112
57
  }
113
58
  oAuthWithApple() {
114
59
  this.appleClick.emit();
115
60
  }
116
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: OAuthComponent, deps: [{ token: i1.ActivatedRoute }, { token: i2.HttpWebRequestService }, { token: i3.UtilService }, { token: i4.EnvironmentService }], target: i0.ɵɵFactoryTarget.Component });
117
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: OAuthComponent, selector: "verben-o-auth", inputs: { authMechanisms: "authMechanisms", redirectUri: "redirectUri", apiKey: "apiKey" }, outputs: { microsoftClick: "microsoftClick", onSubmitGoogleAuth: "onSubmitGoogleAuth", googleClick: "googleClick", appleClick: "appleClick" }, ngImport: i0, template: "<section class=\"oauthWrapper\"> \n <div class=\"OrFlexWrapper\">\n <hr/>\n <span>OR</span>\n <hr/>\n </div>\n <span *ngIf=\"showMicrosoft\"> \n <verbena-button\n svg=\"microsoft-logo\"\n [svgHeight]=\"24\"\n [svgWidth]=\"24\"\n text=\"Continue with Microsoft\"\n bgColor=\"white\"\n textColor=\"black\"\n border=\"1px solid #333\"\n borderRadius=\"40px\"\n pd=\"10px 20px\"\n width=\"100%\"\n svgPosition=\"left\"\n buttonClass=\"font-normal text-[24px] leading-[29.05px] text-[#333] mt-2\"\n (click)=\"oAuthWithMicrosoft()\"\n ></verbena-button>\n </span> \n\n <span *ngIf=\"showGoogle\"> \n <verbena-button\n svg=\"google-logo\"\n [svgHeight]=\"24\"\n [svgWidth]=\"24\"\n text=\"Continue with Google\"\n bgColor=\"white\"\n textColor=\"black\"\n border=\"1px solid #333\"\n borderRadius=\"40px\"\n pd=\"10px 20px\"\n width=\"100%\"\n svgPosition=\"left\"\n buttonClass=\"font-normal text-[24px] leading-[29.05px] text-[#333] mt-2\"\n (click)=\"oAuthWithGoogle()\"\n ></verbena-button>\n\n <!-- <div id=\"g_id_onload\"\n data-client_id=\"834995866282-l8gkp0r3v3a1bdvfmaumurki7ndar3m4.apps.googleusercontent.com\"\n data-context=\"signin\"\n data-ux_mode=\"popup\"\n data-login_uri=\"http://localhost:5124/Authentication/ExternalCallback\"\n data-itp_support=\"true\">\n</div>\n\n<div class=\"g_id_signin\"\n data-type=\"standard\"\n data-shape=\"rectangular\"\n data-theme=\"outline\"\n data-text=\"signin_with\"\n data-size=\"large\"\n data-logo_alignment=\"center\">\n</div> -->\n </span>\n \n <span *ngIf=\"showApple\"> \n <verbena-button\n svg=\"apple-logo\"\n [svgHeight]=\"24\"\n [svgWidth]=\"24\"\n text=\"Continue with Apple\"\n bgColor=\"white\"\n textColor=\"black\"\n border=\"1px solid #333\"\n borderRadius=\"40px\"\n pd=\"10px 20px\"\n width=\"100%\"\n svgPosition=\"left\"\n buttonClass=\"font-normal text-[24px] leading-[29.05px] text-[#333] mt-2\"\n (click)=\"oAuthWithApple()\"\n ></verbena-button>\n </span>\n</section>\n", styles: ["hr{height:1px;margin:0;border:1px solid #66666640;flex:1}.OR{margin:0 2px;color:#666}.oauthWrapper{display:flex;flex-direction:column;gap:12px}.OrFlexWrapper{display:flex;align-items:center;gap:8px}\n"], dependencies: [{ kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i6.VerbenaButtonComponent, selector: "verbena-button", inputs: ["text", "icon", "svgPosition", "bgColor", "textColor", "border", "borderRadius", "pd", "width", "height", "fontSize", "fontWeight", "disable", "styleType", "svg", "svgWidth", "svgHeight", "svgColor", "buttonClass", "buttonTextClass", "isLoading", "spinnerSize", "spinnerColor"] }] });
61
+ oAuthWithMicrosoft() {
62
+ this.microsoftClick.emit();
63
+ }
64
+ checkForValue(value) {
65
+ switch (value) {
66
+ case MechanismType.Google:
67
+ return 'google-logo';
68
+ break;
69
+ case MechanismType.Apple:
70
+ return 'apple-logo';
71
+ break;
72
+ case MechanismType.MicrosoftAD:
73
+ return 'microsoft-logo';
74
+ break;
75
+ default:
76
+ return '';
77
+ }
78
+ }
79
+ handleOauthClick(value) {
80
+ switch (value.AuthMechanism) {
81
+ case MechanismType.Google:
82
+ return this.oAuthWithGoogle(value);
83
+ break;
84
+ case MechanismType.Apple:
85
+ return this.oAuthWithApple();
86
+ break;
87
+ case MechanismType.MicrosoftAD:
88
+ return this.oAuthWithMicrosoft();
89
+ break;
90
+ default:
91
+ return '';
92
+ }
93
+ }
94
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: OAuthComponent, deps: [{ token: i1.ActivatedRoute }, { token: i2.HttpWebRequestService }, { token: i3.UtilService }, { token: i1.Router }], target: i0.ɵɵFactoryTarget.Component });
95
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: OAuthComponent, selector: "verben-o-auth", inputs: { authMechanisms: "authMechanisms" }, outputs: { microsoftClick: "microsoftClick", googleClick: "googleClick", appleClick: "appleClick" }, ngImport: i0, template: "<section class=\"oauthWrapper\"> \n <div class=\"OrFlexWrapper\">\n <hr/>\n <span>OR</span>\n <hr/>\n </div>\n <div class=\"btnWrapper\">\n <div *ngFor=\"let btn of authMechanisms, let i = index\"> \n <verbena-button\n [svg]=\"checkForValue(btn.AuthMechanism)\"\n [svgHeight]=\"24\"\n [svgWidth]=\"24\"\n [text]=\"'Continue with ' + btn.AuthMechanism\"\n bgColor=\"white\"\n textColor=\"black\"\n border=\"1px solid #333\"\n borderRadius=\"40px\"\n pd=\"10px 20px\"\n width=\"100%\"\n svgPosition=\"left\"\n buttonClass=\"font-normal text-[24px] leading-[29.05px] text-[#333] mt-2\"\n (click)=\"handleOauthClick(btn)\"\n ></verbena-button>\n </div> \n </div> \n</section>\n", styles: ["hr{height:1px;margin:0;border:1px solid #66666640;flex:1}.OR{margin:0 2px;color:#666}.oauthWrapper{display:flex;flex-direction:column;gap:12px}.btnWrapper{display:flex;flex-direction:column;gap:10px}.OrFlexWrapper{display:flex;align-items:center;gap:8px}\n"], dependencies: [{ kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: i5.VerbenaButtonComponent, selector: "verbena-button", inputs: ["text", "icon", "svgPosition", "bgColor", "textColor", "border", "borderRadius", "pd", "width", "height", "fontSize", "fontWeight", "disable", "styleType", "svg", "svgWidth", "svgHeight", "svgColor", "buttonClass", "buttonTextClass", "isLoading", "spinnerSize", "spinnerColor"] }] });
118
96
  }
119
97
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: OAuthComponent, decorators: [{
120
98
  type: Component,
121
- args: [{ selector: 'verben-o-auth', template: "<section class=\"oauthWrapper\"> \n <div class=\"OrFlexWrapper\">\n <hr/>\n <span>OR</span>\n <hr/>\n </div>\n <span *ngIf=\"showMicrosoft\"> \n <verbena-button\n svg=\"microsoft-logo\"\n [svgHeight]=\"24\"\n [svgWidth]=\"24\"\n text=\"Continue with Microsoft\"\n bgColor=\"white\"\n textColor=\"black\"\n border=\"1px solid #333\"\n borderRadius=\"40px\"\n pd=\"10px 20px\"\n width=\"100%\"\n svgPosition=\"left\"\n buttonClass=\"font-normal text-[24px] leading-[29.05px] text-[#333] mt-2\"\n (click)=\"oAuthWithMicrosoft()\"\n ></verbena-button>\n </span> \n\n <span *ngIf=\"showGoogle\"> \n <verbena-button\n svg=\"google-logo\"\n [svgHeight]=\"24\"\n [svgWidth]=\"24\"\n text=\"Continue with Google\"\n bgColor=\"white\"\n textColor=\"black\"\n border=\"1px solid #333\"\n borderRadius=\"40px\"\n pd=\"10px 20px\"\n width=\"100%\"\n svgPosition=\"left\"\n buttonClass=\"font-normal text-[24px] leading-[29.05px] text-[#333] mt-2\"\n (click)=\"oAuthWithGoogle()\"\n ></verbena-button>\n\n <!-- <div id=\"g_id_onload\"\n data-client_id=\"834995866282-l8gkp0r3v3a1bdvfmaumurki7ndar3m4.apps.googleusercontent.com\"\n data-context=\"signin\"\n data-ux_mode=\"popup\"\n data-login_uri=\"http://localhost:5124/Authentication/ExternalCallback\"\n data-itp_support=\"true\">\n</div>\n\n<div class=\"g_id_signin\"\n data-type=\"standard\"\n data-shape=\"rectangular\"\n data-theme=\"outline\"\n data-text=\"signin_with\"\n data-size=\"large\"\n data-logo_alignment=\"center\">\n</div> -->\n </span>\n \n <span *ngIf=\"showApple\"> \n <verbena-button\n svg=\"apple-logo\"\n [svgHeight]=\"24\"\n [svgWidth]=\"24\"\n text=\"Continue with Apple\"\n bgColor=\"white\"\n textColor=\"black\"\n border=\"1px solid #333\"\n borderRadius=\"40px\"\n pd=\"10px 20px\"\n width=\"100%\"\n svgPosition=\"left\"\n buttonClass=\"font-normal text-[24px] leading-[29.05px] text-[#333] mt-2\"\n (click)=\"oAuthWithApple()\"\n ></verbena-button>\n </span>\n</section>\n", styles: ["hr{height:1px;margin:0;border:1px solid #66666640;flex:1}.OR{margin:0 2px;color:#666}.oauthWrapper{display:flex;flex-direction:column;gap:12px}.OrFlexWrapper{display:flex;align-items:center;gap:8px}\n"] }]
122
- }], ctorParameters: () => [{ type: i1.ActivatedRoute }, { type: i2.HttpWebRequestService }, { type: i3.UtilService }, { type: i4.EnvironmentService }], propDecorators: { authMechanisms: [{
123
- type: Input
124
- }], redirectUri: [{
125
- type: Input
126
- }], apiKey: [{
99
+ args: [{ selector: 'verben-o-auth', template: "<section class=\"oauthWrapper\"> \n <div class=\"OrFlexWrapper\">\n <hr/>\n <span>OR</span>\n <hr/>\n </div>\n <div class=\"btnWrapper\">\n <div *ngFor=\"let btn of authMechanisms, let i = index\"> \n <verbena-button\n [svg]=\"checkForValue(btn.AuthMechanism)\"\n [svgHeight]=\"24\"\n [svgWidth]=\"24\"\n [text]=\"'Continue with ' + btn.AuthMechanism\"\n bgColor=\"white\"\n textColor=\"black\"\n border=\"1px solid #333\"\n borderRadius=\"40px\"\n pd=\"10px 20px\"\n width=\"100%\"\n svgPosition=\"left\"\n buttonClass=\"font-normal text-[24px] leading-[29.05px] text-[#333] mt-2\"\n (click)=\"handleOauthClick(btn)\"\n ></verbena-button>\n </div> \n </div> \n</section>\n", styles: ["hr{height:1px;margin:0;border:1px solid #66666640;flex:1}.OR{margin:0 2px;color:#666}.oauthWrapper{display:flex;flex-direction:column;gap:12px}.btnWrapper{display:flex;flex-direction:column;gap:10px}.OrFlexWrapper{display:flex;align-items:center;gap:8px}\n"] }]
100
+ }], ctorParameters: () => [{ type: i1.ActivatedRoute }, { type: i2.HttpWebRequestService }, { type: i3.UtilService }, { type: i1.Router }], propDecorators: { authMechanisms: [{
127
101
  type: Input
128
102
  }], microsoftClick: [{
129
103
  type: Output
130
- }], onSubmitGoogleAuth: [{
131
- type: Output
132
104
  }], googleClick: [{
133
105
  type: Output
134
106
  }], appleClick: [{
135
107
  type: Output
136
108
  }] } });
137
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"o-auth.component.js","sourceRoot":"","sources":["../../../../../../projects/verben-authentication-ui/src/lib/components/o-auth/o-auth.component.ts","../../../../../../projects/verben-authentication-ui/src/lib/components/o-auth/o-auth.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { AuthMechanism, MechanismType } from '../../models/auth-mechanism';\nimport { ActivatedRoute } from '@angular/router';\nimport { HttpWebRequestService } from '../../services/http-web-request.service';\nimport { UtilService } from '../../services/util.service';\nimport { EnvironmentService } from '../../services/environment.service';\nimport { ErrorResponse } from '../../models/ErrorResponse';\nimport { ResponseKeyValue } from '../../models/ResponseKeyValue';\n\ndeclare global {\n    interface Window {\n    google: any;\n  }\n}\n\n@Component({\n  selector: 'verben-o-auth',\n  templateUrl: './o-auth.component.html',\n  styleUrl: './o-auth.component.css'\n})\nexport class OAuthComponent implements OnInit {\n  clientId: string = 'YOUR_CLIENT_ID_FROM_BACKEND';\n  showGoogle:boolean = false;\n  showMicrosoft:boolean = false;\n  showApple:boolean = false;\n  @Input() authMechanisms:AuthMechanism[] | null = null\n  @Input() redirectUri:string = 'http://localhost:4200/documentation/login'\n  @Input() apiKey?:string\n  @Output() microsoftClick = new EventEmitter<void>();\n  @Output() onSubmitGoogleAuth: EventEmitter<ResponseKeyValue | ErrorResponse> = new EventEmitter();\n  @Output() googleClick = new EventEmitter<void>();\n  @Output() appleClick = new EventEmitter<void>();\n  code:string = '';\n  googleRedirectUrl : string = ''\n  constructor(\n    private route: ActivatedRoute,\n    private server: HttpWebRequestService,\n    private utilService: UtilService,\n    private envSvc: EnvironmentService,\n  ){ \n  }\n\n  ngOnInit(): void {\n    this.loadGoogleScript(); \n    this.route.queryParams.subscribe(params => {\n      this.code = params['code'];\n    });\n     if(this.code){ \n      console.log('Code from URL:', this.code);\n      this.verifyUserDetails()\n     }\n       if(this.authMechanisms !== null ){ \n        this.showMicrosoft = this.authMechanisms.some(item =>\n           item.AuthMechanism.includes(MechanismType.MicrosoftAD)\n         );\n        this.showGoogle = this.authMechanisms.some(item =>\n           item.AuthMechanism.includes(MechanismType.Google)\n         );\n         if(this.showGoogle){ \n            const data:any = this.authMechanisms.find(item =>\n             item.AuthMechanism.includes(MechanismType.Google)\n           )\n           this.clientId = data?.ClientId;\n           this.googleRedirectUrl = data?.RedirectUri\n         }\n        this.showApple = this.authMechanisms.some(item =>\n           item.AuthMechanism.includes(MechanismType.Apple)\n         );\n     }\n  }\n  \n  async verifyUserDetails(){ \n    if(this.authMechanisms !== null && this.apiKey){ \n      const data:any = this.authMechanisms.find(item =>\n        item.AuthMechanism.includes(MechanismType.Google)\n      )\n      const payload = { \n        AuthCode:this.code,\n        APIKey:this.apiKey,\n        AuthMechanism:data.AuthMechanism\n      }\n\n      this.utilService.sendBI(true);\n      const res = await this.server.post(\n        `Authentication/GetUserDetails`,payload\n      );\n      this.utilService.sendBI(false);\n      if (res instanceof ErrorResponse) {\n        this.onSubmitGoogleAuth.emit(res);\n      } else {\n        var result = res as ResponseKeyValue;\n        this.onSubmitGoogleAuth.emit(result);\n      }\n    }\n\n   \n  }\n\n  loadGoogleScript(): void {\n    console.log('checking here');  \n    if (!document.getElementById('google-jssdk')) {\n      const script = document.createElement('script');\n      script.src = 'https://accounts.google.com/gsi/client';\n      script.id = 'google-jssdk';\n      script.async = true;\n      script.defer = true;\n      script.onload = () => console.log('Google SDK loaded');\n      script.onerror = () => console.log('Error loading Google SDK');\n      document.head.appendChild(script);\n    }\n  }\n\n  oAuthWithMicrosoft(){\n    this.microsoftClick.emit(); \n  }\n\noAuthWithGoogle() {\n  const redirectUri = encodeURIComponent(this.redirectUri);\n  const scope = encodeURIComponent('openid email profile');\n  const responseType = 'code';\n\n  const authUrl = `https://accounts.google.com/o/oauth2/v2/auth?client_id=${this.clientId}&redirect_uri=${redirectUri}&response_type=${responseType}&scope=${scope}`;\n\n  window.location.href = authUrl; // Redirects the current window\n}\n\nexchangeCodeForToken(authCode: string): void {\n  console.log('Exchanging code for token:', authCode);\n\n  // this.http.post('/api/auth/google/token', { code: authCode }).subscribe({\n  //     next: (response) => {\n  //         console.log('Token received:', response);\n  //         // Handle successful login (store token, etc.)\n  //     },\n  //     error: (err) => {\n  //         console.error('Error exchanging code for token:', err);\n  //     }\n  // });\n}\n\n\n  handleCredentialResponse(response: any): void {\n    console.log('Encoded JWT ID token:', response.credential)\n  }\n  oAuthWithApple(){\n    this.appleClick.emit(); \n  }\n\n}\n","<section class=\"oauthWrapper\"> \n    <div class=\"OrFlexWrapper\">\n        <hr/>\n        <span>OR</span>\n        <hr/>\n    </div>\n     <span *ngIf=\"showMicrosoft\"> \n       <verbena-button\n       svg=\"microsoft-logo\"\n       [svgHeight]=\"24\"\n       [svgWidth]=\"24\"\n       text=\"Continue with Microsoft\"\n       bgColor=\"white\"\n       textColor=\"black\"\n       border=\"1px solid #333\"\n       borderRadius=\"40px\"\n       pd=\"10px 20px\"\n       width=\"100%\"\n       svgPosition=\"left\"\n       buttonClass=\"font-normal text-[24px] leading-[29.05px] text-[#333] mt-2\"\n       (click)=\"oAuthWithMicrosoft()\"\n       ></verbena-button>\n     </span> \n\n    <span *ngIf=\"showGoogle\"> \n      <verbena-button\n      svg=\"google-logo\"\n      [svgHeight]=\"24\"\n      [svgWidth]=\"24\"\n      text=\"Continue with Google\"\n      bgColor=\"white\"\n      textColor=\"black\"\n      border=\"1px solid #333\"\n      borderRadius=\"40px\"\n      pd=\"10px 20px\"\n      width=\"100%\"\n      svgPosition=\"left\"\n      buttonClass=\"font-normal text-[24px] leading-[29.05px] text-[#333] mt-2\"\n      (click)=\"oAuthWithGoogle()\"\n      ></verbena-button>\n\n      <!-- <div id=\"g_id_onload\"\n     data-client_id=\"834995866282-l8gkp0r3v3a1bdvfmaumurki7ndar3m4.apps.googleusercontent.com\"\n     data-context=\"signin\"\n     data-ux_mode=\"popup\"\n     data-login_uri=\"http://localhost:5124/Authentication/ExternalCallback\"\n     data-itp_support=\"true\">\n</div>\n\n<div class=\"g_id_signin\"\n     data-type=\"standard\"\n     data-shape=\"rectangular\"\n     data-theme=\"outline\"\n     data-text=\"signin_with\"\n     data-size=\"large\"\n     data-logo_alignment=\"center\">\n</div> -->\n    </span>\n   \n    <span *ngIf=\"showApple\"> \n      <verbena-button\n      svg=\"apple-logo\"\n      [svgHeight]=\"24\"\n      [svgWidth]=\"24\"\n      text=\"Continue with Apple\"\n      bgColor=\"white\"\n      textColor=\"black\"\n      border=\"1px solid #333\"\n      borderRadius=\"40px\"\n      pd=\"10px 20px\"\n      width=\"100%\"\n      svgPosition=\"left\"\n      buttonClass=\"font-normal text-[24px] leading-[29.05px] text-[#333] mt-2\"\n      (click)=\"oAuthWithApple()\"\n      ></verbena-button>\n    </span>\n</section>\n"]}
109
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"o-auth.component.js","sourceRoot":"","sources":["../../../../../../projects/verben-authentication-ui/src/lib/components/o-auth/o-auth.component.ts","../../../../../../projects/verben-authentication-ui/src/lib/components/o-auth/o-auth.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { AuthMechanism, MechanismType } from '../../models/auth-mechanism';\nimport { ActivatedRoute, Router } from '@angular/router';\nimport { HttpWebRequestService } from '../../services/http-web-request.service';\nimport { UtilService } from '../../services/util.service';\n\ndeclare global {\n  interface Window {\n    google: any;\n  }\n}\n\n@Component({\n  selector: 'verben-o-auth',\n  templateUrl: './o-auth.component.html',\n  styleUrl: './o-auth.component.css',\n})\nexport class OAuthComponent implements OnInit {\n  showGoogle: boolean = false;\n  showMicrosoft: boolean = false;\n  showApple: boolean = false;\n  @Input() authMechanisms: AuthMechanism[] | null = null;\n  @Output() microsoftClick = new EventEmitter<void>();\n  @Output() googleClick = new EventEmitter<void>();\n  @Output() appleClick = new EventEmitter<void>();\n  page: string = '';\n\n  constructor(\n    private route: ActivatedRoute,\n    private server: HttpWebRequestService,\n    private utilService: UtilService,\n    private router: Router\n  ) {}\n\n  ngOnInit(): void {\n    this.loadPage();\n    this.loadGoogleScript();\n    if (this.authMechanisms !== null) {\n      this.authMechanisms = this.authMechanisms.filter(\n        (item) => item.AuthMechanism !== MechanismType.InApp\n      );\n    }\n  }\n\n  loadPage() {\n    this.page = this.router.url;\n  }\n\n  loadGoogleScript(): void {\n    if (!document.getElementById('google-jssdk')) {\n      const script = document.createElement('script');\n      script.src = 'https://accounts.google.com/gsi/client';\n      script.id = 'google-jssdk';\n      script.async = true;\n      script.defer = true;\n      script.onload = () => console.log('Google SDK loaded');\n      script.onerror = () => console.log('Error loading Google SDK');\n      document.head.appendChild(script);\n    }\n  }\n\n  oAuthWithGoogle(data: AuthMechanism) {\n    const redirectUri = encodeURIComponent(data.RedirectUri);\n    const scope = encodeURIComponent('openid email profile');\n    const responseType = 'code';\n    const state = encodeURIComponent(JSON.stringify({ returnTo: this.page }));\n    const authUrl = `https://accounts.google.com/o/oauth2/v2/auth?client_id=${data.ClientId}&redirect_uri=${redirectUri}&response_type=${responseType}&scope=${scope}&state=${state}`;\n    window.location.href = authUrl;\n  }\n\n  oAuthWithApple() {\n    this.appleClick.emit();\n  }\n\n  oAuthWithMicrosoft() {\n    this.microsoftClick.emit();\n  }\n\n  checkForValue(value: string) {\n    switch (value) {\n      case MechanismType.Google:\n        return 'google-logo';\n        break;\n      case MechanismType.Apple:\n        return 'apple-logo';\n        break;\n      case MechanismType.MicrosoftAD:\n        return 'microsoft-logo';\n        break;\n      default:\n        return '';\n    }\n  }\n\n  handleOauthClick(value: AuthMechanism) {\n    switch (value.AuthMechanism) {\n      case MechanismType.Google:\n        return this.oAuthWithGoogle(value);\n        break;\n      case MechanismType.Apple:\n        return this.oAuthWithApple();\n        break;\n      case MechanismType.MicrosoftAD:\n        return this.oAuthWithMicrosoft();\n        break;\n      default:\n        return '';\n    }\n  }\n}\n","<section class=\"oauthWrapper\"> \n    <div class=\"OrFlexWrapper\">\n        <hr/>\n        <span>OR</span>\n        <hr/>\n    </div>\n     <div class=\"btnWrapper\">\n      <div *ngFor=\"let btn of authMechanisms, let i = index\"> \n        <verbena-button\n        [svg]=\"checkForValue(btn.AuthMechanism)\"\n        [svgHeight]=\"24\"\n        [svgWidth]=\"24\"\n        [text]=\"'Continue with ' + btn.AuthMechanism\"\n        bgColor=\"white\"\n        textColor=\"black\"\n        border=\"1px solid #333\"\n        borderRadius=\"40px\"\n        pd=\"10px 20px\"\n        width=\"100%\"\n        svgPosition=\"left\"\n        buttonClass=\"font-normal text-[24px] leading-[29.05px] text-[#333] mt-2\"\n        (click)=\"handleOauthClick(btn)\"\n        ></verbena-button>\n      </div> \n     </div> \n</section>\n"]}