@sambath999/localize-token 12.4.12 → 12.4.13
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/bundles/sambath999-localize-token.umd.js +44 -138
- package/bundles/sambath999-localize-token.umd.js.map +1 -1
- package/components/localize-token-login-dialog.component.d.ts +7 -19
- package/esm2015/components/localize-token-login-dialog.component.js +29 -108
- package/esm2015/models/localize-token-models.js +1 -1
- package/fesm2015/sambath999-localize-token.js +28 -107
- package/fesm2015/sambath999-localize-token.js.map +1 -1
- package/models/localize-token-models.d.ts +1 -1
- package/package.json +2 -2
- package/sambath999-localize-token.metadata.json +1 -1
|
@@ -1,67 +1,46 @@
|
|
|
1
1
|
import { __awaiter } from "tslib";
|
|
2
|
-
import { HttpClient } from "@angular/common/http";
|
|
3
2
|
import { ChangeDetectorRef, Component, Injector, ViewEncapsulation, } from "@angular/core";
|
|
4
3
|
import { MessageService } from "primeng/api";
|
|
5
4
|
import { DynamicDialogConfig, DynamicDialogRef } from "primeng/dynamicdialog";
|
|
6
5
|
import { DomSanitizer } from "@angular/platform-browser";
|
|
7
|
-
import {
|
|
8
|
-
var ELoginState;
|
|
9
|
-
(function (ELoginState) {
|
|
10
|
-
ELoginState[ELoginState["Requesting"] = 0] = "Requesting";
|
|
11
|
-
ELoginState[ELoginState["Success"] = 1] = "Success";
|
|
12
|
-
ELoginState[ELoginState["Error"] = 2] = "Error";
|
|
13
|
-
})(ELoginState || (ELoginState = {}));
|
|
6
|
+
import { LocalizeApiLoginService, waitFor } from "@sambath999/localize-api";
|
|
14
7
|
export class LocalizeTokenLoginDialogComponent {
|
|
15
|
-
constructor(messageService, cdt, dlgRef, dlgConfig,
|
|
8
|
+
constructor(messageService, cdt, dlgRef, dlgConfig, sanitizer, injector) {
|
|
16
9
|
this.messageService = messageService;
|
|
17
10
|
this.cdt = cdt;
|
|
18
11
|
this.dlgRef = dlgRef;
|
|
19
12
|
this.dlgConfig = dlgConfig;
|
|
20
|
-
this.httpClient = httpClient;
|
|
21
13
|
this.sanitizer = sanitizer;
|
|
22
14
|
this.injector = injector;
|
|
23
15
|
this.messageKey = "$login-dlg";
|
|
24
|
-
this.loading = false;
|
|
25
|
-
this.success = false;
|
|
26
|
-
this.loginBroadcastChannel = "bc-localize-login";
|
|
27
|
-
this.sourceId = `${Date.now()}-${Math.random().toString(36).slice(2)}`;
|
|
28
|
-
this.clickLogout = () => { var _a; return (_a = this.logout) === null || _a === void 0 ? void 0 : _a.call(this); };
|
|
29
|
-
this.tokenService = this.injector.get(LocalizeApiTokenService);
|
|
30
|
-
this.broadcastService = this.injector.get(LocalizeApiBroadcastService);
|
|
31
|
-
this.apiService = this.injector.get(LocalizeApiService);
|
|
32
|
-
this.decodeToken = this.tokenService.decodeRefreshToken;
|
|
33
16
|
this.loginConfig = this.dlgConfig.data.loginConfig;
|
|
17
|
+
this.apiLoginService = this.injector.get(LocalizeApiLoginService);
|
|
34
18
|
this.properties = this.loginConfig.properties;
|
|
35
|
-
this.
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
console.warn('Ignoring login state message with invalid payload or from same source', payload);
|
|
39
|
-
return;
|
|
40
|
-
}
|
|
41
|
-
switch (payload.state) {
|
|
42
|
-
case ELoginState.Requesting:
|
|
43
|
-
this.loading = true;
|
|
44
|
-
this.success = false;
|
|
45
|
-
break;
|
|
46
|
-
case ELoginState.Success:
|
|
47
|
-
this.apiService.clearRequiredLoginStateAfterLogin();
|
|
48
|
-
this.loginSuccess();
|
|
49
|
-
break;
|
|
50
|
-
case ELoginState.Error:
|
|
51
|
-
this.showMessage("error", (_a = payload.message) !== null && _a !== void 0 ? _a : "Login failed");
|
|
52
|
-
break;
|
|
53
|
-
}
|
|
54
|
-
});
|
|
19
|
+
this.decodeToken = this.apiLoginService.decodedToken;
|
|
20
|
+
this.logout = this.loginConfig.logoutFunc;
|
|
21
|
+
this.configure();
|
|
55
22
|
}
|
|
56
|
-
get
|
|
57
|
-
|
|
23
|
+
get loading() { return this.apiLoginService.isLoading; }
|
|
24
|
+
get success() { return this.apiLoginService.isSuccess; }
|
|
25
|
+
configure() {
|
|
26
|
+
var _a, _b;
|
|
58
27
|
this.dlgConfig.closable = false;
|
|
59
28
|
this.dlgConfig.dismissableMask = false;
|
|
60
29
|
this.dlgConfig.modal = true;
|
|
61
|
-
this.
|
|
62
|
-
|
|
30
|
+
this.apiLoginService.configure({
|
|
31
|
+
loginUrl: this.loginConfig.loginUrl,
|
|
32
|
+
onSuccess: this.loginSuccess.bind(this),
|
|
33
|
+
onFailure: (msg) => this.showMessage("error", msg),
|
|
34
|
+
onError: (msg) => this.showMessage("error", msg),
|
|
35
|
+
loginFunction: this.loginConfig.loginFunction,
|
|
36
|
+
refreshTokenTtl: this.loginConfig.expire,
|
|
37
|
+
passwordResolver: () => this.password,
|
|
38
|
+
passwordValidator: (_b = (_a = this.loginConfig.properties) === null || _a === void 0 ? void 0 : _a.passwordValidator) === null || _b === void 0 ? void 0 : _b.bind(this),
|
|
39
|
+
});
|
|
40
|
+
}
|
|
41
|
+
ngOnInit() {
|
|
63
42
|
if (!this.decodeToken) {
|
|
64
|
-
this.showMessage("error", "Token
|
|
43
|
+
this.showMessage("error", "Invalid Token. Please login again.");
|
|
65
44
|
setTimeout(() => { var _a; return (_a = this.logout) === null || _a === void 0 ? void 0 : _a.call(this); }, 2000);
|
|
66
45
|
}
|
|
67
46
|
}
|
|
@@ -70,85 +49,28 @@ export class LocalizeTokenLoginDialogComponent {
|
|
|
70
49
|
}
|
|
71
50
|
loginSuccess() {
|
|
72
51
|
return __awaiter(this, void 0, void 0, function* () {
|
|
73
|
-
this.success = true;
|
|
74
52
|
yield waitFor(2000);
|
|
75
53
|
this.dlgRef.close(true);
|
|
76
54
|
});
|
|
77
55
|
}
|
|
78
56
|
clickLogin() {
|
|
79
|
-
var _a, _b, _c;
|
|
80
57
|
return __awaiter(this, void 0, void 0, function* () {
|
|
81
|
-
|
|
82
|
-
return this.showMessage("error", "Password is required and must be at least 6 characters");
|
|
83
|
-
}
|
|
84
|
-
this.publishLoginState(ELoginState.Requesting);
|
|
85
|
-
yield waitFor(300);
|
|
86
|
-
this.loading = true;
|
|
87
|
-
const loginRes = yield this.login();
|
|
88
|
-
if (!(loginRes === null || loginRes === void 0 ? void 0 : loginRes.status)) {
|
|
89
|
-
const message = (_a = loginRes === null || loginRes === void 0 ? void 0 : loginRes.message) !== null && _a !== void 0 ? _a : "An error occurred";
|
|
90
|
-
this.publishLoginState(ELoginState.Error, message);
|
|
91
|
-
return this.showMessage("error", message);
|
|
92
|
-
}
|
|
93
|
-
this.tokenService.accessToken = loginRes.tokens.accessToken;
|
|
94
|
-
const cookieOptions = { expires: (_b = this.loginConfig.expire) !== null && _b !== void 0 ? _b : 365 };
|
|
95
|
-
LocalizeApiToken.storage.set(((_c = this.config.refreshToken) === null || _c === void 0 ? void 0 : _c.name) || '', loginRes.tokens.refreshToken, cookieOptions);
|
|
96
|
-
this.apiService.clearRequiredLoginStateAfterLogin();
|
|
97
|
-
this.publishLoginState(ELoginState.Success);
|
|
98
|
-
this.loginSuccess();
|
|
58
|
+
yield this.apiLoginService.clickLogin();
|
|
99
59
|
});
|
|
100
60
|
}
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
sourceId: this.sourceId,
|
|
105
|
-
message,
|
|
106
|
-
});
|
|
107
|
-
}
|
|
108
|
-
login() {
|
|
109
|
-
var _a, _b, _c;
|
|
110
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
111
|
-
if (!((_a = this.loginUrl) === null || _a === void 0 ? void 0 : _a.trim().length)) {
|
|
112
|
-
this.showMessage("error", "Login url is required");
|
|
113
|
-
throw new Error("Login url is required");
|
|
114
|
-
}
|
|
115
|
-
try {
|
|
116
|
-
if (this.loginConfig.loginFunction) {
|
|
117
|
-
console.log("Using custom login function");
|
|
118
|
-
return yield this.loginConfig.loginFunction((_c = (_b = this.decodeToken) === null || _b === void 0 ? void 0 : _b.email) !== null && _c !== void 0 ? _c : '', this.password.trim(), this.getHeaders());
|
|
119
|
-
}
|
|
120
|
-
return yield new Promise((resolve, reject) => this.httpClient.post(this.loginUrl, { password: this.password.trim() }, { headers: this.getHeaders() }).subscribe({ next: resolve, error: reject }));
|
|
121
|
-
}
|
|
122
|
-
catch (e) {
|
|
123
|
-
this.showMessage("error", e.message);
|
|
124
|
-
return null;
|
|
125
|
-
}
|
|
126
|
-
});
|
|
127
|
-
}
|
|
128
|
-
getHeaders() {
|
|
129
|
-
var _a, _b;
|
|
130
|
-
return {
|
|
131
|
-
[LocalizeApiToken.httpHeaders.X_REFRESH_TOKEN]: (_a = this.tokenService.refreshToken) !== null && _a !== void 0 ? _a : "",
|
|
132
|
-
[LocalizeApiToken.httpHeaders.X_TENANT]: (_b = this.tokenService.tenantToken) !== null && _b !== void 0 ? _b : "",
|
|
133
|
-
};
|
|
134
|
-
}
|
|
135
|
-
get isValidPassword() {
|
|
136
|
-
this.loading = false;
|
|
137
|
-
return this.properties.passwordValidator
|
|
138
|
-
? this.properties.passwordValidator(this.password)
|
|
139
|
-
: this.password && this.password.trim().length >= 6 && this.password.trim().length <= 50;
|
|
61
|
+
clickLogout() {
|
|
62
|
+
var _a;
|
|
63
|
+
(_a = this.logout) === null || _a === void 0 ? void 0 : _a.call(this);
|
|
140
64
|
}
|
|
141
65
|
showMessage(severity, summary) {
|
|
142
66
|
this.messageService.add({ key: this.messageKey, severity, summary });
|
|
143
|
-
this.loading = false;
|
|
144
67
|
}
|
|
145
68
|
get sanitizedTitle() {
|
|
146
69
|
var _a;
|
|
147
70
|
return this.sanitizer.bypassSecurityTrustHtml((_a = this.properties.title) !== null && _a !== void 0 ? _a : '');
|
|
148
71
|
}
|
|
149
72
|
ngOnDestroy() {
|
|
150
|
-
|
|
151
|
-
(_a = this.removeLoginListener) === null || _a === void 0 ? void 0 : _a.call(this);
|
|
73
|
+
this.apiLoginService.unConfigure();
|
|
152
74
|
}
|
|
153
75
|
}
|
|
154
76
|
LocalizeTokenLoginDialogComponent.decorators = [
|
|
@@ -467,8 +389,7 @@ LocalizeTokenLoginDialogComponent.ctorParameters = () => [
|
|
|
467
389
|
{ type: ChangeDetectorRef },
|
|
468
390
|
{ type: DynamicDialogRef },
|
|
469
391
|
{ type: DynamicDialogConfig },
|
|
470
|
-
{ type: HttpClient },
|
|
471
392
|
{ type: DomSanitizer },
|
|
472
393
|
{ type: Injector }
|
|
473
394
|
];
|
|
474
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"localize-token-login-dialog.component.js","sourceRoot":"","sources":["../../../src/package/components/localize-token-login-dialog.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient } from \"@angular/common/http\";\r\nimport {\r\n  ChangeDetectorRef,\r\n  Component,\r\n  Injector,\r\n  OnDestroy,\r\n  OnInit,\r\n  ViewEncapsulation,\r\n} from \"@angular/core\";\r\nimport { MessageService } from \"primeng/api\";\r\nimport { DynamicDialogConfig, DynamicDialogRef } from \"primeng/dynamicdialog\";\r\nimport { ILoginDialogConfig, ILoginDialogProperties } from \"../models/localize-token-models\";\r\nimport { DomSanitizer } from \"@angular/platform-browser\";\r\nimport { JwtPayload, LocalizeApiService, LocalizeApiBroadcastService, LocalizeApiToken, LocalizeApiTokenService, waitFor } from \"@sambath999/localize-api\";\r\n\r\n\r\nenum ELoginState {\r\n  Requesting,\r\n  Success,\r\n  Error\r\n}\r\n\r\ninterface ILoginBroadcastMessage {\r\n  state: ELoginState;\r\n  sourceId: string;\r\n  requestId?: string;\r\n  emittedAt?: number;\r\n  message?: string;\r\n}\r\n\r\n@Component({\r\n  styles: [`\r\n  #login-dlg-wrap {\r\n    width: 100%;\r\n    max-width: 400px;\r\n    margin: 0 auto;\r\n    padding: 30px;\r\n    height: 100%;\r\n  }\r\n  \r\n  .login-dlg-elm {\r\n    margin-top: 1rem;\r\n  }\r\n\r\n  .login-dlg-elm.login-dlg-suggest {\r\n    display: flex ;\r\n    align-items: center;\r\n    user-select: none;\r\n    border-bottom: solid 1px #ddd;\r\n    border-radius: 5px;\r\n    padding: 5px 10px;\r\n    background: #f9f9f9;\r\n    box-shadow: 1px 5px 10px -12px #000;\r\n  }\r\n  \r\n  #login-dlg-header {\r\n    display: flex;\r\n    flex-direction: column;\r\n    align-items: center;\r\n    justify-content: center;\r\n  }\r\n  \r\n  #login-dlg-header h3 {\r\n    font-weight: bold;\r\n    font-size: 0.9rem;\r\n    color: orange;\r\n    text-align: center;\r\n  }\r\n  \r\n  #login-logo {\r\n    height: 55px;\r\n    width: 55px;\r\n    /* background: url(\"/assets/images/logo-300px.png\") no-repeat; */\r\n    background-size: contain !important;\r\n  }\r\n  \r\n  #login-dlg-content .p-inputgroup {\r\n    height: 45px;\r\n  }\r\n  \r\n  #login-dlg-content .p-inputgroup .p-inputgroup-addon {\r\n    height: 45px;\r\n    border-radius: 15px 0 0 15px;\r\n    width: 50px;\r\n  }\r\n  #login-dlg-content *{\r\n    font-size: .9rem;\r\n    /* font-family: 'Lexend', 'Roboto', sans-serif, 'material-icons-round'; */\r\n  }\r\n  \r\n  #login-dlg-content .p-inputgroup .p-inputgroup-addon * {\r\n    font-size: 1rem;\r\n  }\r\n  \r\n  #login-dlg-content .p-inputgroup input {\r\n    height: 45px;\r\n    border-radius: 0 15px 15px 0;\r\n  }\r\n  \r\n  #login-dlg-content button {\r\n    height: 45px;\r\n    border-radius: 15px;\r\n  }\r\n  \r\n  /*check animation block*/\r\n  \r\n  .check-animation-wrap {\r\n    top: 0;\r\n    left: 0;\r\n    position: absolute;\r\n    display: flex;\r\n    flex-direction: column;\r\n    align-items: center;\r\n    justify-content: center;\r\n    width: 100%;\r\n    height: calc(100% - 200px);\r\n    min-height: 400px;\r\n  }\r\n  \r\n  .check-main-container {\r\n    width: 100%;\r\n    height: 100vh;\r\n    display: flex;\r\n    flex-flow: column;\r\n    justify-content: center;\r\n    align-items: center;\r\n  }\r\n  \r\n  .check-container {\r\n    width: 6.25rem;\r\n    height: 7.5rem;\r\n    display: flex;\r\n    flex-flow: column;\r\n    align-items: center;\r\n    justify-content: space-between;\r\n  }\r\n  \r\n  .check-container .check-background {\r\n    width: 100%;\r\n    height: calc(100% - 1.25rem);\r\n    background: linear-gradient(to bottom right, #5de593, #41d67c);\r\n    box-shadow: 0px 0px 0px 65px rgba(255, 255, 255, 0.25) inset, 0px 0px 0px 65px rgba(255, 255, 255, 0.25) inset;\r\n    transform: scale(0.84);\r\n    border-radius: 50%;\r\n    animation: animateContainer 0.75s ease-out forwards 0.75s;\r\n    display: flex;\r\n    align-items: center;\r\n    justify-content: center;\r\n    opacity: 0;\r\n  }\r\n  \r\n  .check-container .check-background svg {\r\n    width: 65%;\r\n    transform: translateY(0.25rem);\r\n    stroke-dasharray: 80;\r\n    stroke-dashoffset: 80;\r\n    animation: animateCheck 0.35s forwards 1.25s ease-out;\r\n    min-width: auto !important;\r\n  }\r\n  \r\n  .check-container .check-shadow {\r\n    bottom: calc(-15% - 5px);\r\n    left: 0;\r\n    border-radius: 50%;\r\n    background: radial-gradient(closest-side, rgba(73, 218, 131, 1), transparent);\r\n    animation: animateShadow 0.75s ease-out forwards 0.75s;\r\n  }\r\n  \r\n  @keyframes animateContainer {\r\n    0% {\r\n      opacity: 0;\r\n      transform: scale(0);\r\n      box-shadow: 0px 0px 0px 65px rgba(255, 255, 255, 0.25) inset, 0px 0px 0px 65px rgba(255, 255, 255, 0.25) inset;\r\n    }\r\n  \r\n    25% {\r\n      opacity: 1;\r\n      transform: scale(0.9);\r\n      box-shadow: 0px 0px 0px 65px rgba(255, 255, 255, 0.25) inset, 0px 0px 0px 65px rgba(255, 255, 255, 0.25) inset;\r\n    }\r\n  \r\n    43.75% {\r\n      transform: scale(1.15);\r\n      box-shadow: 0px 0px 0px 43.334px rgba(255, 255, 255, 0.25) inset, 0px 0px 0px 65px rgba(255, 255, 255, 0.25) inset;\r\n    }\r\n  \r\n    62.5% {\r\n      transform: scale(1);\r\n      box-shadow: 0px 0px 0px 0px rgba(255, 255, 255, 0.25) inset, 0px 0px 0px 21.667px rgba(255, 255, 255, 0.25) inset;\r\n    }\r\n  \r\n    81.25% {\r\n      box-shadow: 0px 0px 0px 0px rgba(255, 255, 255, 0.25) inset, 0px 0px 0px 0px rgba(255, 255, 255, 0.25) inset;\r\n    }\r\n  \r\n    100% {\r\n      opacity: 1;\r\n      box-shadow: 0px 0px 0px 0px rgba(255, 255, 255, 0.25) inset, 0px 0px 0px 0px rgba(255, 255, 255, 0.25) inset;\r\n    }\r\n  }\r\n  \r\n  @keyframes animateCheck {\r\n    from {\r\n      stroke-dashoffset: 80;\r\n    }\r\n  \r\n    to {\r\n      stroke-dashoffset: 0;\r\n    }\r\n  }\r\n  \r\n  @keyframes animateShadow {\r\n    0% {\r\n      opacity: 0;\r\n      width: 100%;\r\n      height: 15%;\r\n    }\r\n  \r\n    25% {\r\n      opacity: 0.25;\r\n    }\r\n  \r\n    43.75% {\r\n      width: 40%;\r\n      height: 7%;\r\n      opacity: 0.35;\r\n    }\r\n  \r\n    100% {\r\n      width: 85%;\r\n      height: 15%;\r\n      opacity: 0.25;\r\n    }\r\n  }\r\n  #login-dlg-wrap .loader-wrap {\r\n    display: flex;\r\n    justify-content: center;\r\n    align-items: center;\r\n    height:100%;\r\n    width:100%;\r\n    position: absolute;\r\n    top: 0;\r\n    left: 0;\r\n    z-index: 100;\r\n    background: #ffffff42;\r\n    backdrop-filter: blur(1px);\r\n  }\r\n\r\n  #login-dlg-wrap .login-dlg-loader {\r\n    border: 15px solid #e7e7e7;\r\n    border-top: 15px solid #52dba1;\r\n    border-radius: 50%;\r\n    width: 100px;\r\n    height: 100px;\r\n    animation: spinloader 2s linear infinite;\r\n  }\r\n\r\n  #login-dlg-wrap .loader-wrap::before {\r\n    content: \"\";\r\n    position: absolute;\r\n    width: 70px;\r\n    height: 70px;\r\n    transform: translate(-50%, -50%);\r\n    z-index: 1;\r\n    border: 15px solid #e7e7e700;\r\n    border-top: 15px solid #52dba1c9;\r\n    border-radius: 50%;\r\n    animation: spinloader .75s linear infinite;\r\n  }\r\n\r\n  @keyframes spinloader {\r\n    0% { transform: rotate(0deg); }\r\n    100% { transform: rotate(360deg); }\r\n  }\r\n  `],\r\n  template: `<p-toast key=\"$login-dlg\" position=\"top-center\"></p-toast>\r\n  <div id=\"login-dlg-wrap\">\r\n    <div id=\"login-dlg-header\">\r\n      <div id=\"login-logo\" class=\"p-mb-2\" style=\"background: url('{{properties.logoImage}}') no-repeat\"></div>\r\n      <h3 *ngIf=\"!success\" [innerHTML]=\"sanitizedTitle\"></h3>\r\n      <h3 *ngIf=\"success\" style=\"color:green !important;\">{{properties.loginSuccessMessage}}</h3>\r\n    </div>\r\n    <div id=\"login-dlg-content\">\r\n      <ng-container *ngIf=\"!success\">\r\n        <div *ngIf=\"loading\" class=\"loader-wrap\">\r\n          <div class=\"login-dlg-loader\"></div>\r\n        </div>\r\n        <div class=\"login-dlg-elm\">\r\n          <div class=\"p-inputgroup\">\r\n            <span class=\"p-inputgroup-addon\">\r\n              <i class=\"material-icons-round\">person</i>\r\n            </span>\r\n            <input disabled pInputText type=\"text\" placeholder=\"{{properties.username?.placeHolder}}\" [value]=\"decodeToken?.email\" />\r\n          </div>\r\n        </div>\r\n  \r\n        <div class=\"login-dlg-elm\">\r\n          <div class=\"p-inputgroup\">\r\n            <span class=\"p-inputgroup-addon\">\r\n              <i class=\"material-icons-round\">lock</i>\r\n            </span>\r\n            <input [disabled]=\"loading\" (keydown.enter)=\"clickLogin()\" pInputText type=\"password\" \r\n              placeholder=\"{{properties.password?.placeHolder}}\" [(ngModel)]=\"password\"\r\n              autofocus />\r\n          </div>\r\n        </div>\r\n        <div class=\"login-dlg-elm\">\r\n          <button style=\"width: 100%;\" pButton type=\"button\" label=\"{{properties.loginButton?.placeHolder}}\" (click)=\"clickLogin()\"\r\n            [disabled]=\"!password || loading\"></button>\r\n        </div>\r\n  \r\n        <div class=\"login-dlg-elm login-dlg-suggest\" style=\"display:flex;align-items: center;user-select: none;\">\r\n          <span>{{properties.logoutButton?.message}}</span>\r\n          <button class=\"p-button-text\" pButton type=\"button\" label=\"{{properties.logoutButton?.placeHolder}}\" \r\n            (click)=\"clickLogout()\"></button>\r\n        </div>\r\n      </ng-container>\r\n  \r\n      <ng-container *ngIf=\"success\">\r\n        <div style=\"margin-top:35px;\"></div>\r\n        <div class=\"check-animation-wrap\">\r\n          <div class=\"check-main-container\">\r\n            <div class=\"check-container\">\r\n              <div class=\"check-background\">\r\n                <svg viewBox=\"0 0 65 51\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n                  <path d=\"M7 25L27.3077 44L58.5 7\" stroke=\"white\" stroke-width=\"13\" stroke-linecap=\"round\"\r\n                    stroke-linejoin=\"round\"></path>\r\n                </svg>\r\n              </div>\r\n            </div>\r\n          </div>\r\n        </div>\r\n      </ng-container>\r\n    </div>\r\n  </div>`,\r\n  selector: \"app-localize-logindlg\",\r\n  providers: [MessageService],\r\n  encapsulation: ViewEncapsulation.None,\r\n})\r\nexport class LocalizeTokenLoginDialogComponent implements OnInit, OnDestroy {\r\n  readonly messageKey = \"$login-dlg\";\r\n  password: any;\r\n  readonly decodeToken: JwtPayload | null;\r\n  loading = false;\r\n  success = false;\r\n  private get config() { return this.tokenService.config; }\r\n  private readonly loginConfig: ILoginDialogConfig\r\n\r\n  private logout?: () => any\r\n  private loginUrl?: string;\r\n  readonly properties: ILoginDialogProperties;\r\n  private readonly removeLoginListener?: () => void;\r\n  private readonly loginBroadcastChannel = \"bc-localize-login\";\r\n  private readonly sourceId = `${Date.now()}-${Math.random().toString(36).slice(2)}`;\r\n  private readonly tokenService: LocalizeApiTokenService;\r\n  private readonly broadcastService: LocalizeApiBroadcastService;\r\n  private readonly apiService: LocalizeApiService;\r\n\r\n\r\n  constructor(\r\n    private readonly messageService: MessageService,\r\n    private readonly cdt: ChangeDetectorRef,\r\n    private readonly dlgRef: DynamicDialogRef,\r\n    private readonly dlgConfig: DynamicDialogConfig,\r\n    private readonly httpClient: HttpClient,\r\n    private readonly sanitizer: DomSanitizer,\r\n    private readonly injector: Injector\r\n  ) {\r\n    this.tokenService = this.injector.get(LocalizeApiTokenService);\r\n    this.broadcastService = this.injector.get(LocalizeApiBroadcastService);\r\n    this.apiService = this.injector.get(LocalizeApiService);\r\n    this.decodeToken = this.tokenService.decodeRefreshToken;\r\n    this.loginConfig = this.dlgConfig.data.loginConfig;\r\n    this.properties = this.loginConfig.properties!;\r\n\r\n    this.removeLoginListener = this.broadcastService.listen<ILoginBroadcastMessage>(this.loginBroadcastChannel, (payload) => {\r\n      if (!payload || payload.sourceId === this.sourceId) {\r\n        console.warn('Ignoring login state message with invalid payload or from same source', payload);\r\n        return;\r\n      }\r\n\r\n      switch (payload.state) {\r\n        case ELoginState.Requesting:\r\n          this.loading = true;\r\n          this.success = false;\r\n          break;\r\n        case ELoginState.Success:\r\n          this.apiService.clearRequiredLoginStateAfterLogin();\r\n          this.loginSuccess();\r\n          break;\r\n        case ELoginState.Error:\r\n          this.showMessage(\"error\", payload.message ?? \"Login failed\");\r\n          break;\r\n      }\r\n    });\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.dlgConfig.closable = false;\r\n    this.dlgConfig.dismissableMask = false;\r\n    this.dlgConfig.modal = true;\r\n\r\n    this.logout = this.loginConfig.logoutFunc;\r\n    this.loginUrl = this.loginConfig.loginUrl\r\n\r\n    if (!this.decodeToken) {\r\n      this.showMessage(\"error\", \"Token is invalid\");\r\n      setTimeout(() => this.logout?.(), 2000);\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.cdt.detectChanges();\r\n  }\r\n\r\n  private async loginSuccess() {\r\n    this.success = true;\r\n    await waitFor(2000);\r\n    this.dlgRef.close(true);\r\n  }\r\n\r\n  async clickLogin() {\r\n    if (!this.isValidPassword) {\r\n      return this.showMessage(\"error\", \"Password is required and must be at least 6 characters\");\r\n    }\r\n\r\n    this.publishLoginState(ELoginState.Requesting);\r\n    await waitFor(300);\r\n    this.loading = true;\r\n    const loginRes = await this.login();\r\n    if (!loginRes?.status) {\r\n      const message = loginRes?.message ?? \"An error occurred\";\r\n      this.publishLoginState(ELoginState.Error, message);\r\n      return this.showMessage(\"error\", message);\r\n    }\r\n\r\n    this.tokenService.accessToken = loginRes.tokens.accessToken;\r\n    const cookieOptions = { expires: this.loginConfig.expire ?? 365 }\r\n    LocalizeApiToken.storage.set(this.config.refreshToken?.name || '', loginRes.tokens.refreshToken, cookieOptions);\r\n    this.apiService.clearRequiredLoginStateAfterLogin();\r\n\r\n    this.publishLoginState(ELoginState.Success);\r\n    this.loginSuccess();\r\n  }\r\n\r\n  private publishLoginState(state: ELoginState, message?: string): void {\r\n    this.broadcastService.publish<ILoginBroadcastMessage>(this.loginBroadcastChannel, {\r\n      state,\r\n      sourceId: this.sourceId,\r\n      message,\r\n    });\r\n  }\r\n\r\n  private async login() {\r\n    if (!this.loginUrl?.trim().length) {\r\n      this.showMessage(\"error\", \"Login url is required\");\r\n      throw new Error(\"Login url is required\");\r\n    }\r\n\r\n    try {\r\n\r\n      if (this.loginConfig.loginFunction) {\r\n        console.log(\"Using custom login function\");\r\n        return await this.loginConfig.loginFunction(this.decodeToken?.email ?? '', this.password.trim(), this.getHeaders());\r\n      }\r\n\r\n      return await new Promise<any>((resolve, reject) =>\r\n        this.httpClient.post(this.loginUrl!,\r\n          { password: this.password.trim() },\r\n          { headers: this.getHeaders() }).subscribe({ next: resolve, error: reject }));\r\n\r\n    } catch (e: any) {\r\n      this.showMessage(\"error\", e.message);\r\n      return null;\r\n    }\r\n  }\r\n\r\n  private getHeaders() {\r\n    return {\r\n      [LocalizeApiToken.httpHeaders.X_REFRESH_TOKEN]: this.tokenService.refreshToken ?? \"\",\r\n      [LocalizeApiToken.httpHeaders.X_TENANT]: this.tokenService.tenantToken ?? \"\",\r\n    };\r\n  }\r\n\r\n  get isValidPassword(): boolean {\r\n    this.loading = false;\r\n    return this.properties.passwordValidator\r\n      ? this.properties.passwordValidator(this.password)\r\n      : this.password && this.password.trim().length >= 6 && this.password.trim().length <= 50;\r\n  }\r\n\r\n  clickLogout = () => this.logout?.();\r\n\r\n  private showMessage(severity: string, summary: string) {\r\n    this.messageService.add({ key: this.messageKey, severity, summary });\r\n    this.loading = false;\r\n  }\r\n\r\n  get sanitizedTitle() {\r\n    return this.sanitizer.bypassSecurityTrustHtml(this.properties.title ?? '');\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.removeLoginListener?.();\r\n  }\r\n}\r\n"]}
|
|
395
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"localize-token-login-dialog.component.js","sourceRoot":"","sources":["../../../src/package/components/localize-token-login-dialog.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectorRef,\r\n  Component,\r\n  Injector,\r\n  OnDestroy,\r\n  OnInit,\r\n  ViewEncapsulation,\r\n} from \"@angular/core\";\r\nimport { MessageService } from \"primeng/api\";\r\nimport { DynamicDialogConfig, DynamicDialogRef } from \"primeng/dynamicdialog\";\r\nimport { ILoginDialogConfig, ILoginDialogProperties } from \"../models/localize-token-models\";\r\nimport { DomSanitizer } from \"@angular/platform-browser\";\r\nimport { JwtPayload, LocalizeApiLoginService, waitFor } from \"@sambath999/localize-api\";\r\n\r\n@Component({\r\n  styles: [`\r\n  #login-dlg-wrap {\r\n    width: 100%;\r\n    max-width: 400px;\r\n    margin: 0 auto;\r\n    padding: 30px;\r\n    height: 100%;\r\n  }\r\n  \r\n  .login-dlg-elm {\r\n    margin-top: 1rem;\r\n  }\r\n\r\n  .login-dlg-elm.login-dlg-suggest {\r\n    display: flex ;\r\n    align-items: center;\r\n    user-select: none;\r\n    border-bottom: solid 1px #ddd;\r\n    border-radius: 5px;\r\n    padding: 5px 10px;\r\n    background: #f9f9f9;\r\n    box-shadow: 1px 5px 10px -12px #000;\r\n  }\r\n  \r\n  #login-dlg-header {\r\n    display: flex;\r\n    flex-direction: column;\r\n    align-items: center;\r\n    justify-content: center;\r\n  }\r\n  \r\n  #login-dlg-header h3 {\r\n    font-weight: bold;\r\n    font-size: 0.9rem;\r\n    color: orange;\r\n    text-align: center;\r\n  }\r\n  \r\n  #login-logo {\r\n    height: 55px;\r\n    width: 55px;\r\n    /* background: url(\"/assets/images/logo-300px.png\") no-repeat; */\r\n    background-size: contain !important;\r\n  }\r\n  \r\n  #login-dlg-content .p-inputgroup {\r\n    height: 45px;\r\n  }\r\n  \r\n  #login-dlg-content .p-inputgroup .p-inputgroup-addon {\r\n    height: 45px;\r\n    border-radius: 15px 0 0 15px;\r\n    width: 50px;\r\n  }\r\n  #login-dlg-content *{\r\n    font-size: .9rem;\r\n    /* font-family: 'Lexend', 'Roboto', sans-serif, 'material-icons-round'; */\r\n  }\r\n  \r\n  #login-dlg-content .p-inputgroup .p-inputgroup-addon * {\r\n    font-size: 1rem;\r\n  }\r\n  \r\n  #login-dlg-content .p-inputgroup input {\r\n    height: 45px;\r\n    border-radius: 0 15px 15px 0;\r\n  }\r\n  \r\n  #login-dlg-content button {\r\n    height: 45px;\r\n    border-radius: 15px;\r\n  }\r\n  \r\n  /*check animation block*/\r\n  \r\n  .check-animation-wrap {\r\n    top: 0;\r\n    left: 0;\r\n    position: absolute;\r\n    display: flex;\r\n    flex-direction: column;\r\n    align-items: center;\r\n    justify-content: center;\r\n    width: 100%;\r\n    height: calc(100% - 200px);\r\n    min-height: 400px;\r\n  }\r\n  \r\n  .check-main-container {\r\n    width: 100%;\r\n    height: 100vh;\r\n    display: flex;\r\n    flex-flow: column;\r\n    justify-content: center;\r\n    align-items: center;\r\n  }\r\n  \r\n  .check-container {\r\n    width: 6.25rem;\r\n    height: 7.5rem;\r\n    display: flex;\r\n    flex-flow: column;\r\n    align-items: center;\r\n    justify-content: space-between;\r\n  }\r\n  \r\n  .check-container .check-background {\r\n    width: 100%;\r\n    height: calc(100% - 1.25rem);\r\n    background: linear-gradient(to bottom right, #5de593, #41d67c);\r\n    box-shadow: 0px 0px 0px 65px rgba(255, 255, 255, 0.25) inset, 0px 0px 0px 65px rgba(255, 255, 255, 0.25) inset;\r\n    transform: scale(0.84);\r\n    border-radius: 50%;\r\n    animation: animateContainer 0.75s ease-out forwards 0.75s;\r\n    display: flex;\r\n    align-items: center;\r\n    justify-content: center;\r\n    opacity: 0;\r\n  }\r\n  \r\n  .check-container .check-background svg {\r\n    width: 65%;\r\n    transform: translateY(0.25rem);\r\n    stroke-dasharray: 80;\r\n    stroke-dashoffset: 80;\r\n    animation: animateCheck 0.35s forwards 1.25s ease-out;\r\n    min-width: auto !important;\r\n  }\r\n  \r\n  .check-container .check-shadow {\r\n    bottom: calc(-15% - 5px);\r\n    left: 0;\r\n    border-radius: 50%;\r\n    background: radial-gradient(closest-side, rgba(73, 218, 131, 1), transparent);\r\n    animation: animateShadow 0.75s ease-out forwards 0.75s;\r\n  }\r\n  \r\n  @keyframes animateContainer {\r\n    0% {\r\n      opacity: 0;\r\n      transform: scale(0);\r\n      box-shadow: 0px 0px 0px 65px rgba(255, 255, 255, 0.25) inset, 0px 0px 0px 65px rgba(255, 255, 255, 0.25) inset;\r\n    }\r\n  \r\n    25% {\r\n      opacity: 1;\r\n      transform: scale(0.9);\r\n      box-shadow: 0px 0px 0px 65px rgba(255, 255, 255, 0.25) inset, 0px 0px 0px 65px rgba(255, 255, 255, 0.25) inset;\r\n    }\r\n  \r\n    43.75% {\r\n      transform: scale(1.15);\r\n      box-shadow: 0px 0px 0px 43.334px rgba(255, 255, 255, 0.25) inset, 0px 0px 0px 65px rgba(255, 255, 255, 0.25) inset;\r\n    }\r\n  \r\n    62.5% {\r\n      transform: scale(1);\r\n      box-shadow: 0px 0px 0px 0px rgba(255, 255, 255, 0.25) inset, 0px 0px 0px 21.667px rgba(255, 255, 255, 0.25) inset;\r\n    }\r\n  \r\n    81.25% {\r\n      box-shadow: 0px 0px 0px 0px rgba(255, 255, 255, 0.25) inset, 0px 0px 0px 0px rgba(255, 255, 255, 0.25) inset;\r\n    }\r\n  \r\n    100% {\r\n      opacity: 1;\r\n      box-shadow: 0px 0px 0px 0px rgba(255, 255, 255, 0.25) inset, 0px 0px 0px 0px rgba(255, 255, 255, 0.25) inset;\r\n    }\r\n  }\r\n  \r\n  @keyframes animateCheck {\r\n    from {\r\n      stroke-dashoffset: 80;\r\n    }\r\n  \r\n    to {\r\n      stroke-dashoffset: 0;\r\n    }\r\n  }\r\n  \r\n  @keyframes animateShadow {\r\n    0% {\r\n      opacity: 0;\r\n      width: 100%;\r\n      height: 15%;\r\n    }\r\n  \r\n    25% {\r\n      opacity: 0.25;\r\n    }\r\n  \r\n    43.75% {\r\n      width: 40%;\r\n      height: 7%;\r\n      opacity: 0.35;\r\n    }\r\n  \r\n    100% {\r\n      width: 85%;\r\n      height: 15%;\r\n      opacity: 0.25;\r\n    }\r\n  }\r\n  #login-dlg-wrap .loader-wrap {\r\n    display: flex;\r\n    justify-content: center;\r\n    align-items: center;\r\n    height:100%;\r\n    width:100%;\r\n    position: absolute;\r\n    top: 0;\r\n    left: 0;\r\n    z-index: 100;\r\n    background: #ffffff42;\r\n    backdrop-filter: blur(1px);\r\n  }\r\n\r\n  #login-dlg-wrap .login-dlg-loader {\r\n    border: 15px solid #e7e7e7;\r\n    border-top: 15px solid #52dba1;\r\n    border-radius: 50%;\r\n    width: 100px;\r\n    height: 100px;\r\n    animation: spinloader 2s linear infinite;\r\n  }\r\n\r\n  #login-dlg-wrap .loader-wrap::before {\r\n    content: \"\";\r\n    position: absolute;\r\n    width: 70px;\r\n    height: 70px;\r\n    transform: translate(-50%, -50%);\r\n    z-index: 1;\r\n    border: 15px solid #e7e7e700;\r\n    border-top: 15px solid #52dba1c9;\r\n    border-radius: 50%;\r\n    animation: spinloader .75s linear infinite;\r\n  }\r\n\r\n  @keyframes spinloader {\r\n    0% { transform: rotate(0deg); }\r\n    100% { transform: rotate(360deg); }\r\n  }\r\n  `],\r\n  template: `<p-toast key=\"$login-dlg\" position=\"top-center\"></p-toast>\r\n  <div id=\"login-dlg-wrap\">\r\n    <div id=\"login-dlg-header\">\r\n      <div id=\"login-logo\" class=\"p-mb-2\" style=\"background: url('{{properties.logoImage}}') no-repeat\"></div>\r\n      <h3 *ngIf=\"!success\" [innerHTML]=\"sanitizedTitle\"></h3>\r\n      <h3 *ngIf=\"success\" style=\"color:green !important;\">{{properties.loginSuccessMessage}}</h3>\r\n    </div>\r\n    <div id=\"login-dlg-content\">\r\n      <ng-container *ngIf=\"!success\">\r\n        <div *ngIf=\"loading\" class=\"loader-wrap\">\r\n          <div class=\"login-dlg-loader\"></div>\r\n        </div>\r\n        <div class=\"login-dlg-elm\">\r\n          <div class=\"p-inputgroup\">\r\n            <span class=\"p-inputgroup-addon\">\r\n              <i class=\"material-icons-round\">person</i>\r\n            </span>\r\n            <input disabled pInputText type=\"text\" placeholder=\"{{properties.username?.placeHolder}}\" [value]=\"decodeToken?.email\" />\r\n          </div>\r\n        </div>\r\n  \r\n        <div class=\"login-dlg-elm\">\r\n          <div class=\"p-inputgroup\">\r\n            <span class=\"p-inputgroup-addon\">\r\n              <i class=\"material-icons-round\">lock</i>\r\n            </span>\r\n            <input [disabled]=\"loading\" (keydown.enter)=\"clickLogin()\" pInputText type=\"password\" \r\n              placeholder=\"{{properties.password?.placeHolder}}\" [(ngModel)]=\"password\"\r\n              autofocus />\r\n          </div>\r\n        </div>\r\n        <div class=\"login-dlg-elm\">\r\n          <button style=\"width: 100%;\" pButton type=\"button\" label=\"{{properties.loginButton?.placeHolder}}\" (click)=\"clickLogin()\"\r\n            [disabled]=\"!password || loading\"></button>\r\n        </div>\r\n  \r\n        <div class=\"login-dlg-elm login-dlg-suggest\" style=\"display:flex;align-items: center;user-select: none;\">\r\n          <span>{{properties.logoutButton?.message}}</span>\r\n          <button class=\"p-button-text\" pButton type=\"button\" label=\"{{properties.logoutButton?.placeHolder}}\" \r\n            (click)=\"clickLogout()\"></button>\r\n        </div>\r\n      </ng-container>\r\n  \r\n      <ng-container *ngIf=\"success\">\r\n        <div style=\"margin-top:35px;\"></div>\r\n        <div class=\"check-animation-wrap\">\r\n          <div class=\"check-main-container\">\r\n            <div class=\"check-container\">\r\n              <div class=\"check-background\">\r\n                <svg viewBox=\"0 0 65 51\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n                  <path d=\"M7 25L27.3077 44L58.5 7\" stroke=\"white\" stroke-width=\"13\" stroke-linecap=\"round\"\r\n                    stroke-linejoin=\"round\"></path>\r\n                </svg>\r\n              </div>\r\n            </div>\r\n          </div>\r\n        </div>\r\n      </ng-container>\r\n    </div>\r\n  </div>`,\r\n  selector: \"app-localize-logindlg\",\r\n  providers: [MessageService],\r\n  encapsulation: ViewEncapsulation.None,\r\n})\r\nexport class LocalizeTokenLoginDialogComponent implements OnInit, OnDestroy {\r\n  readonly messageKey = \"$login-dlg\";\r\n  password: any;\r\n  readonly decodeToken: JwtPayload | null;\r\n  get loading() { return this.apiLoginService.isLoading; }\r\n  get success() { return this.apiLoginService.isSuccess; }\r\n  private readonly loginConfig: ILoginDialogConfig\r\n\r\n  private readonly logout?: () => any\r\n  readonly properties: ILoginDialogProperties;\r\n  private readonly apiLoginService: LocalizeApiLoginService;\r\n\r\n  constructor(\r\n    private readonly messageService: MessageService,\r\n    private readonly cdt: ChangeDetectorRef,\r\n    private readonly dlgRef: DynamicDialogRef,\r\n    private readonly dlgConfig: DynamicDialogConfig,\r\n    private readonly sanitizer: DomSanitizer,\r\n    private readonly injector: Injector\r\n  ) {\r\n    this.loginConfig = this.dlgConfig.data.loginConfig;\r\n    this.apiLoginService = this.injector.get(LocalizeApiLoginService);\r\n    this.properties = this.loginConfig.properties!;\r\n    this.decodeToken = this.apiLoginService.decodedToken;\r\n\r\n    this.logout = this.loginConfig.logoutFunc;\r\n    this.configure();\r\n  }\r\n\r\n  private configure() {\r\n    this.dlgConfig.closable = false;\r\n    this.dlgConfig.dismissableMask = false;\r\n    this.dlgConfig.modal = true;\r\n\r\n    this.apiLoginService.configure({\r\n      loginUrl: this.loginConfig.loginUrl,\r\n      onSuccess: this.loginSuccess.bind(this),\r\n      onFailure: (msg) => this.showMessage(\"error\", msg),\r\n      onError: (msg) => this.showMessage(\"error\", msg),\r\n      loginFunction: this.loginConfig.loginFunction,\r\n      refreshTokenTtl: this.loginConfig.expire,\r\n      passwordResolver: () => this.password,\r\n      passwordValidator: this.loginConfig.properties?.passwordValidator?.bind(this),\r\n    });\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    if (!this.decodeToken) {\r\n      this.showMessage(\"error\", \"Invalid Token. Please login again.\");\r\n      setTimeout(() => this.logout?.(), 2000);\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.cdt.detectChanges();\r\n  }\r\n\r\n  private async loginSuccess() {\r\n    await waitFor(2000);\r\n    this.dlgRef.close(true);\r\n  }\r\n\r\n  async clickLogin() {\r\n    await this.apiLoginService.clickLogin();\r\n  }\r\n\r\n  clickLogout() {\r\n    this.logout?.();\r\n  }\r\n\r\n  private showMessage(severity: string, summary: string) {\r\n    this.messageService.add({ key: this.messageKey, severity, summary });\r\n  }\r\n\r\n  get sanitizedTitle() {\r\n    return this.sanitizer.bypassSecurityTrustHtml(this.properties.title ?? '');\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.apiLoginService.unConfigure();\r\n  }\r\n}\r\n"]}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9jYWxpemUtdG9rZW4tbW9kZWxzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3BhY2thZ2UvbW9kZWxzL2xvY2FsaXplLXRva2VuLW1vZGVscy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBJTG9naW5EaWFsb2dQbGFjZUhvbGRlciB7XHJcbiAgLyoqXHJcbiAgICogTWVzc2FnZSB0byBkaXNwbGF5IGluIHRoZSBpbnB1dCBmaWVsZCwgdHlwaWNhbGx5IHVzZWQgZm9yIGVycm9yIG1lc3NhZ2VzIG9yIGhpbnRzLlxyXG4gICAqIFRoaXMgaXMgb3B0aW9uYWwgYW5kIGNhbiBiZSB1c2VkIHRvIHByb3ZpZGUgYWRkaXRpb25hbCBjb250ZXh0IG9yIGluc3RydWN0aW9ucyB0byB0aGUgdXNlci5cclxuICAgKi9cclxuICBtZXNzYWdlPzogc3RyaW5nO1xyXG4gIC8qKlxyXG4gICAqIFBsYWNlaG9sZGVyIG9yIGxhYmVsIHRleHQgZm9yIHRoZSBpbnB1dCBmaWVsZFxyXG4gICAqL1xyXG4gIHBsYWNlSG9sZGVyPzogc3RyaW5nO1xyXG59XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIElMb2dpbkRpYWxvZ1Byb3BlcnRpZXMge1xyXG4gIC8qKlxyXG4gICAqIFRpdGxlIG9mIHRoZSBsb2dpbiBkaWFsb2dcclxuICAgKi9cclxuICB0aXRsZT86IHN0cmluZztcclxuICBsb2dpblN1Y2Nlc3NNZXNzYWdlPzogc3RyaW5nO1xyXG4gIC8qKlxyXG4gICAqIExvZ29nIGltYWdlIHBhdGggb3IgVVJMIHRvIGRpc3BsYXkgaW4gdGhlIGxvZ2luIGRpYWxvZ1xyXG4gICAqIElmIG5vdCBwcm92aWRlZCwgdGhlIFwiL2Fzc2V0cy9pbWFnZXMvbG9nby0zMDBweC5wbmdcIiBpbWFnZSB3aWxsIGJlIHVzZWQuXHJcbiAgICovXHJcbiAgbG9nb0ltYWdlPzogc3RyaW5nO1xyXG4gIHVzZXJuYW1lPzogSUxvZ2luRGlhbG9nUGxhY2VIb2xkZXI7XHJcbiAgcGFzc3dvcmQ/
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9jYWxpemUtdG9rZW4tbW9kZWxzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3BhY2thZ2UvbW9kZWxzL2xvY2FsaXplLXRva2VuLW1vZGVscy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBJTG9naW5EaWFsb2dQbGFjZUhvbGRlciB7XHJcbiAgLyoqXHJcbiAgICogTWVzc2FnZSB0byBkaXNwbGF5IGluIHRoZSBpbnB1dCBmaWVsZCwgdHlwaWNhbGx5IHVzZWQgZm9yIGVycm9yIG1lc3NhZ2VzIG9yIGhpbnRzLlxyXG4gICAqIFRoaXMgaXMgb3B0aW9uYWwgYW5kIGNhbiBiZSB1c2VkIHRvIHByb3ZpZGUgYWRkaXRpb25hbCBjb250ZXh0IG9yIGluc3RydWN0aW9ucyB0byB0aGUgdXNlci5cclxuICAgKi9cclxuICBtZXNzYWdlPzogc3RyaW5nO1xyXG4gIC8qKlxyXG4gICAqIFBsYWNlaG9sZGVyIG9yIGxhYmVsIHRleHQgZm9yIHRoZSBpbnB1dCBmaWVsZFxyXG4gICAqL1xyXG4gIHBsYWNlSG9sZGVyPzogc3RyaW5nO1xyXG59XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIElMb2dpbkRpYWxvZ1Byb3BlcnRpZXMge1xyXG4gIC8qKlxyXG4gICAqIFRpdGxlIG9mIHRoZSBsb2dpbiBkaWFsb2dcclxuICAgKi9cclxuICB0aXRsZT86IHN0cmluZztcclxuICBsb2dpblN1Y2Nlc3NNZXNzYWdlPzogc3RyaW5nO1xyXG4gIC8qKlxyXG4gICAqIExvZ29nIGltYWdlIHBhdGggb3IgVVJMIHRvIGRpc3BsYXkgaW4gdGhlIGxvZ2luIGRpYWxvZ1xyXG4gICAqIElmIG5vdCBwcm92aWRlZCwgdGhlIFwiL2Fzc2V0cy9pbWFnZXMvbG9nby0zMDBweC5wbmdcIiBpbWFnZSB3aWxsIGJlIHVzZWQuXHJcbiAgICovXHJcbiAgbG9nb0ltYWdlPzogc3RyaW5nO1xyXG4gIHVzZXJuYW1lPzogSUxvZ2luRGlhbG9nUGxhY2VIb2xkZXI7XHJcbiAgcGFzc3dvcmQ/OiBJTG9naW5EaWFsb2dQbGFjZUhvbGRlcjtcclxuICBsb2dpbkJ1dHRvbj86IElMb2dpbkRpYWxvZ1BsYWNlSG9sZGVyO1xyXG4gIGxvZ291dEJ1dHRvbj86IElMb2dpbkRpYWxvZ1BsYWNlSG9sZGVyO1xyXG4gIC8qKlxyXG4gICAqIEZ1bmN0aW9uIHRvIHZhbGlkYXRlIHRoZSBwYXNzd29yZC5cclxuICAgKiBJZiBub3QgcHJvdmlkZWQsIHRoZSBkZWZhdWx0IHZhbGlkYXRpb24gY2hlY2tzIGlmIHRoZSBwYXNzd29yZCBpcyBiZXR3ZWVuIDYgYW5kIDUwIGNoYXJhY3RlcnMgbG9uZy5cclxuICAgKiBAcGFyYW0gcGFzc3dvcmRcclxuICAgKiBAcmV0dXJuc1xyXG4gICAqL1xyXG4gIHBhc3N3b3JkVmFsaWRhdG9yPzogKHBhc3N3b3JkOiBzdHJpbmcgfCB1bmRlZmluZWQpID0+IGJvb2xlYW47XHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgSUxvZ2luRGlhbG9nQ29uZmlnIHtcclxuICBsb2dpblVybD86IHN0cmluZztcclxuICBsb2dvdXRVcmw/OiBzdHJpbmc7XHJcbiAgbG9naW5GdW5jdGlvbj86ICh1c2VybmFtZTogc3RyaW5nLCBwYXNzd29yZDogc3RyaW5nLCBoZWFkZXJzPzogeyBba2V5OiBzdHJpbmddOiBzdHJpbmcgfSkgPT4gUHJvbWlzZTxhbnk+O1xyXG4gIGxvZ291dEZ1bmM/OiAoKSA9PiB2b2lkO1xyXG4gIC8qKlxyXG4gICAqIENvb2tpZSBleHBpcmF0aW9uIGRhdGUgaW4gZGF5cyBmcm9tIG5vdy4gSWYgbm90IHByb3ZpZGVkIHRoZSBjb29raWUgaXMgYSBzZXNzaW9uIGNvb2tpZVxyXG4gICAqL1xyXG4gIGV4cGlyZT86IG51bWJlcjtcclxuICAvKipcclxuICAgKiBDb25maWd1cmF0aW9uIGZvciB0aGUgbG9naW4gZGlhbG9nLlxyXG4gICAqIFRoaXMgaW50ZXJmYWNlIGRlZmluZXMgdGhlIHByb3BlcnRpZXMgdGhhdCBjYW4gYmUgdXNlZCB0byBjdXN0b21pemUgdGhlIGxvZ2luIGRpYWxvZydzIGJlaGF2aW9yIGFuZCBhcHBlYXJhbmNlXHJcbiAgICovXHJcbiAgcHJvcGVydGllcz86IElMb2dpbkRpYWxvZ1Byb3BlcnRpZXM7XHJcbn1cclxuIl19
|
|
@@ -1,75 +1,54 @@
|
|
|
1
1
|
import { __awaiter } from 'tslib';
|
|
2
|
-
import { HttpClient } from '@angular/common/http';
|
|
3
2
|
import * as i0 from '@angular/core';
|
|
4
3
|
import { Component, ViewEncapsulation, ChangeDetectorRef, Injector, Injectable, NgModule, CUSTOM_ELEMENTS_SCHEMA } from '@angular/core';
|
|
5
4
|
import { MessageService } from 'primeng/api';
|
|
6
5
|
import { DynamicDialogRef, DynamicDialogConfig, DialogService } from 'primeng/dynamicdialog';
|
|
7
6
|
import { DomSanitizer } from '@angular/platform-browser';
|
|
8
7
|
import * as i1 from '@sambath999/localize-api';
|
|
9
|
-
import {
|
|
8
|
+
import { LocalizeApiLoginService, waitFor, LocalizeApiTokenService, LocalizeApiService } from '@sambath999/localize-api';
|
|
10
9
|
import { CommonModule } from '@angular/common';
|
|
11
10
|
import { ToastModule } from 'primeng/toast';
|
|
12
11
|
import { InputTextModule } from 'primeng/inputtext';
|
|
13
12
|
import { ButtonModule } from 'primeng/button';
|
|
14
13
|
import { FormsModule } from '@angular/forms';
|
|
15
14
|
|
|
16
|
-
var ELoginState;
|
|
17
|
-
(function (ELoginState) {
|
|
18
|
-
ELoginState[ELoginState["Requesting"] = 0] = "Requesting";
|
|
19
|
-
ELoginState[ELoginState["Success"] = 1] = "Success";
|
|
20
|
-
ELoginState[ELoginState["Error"] = 2] = "Error";
|
|
21
|
-
})(ELoginState || (ELoginState = {}));
|
|
22
15
|
class LocalizeTokenLoginDialogComponent {
|
|
23
|
-
constructor(messageService, cdt, dlgRef, dlgConfig,
|
|
16
|
+
constructor(messageService, cdt, dlgRef, dlgConfig, sanitizer, injector) {
|
|
24
17
|
this.messageService = messageService;
|
|
25
18
|
this.cdt = cdt;
|
|
26
19
|
this.dlgRef = dlgRef;
|
|
27
20
|
this.dlgConfig = dlgConfig;
|
|
28
|
-
this.httpClient = httpClient;
|
|
29
21
|
this.sanitizer = sanitizer;
|
|
30
22
|
this.injector = injector;
|
|
31
23
|
this.messageKey = "$login-dlg";
|
|
32
|
-
this.loading = false;
|
|
33
|
-
this.success = false;
|
|
34
|
-
this.loginBroadcastChannel = "bc-localize-login";
|
|
35
|
-
this.sourceId = `${Date.now()}-${Math.random().toString(36).slice(2)}`;
|
|
36
|
-
this.clickLogout = () => { var _a; return (_a = this.logout) === null || _a === void 0 ? void 0 : _a.call(this); };
|
|
37
|
-
this.tokenService = this.injector.get(LocalizeApiTokenService);
|
|
38
|
-
this.broadcastService = this.injector.get(LocalizeApiBroadcastService);
|
|
39
|
-
this.apiService = this.injector.get(LocalizeApiService);
|
|
40
|
-
this.decodeToken = this.tokenService.decodeRefreshToken;
|
|
41
24
|
this.loginConfig = this.dlgConfig.data.loginConfig;
|
|
25
|
+
this.apiLoginService = this.injector.get(LocalizeApiLoginService);
|
|
42
26
|
this.properties = this.loginConfig.properties;
|
|
43
|
-
this.
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
console.warn('Ignoring login state message with invalid payload or from same source', payload);
|
|
47
|
-
return;
|
|
48
|
-
}
|
|
49
|
-
switch (payload.state) {
|
|
50
|
-
case ELoginState.Requesting:
|
|
51
|
-
this.loading = true;
|
|
52
|
-
this.success = false;
|
|
53
|
-
break;
|
|
54
|
-
case ELoginState.Success:
|
|
55
|
-
this.apiService.clearRequiredLoginStateAfterLogin();
|
|
56
|
-
this.loginSuccess();
|
|
57
|
-
break;
|
|
58
|
-
case ELoginState.Error:
|
|
59
|
-
this.showMessage("error", (_a = payload.message) !== null && _a !== void 0 ? _a : "Login failed");
|
|
60
|
-
break;
|
|
61
|
-
}
|
|
62
|
-
});
|
|
27
|
+
this.decodeToken = this.apiLoginService.decodedToken;
|
|
28
|
+
this.logout = this.loginConfig.logoutFunc;
|
|
29
|
+
this.configure();
|
|
63
30
|
}
|
|
64
|
-
get
|
|
65
|
-
|
|
31
|
+
get loading() { return this.apiLoginService.isLoading; }
|
|
32
|
+
get success() { return this.apiLoginService.isSuccess; }
|
|
33
|
+
configure() {
|
|
34
|
+
var _a, _b;
|
|
66
35
|
this.dlgConfig.closable = false;
|
|
67
36
|
this.dlgConfig.dismissableMask = false;
|
|
68
37
|
this.dlgConfig.modal = true;
|
|
69
|
-
this.
|
|
70
|
-
|
|
38
|
+
this.apiLoginService.configure({
|
|
39
|
+
loginUrl: this.loginConfig.loginUrl,
|
|
40
|
+
onSuccess: this.loginSuccess.bind(this),
|
|
41
|
+
onFailure: (msg) => this.showMessage("error", msg),
|
|
42
|
+
onError: (msg) => this.showMessage("error", msg),
|
|
43
|
+
loginFunction: this.loginConfig.loginFunction,
|
|
44
|
+
refreshTokenTtl: this.loginConfig.expire,
|
|
45
|
+
passwordResolver: () => this.password,
|
|
46
|
+
passwordValidator: (_b = (_a = this.loginConfig.properties) === null || _a === void 0 ? void 0 : _a.passwordValidator) === null || _b === void 0 ? void 0 : _b.bind(this),
|
|
47
|
+
});
|
|
48
|
+
}
|
|
49
|
+
ngOnInit() {
|
|
71
50
|
if (!this.decodeToken) {
|
|
72
|
-
this.showMessage("error", "Token
|
|
51
|
+
this.showMessage("error", "Invalid Token. Please login again.");
|
|
73
52
|
setTimeout(() => { var _a; return (_a = this.logout) === null || _a === void 0 ? void 0 : _a.call(this); }, 2000);
|
|
74
53
|
}
|
|
75
54
|
}
|
|
@@ -78,85 +57,28 @@ class LocalizeTokenLoginDialogComponent {
|
|
|
78
57
|
}
|
|
79
58
|
loginSuccess() {
|
|
80
59
|
return __awaiter(this, void 0, void 0, function* () {
|
|
81
|
-
this.success = true;
|
|
82
60
|
yield waitFor(2000);
|
|
83
61
|
this.dlgRef.close(true);
|
|
84
62
|
});
|
|
85
63
|
}
|
|
86
64
|
clickLogin() {
|
|
87
|
-
var _a, _b, _c;
|
|
88
65
|
return __awaiter(this, void 0, void 0, function* () {
|
|
89
|
-
|
|
90
|
-
return this.showMessage("error", "Password is required and must be at least 6 characters");
|
|
91
|
-
}
|
|
92
|
-
this.publishLoginState(ELoginState.Requesting);
|
|
93
|
-
yield waitFor(300);
|
|
94
|
-
this.loading = true;
|
|
95
|
-
const loginRes = yield this.login();
|
|
96
|
-
if (!(loginRes === null || loginRes === void 0 ? void 0 : loginRes.status)) {
|
|
97
|
-
const message = (_a = loginRes === null || loginRes === void 0 ? void 0 : loginRes.message) !== null && _a !== void 0 ? _a : "An error occurred";
|
|
98
|
-
this.publishLoginState(ELoginState.Error, message);
|
|
99
|
-
return this.showMessage("error", message);
|
|
100
|
-
}
|
|
101
|
-
this.tokenService.accessToken = loginRes.tokens.accessToken;
|
|
102
|
-
const cookieOptions = { expires: (_b = this.loginConfig.expire) !== null && _b !== void 0 ? _b : 365 };
|
|
103
|
-
LocalizeApiToken.storage.set(((_c = this.config.refreshToken) === null || _c === void 0 ? void 0 : _c.name) || '', loginRes.tokens.refreshToken, cookieOptions);
|
|
104
|
-
this.apiService.clearRequiredLoginStateAfterLogin();
|
|
105
|
-
this.publishLoginState(ELoginState.Success);
|
|
106
|
-
this.loginSuccess();
|
|
66
|
+
yield this.apiLoginService.clickLogin();
|
|
107
67
|
});
|
|
108
68
|
}
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
sourceId: this.sourceId,
|
|
113
|
-
message,
|
|
114
|
-
});
|
|
115
|
-
}
|
|
116
|
-
login() {
|
|
117
|
-
var _a, _b, _c;
|
|
118
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
119
|
-
if (!((_a = this.loginUrl) === null || _a === void 0 ? void 0 : _a.trim().length)) {
|
|
120
|
-
this.showMessage("error", "Login url is required");
|
|
121
|
-
throw new Error("Login url is required");
|
|
122
|
-
}
|
|
123
|
-
try {
|
|
124
|
-
if (this.loginConfig.loginFunction) {
|
|
125
|
-
console.log("Using custom login function");
|
|
126
|
-
return yield this.loginConfig.loginFunction((_c = (_b = this.decodeToken) === null || _b === void 0 ? void 0 : _b.email) !== null && _c !== void 0 ? _c : '', this.password.trim(), this.getHeaders());
|
|
127
|
-
}
|
|
128
|
-
return yield new Promise((resolve, reject) => this.httpClient.post(this.loginUrl, { password: this.password.trim() }, { headers: this.getHeaders() }).subscribe({ next: resolve, error: reject }));
|
|
129
|
-
}
|
|
130
|
-
catch (e) {
|
|
131
|
-
this.showMessage("error", e.message);
|
|
132
|
-
return null;
|
|
133
|
-
}
|
|
134
|
-
});
|
|
135
|
-
}
|
|
136
|
-
getHeaders() {
|
|
137
|
-
var _a, _b;
|
|
138
|
-
return {
|
|
139
|
-
[LocalizeApiToken.httpHeaders.X_REFRESH_TOKEN]: (_a = this.tokenService.refreshToken) !== null && _a !== void 0 ? _a : "",
|
|
140
|
-
[LocalizeApiToken.httpHeaders.X_TENANT]: (_b = this.tokenService.tenantToken) !== null && _b !== void 0 ? _b : "",
|
|
141
|
-
};
|
|
142
|
-
}
|
|
143
|
-
get isValidPassword() {
|
|
144
|
-
this.loading = false;
|
|
145
|
-
return this.properties.passwordValidator
|
|
146
|
-
? this.properties.passwordValidator(this.password)
|
|
147
|
-
: this.password && this.password.trim().length >= 6 && this.password.trim().length <= 50;
|
|
69
|
+
clickLogout() {
|
|
70
|
+
var _a;
|
|
71
|
+
(_a = this.logout) === null || _a === void 0 ? void 0 : _a.call(this);
|
|
148
72
|
}
|
|
149
73
|
showMessage(severity, summary) {
|
|
150
74
|
this.messageService.add({ key: this.messageKey, severity, summary });
|
|
151
|
-
this.loading = false;
|
|
152
75
|
}
|
|
153
76
|
get sanitizedTitle() {
|
|
154
77
|
var _a;
|
|
155
78
|
return this.sanitizer.bypassSecurityTrustHtml((_a = this.properties.title) !== null && _a !== void 0 ? _a : '');
|
|
156
79
|
}
|
|
157
80
|
ngOnDestroy() {
|
|
158
|
-
|
|
159
|
-
(_a = this.removeLoginListener) === null || _a === void 0 ? void 0 : _a.call(this);
|
|
81
|
+
this.apiLoginService.unConfigure();
|
|
160
82
|
}
|
|
161
83
|
}
|
|
162
84
|
LocalizeTokenLoginDialogComponent.decorators = [
|
|
@@ -475,7 +397,6 @@ LocalizeTokenLoginDialogComponent.ctorParameters = () => [
|
|
|
475
397
|
{ type: ChangeDetectorRef },
|
|
476
398
|
{ type: DynamicDialogRef },
|
|
477
399
|
{ type: DynamicDialogConfig },
|
|
478
|
-
{ type: HttpClient },
|
|
479
400
|
{ type: DomSanitizer },
|
|
480
401
|
{ type: Injector }
|
|
481
402
|
];
|