@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.
@@ -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 { LocalizeApiService, LocalizeApiBroadcastService, LocalizeApiToken, LocalizeApiTokenService, waitFor } from "@sambath999/localize-api";
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, httpClient, sanitizer, injector) {
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.removeLoginListener = this.broadcastService.listen(this.loginBroadcastChannel, (payload) => {
36
- var _a;
37
- if (!payload || payload.sourceId === this.sourceId) {
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 config() { return this.tokenService.config; }
57
- ngOnInit() {
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.logout = this.loginConfig.logoutFunc;
62
- this.loginUrl = this.loginConfig.loginUrl;
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 is invalid");
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
- if (!this.isValidPassword) {
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
- publishLoginState(state, message) {
102
- this.broadcastService.publish(this.loginBroadcastChannel, {
103
- state,
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
- var _a;
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":";AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAClD,OAAO,EACL,iBAAiB,EACjB,SAAS,EACT,QAAQ,EAGR,iBAAiB,GAClB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAC7C,OAAO,EAAE,mBAAmB,EAAE,gBAAgB,EAAE,MAAM,uBAAuB,CAAC;AAE9E,OAAO,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AACzD,OAAO,EAAc,kBAAkB,EAAE,2BAA2B,EAAE,gBAAgB,EAAE,uBAAuB,EAAE,OAAO,EAAE,MAAM,0BAA0B,CAAC;AAG3J,IAAK,WAIJ;AAJD,WAAK,WAAW;IACd,yDAAU,CAAA;IACV,mDAAO,CAAA;IACP,+CAAK,CAAA;AACP,CAAC,EAJI,WAAW,KAAX,WAAW,QAIf;AA+TD,MAAM,OAAO,iCAAiC;IAoB5C,YACmB,cAA8B,EAC9B,GAAsB,EACtB,MAAwB,EACxB,SAA8B,EAC9B,UAAsB,EACtB,SAAuB,EACvB,QAAkB;QANlB,mBAAc,GAAd,cAAc,CAAgB;QAC9B,QAAG,GAAH,GAAG,CAAmB;QACtB,WAAM,GAAN,MAAM,CAAkB;QACxB,cAAS,GAAT,SAAS,CAAqB;QAC9B,eAAU,GAAV,UAAU,CAAY;QACtB,cAAS,GAAT,SAAS,CAAc;QACvB,aAAQ,GAAR,QAAQ,CAAU;QA1B5B,eAAU,GAAG,YAAY,CAAC;QAGnC,YAAO,GAAG,KAAK,CAAC;QAChB,YAAO,GAAG,KAAK,CAAC;QAQC,0BAAqB,GAAG,mBAAmB,CAAC;QAC5C,aAAQ,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC;QA0InF,gBAAW,GAAG,GAAG,EAAE,WAAC,OAAA,MAAA,IAAI,CAAC,MAAM,+CAAX,IAAI,CAAW,CAAA,EAAA,CAAC;QA3HlC,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,uBAAuB,CAAC,CAAC;QAC/D,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,2BAA2B,CAAC,CAAC;QACvE,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,kBAAkB,CAAC,CAAC;QACxD,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,YAAY,CAAC,kBAAkB,CAAC;QACxD,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC;QACnD,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,WAAW,CAAC,UAAW,CAAC;QAE/C,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAyB,IAAI,CAAC,qBAAqB,EAAE,CAAC,OAAO,EAAE,EAAE;;YACtH,IAAI,CAAC,OAAO,IAAI,OAAO,CAAC,QAAQ,KAAK,IAAI,CAAC,QAAQ,EAAE;gBAClD,OAAO,CAAC,IAAI,CAAC,uEAAuE,EAAE,OAAO,CAAC,CAAC;gBAC/F,OAAO;aACR;YAED,QAAQ,OAAO,CAAC,KAAK,EAAE;gBACrB,KAAK,WAAW,CAAC,UAAU;oBACzB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;oBACpB,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;oBACrB,MAAM;gBACR,KAAK,WAAW,CAAC,OAAO;oBACtB,IAAI,CAAC,UAAU,CAAC,iCAAiC,EAAE,CAAC;oBACpD,IAAI,CAAC,YAAY,EAAE,CAAC;oBACpB,MAAM;gBACR,KAAK,WAAW,CAAC,KAAK;oBACpB,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE,MAAA,OAAO,CAAC,OAAO,mCAAI,cAAc,CAAC,CAAC;oBAC7D,MAAM;aACT;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAlDD,IAAY,MAAM,KAAK,OAAO,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,CAAC;IAoDzD,QAAQ;QACN,IAAI,CAAC,SAAS,CAAC,QAAQ,GAAG,KAAK,CAAC;QAChC,IAAI,CAAC,SAAS,CAAC,eAAe,GAAG,KAAK,CAAC;QACvC,IAAI,CAAC,SAAS,CAAC,KAAK,GAAG,IAAI,CAAC;QAE5B,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC;QAC1C,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAA;QAEzC,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE;YACrB,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE,kBAAkB,CAAC,CAAC;YAC9C,UAAU,CAAC,GAAG,EAAE,WAAC,OAAA,MAAA,IAAI,CAAC,MAAM,+CAAX,IAAI,CAAW,CAAA,EAAA,EAAE,IAAI,CAAC,CAAC;SACzC;IACH,CAAC;IAED,eAAe;QACb,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;IAC3B,CAAC;IAEa,YAAY;;YACxB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;YACpB,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;YACpB,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QAC1B,CAAC;KAAA;IAEK,UAAU;;;YACd,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE;gBACzB,OAAO,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE,wDAAwD,CAAC,CAAC;aAC5F;YAED,IAAI,CAAC,iBAAiB,CAAC,WAAW,CAAC,UAAU,CAAC,CAAC;YAC/C,MAAM,OAAO,CAAC,GAAG,CAAC,CAAC;YACnB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;YACpB,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,KAAK,EAAE,CAAC;YACpC,IAAI,CAAC,CAAA,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAE,MAAM,CAAA,EAAE;gBACrB,MAAM,OAAO,GAAG,MAAA,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAE,OAAO,mCAAI,mBAAmB,CAAC;gBACzD,IAAI,CAAC,iBAAiB,CAAC,WAAW,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;gBACnD,OAAO,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;aAC3C;YAED,IAAI,CAAC,YAAY,CAAC,WAAW,GAAG,QAAQ,CAAC,MAAM,CAAC,WAAW,CAAC;YAC5D,MAAM,aAAa,GAAG,EAAE,OAAO,EAAE,MAAA,IAAI,CAAC,WAAW,CAAC,MAAM,mCAAI,GAAG,EAAE,CAAA;YACjE,gBAAgB,CAAC,OAAO,CAAC,GAAG,CAAC,CAAA,MAAA,IAAI,CAAC,MAAM,CAAC,YAAY,0CAAE,IAAI,KAAI,EAAE,EAAE,QAAQ,CAAC,MAAM,CAAC,YAAY,EAAE,aAAa,CAAC,CAAC;YAChH,IAAI,CAAC,UAAU,CAAC,iCAAiC,EAAE,CAAC;YAEpD,IAAI,CAAC,iBAAiB,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;YAC5C,IAAI,CAAC,YAAY,EAAE,CAAC;;KACrB;IAEO,iBAAiB,CAAC,KAAkB,EAAE,OAAgB;QAC5D,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAyB,IAAI,CAAC,qBAAqB,EAAE;YAChF,KAAK;YACL,QAAQ,EAAE,IAAI,CAAC,QAAQ;YACvB,OAAO;SACR,CAAC,CAAC;IACL,CAAC;IAEa,KAAK;;;YACjB,IAAI,CAAC,CAAA,MAAA,IAAI,CAAC,QAAQ,0CAAE,IAAI,GAAG,MAAM,CAAA,EAAE;gBACjC,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE,uBAAuB,CAAC,CAAC;gBACnD,MAAM,IAAI,KAAK,CAAC,uBAAuB,CAAC,CAAC;aAC1C;YAED,IAAI;gBAEF,IAAI,IAAI,CAAC,WAAW,CAAC,aAAa,EAAE;oBAClC,OAAO,CAAC,GAAG,CAAC,6BAA6B,CAAC,CAAC;oBAC3C,OAAO,MAAM,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,MAAA,MAAA,IAAI,CAAC,WAAW,0CAAE,KAAK,mCAAI,EAAE,EAAE,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,EAAE,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC;iBACrH;gBAED,OAAO,MAAM,IAAI,OAAO,CAAM,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE,CAChD,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,QAAS,EACjC,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,EAAE,EAClC,EAAE,OAAO,EAAE,IAAI,CAAC,UAAU,EAAE,EAAE,CAAC,CAAC,SAAS,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC,CAAC,CAAC;aAElF;YAAC,OAAO,CAAM,EAAE;gBACf,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE,CAAC,CAAC,OAAO,CAAC,CAAC;gBACrC,OAAO,IAAI,CAAC;aACb;;KACF;IAEO,UAAU;;QAChB,OAAO;YACL,CAAC,gBAAgB,CAAC,WAAW,CAAC,eAAe,CAAC,EAAE,MAAA,IAAI,CAAC,YAAY,CAAC,YAAY,mCAAI,EAAE;YACpF,CAAC,gBAAgB,CAAC,WAAW,CAAC,QAAQ,CAAC,EAAE,MAAA,IAAI,CAAC,YAAY,CAAC,WAAW,mCAAI,EAAE;SAC7E,CAAC;IACJ,CAAC;IAED,IAAI,eAAe;QACjB,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;QACrB,OAAO,IAAI,CAAC,UAAU,CAAC,iBAAiB;YACtC,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,iBAAiB,CAAC,IAAI,CAAC,QAAQ,CAAC;YAClD,CAAC,CAAC,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC,MAAM,IAAI,CAAC,IAAI,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC,MAAM,IAAI,EAAE,CAAC;IAC7F,CAAC;IAIO,WAAW,CAAC,QAAgB,EAAE,OAAe;QACnD,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,UAAU,EAAE,QAAQ,EAAE,OAAO,EAAE,CAAC,CAAC;QACrE,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;IACvB,CAAC;IAED,IAAI,cAAc;;QAChB,OAAO,IAAI,CAAC,SAAS,CAAC,uBAAuB,CAAC,MAAA,IAAI,CAAC,UAAU,CAAC,KAAK,mCAAI,EAAE,CAAC,CAAC;IAC7E,CAAC;IAED,WAAW;;QACT,MAAA,IAAI,CAAC,mBAAmB,+CAAxB,IAAI,CAAwB,CAAC;IAC/B,CAAC;;;YA1dF,SAAS,SAAC;gBAqPT,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;SA2DH;gBACP,QAAQ,EAAE,uBAAuB;gBACjC,SAAS,EAAE,CAAC,cAAc,CAAC;gBAC3B,aAAa,EAAE,iBAAiB,CAAC,IAAI;yBAlT5B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAmPR;aAgEF;;;YAzUQ,cAAc;YAPrB,iBAAiB;YAQW,gBAAgB;YAArC,mBAAmB;YAVnB,UAAU;YAYV,YAAY;YARnB,QAAQ","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/OiBJTG9naW5EaWFsb2dQbGFjZUhvbGRlcjtcclxuICBsb2dpbkJ1dHRvbj86IElMb2dpbkRpYWxvZ1BsYWNlSG9sZGVyO1xyXG4gIGxvZ291dEJ1dHRvbj86IElMb2dpbkRpYWxvZ1BsYWNlSG9sZGVyO1xyXG4gIC8qKlxyXG4gICAqIEZ1bmN0aW9uIHRvIHZhbGlkYXRlIHRoZSBwYXNzd29yZC5cclxuICAgKiBJZiBub3QgcHJvdmlkZWQsIHRoZSBkZWZhdWx0IHZhbGlkYXRpb24gY2hlY2tzIGlmIHRoZSBwYXNzd29yZCBpcyBiZXR3ZWVuIDYgYW5kIDUwIGNoYXJhY3RlcnMgbG9uZy5cclxuICAgKiBAcGFyYW0gcGFzc3dvcmRcclxuICAgKiBAcmV0dXJuc1xyXG4gICAqL1xyXG4gIHBhc3N3b3JkVmFsaWRhdG9yPzogKHBhc3N3b3JkOiBzdHJpbmcpID0+IGJvb2xlYW47XHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgSUxvZ2luRGlhbG9nQ29uZmlnIHtcclxuICBsb2dpblVybD86IHN0cmluZztcclxuICBsb2dvdXRVcmw/OiBzdHJpbmc7XHJcbiAgbG9naW5GdW5jdGlvbj86ICh1c2VybmFtZTogc3RyaW5nLCBwYXNzd29yZDogc3RyaW5nLCBoZWFkZXJzPzogeyBba2V5OiBzdHJpbmddOiBzdHJpbmcgfSkgPT4gUHJvbWlzZTxhbnk+O1xyXG4gIGxvZ291dEZ1bmM/OiAoKSA9PiB2b2lkO1xyXG4gIC8qKlxyXG4gICAqIENvb2tpZSBleHBpcmF0aW9uIGRhdGUgaW4gZGF5cyBmcm9tIG5vdy4gSWYgbm90IHByb3ZpZGVkIHRoZSBjb29raWUgaXMgYSBzZXNzaW9uIGNvb2tpZVxyXG4gICAqL1xyXG4gIGV4cGlyZT86IG51bWJlcjtcclxuICAvKipcclxuICAgKiBDb25maWd1cmF0aW9uIGZvciB0aGUgbG9naW4gZGlhbG9nLlxyXG4gICAqIFRoaXMgaW50ZXJmYWNlIGRlZmluZXMgdGhlIHByb3BlcnRpZXMgdGhhdCBjYW4gYmUgdXNlZCB0byBjdXN0b21pemUgdGhlIGxvZ2luIGRpYWxvZydzIGJlaGF2aW9yIGFuZCBhcHBlYXJhbmNlXHJcbiAgICovXHJcbiAgcHJvcGVydGllcz86IElMb2dpbkRpYWxvZ1Byb3BlcnRpZXM7XHJcbn1cclxuIl19
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 { LocalizeApiTokenService, LocalizeApiBroadcastService, LocalizeApiService, waitFor, LocalizeApiToken } from '@sambath999/localize-api';
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, httpClient, sanitizer, injector) {
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.removeLoginListener = this.broadcastService.listen(this.loginBroadcastChannel, (payload) => {
44
- var _a;
45
- if (!payload || payload.sourceId === this.sourceId) {
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 config() { return this.tokenService.config; }
65
- ngOnInit() {
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.logout = this.loginConfig.logoutFunc;
70
- this.loginUrl = this.loginConfig.loginUrl;
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 is invalid");
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
- if (!this.isValidPassword) {
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
- publishLoginState(state, message) {
110
- this.broadcastService.publish(this.loginBroadcastChannel, {
111
- state,
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
- var _a;
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
  ];