@trudb/tru-common-lib 0.1.551 → 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==
@@ -1,6 +1,7 @@
1
1
  import { Injectable } from "@angular/core";
2
2
  import { TruErrorDialog } from "../components/error-dialog/tru-error-dialog";
3
3
  import { TruErrorDialogConfig } from "../components/error-dialog/classes/tru-error-dialog-config";
4
+ import { TruServerError } from "../classes/tru-server-error";
4
5
  import * as i0 from "@angular/core";
5
6
  import * as i1 from "@angular/common/http";
6
7
  import * as i2 from "@angular/material/dialog";
@@ -24,24 +25,35 @@ export class TruErrorManager {
24
25
  this.baseUrl = appEnvironment.appUri;
25
26
  this.appName = appEnvironment.appName;
26
27
  }
27
- parseErrorMessage(error) {
28
- if (error.error && error.error.message) {
29
- return error.error.message;
30
- }
31
- else if (error.error && typeof error.error === 'string') {
32
- return error.error;
33
- }
34
- else {
35
- return `Server returned code ${error.status}, body was: ${error.error}`;
36
- }
37
- }
38
- handleError = (error) => {
39
- if (error.type.toString() === 'tru-db-custom-exception') {
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') {
40
52
  //var service = $injector.get(error.httpResponse.data.serviceName);
41
53
  //var exceptionData = error.httpResponse.data.data;
42
54
  //service(exceptionData);
43
55
  }
44
- else if (error.type.toString().indexOf('TruDbRequireValidChoiceException') !== -1) {
56
+ else if (serverError.type.indexOf('TruDbRequireValidChoiceException') !== -1) {
45
57
  let dialogConfig = new TruErrorDialogConfig('Require Valid Choice Exception', error.message);
46
58
  this.dialog.open(TruErrorDialog, {
47
59
  disableClose: true,
@@ -50,7 +62,7 @@ export class TruErrorManager {
50
62
  data: dialogConfig
51
63
  });
52
64
  }
53
- else if (error.type.toString().indexOf('DuplicateKeyError') !== -1) {
65
+ else if (serverError.type.indexOf('DuplicateKeyError') !== -1) {
54
66
  let dialogConfig = new TruErrorDialogConfig('Duplicate Key Error', error.message
55
67
  .replace('Cannot insert duplicate key row in object', 'Cannot insert duplicate value in table')
56
68
  .replace('dbo.', '')
@@ -63,7 +75,7 @@ export class TruErrorManager {
63
75
  data: dialogConfig
64
76
  });
65
77
  }
66
- else if (error.type.toString().indexOf('OptimisticLockViolation') !== -1) {
78
+ else if (serverError.type.indexOf('OptimisticLockViolation') !== -1) {
67
79
  let dialogConfig = new TruErrorDialogConfig('Concurrent saves not allowed', 'Please review any changes and save again.');
68
80
  this.dialog.open(TruErrorDialog, {
69
81
  disableClose: true,
@@ -82,28 +94,12 @@ export class TruErrorManager {
82
94
  //this.uiNotification.showErrorDialog(message);
83
95
  //this.logErrorEvent(message);
84
96
  }
85
- //if (window.appInsights) window.appInsights.trackException(error, null, {
86
- // 'User': dataService.activeUser.username
87
- //});
88
97
  };
89
- logErrorEvent = (message, context, area) => {
90
- area = area || 'unknown';
91
- console.log('[' + area + '|' + context + '] ' + message);
92
- var logEvent = {
93
- eventType: 'Error',
94
- eventDate: new Date(),
95
- applicationName: this.appName,
96
- applicationUrl: this.baseUrl,
97
- applicationArea: area,
98
- context: context,
99
- message: message
100
- };
101
- this.http
102
- .post(`${this.baseUrl}/api/log/logevent`, logEvent)
103
- .subscribe(() => {
104
- }, (ex) => {
105
- console.log('Unable to log error to server. ' + ex);
106
- });
98
+ handleError = (error) => {
99
+ if (error.type)
100
+ this.handleClientSideError(error);
101
+ else
102
+ this.handleServerSideError(error);
107
103
  };
108
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 });
109
105
  static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: TruErrorManager, providedIn: 'root' });
@@ -114,4 +110,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImpor
114
110
  providedIn: 'root',
115
111
  }]
116
112
  }], ctorParameters: () => [{ type: i1.HttpClient }, { type: i2.MatDialog }, { type: i3.TruTextManager }, { type: i4.TruUiNotification }, { type: i5.TruAppEnvironment }] });
117
- //# 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":"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","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\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 parseErrorMessage(error: HttpErrorResponse): string {\r\n    if (error.error && error.error.message) {\r\n      return error.error.message;\r\n    } else if (error.error && typeof error.error === 'string') {\r\n      return error.error;\r\n    } else {\r\n      return `Server returned code ${error.status}, body was: ${error.error}`;\r\n    }\r\n  }\r\n\r\n  handleError = (error: HttpErrorResponse) => {\r\n    if (error.type.toString() === '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 (error.type.toString().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 (error.type.toString().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 (error.type.toString().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    //if (window.appInsights) window.appInsights.trackException(error, null, {\r\n    //  'User': dataService.activeUser.username\r\n    //});\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"]}
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"]}
@@ -9211,6 +9211,24 @@ class TruErrorDialogConfig {
9211
9211
  }
9212
9212
  }
9213
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
+
9214
9232
  class TruErrorManager {
9215
9233
  http;
9216
9234
  dialog;
@@ -9228,24 +9246,35 @@ class TruErrorManager {
9228
9246
  this.baseUrl = appEnvironment.appUri;
9229
9247
  this.appName = appEnvironment.appName;
9230
9248
  }
9231
- parseErrorMessage(error) {
9232
- if (error.error && error.error.message) {
9233
- return error.error.message;
9234
- }
9235
- else if (error.error && typeof error.error === 'string') {
9236
- return error.error;
9237
- }
9238
- else {
9239
- return `Server returned code ${error.status}, body was: ${error.error}`;
9240
- }
9241
- }
9242
- handleError = (error) => {
9243
- if (error.type.toString() === 'tru-db-custom-exception') {
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') {
9244
9273
  //var service = $injector.get(error.httpResponse.data.serviceName);
9245
9274
  //var exceptionData = error.httpResponse.data.data;
9246
9275
  //service(exceptionData);
9247
9276
  }
9248
- else if (error.type.toString().indexOf('TruDbRequireValidChoiceException') !== -1) {
9277
+ else if (serverError.type.indexOf('TruDbRequireValidChoiceException') !== -1) {
9249
9278
  let dialogConfig = new TruErrorDialogConfig('Require Valid Choice Exception', error.message);
9250
9279
  this.dialog.open(TruErrorDialog, {
9251
9280
  disableClose: true,
@@ -9254,7 +9283,7 @@ class TruErrorManager {
9254
9283
  data: dialogConfig
9255
9284
  });
9256
9285
  }
9257
- else if (error.type.toString().indexOf('DuplicateKeyError') !== -1) {
9286
+ else if (serverError.type.indexOf('DuplicateKeyError') !== -1) {
9258
9287
  let dialogConfig = new TruErrorDialogConfig('Duplicate Key Error', error.message
9259
9288
  .replace('Cannot insert duplicate key row in object', 'Cannot insert duplicate value in table')
9260
9289
  .replace('dbo.', '')
@@ -9267,7 +9296,7 @@ class TruErrorManager {
9267
9296
  data: dialogConfig
9268
9297
  });
9269
9298
  }
9270
- else if (error.type.toString().indexOf('OptimisticLockViolation') !== -1) {
9299
+ else if (serverError.type.indexOf('OptimisticLockViolation') !== -1) {
9271
9300
  let dialogConfig = new TruErrorDialogConfig('Concurrent saves not allowed', 'Please review any changes and save again.');
9272
9301
  this.dialog.open(TruErrorDialog, {
9273
9302
  disableClose: true,
@@ -9286,28 +9315,12 @@ class TruErrorManager {
9286
9315
  //this.uiNotification.showErrorDialog(message);
9287
9316
  //this.logErrorEvent(message);
9288
9317
  }
9289
- //if (window.appInsights) window.appInsights.trackException(error, null, {
9290
- // 'User': dataService.activeUser.username
9291
- //});
9292
9318
  };
9293
- logErrorEvent = (message, context, area) => {
9294
- area = area || 'unknown';
9295
- console.log('[' + area + '|' + context + '] ' + message);
9296
- var logEvent = {
9297
- eventType: 'Error',
9298
- eventDate: new Date(),
9299
- applicationName: this.appName,
9300
- applicationUrl: this.baseUrl,
9301
- applicationArea: area,
9302
- context: context,
9303
- message: message
9304
- };
9305
- this.http
9306
- .post(`${this.baseUrl}/api/log/logevent`, logEvent)
9307
- .subscribe(() => {
9308
- }, (ex) => {
9309
- console.log('Unable to log error to server. ' + ex);
9310
- });
9319
+ handleError = (error) => {
9320
+ if (error.type)
9321
+ this.handleClientSideError(error);
9322
+ else
9323
+ this.handleServerSideError(error);
9311
9324
  };
9312
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 });
9313
9326
  static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: TruErrorManager, providedIn: 'root' });