@trudb/tru-common-lib 0.1.550 → 0.1.552

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.
@@ -0,0 +1,18 @@
1
+ export class TruServerError {
2
+ id;
3
+ type;
4
+ code;
5
+ message;
6
+ stackTrace;
7
+ status;
8
+ constructor(error) {
9
+ let parsedError = JSON.parse(error.error);
10
+ this.id = parsedError.$id;
11
+ this.type = parsedError.$type;
12
+ this.code = parsedError.Code;
13
+ this.message = parsedError.Message;
14
+ this.stackTrace = parsedError.StackTrace;
15
+ this.status = error.status;
16
+ }
17
+ }
18
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJ1LXNlcnZlci1lcnJvci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3RydS1jb21tb24tbGliL3NyYy9saWIvY2xhc3Nlcy90cnUtc2VydmVyLWVycm9yLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUdBLE1BQU0sT0FBTyxjQUFjO0lBQ3pCLEVBQUUsQ0FBUztJQUNYLElBQUksQ0FBUztJQUNiLElBQUksQ0FBUztJQUNiLE9BQU8sQ0FBUztJQUNoQixVQUFVLENBQVM7SUFDbkIsTUFBTSxDQUFTO0lBRWYsWUFBWSxLQUF3QjtRQUNsQyxJQUFJLFdBQVcsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUMxQyxJQUFJLENBQUMsRUFBRSxHQUFHLFdBQVcsQ0FBQyxHQUFHLENBQUM7UUFDMUIsSUFBSSxDQUFDLElBQUksR0FBRyxXQUFXLENBQUMsS0FBSyxDQUFDO1FBQzlCLElBQUksQ0FBQyxJQUFJLEdBQUcsV0FBVyxDQUFDLElBQUksQ0FBQztRQUM3QixJQUFJLENBQUMsT0FBTyxHQUFHLFdBQVcsQ0FBQyxPQUFPLENBQUM7UUFDbkMsSUFBSSxDQUFDLFVBQVUsR0FBRyxXQUFXLENBQUMsVUFBVSxDQUFDO1FBQ3pDLElBQUksQ0FBQyxNQUFNLEdBQUcsS0FBSyxDQUFDLE1BQU0sQ0FBQztJQUM3QixDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBIdHRwRXJyb3JSZXNwb25zZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbi9odHRwJztcclxuaW1wb3J0IHsgVHJ1UHJvcGVydHlDb25maWdCYXNlIH0gZnJvbSAnLi4vYmFzZS1jbGFzc2VzL3RydS1wcm9wZXJ0eS1jb25maWctYmFzZSc7XHJcblxyXG5leHBvcnQgY2xhc3MgVHJ1U2VydmVyRXJyb3Ige1xyXG4gIGlkOiBzdHJpbmc7XHJcbiAgdHlwZTogc3RyaW5nO1xyXG4gIGNvZGU6IG51bWJlcjtcclxuICBtZXNzYWdlOiBzdHJpbmc7XHJcbiAgc3RhY2tUcmFjZTogc3RyaW5nO1xyXG4gIHN0YXR1czogbnVtYmVyO1xyXG5cclxuICBjb25zdHJ1Y3RvcihlcnJvcjogSHR0cEVycm9yUmVzcG9uc2UpIHtcclxuICAgIGxldCBwYXJzZWRFcnJvciA9IEpTT04ucGFyc2UoZXJyb3IuZXJyb3IpO1xyXG4gICAgdGhpcy5pZCA9IHBhcnNlZEVycm9yLiRpZDtcclxuICAgIHRoaXMudHlwZSA9IHBhcnNlZEVycm9yLiR0eXBlO1xyXG4gICAgdGhpcy5jb2RlID0gcGFyc2VkRXJyb3IuQ29kZTtcclxuICAgIHRoaXMubWVzc2FnZSA9IHBhcnNlZEVycm9yLk1lc3NhZ2U7XHJcbiAgICB0aGlzLnN0YWNrVHJhY2UgPSBwYXJzZWRFcnJvci5TdGFja1RyYWNlO1xyXG4gICAgdGhpcy5zdGF0dXMgPSBlcnJvci5zdGF0dXM7XHJcbiAgfVxyXG59XHJcbiJdfQ==
@@ -0,0 +1,9 @@
1
+ export class TruErrorDialogConfig {
2
+ title;
3
+ message;
4
+ constructor(title, message) {
5
+ this.title = title;
6
+ this.message = message;
7
+ }
8
+ }
9
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJ1LWVycm9yLWRpYWxvZy1jb25maWcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90cnUtY29tbW9uLWxpYi9zcmMvbGliL2NvbXBvbmVudHMvZXJyb3ItZGlhbG9nL2NsYXNzZXMvdHJ1LWVycm9yLWRpYWxvZy1jb25maWcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxPQUFPLG9CQUFvQjtJQUV0QjtJQUNBO0lBRlQsWUFDUyxLQUFhLEVBQ2IsT0FBZTtRQURmLFVBQUssR0FBTCxLQUFLLENBQVE7UUFDYixZQUFPLEdBQVAsT0FBTyxDQUFRO0lBQ3hCLENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjbGFzcyBUcnVFcnJvckRpYWxvZ0NvbmZpZyB7XHJcbiAgY29uc3RydWN0b3IoXHJcbiAgICBwdWJsaWMgdGl0bGU6IHN0cmluZyxcclxuICAgIHB1YmxpYyBtZXNzYWdlOiBzdHJpbmcpIHtcclxuICB9XHJcbn1cclxuIl19
@@ -2,21 +2,22 @@ import { Injectable } from "@angular/core";
2
2
  import { throwError } from "rxjs";
3
3
  import { catchError } from "rxjs/operators";
4
4
  import * as i0 from "@angular/core";
5
- import * as i1 from "../../../services/tru-app-environment";
5
+ import * as i1 from "../../../services/tru-error-manager";
6
6
  export class TruErrorInterceptor {
7
- appEnvironment;
8
- constructor(appEnvironment) {
9
- this.appEnvironment = appEnvironment;
7
+ errorManager;
8
+ constructor(errorManager) {
9
+ this.errorManager = errorManager;
10
10
  }
11
11
  intercept(request, next) {
12
12
  return next.handle(request).pipe(catchError((error) => {
13
+ this.errorManager.handleError(error);
13
14
  return throwError(error);
14
15
  }));
15
16
  }
16
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: TruErrorInterceptor, deps: [{ token: i1.TruAppEnvironment }], target: i0.ɵɵFactoryTarget.Injectable });
17
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: TruErrorInterceptor, deps: [{ token: i1.TruErrorManager }], target: i0.ɵɵFactoryTarget.Injectable });
17
18
  static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: TruErrorInterceptor });
18
19
  }
19
20
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: TruErrorInterceptor, decorators: [{
20
21
  type: Injectable
21
- }], ctorParameters: () => [{ type: i1.TruAppEnvironment }] });
22
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJ1LWVycm9yLWludGVyY2VwdG9yLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdHJ1LWNvbW1vbi1saWIvc3JjL2xpYi9jb21wb25lbnRzL2Vycm9yLWRpYWxvZy9zZXJ2aWNlcy90cnUtZXJyb3ItaW50ZXJjZXB0b3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBVSxNQUFNLGVBQWUsQ0FBQztBQU9uRCxPQUFPLEVBQWMsVUFBVSxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBQzlDLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQzs7O0FBSTVDLE1BQU0sT0FBTyxtQkFBbUI7SUFFcEI7SUFEVixZQUNVLGNBQWlDO1FBQWpDLG1CQUFjLEdBQWQsY0FBYyxDQUFtQjtJQUN2QyxDQUFDO0lBRUwsU0FBUyxDQUNQLE9BQXlCLEVBQ3pCLElBQWlCO1FBRWpCLE9BQU8sSUFBSSxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsQ0FBQyxJQUFJLENBQzlCLFVBQVUsQ0FBQyxDQUFDLEtBQUssRUFBRSxFQUFFO1lBRW5CLE9BQU8sVUFBVSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQzNCLENBQUMsQ0FBQyxDQUNILENBQUM7SUFDSixDQUFDO3VHQWZVLG1CQUFtQjsyR0FBbkIsbUJBQW1COzsyRkFBbkIsbUJBQW1CO2tCQUQvQixVQUFVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSwgSW5qZWN0IH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0IHtcclxuICBIdHRwUmVxdWVzdCxcclxuICBIdHRwSGFuZGxlcixcclxuICBIdHRwRXZlbnQsXHJcbiAgSHR0cEludGVyY2VwdG9yLFxyXG59IGZyb20gXCJAYW5ndWxhci9jb21tb24vaHR0cFwiO1xyXG5pbXBvcnQgeyBPYnNlcnZhYmxlLCB0aHJvd0Vycm9yIH0gZnJvbSBcInJ4anNcIjtcclxuaW1wb3J0IHsgY2F0Y2hFcnJvciB9IGZyb20gXCJyeGpzL29wZXJhdG9yc1wiO1xyXG5pbXBvcnQgeyBUcnVBcHBFbnZpcm9ubWVudCB9IGZyb20gXCIuLi8uLi8uLi9zZXJ2aWNlcy90cnUtYXBwLWVudmlyb25tZW50XCI7XHJcblxyXG5ASW5qZWN0YWJsZSgpXHJcbmV4cG9ydCBjbGFzcyBUcnVFcnJvckludGVyY2VwdG9yIGltcGxlbWVudHMgSHR0cEludGVyY2VwdG9yIHtcclxuICBjb25zdHJ1Y3RvcihcclxuICAgIHByaXZhdGUgYXBwRW52aXJvbm1lbnQ6IFRydUFwcEVudmlyb25tZW50LFxyXG4gICkgeyB9XHJcblxyXG4gIGludGVyY2VwdChcclxuICAgIHJlcXVlc3Q6IEh0dHBSZXF1ZXN0PGFueT4sXHJcbiAgICBuZXh0OiBIdHRwSGFuZGxlclxyXG4gICk6IE9ic2VydmFibGU8SHR0cEV2ZW50PGFueT4+IHtcclxuICAgIHJldHVybiBuZXh0LmhhbmRsZShyZXF1ZXN0KS5waXBlKFxyXG4gICAgICBjYXRjaEVycm9yKChlcnJvcikgPT4ge1xyXG4gICAgICAgIFxyXG4gICAgICAgIHJldHVybiB0aHJvd0Vycm9yKGVycm9yKTtcclxuICAgICAgfSlcclxuICAgICk7XHJcbiAgfVxyXG59XHJcbiJdfQ==
22
+ }], ctorParameters: () => [{ type: i1.TruErrorManager }] });
23
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJ1LWVycm9yLWludGVyY2VwdG9yLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdHJ1LWNvbW1vbi1saWIvc3JjL2xpYi9jb21wb25lbnRzL2Vycm9yLWRpYWxvZy9zZXJ2aWNlcy90cnUtZXJyb3ItaW50ZXJjZXB0b3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBVSxNQUFNLGVBQWUsQ0FBQztBQVFuRCxPQUFPLEVBQWMsVUFBVSxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBQzlDLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQzs7O0FBSTVDLE1BQU0sT0FBTyxtQkFBbUI7SUFDVjtJQUFwQixZQUFvQixZQUE2QjtRQUE3QixpQkFBWSxHQUFaLFlBQVksQ0FBaUI7SUFBSSxDQUFDO0lBRXRELFNBQVMsQ0FDUCxPQUF5QixFQUN6QixJQUFpQjtRQUVqQixPQUFPLElBQUksQ0FBQyxNQUFNLENBQUMsT0FBTyxDQUFDLENBQUMsSUFBSSxDQUM5QixVQUFVLENBQUMsQ0FBQyxLQUF3QixFQUFFLEVBQUU7WUFDdEMsSUFBSSxDQUFDLFlBQVksQ0FBQyxXQUFXLENBQUMsS0FBSyxDQUFDLENBQUM7WUFDckMsT0FBTyxVQUFVLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDM0IsQ0FBQyxDQUFDLENBQ0gsQ0FBQztJQUNKLENBQUM7dUdBYlUsbUJBQW1COzJHQUFuQixtQkFBbUI7OzJGQUFuQixtQkFBbUI7a0JBRC9CLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlLCBJbmplY3QgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQge1xyXG4gIEh0dHBSZXF1ZXN0LFxyXG4gIEh0dHBIYW5kbGVyLFxyXG4gIEh0dHBFdmVudCxcclxuICBIdHRwSW50ZXJjZXB0b3IsXHJcbiAgSHR0cEVycm9yUmVzcG9uc2UsXHJcbn0gZnJvbSBcIkBhbmd1bGFyL2NvbW1vbi9odHRwXCI7XHJcbmltcG9ydCB7IE9ic2VydmFibGUsIHRocm93RXJyb3IgfSBmcm9tIFwicnhqc1wiO1xyXG5pbXBvcnQgeyBjYXRjaEVycm9yIH0gZnJvbSBcInJ4anMvb3BlcmF0b3JzXCI7XHJcbmltcG9ydCB7IFRydUVycm9yTWFuYWdlciB9IGZyb20gXCIuLi8uLi8uLi9zZXJ2aWNlcy90cnUtZXJyb3ItbWFuYWdlclwiO1xyXG5cclxuQEluamVjdGFibGUoKVxyXG5leHBvcnQgY2xhc3MgVHJ1RXJyb3JJbnRlcmNlcHRvciBpbXBsZW1lbnRzIEh0dHBJbnRlcmNlcHRvciB7XHJcbiAgY29uc3RydWN0b3IocHJpdmF0ZSBlcnJvck1hbmFnZXI6IFRydUVycm9yTWFuYWdlcikgeyB9XHJcblxyXG4gIGludGVyY2VwdChcclxuICAgIHJlcXVlc3Q6IEh0dHBSZXF1ZXN0PGFueT4sXHJcbiAgICBuZXh0OiBIdHRwSGFuZGxlclxyXG4gICk6IE9ic2VydmFibGU8SHR0cEV2ZW50PGFueT4+IHtcclxuICAgIHJldHVybiBuZXh0LmhhbmRsZShyZXF1ZXN0KS5waXBlKFxyXG4gICAgICBjYXRjaEVycm9yKChlcnJvcjogSHR0cEVycm9yUmVzcG9uc2UpID0+IHtcclxuICAgICAgICB0aGlzLmVycm9yTWFuYWdlci5oYW5kbGVFcnJvcihlcnJvcik7XHJcbiAgICAgICAgcmV0dXJuIHRocm93RXJyb3IoZXJyb3IpO1xyXG4gICAgICB9KVxyXG4gICAgKTtcclxuICB9XHJcbn1cclxuIl19
@@ -0,0 +1,113 @@
1
+ import { Injectable } from "@angular/core";
2
+ import { TruErrorDialog } from "../components/error-dialog/tru-error-dialog";
3
+ import { TruErrorDialogConfig } from "../components/error-dialog/classes/tru-error-dialog-config";
4
+ import { TruServerError } from "../classes/tru-server-error";
5
+ import * as i0 from "@angular/core";
6
+ import * as i1 from "@angular/common/http";
7
+ import * as i2 from "@angular/material/dialog";
8
+ import * as i3 from "./tru-text-manager";
9
+ import * as i4 from "./tru-ui-notification";
10
+ import * as i5 from "./tru-app-environment";
11
+ export class TruErrorManager {
12
+ http;
13
+ dialog;
14
+ textManager;
15
+ uiNotification;
16
+ appEnvironment;
17
+ baseUrl;
18
+ appName;
19
+ constructor(http, dialog, textManager, uiNotification, appEnvironment) {
20
+ this.http = http;
21
+ this.dialog = dialog;
22
+ this.textManager = textManager;
23
+ this.uiNotification = uiNotification;
24
+ this.appEnvironment = appEnvironment;
25
+ this.baseUrl = appEnvironment.appUri;
26
+ this.appName = appEnvironment.appName;
27
+ }
28
+ logErrorEvent = (message, context, area) => {
29
+ area = area || 'unknown';
30
+ console.log('[' + area + '|' + context + '] ' + message);
31
+ var logEvent = {
32
+ eventType: 'Error',
33
+ eventDate: new Date(),
34
+ applicationName: this.appName,
35
+ applicationUrl: this.baseUrl,
36
+ applicationArea: area,
37
+ context: context,
38
+ message: message
39
+ };
40
+ this.http
41
+ .post(`${this.baseUrl}/api/log/logevent`, logEvent)
42
+ .subscribe(() => {
43
+ }, (ex) => {
44
+ console.log('Unable to log error to server. ' + ex);
45
+ });
46
+ };
47
+ handleClientSideError = (error) => {
48
+ };
49
+ handleServerSideError = (error) => {
50
+ let serverError = new TruServerError(error);
51
+ if (serverError.type === 'tru-db-custom-exception') {
52
+ //var service = $injector.get(error.httpResponse.data.serviceName);
53
+ //var exceptionData = error.httpResponse.data.data;
54
+ //service(exceptionData);
55
+ }
56
+ else if (serverError.type.indexOf('TruDbRequireValidChoiceException') !== -1) {
57
+ let dialogConfig = new TruErrorDialogConfig('Require Valid Choice Exception', error.message);
58
+ this.dialog.open(TruErrorDialog, {
59
+ disableClose: true,
60
+ minWidth: "400px",
61
+ maxWidth: "600px",
62
+ data: dialogConfig
63
+ });
64
+ }
65
+ else if (serverError.type.indexOf('DuplicateKeyError') !== -1) {
66
+ let dialogConfig = new TruErrorDialogConfig('Duplicate Key Error', error.message
67
+ .replace('Cannot insert duplicate key row in object', 'Cannot insert duplicate value in table')
68
+ .replace('dbo.', '')
69
+ .replace('UIX_', '')
70
+ .replace('The statement has been terminated.', ''));
71
+ this.dialog.open(TruErrorDialog, {
72
+ disableClose: true,
73
+ minWidth: "400px",
74
+ maxWidth: "600px",
75
+ data: dialogConfig
76
+ });
77
+ }
78
+ else if (serverError.type.indexOf('OptimisticLockViolation') !== -1) {
79
+ let dialogConfig = new TruErrorDialogConfig('Concurrent saves not allowed', 'Please review any changes and save again.');
80
+ this.dialog.open(TruErrorDialog, {
81
+ disableClose: true,
82
+ minWidth: "400px",
83
+ maxWidth: "600px",
84
+ data: dialogConfig
85
+ });
86
+ }
87
+ else if (error.type.toString().lastIndexOf('TruDB.EfMssql.Runtime.DataError', 0) === 0) {
88
+ //this.uiNotification.error(
89
+ // this.textManager.fmtDataError(error.httpResponse.data.Detail.$type),
90
+ // [this.textManager.fmtExceptionToShow(error.httpResponse.data.Exception)])
91
+ }
92
+ else {
93
+ //var message = this.textManager.fmtErrorToShow(error);
94
+ //this.uiNotification.showErrorDialog(message);
95
+ //this.logErrorEvent(message);
96
+ }
97
+ };
98
+ handleError = (error) => {
99
+ if (error.type)
100
+ this.handleClientSideError(error);
101
+ else
102
+ this.handleServerSideError(error);
103
+ };
104
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: TruErrorManager, deps: [{ token: i1.HttpClient }, { token: i2.MatDialog }, { token: i3.TruTextManager }, { token: i4.TruUiNotification }, { token: i5.TruAppEnvironment }], target: i0.ɵɵFactoryTarget.Injectable });
105
+ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: TruErrorManager, providedIn: 'root' });
106
+ }
107
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: TruErrorManager, decorators: [{
108
+ type: Injectable,
109
+ args: [{
110
+ providedIn: 'root',
111
+ }]
112
+ }], ctorParameters: () => [{ type: i1.HttpClient }, { type: i2.MatDialog }, { type: i3.TruTextManager }, { type: i4.TruUiNotification }, { type: i5.TruAppEnvironment }] });
113
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tru-error-manager.js","sourceRoot":"","sources":["../../../../../projects/tru-common-lib/src/lib/services/tru-error-manager.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAG3C,OAAO,EAAE,cAAc,EAAE,MAAM,6CAA6C,CAAC;AAC7E,OAAO,EAAE,oBAAoB,EAAE,MAAM,4DAA4D,CAAC;AAIlG,OAAO,EAAE,cAAc,EAAE,MAAM,6BAA6B,CAAC;;;;;;;AAK7D,MAAM,OAAO,eAAe;IAKhB;IACA;IACA;IACA;IACA;IARF,OAAO,CAAS;IAChB,OAAO,CAAS;IAExB,YACU,IAAgB,EAChB,MAAiB,EACjB,WAA2B,EAC3B,cAAiC,EACjC,cAAiC;QAJjC,SAAI,GAAJ,IAAI,CAAY;QAChB,WAAM,GAAN,MAAM,CAAW;QACjB,gBAAW,GAAX,WAAW,CAAgB;QAC3B,mBAAc,GAAd,cAAc,CAAmB;QACjC,mBAAc,GAAd,cAAc,CAAmB;QACzC,IAAI,CAAC,OAAO,GAAG,cAAc,CAAC,MAAM,CAAC;QACrC,IAAI,CAAC,OAAO,GAAG,cAAc,CAAC,OAAO,CAAC;IACxC,CAAC;IAEO,aAAa,GAAG,CAAC,OAAe,EAAE,OAAe,EAAE,IAAY,EAAE,EAAE;QACzE,IAAI,GAAG,IAAI,IAAI,SAAS,CAAC;QACzB,OAAO,CAAC,GAAG,CAAC,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,OAAO,GAAG,IAAI,GAAG,OAAO,CAAC,CAAC;QACzD,IAAI,QAAQ,GAAG;YACb,SAAS,EAAE,OAAO;YAClB,SAAS,EAAE,IAAI,IAAI,EAAE;YACrB,eAAe,EAAE,IAAI,CAAC,OAAO;YAC7B,cAAc,EAAE,IAAI,CAAC,OAAO;YAC5B,eAAe,EAAE,IAAI;YACrB,OAAO,EAAE,OAAO;YAChB,OAAO,EAAE,OAAO;SACjB,CAAC;QACF,IAAI,CAAC,IAAI;aACN,IAAI,CAAM,GAAG,IAAI,CAAC,OAAO,mBAAmB,EAAE,QAAQ,CAAC;aACvD,SAAS,CAAC,GAAG,EAAE;QAEhB,CAAC,EAAE,CAAC,EAAO,EAAE,EAAE;YACb,OAAO,CAAC,GAAG,CAAC,iCAAiC,GAAG,EAAE,CAAC,CAAC;QACtD,CAAC,CAAC,CAAC;IACP,CAAC,CAAA;IAEO,qBAAqB,GAAG,CAAC,KAAwB,EAAE,EAAE;IAE7D,CAAC,CAAA;IAEO,qBAAqB,GAAG,CAAC,KAAwB,EAAE,EAAE;QAC3D,IAAI,WAAW,GAAG,IAAI,cAAc,CAAC,KAAK,CAAC,CAAC;QAC5C,IAAI,WAAW,CAAC,IAAI,KAAK,yBAAyB,EAAE,CAAC;YACnD,mEAAmE;YACnE,mDAAmD;YACnD,yBAAyB;QAC3B,CAAC;aAAM,IAAI,WAAW,CAAC,IAAI,CAAC,OAAO,CAAC,kCAAkC,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC;YAE/E,IAAI,YAAY,GAAG,IAAI,oBAAoB,CACzC,gCAAgC,EAChC,KAAK,CAAC,OAAO,CAAC,CAAC;YAEjB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,cAAc,EAAE;gBAC/B,YAAY,EAAE,IAAI;gBAClB,QAAQ,EAAE,OAAO;gBACjB,QAAQ,EAAE,OAAO;gBACjB,IAAI,EAAE,YAAY;aACnB,CAAC,CAAC;QACL,CAAC;aAAM,IAAI,WAAW,CAAC,IAAI,CAAC,OAAO,CAAC,mBAAmB,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC;YAEhE,IAAI,YAAY,GAAG,IAAI,oBAAoB,CACzC,qBAAqB,EACrB,KAAK,CAAC,OAAO;iBACV,OAAO,CAAC,2CAA2C,EAAE,wCAAwC,CAAC;iBAC9F,OAAO,CAAC,MAAM,EAAE,EAAE,CAAC;iBACnB,OAAO,CAAC,MAAM,EAAE,EAAE,CAAC;iBACnB,OAAO,CAAC,oCAAoC,EAAE,EAAE,CAAC,CAAC,CAAC;YAExD,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,cAAc,EAAE;gBAC/B,YAAY,EAAE,IAAI;gBAClB,QAAQ,EAAE,OAAO;gBACjB,QAAQ,EAAE,OAAO;gBACjB,IAAI,EAAE,YAAY;aACnB,CAAC,CAAC;QAEL,CAAC;aAAM,IAAI,WAAW,CAAC,IAAI,CAAC,OAAO,CAAC,yBAAyB,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC;YAEtE,IAAI,YAAY,GAAG,IAAI,oBAAoB,CACzC,8BAA8B,EAC9B,2CAA2C,CAAC,CAAC;YAE/C,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,cAAc,EAAE;gBAC/B,YAAY,EAAE,IAAI;gBAClB,QAAQ,EAAE,OAAO;gBACjB,QAAQ,EAAE,OAAO;gBACjB,IAAI,EAAE,YAAY;aACnB,CAAC,CAAC;QACL,CAAC;aAAM,IAAI,KAAK,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,WAAW,CAAC,iCAAiC,EAAE,CAAC,CAAC,KAAK,CAAC,EAAE,CAAC;YAEzF,4BAA4B;YAC5B,wEAAwE;YACxE,6EAA6E;QAC/E,CAAC;aAAM,CAAC;YACN,uDAAuD;YACvD,+CAA+C;YAC/C,8BAA8B;QAChC,CAAC;IACH,CAAC,CAAA;IAED,WAAW,GAAG,CAAC,KAAwB,EAAE,EAAE;QACzC,IAAI,KAAK,CAAC,IAAI;YACZ,IAAI,CAAC,qBAAqB,CAAC,KAAK,CAAC,CAAC;;YAElC,IAAI,CAAC,qBAAqB,CAAC,KAAK,CAAC,CAAC;IACtC,CAAC,CAAA;uGAvGU,eAAe;2GAAf,eAAe,cAFd,MAAM;;2FAEP,eAAe;kBAH3B,UAAU;mBAAC;oBACV,UAAU,EAAE,MAAM;iBACnB","sourcesContent":["import { Injectable } from \"@angular/core\";\r\nimport { TruUiNotification } from \"./tru-ui-notification\";\r\nimport { TruTextManager } from \"./tru-text-manager\";\r\nimport { TruErrorDialog } from \"../components/error-dialog/tru-error-dialog\";\r\nimport { TruErrorDialogConfig } from \"../components/error-dialog/classes/tru-error-dialog-config\";\r\nimport { MatDialog } from \"@angular/material/dialog\";\r\nimport { HttpClient, HttpErrorResponse } from \"@angular/common/http\";\r\nimport { TruAppEnvironment } from \"./tru-app-environment\";\r\nimport { TruServerError } from \"../classes/tru-server-error\";\r\n\r\n@Injectable({\r\n  providedIn: 'root',\r\n})\r\nexport class TruErrorManager {\r\n  private baseUrl: string;\r\n  private appName: string;\r\n\r\n  constructor(\r\n    private http: HttpClient,\r\n    private dialog: MatDialog,\r\n    private textManager: TruTextManager,\r\n    private uiNotification: TruUiNotification,\r\n    private appEnvironment: TruAppEnvironment) {\r\n    this.baseUrl = appEnvironment.appUri;\r\n    this.appName = appEnvironment.appName;\r\n  }\r\n\r\n  private logErrorEvent = (message: string, context: string, area: string) => {\r\n    area = area || 'unknown';\r\n    console.log('[' + area + '|' + context + '] ' + message);\r\n    var logEvent = {\r\n      eventType: 'Error',\r\n      eventDate: new Date(),\r\n      applicationName: this.appName,\r\n      applicationUrl: this.baseUrl,\r\n      applicationArea: area,\r\n      context: context,\r\n      message: message\r\n    };\r\n    this.http\r\n      .post<any>(`${this.baseUrl}/api/log/logevent`, logEvent)\r\n      .subscribe(() => {\r\n\r\n      }, (ex: any) => {\r\n        console.log('Unable to log error to server. ' + ex);\r\n      });\r\n  }\r\n\r\n  private handleClientSideError = (error: HttpErrorResponse) => {\r\n\r\n  }\r\n\r\n  private handleServerSideError = (error: HttpErrorResponse) => {\r\n    let serverError = new TruServerError(error);\r\n    if (serverError.type === 'tru-db-custom-exception') {\r\n      //var service = $injector.get(error.httpResponse.data.serviceName);\r\n      //var exceptionData = error.httpResponse.data.data;\r\n      //service(exceptionData);\r\n    } else if (serverError.type.indexOf('TruDbRequireValidChoiceException') !== -1) {\r\n\r\n      let dialogConfig = new TruErrorDialogConfig(\r\n        'Require Valid Choice Exception',\r\n        error.message);\r\n\r\n      this.dialog.open(TruErrorDialog, {\r\n        disableClose: true,\r\n        minWidth: \"400px\",\r\n        maxWidth: \"600px\",\r\n        data: dialogConfig\r\n      });\r\n    } else if (serverError.type.indexOf('DuplicateKeyError') !== -1) {\r\n\r\n      let dialogConfig = new TruErrorDialogConfig(\r\n        'Duplicate Key Error',\r\n        error.message\r\n          .replace('Cannot insert duplicate key row in object', 'Cannot insert duplicate value in table')\r\n          .replace('dbo.', '')\r\n          .replace('UIX_', '')\r\n          .replace('The statement has been terminated.', ''));\r\n\r\n      this.dialog.open(TruErrorDialog, {\r\n        disableClose: true,\r\n        minWidth: \"400px\",\r\n        maxWidth: \"600px\",\r\n        data: dialogConfig\r\n      });\r\n\r\n    } else if (serverError.type.indexOf('OptimisticLockViolation') !== -1) {\r\n\r\n      let dialogConfig = new TruErrorDialogConfig(\r\n        'Concurrent saves not allowed',\r\n        'Please review any changes and save again.');\r\n\r\n      this.dialog.open(TruErrorDialog, {\r\n        disableClose: true,\r\n        minWidth: \"400px\",\r\n        maxWidth: \"600px\",\r\n        data: dialogConfig\r\n      });\r\n    } else if (error.type.toString().lastIndexOf('TruDB.EfMssql.Runtime.DataError', 0) === 0) {\r\n\r\n      //this.uiNotification.error(\r\n      //  this.textManager.fmtDataError(error.httpResponse.data.Detail.$type),\r\n      //  [this.textManager.fmtExceptionToShow(error.httpResponse.data.Exception)])\r\n    } else {\r\n      //var message = this.textManager.fmtErrorToShow(error);\r\n      //this.uiNotification.showErrorDialog(message);\r\n      //this.logErrorEvent(message);\r\n    }\r\n  }\r\n\r\n  handleError = (error: HttpErrorResponse) => {\r\n    if (error.type)\r\n      this.handleClientSideError(error);\r\n    else\r\n      this.handleServerSideError(error);\r\n  }\r\n}\r\n"]}
@@ -9176,23 +9176,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImpor
9176
9176
  type: Injectable
9177
9177
  }] });
9178
9178
 
9179
- class TruErrorInterceptor {
9180
- appEnvironment;
9181
- constructor(appEnvironment) {
9182
- this.appEnvironment = appEnvironment;
9183
- }
9184
- intercept(request, next) {
9185
- return next.handle(request).pipe(catchError((error) => {
9186
- return throwError(error);
9187
- }));
9188
- }
9189
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: TruErrorInterceptor, deps: [{ token: TruAppEnvironment }], target: i0.ɵɵFactoryTarget.Injectable });
9190
- static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: TruErrorInterceptor });
9191
- }
9192
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: TruErrorInterceptor, decorators: [{
9193
- type: Injectable
9194
- }], ctorParameters: () => [{ type: TruAppEnvironment }] });
9195
-
9196
9179
  class TruErrorDialog {
9197
9180
  dialogRef;
9198
9181
  data;
@@ -9219,6 +9202,154 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImpor
9219
9202
  args: [MAT_DIALOG_DATA]
9220
9203
  }] }] });
9221
9204
 
9205
+ class TruErrorDialogConfig {
9206
+ title;
9207
+ message;
9208
+ constructor(title, message) {
9209
+ this.title = title;
9210
+ this.message = message;
9211
+ }
9212
+ }
9213
+
9214
+ class TruServerError {
9215
+ id;
9216
+ type;
9217
+ code;
9218
+ message;
9219
+ stackTrace;
9220
+ status;
9221
+ constructor(error) {
9222
+ let parsedError = JSON.parse(error.error);
9223
+ this.id = parsedError.$id;
9224
+ this.type = parsedError.$type;
9225
+ this.code = parsedError.Code;
9226
+ this.message = parsedError.Message;
9227
+ this.stackTrace = parsedError.StackTrace;
9228
+ this.status = error.status;
9229
+ }
9230
+ }
9231
+
9232
+ class TruErrorManager {
9233
+ http;
9234
+ dialog;
9235
+ textManager;
9236
+ uiNotification;
9237
+ appEnvironment;
9238
+ baseUrl;
9239
+ appName;
9240
+ constructor(http, dialog, textManager, uiNotification, appEnvironment) {
9241
+ this.http = http;
9242
+ this.dialog = dialog;
9243
+ this.textManager = textManager;
9244
+ this.uiNotification = uiNotification;
9245
+ this.appEnvironment = appEnvironment;
9246
+ this.baseUrl = appEnvironment.appUri;
9247
+ this.appName = appEnvironment.appName;
9248
+ }
9249
+ logErrorEvent = (message, context, area) => {
9250
+ area = area || 'unknown';
9251
+ console.log('[' + area + '|' + context + '] ' + message);
9252
+ var logEvent = {
9253
+ eventType: 'Error',
9254
+ eventDate: new Date(),
9255
+ applicationName: this.appName,
9256
+ applicationUrl: this.baseUrl,
9257
+ applicationArea: area,
9258
+ context: context,
9259
+ message: message
9260
+ };
9261
+ this.http
9262
+ .post(`${this.baseUrl}/api/log/logevent`, logEvent)
9263
+ .subscribe(() => {
9264
+ }, (ex) => {
9265
+ console.log('Unable to log error to server. ' + ex);
9266
+ });
9267
+ };
9268
+ handleClientSideError = (error) => {
9269
+ };
9270
+ handleServerSideError = (error) => {
9271
+ let serverError = new TruServerError(error);
9272
+ if (serverError.type === 'tru-db-custom-exception') {
9273
+ //var service = $injector.get(error.httpResponse.data.serviceName);
9274
+ //var exceptionData = error.httpResponse.data.data;
9275
+ //service(exceptionData);
9276
+ }
9277
+ else if (serverError.type.indexOf('TruDbRequireValidChoiceException') !== -1) {
9278
+ let dialogConfig = new TruErrorDialogConfig('Require Valid Choice Exception', error.message);
9279
+ this.dialog.open(TruErrorDialog, {
9280
+ disableClose: true,
9281
+ minWidth: "400px",
9282
+ maxWidth: "600px",
9283
+ data: dialogConfig
9284
+ });
9285
+ }
9286
+ else if (serverError.type.indexOf('DuplicateKeyError') !== -1) {
9287
+ let dialogConfig = new TruErrorDialogConfig('Duplicate Key Error', error.message
9288
+ .replace('Cannot insert duplicate key row in object', 'Cannot insert duplicate value in table')
9289
+ .replace('dbo.', '')
9290
+ .replace('UIX_', '')
9291
+ .replace('The statement has been terminated.', ''));
9292
+ this.dialog.open(TruErrorDialog, {
9293
+ disableClose: true,
9294
+ minWidth: "400px",
9295
+ maxWidth: "600px",
9296
+ data: dialogConfig
9297
+ });
9298
+ }
9299
+ else if (serverError.type.indexOf('OptimisticLockViolation') !== -1) {
9300
+ let dialogConfig = new TruErrorDialogConfig('Concurrent saves not allowed', 'Please review any changes and save again.');
9301
+ this.dialog.open(TruErrorDialog, {
9302
+ disableClose: true,
9303
+ minWidth: "400px",
9304
+ maxWidth: "600px",
9305
+ data: dialogConfig
9306
+ });
9307
+ }
9308
+ else if (error.type.toString().lastIndexOf('TruDB.EfMssql.Runtime.DataError', 0) === 0) {
9309
+ //this.uiNotification.error(
9310
+ // this.textManager.fmtDataError(error.httpResponse.data.Detail.$type),
9311
+ // [this.textManager.fmtExceptionToShow(error.httpResponse.data.Exception)])
9312
+ }
9313
+ else {
9314
+ //var message = this.textManager.fmtErrorToShow(error);
9315
+ //this.uiNotification.showErrorDialog(message);
9316
+ //this.logErrorEvent(message);
9317
+ }
9318
+ };
9319
+ handleError = (error) => {
9320
+ if (error.type)
9321
+ this.handleClientSideError(error);
9322
+ else
9323
+ this.handleServerSideError(error);
9324
+ };
9325
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: TruErrorManager, deps: [{ token: i2.HttpClient }, { token: i1.MatDialog }, { token: TruTextManager }, { token: TruUiNotification }, { token: TruAppEnvironment }], target: i0.ɵɵFactoryTarget.Injectable });
9326
+ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: TruErrorManager, providedIn: 'root' });
9327
+ }
9328
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: TruErrorManager, decorators: [{
9329
+ type: Injectable,
9330
+ args: [{
9331
+ providedIn: 'root',
9332
+ }]
9333
+ }], ctorParameters: () => [{ type: i2.HttpClient }, { type: i1.MatDialog }, { type: TruTextManager }, { type: TruUiNotification }, { type: TruAppEnvironment }] });
9334
+
9335
+ class TruErrorInterceptor {
9336
+ errorManager;
9337
+ constructor(errorManager) {
9338
+ this.errorManager = errorManager;
9339
+ }
9340
+ intercept(request, next) {
9341
+ return next.handle(request).pipe(catchError((error) => {
9342
+ this.errorManager.handleError(error);
9343
+ return throwError(error);
9344
+ }));
9345
+ }
9346
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: TruErrorInterceptor, deps: [{ token: TruErrorManager }], target: i0.ɵɵFactoryTarget.Injectable });
9347
+ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: TruErrorInterceptor });
9348
+ }
9349
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: TruErrorInterceptor, decorators: [{
9350
+ type: Injectable
9351
+ }], ctorParameters: () => [{ type: TruErrorManager }] });
9352
+
9222
9353
  class TruErrorDialogModule {
9223
9354
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: TruErrorDialogModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
9224
9355
  static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.3.5", ngImport: i0, type: TruErrorDialogModule, declarations: [TruErrorDialog], imports: [CommonModule,