verben-authentication-ui 0.7.5 → 0.7.6
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.
- package/esm2022/lib/components/auth-callback/auth-callback.component.mjs +5 -3
- package/esm2022/lib/components/o-auth/o-auth.component.mjs +4 -4
- package/esm2022/lib/components/user-management/user-management.component.mjs +39 -13
- package/esm2022/lib/services/http-web-request.service.mjs +2 -2
- package/fesm2022/verben-authentication-ui.mjs +62 -35
- package/fesm2022/verben-authentication-ui.mjs.map +1 -1
- package/lib/components/o-auth/o-auth.component.d.ts +1 -1
- package/lib/components/user-management/user-management.component.d.ts +7 -1
- package/package.json +1 -1
|
@@ -26,11 +26,13 @@ export class AuthCallbackComponent {
|
|
|
26
26
|
const params = new URLSearchParams(window.location.search);
|
|
27
27
|
const code = params.get('code');
|
|
28
28
|
const stateParam = params.get('state');
|
|
29
|
-
|
|
29
|
+
console.log({ code: code, state: stateParam }, 'data');
|
|
30
30
|
if (code && stateParam) {
|
|
31
31
|
try {
|
|
32
32
|
const state = JSON.parse(decodeURIComponent(stateParam));
|
|
33
|
-
const returnTo = state.returnTo || '/';
|
|
33
|
+
// const returnTo = state.returnTo || '/';
|
|
34
|
+
const splitStateArray = state.returnTo.split('?');
|
|
35
|
+
const returnTo = splitStateArray.length > 0 ? splitStateArray[0] : state.returnTo;
|
|
34
36
|
const queryParams = { code };
|
|
35
37
|
if (this.type) {
|
|
36
38
|
queryParams.type = this.type;
|
|
@@ -52,4 +54,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
52
54
|
}], ctorParameters: () => [{ type: i1.Router }, { type: i1.ActivatedRoute }], propDecorators: { redirectText: [{
|
|
53
55
|
type: Input
|
|
54
56
|
}] } });
|
|
55
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
57
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0aC1jYWxsYmFjay5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy92ZXJiZW4tYXV0aGVudGljYXRpb24tdWkvc3JjL2xpYi9jb21wb25lbnRzL2F1dGgtY2FsbGJhY2svYXV0aC1jYWxsYmFjay5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy92ZXJiZW4tYXV0aGVudGljYXRpb24tdWkvc3JjL2xpYi9jb21wb25lbnRzL2F1dGgtY2FsbGJhY2svYXV0aC1jYWxsYmFjay5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBVSxNQUFNLGVBQWUsQ0FBQzs7O0FBUXpELE1BQU0sT0FBTyxxQkFBcUI7SUFNWjtJQUNWO0lBTlYsSUFBSSxHQUFXLEVBQUUsQ0FBQztJQUNsQixXQUFXLEdBQVcsRUFBRSxDQUFDO0lBQ3pCLElBQUksR0FBVyxFQUFFLENBQUM7SUFDVCxZQUFZLENBQVM7SUFFOUIsWUFBb0IsTUFBYyxFQUN4QixLQUFxQjtRQURYLFdBQU0sR0FBTixNQUFNLENBQVE7UUFDeEIsVUFBSyxHQUFMLEtBQUssQ0FBZ0I7SUFDNUIsQ0FBQztJQUVKLFFBQVE7UUFDTixJQUFJLENBQUMsT0FBTyxFQUFFLENBQUE7UUFDZCxJQUFJLENBQUMsY0FBYyxFQUFFLENBQUM7SUFDeEIsQ0FBQztJQUVELE9BQU87UUFDUCxNQUFNLElBQUksR0FBRyxZQUFZLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQyxDQUFBO1FBQ3pDLElBQUcsSUFBSSxFQUFDLENBQUM7WUFDUCxJQUFJLENBQUMsSUFBSSxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUE7UUFDOUIsQ0FBQztJQUNELENBQUM7SUFDRCxjQUFjO1FBQ1osTUFBTSxNQUFNLEdBQUcsSUFBSSxlQUFlLENBQUMsTUFBTSxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUMzRCxNQUFNLElBQUksR0FBRyxNQUFNLENBQUMsR0FBRyxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQ2hDLE1BQU0sVUFBVSxHQUFHLE1BQU0sQ0FBQyxHQUFHLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDekMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxFQUFDLElBQUksRUFBQyxJQUFJLEVBQUUsS0FBSyxFQUFDLFVBQVUsRUFBQyxFQUFFLE1BQU0sQ0FBQyxDQUFDO1FBR2pELElBQUksSUFBSSxJQUFJLFVBQVUsRUFBRSxDQUFDO1lBQ3ZCLElBQUksQ0FBQztnQkFDSCxNQUFNLEtBQUssR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLGtCQUFrQixDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUM7Z0JBQ3pELDBDQUEwQztnQkFDMUMsTUFBTSxlQUFlLEdBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUM7Z0JBQ2hELE1BQU0sUUFBUSxHQUFHLGVBQWUsQ0FBQyxNQUFNLEdBQUMsQ0FBQyxDQUFBLENBQUMsQ0FBQSxlQUFlLENBQUMsQ0FBQyxDQUFDLENBQUEsQ0FBQyxDQUFBLEtBQUssQ0FBQyxRQUFRLENBQUM7Z0JBQzVFLE1BQU0sV0FBVyxHQUFRLEVBQUUsSUFBSSxFQUFFLENBQUM7Z0JBQ3BDLElBQUksSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDO29CQUNkLFdBQVcsQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQztnQkFDL0IsQ0FBQztnQkFFRCxJQUFJLENBQUMsTUFBTSxDQUFDLFFBQVEsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxFQUFFLEVBQUUsV0FBVyxFQUFFLENBQUMsQ0FBQztnQkFDaEQsK0RBQStEO1lBQ2pFLENBQUM7WUFBQyxPQUFPLENBQUMsRUFBRSxDQUFDO2dCQUNaLE1BQU0sR0FBRyxHQUFHLENBQUMsQ0FBQTtZQUNkLENBQUM7UUFDSCxDQUFDO0lBQ0gsQ0FBQzt3R0E3Q1UscUJBQXFCOzRGQUFyQixxQkFBcUIsc0dDUmxDLHlMQUtVOzs0RkRHRyxxQkFBcUI7a0JBTGpDLFNBQVM7K0JBQ0Usc0JBQXNCO3dHQVF2QixZQUFZO3NCQUFwQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBBY3RpdmF0ZWRSb3V0ZSwgUm91dGVyIH0gZnJvbSAnQGFuZ3VsYXIvcm91dGVyJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAndmVyYmVuLWF1dGgtY2FsbGJhY2snLFxuICB0ZW1wbGF0ZVVybDogJy4vYXV0aC1jYWxsYmFjay5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsOiAnLi9hdXRoLWNhbGxiYWNrLmNvbXBvbmVudC5jc3MnXG59KVxuZXhwb3J0IGNsYXNzIEF1dGhDYWxsYmFja0NvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gIGNvZGU6IHN0cmluZyA9ICcnO1xuICBwcmV2aW91c1VybDogc3RyaW5nID0gJyc7XG4gIHR5cGU6IHN0cmluZyA9ICcnO1xuICBASW5wdXQoKSByZWRpcmVjdFRleHQ/OnN0cmluZztcbiAgXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgcm91dGVyOiBSb3V0ZXIsXG4gICAgcHJpdmF0ZSByb3V0ZTogQWN0aXZhdGVkUm91dGVcbiAgKSB7fVxuXG4gIG5nT25Jbml0KCkge1xuICAgIHRoaXMuZ2V0VHlwZSgpXG4gICAgdGhpcy5oYW5kbGVSZWRpcmVjdCgpO1xuICB9XG4gXG4gIGdldFR5cGUoKXsgXG4gIGNvbnN0IGRhdGEgPSBsb2NhbFN0b3JhZ2UuZ2V0SXRlbSgndHlwZScpXG4gIGlmKGRhdGEpeyBcbiAgICB0aGlzLnR5cGUgPSBKU09OLnBhcnNlKGRhdGEpXG4gIH1cbiAgfVxuICBoYW5kbGVSZWRpcmVjdCgpIHtcbiAgICBjb25zdCBwYXJhbXMgPSBuZXcgVVJMU2VhcmNoUGFyYW1zKHdpbmRvdy5sb2NhdGlvbi5zZWFyY2gpO1xuICAgIGNvbnN0IGNvZGUgPSBwYXJhbXMuZ2V0KCdjb2RlJyk7XG4gICAgY29uc3Qgc3RhdGVQYXJhbSA9IHBhcmFtcy5nZXQoJ3N0YXRlJyk7XG4gIGNvbnNvbGUubG9nKHtjb2RlOmNvZGUsIHN0YXRlOnN0YXRlUGFyYW19LCAnZGF0YScpO1xuICBcblxuICAgIGlmIChjb2RlICYmIHN0YXRlUGFyYW0pIHtcbiAgICAgIHRyeSB7XG4gICAgICAgIGNvbnN0IHN0YXRlID0gSlNPTi5wYXJzZShkZWNvZGVVUklDb21wb25lbnQoc3RhdGVQYXJhbSkpO1xuICAgICAgICAvLyBjb25zdCByZXR1cm5UbyA9IHN0YXRlLnJldHVyblRvIHx8ICcvJztcbiAgICAgICAgY29uc3Qgc3BsaXRTdGF0ZUFycmF5PXN0YXRlLnJldHVyblRvLnNwbGl0KCc/Jyk7XG4gICAgICAgIGNvbnN0IHJldHVyblRvID0gc3BsaXRTdGF0ZUFycmF5Lmxlbmd0aD4wP3NwbGl0U3RhdGVBcnJheVswXTpzdGF0ZS5yZXR1cm5UbztcbiAgICAgICAgY29uc3QgcXVlcnlQYXJhbXM6IGFueSA9IHsgY29kZSB9O1xuICAgICAgaWYgKHRoaXMudHlwZSkge1xuICAgICAgICBxdWVyeVBhcmFtcy50eXBlID0gdGhpcy50eXBlO1xuICAgICAgfVxuXG4gICAgICB0aGlzLnJvdXRlci5uYXZpZ2F0ZShbcmV0dXJuVG9dLCB7IHF1ZXJ5UGFyYW1zIH0pO1xuICAgICAgICAvLyB0aGlzLnJvdXRlci5uYXZpZ2F0ZShbcmV0dXJuVG9dLCB7IHF1ZXJ5UGFyYW1zOiB7IGNvZGUgfSB9KTtcbiAgICAgIH0gY2F0Y2ggKGUpIHtcbiAgICAgICBjb25zdCBtc2cgPSBlXG4gICAgICB9XG4gICAgfVxuICB9XG4gIFxufVxuIiwiPHNlY3Rpb24gY2xhc3M9XCJ3cmFwcGVyXCI+IFxuICAgIDxkaXYgY2xhc3M9XCJmbGV4V3JhcHBlclwiPiBcbiAgICAgICAgPHAgY2xhc3M9XCJ7e3JlZGlyZWN0VGV4dH19XCI+UmVkaXJlY3RpbmcgLi4uPC9wPlxuICAgICAgICA8ZGl2IGNsYXNzPVwibG9hZGVyXCI+PC9kaXY+XG4gICAgPC9kaXY+XG48L3NlY3Rpb24+Il19
|
|
@@ -48,11 +48,11 @@ export class OAuthComponent {
|
|
|
48
48
|
const authUrl = `https://accounts.google.com/o/oauth2/v2/auth?client_id=${data.ClientId}&redirect_uri=${redirectUri}&response_type=${responseType}&scope=${scope}&state=${state}`;
|
|
49
49
|
window.location.href = authUrl;
|
|
50
50
|
}
|
|
51
|
-
oAuthWithApple() {
|
|
52
|
-
}
|
|
51
|
+
oAuthWithApple() { }
|
|
53
52
|
oAuthWithMicrosoft(data) {
|
|
54
53
|
this.type = data.AuthMechanism;
|
|
55
|
-
;
|
|
54
|
+
const cleanUrl = window.location.href.split('?')[0];
|
|
55
|
+
window.history.replaceState({}, document.title, cleanUrl); // Update the URL without reloading
|
|
56
56
|
localStorage.setItem('type', JSON.stringify(this.type));
|
|
57
57
|
const redirectUri = encodeURIComponent(data.RedirectUri);
|
|
58
58
|
const scope = encodeURIComponent('openid email profile');
|
|
@@ -104,4 +104,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
104
104
|
}], emitMechanismFn: [{
|
|
105
105
|
type: Output
|
|
106
106
|
}] } });
|
|
107
|
-
//# 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":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAU,MAAM,EAAE,MAAM,eAAe,CAAC;AAC/E,OAAO,EAAiB,aAAa,EAAE,MAAM,6BAA6B,CAAC;;;;;AAgB3E,MAAM,OAAO,cAAc;IAUf;IATV,UAAU,GAAY,KAAK,CAAC;IAC5B,aAAa,GAAY,KAAK,CAAC;IAC/B,SAAS,GAAY,KAAK,CAAC;IAClB,cAAc,GAA2B,IAAI,CAAC;IAC7C,eAAe,GAAG,IAAI,YAAY,EAAU,CAAC;IACvD,IAAI,GAAW,EAAE,CAAC;IAClB,IAAI,GAAU,EAAE,CAAA;IAEhB,YACU,MAAc;QAAd,WAAM,GAAN,MAAM,CAAQ;IACrB,CAAC;IAEJ,QAAQ;QACN,IAAI,CAAC,QAAQ,EAAE,CAAC;QAChB,IAAI,CAAC,gBAAgB,EAAE,CAAC;QACxB,IAAI,IAAI,CAAC,cAAc,KAAK,IAAI,EAAE,CAAC;YACjC,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,cAAc,CAAC,MAAM,CAC9C,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,aAAa,KAAK,aAAa,CAAC,KAAK,CACrD,CAAC;QACJ,CAAC;IACH,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC;IAC9B,CAAC;IAED,gBAAgB;QACd,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,cAAc,CAAC,EAAE,CAAC;YAC7C,MAAM,MAAM,GAAG,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;YAChD,MAAM,CAAC,GAAG,GAAG,wCAAwC,CAAC;YACtD,MAAM,CAAC,EAAE,GAAG,cAAc,CAAC;YAC3B,MAAM,CAAC,KAAK,GAAG,IAAI,CAAC;YACpB,MAAM,CAAC,KAAK,GAAG,IAAI,CAAC;YACpB,MAAM,CAAC,MAAM,GAAG,GAAG,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,mBAAmB,CAAC,CAAC;YACvD,MAAM,CAAC,OAAO,GAAG,GAAG,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,0BAA0B,CAAC,CAAC;YAC/D,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;QACpC,CAAC;IACH,CAAC;IAED,eAAe,CAAC,IAAmB;QACjC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,aAAa,CAAC;QAC/B,YAAY,CAAC,OAAO,CAAC,MAAM,EAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAA;QACtD,MAAM,WAAW,GAAG,kBAAkB,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QACzD,MAAM,KAAK,GAAG,kBAAkB,CAAC,sBAAsB,CAAC,CAAC;QACzD,MAAM,YAAY,GAAG,MAAM,CAAC;QAC5B,MAAM,KAAK,GAAG,kBAAkB,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,QAAQ,EAAE,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;QAC1E,MAAM,OAAO,GAAG,0DAA0D,IAAI,CAAC,QAAQ,iBAAiB,WAAW,kBAAkB,YAAY,UAAU,KAAK,UAAU,KAAK,EAAE,CAAC;QAClL,MAAM,CAAC,QAAQ,CAAC,IAAI,GAAG,OAAO,CAAC;IACjC,CAAC;IAED,cAAc;IACd,CAAC;IAED,kBAAkB,CAAC,IAAmB;QACpC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,aAAa,CAAC;QAAA,CAAC;QAChC,YAAY,CAAC,OAAO,CAAC,MAAM,EAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAA;QACtD,MAAM,WAAW,GAAG,kBAAkB,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QACzD,MAAM,KAAK,GAAG,kBAAkB,CAAC,sBAAsB,CAAC,CAAC;QACzD,MAAM,YAAY,GAAG,MAAM,CAAC;QAC5B,MAAM,KAAK,GAAG,kBAAkB,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,QAAQ,EAAE,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;QAC1E,sNAAsN;QACtN,MAAM,OAAO,GAAG;aACP,IAAI,CAAC,QAAQ;iBACT,YAAY;gBACb,WAAW,UAAU,KAAK;6BACb,KAAK,EAAE,CAAC;QACjC,MAAM,CAAC,QAAQ,CAAC,IAAI,GAAG,OAAO,CAAC;IACjC,CAAC;IAED,aAAa,CAAC,KAAa;QACzB,QAAQ,KAAK,EAAE,CAAC;YACd,KAAK,aAAa,CAAC,MAAM;gBACvB,OAAO,aAAa,CAAC;YACvB,KAAK,aAAa,CAAC,KAAK;gBACtB,OAAO,YAAY,CAAC;YACtB,KAAK,aAAa,CAAC,WAAW;gBAC5B,OAAO,gBAAgB,CAAC;YAC1B;gBACE,OAAO,EAAE,CAAC;QACd,CAAC;IACH,CAAC;IAED,gBAAgB,CAAC,KAAoB;QACnC,QAAQ,KAAK,CAAC,aAAa,EAAE,CAAC;YAC5B,KAAK,aAAa,CAAC,MAAM;gBACvB,OAAO,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC;gBACnC,MAAM;YACR,KAAK,aAAa,CAAC,KAAK;gBACtB,OAAO,IAAI,CAAC,cAAc,EAAE,CAAC;gBAC7B,MAAM;YACR,KAAK,aAAa,CAAC,WAAW;gBAC5B,OAAO,IAAI,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC;gBACtC,MAAM;YACR;gBACE,OAAO,EAAE,CAAC;QACd,CAAC;IACH,CAAC;wGAjGU,cAAc;4FAAd,cAAc,oJCjB3B,yzBA0BA;;4FDTa,cAAc;kBAL1B,SAAS;+BACE,eAAe;2EAQhB,cAAc;sBAAtB,KAAK;gBACI,eAAe;sBAAxB,MAAM","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() emitMechanismFn = new EventEmitter<string>();\n  page: string = '';\n  type:string = ''\n\n  constructor(\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    this.type = data.AuthMechanism;\n    localStorage.setItem('type',JSON.stringify(this.type))\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  }\n\n  oAuthWithMicrosoft(data: AuthMechanism) {\n    this.type = data.AuthMechanism;;\n    localStorage.setItem('type',JSON.stringify(this.type))\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://login.microsoftonline.com/${data.TenantId}/oauth2/v2.0/authorize?client_id=${data.ClientId}&response_type=${responseType}&redirect_uri=${redirectUri}&response_mode=query&state=${state}`;\n    const authUrl = `https://login.microsoftonline.com/common/oauth2/v2.0/authorize\n?client_id=${data.ClientId}\n&response_type=${responseType}\n&redirect_uri=${redirectUri}&scope=${scope}\n&response_mode=query&state=${state}`;\n    window.location.href = authUrl;\n  }\n\n  checkForValue(value: string) {\n    switch (value) {\n      case MechanismType.Google:\n        return 'google-logo';\n      case MechanismType.Apple:\n        return 'apple-logo';\n      case MechanismType.MicrosoftAD:\n        return 'microsoft-logo';\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(value);\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"]}
|
|
107
|
+
//# 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() emitMechanismFn = new EventEmitter<string>();\n  page: string = '';\n  type: string = '';\n\n  constructor(private router: Router) {}\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    this.type = data.AuthMechanism;\n    localStorage.setItem('type', JSON.stringify(this.type));\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\n  oAuthWithMicrosoft(data: AuthMechanism) {\n    this.type = data.AuthMechanism;\n    const cleanUrl = window.location.href.split('?')[0];\n    window.history.replaceState({}, document.title, cleanUrl);  // Update the URL without reloading\n    localStorage.setItem('type', JSON.stringify(this.type));\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://login.microsoftonline.com/${data.TenantId}/oauth2/v2.0/authorize?client_id=${data.ClientId}&response_type=${responseType}&redirect_uri=${redirectUri}&response_mode=query&state=${state}`;\n    const authUrl = `https://login.microsoftonline.com/common/oauth2/v2.0/authorize\n?client_id=${data.ClientId}\n&response_type=${responseType}\n&redirect_uri=${redirectUri}&scope=${scope}\n&response_mode=query&state=${state}`;\n    window.location.href = authUrl;\n  }\n\n  checkForValue(value: string) {\n    switch (value) {\n      case MechanismType.Google:\n        return 'google-logo';\n      case MechanismType.Apple:\n        return 'apple-logo';\n      case MechanismType.MicrosoftAD:\n        return 'microsoft-logo';\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(value);\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"]}
|