@elite.framework/ng.core 2.0.12 → 2.0.14

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.
@@ -3,7 +3,7 @@ import { NgModule, inject } from '@angular/core';
3
3
  import { CommonModule } from '@angular/common';
4
4
  import { TranslateService } from '@ngx-translate/core';
5
5
  import { Router } from '@angular/router';
6
- import { SwalService } from '@elite.framework/ng.core/services';
6
+ import { SwalService, LoggerService } from '@elite.framework/ng.core/services';
7
7
  import { ENVIRONMENT } from '@elite.framework/ng.core/tokens';
8
8
  import { throwError } from 'rxjs';
9
9
  import { catchError, finalize } from 'rxjs/operators';
@@ -39,22 +39,19 @@ const apiInterceptor = (req, next) => {
39
39
  const router = inject(Router);
40
40
  const swal = inject(SwalService);
41
41
  const translate = inject(TranslateService);
42
+ const logger = inject(LoggerService);
42
43
  const apiUrl = env.apiUrl;
43
44
  let newReq = req;
44
- // 🔹 Example: add base API url
45
- // if (!/^https?:\/\//i.test(req.url)) {
46
- // newReq = req.clone({
47
- // url: `${apiUrl}${req.url.startsWith('/') ? '' : '/'}${req.url}`
48
- // });
49
- // }
50
- // 🔹 Example: add JWT token
51
- // const token = localStorage.getItem('token');
52
- // if (token) {
53
- // newReq = newReq.clone({
54
- // setHeaders: { Authorization: `Bearer ${token}` }
55
- // });
56
- // }
45
+ // Log request details (only in debug mode for performance)
46
+ if (env['enableDebug']) {
47
+ logger.debug(`➡️ HTTP REQUEST: ${req.method} ${req.url}`, {
48
+ headers: Object.fromEntries(req.headers.keys().map(key => [key, req.headers.get(key)])),
49
+ timestamp: new Date().toISOString()
50
+ });
51
+ }
52
+ const startTime = Date.now();
57
53
  return next(newReq).pipe(catchError((error) => {
54
+ const duration = Date.now() - startTime;
58
55
  let problem = null;
59
56
  if (error.error && typeof error.error === 'object') {
60
57
  problem = error.error;
@@ -67,33 +64,60 @@ const apiInterceptor = (req, next) => {
67
64
  problem = null;
68
65
  }
69
66
  }
67
+ // Structured error logging
68
+ const errorContext = {
69
+ url: req.url,
70
+ method: req.method,
71
+ duration: `${duration}ms`,
72
+ status: error.status,
73
+ statusText: error.statusText,
74
+ problemDetails: problem,
75
+ timestamp: new Date().toISOString()
76
+ };
70
77
  if (problem) {
71
78
  switch (problem.status) {
72
79
  case 400:
80
+ logger.warn(`🛑 Bad Request (400) - ${problem.title}`, errorContext);
73
81
  swal.error(translate.instant(problem.title || 'Error.BadRequest'), problem.detail ? translate.instant(problem.detail) : undefined);
74
82
  break;
75
83
  case 401:
84
+ logger.warn(`🔐 Unauthorized (401) - Redirecting to login`, errorContext);
76
85
  swal.error(translate.instant('Error.Unauthorized'), translate.instant('Error.SessionExpired'));
77
86
  localStorage.removeItem('token');
78
87
  router.navigate(['/login']);
79
88
  break;
80
89
  case 403:
90
+ logger.warn(`🚫 Forbidden (403) - Access denied`, errorContext);
81
91
  swal.error(translate.instant('Error.Forbidden'), problem.title || translate.instant('Error.NoPermission'));
82
92
  break;
93
+ case 404:
94
+ logger.warn(`❓ Not Found (404) - ${req.url}`, errorContext);
95
+ break;
83
96
  case 500:
97
+ logger.error(`💥 Server Error (500) - ${problem.title}`, errorContext);
84
98
  swal.error(translate.instant('Error.ServerError'), problem.detail || problem.title);
85
- break; // || error.status === 0
99
+ break;
100
+ case 0:
101
+ logger.error(`🌐 Network Error - Cannot connect to server`, errorContext);
102
+ swal.error(translate.instant('Error.NoConnection'), translate.instant('Error.NetworkUnavailable'));
103
+ break;
86
104
  default:
87
- swal.error(translate.instant(problem.title || 'Error.NoConnection' /* 'Error.Unexpected' */), problem.detail ? translate.instant(problem.detail) : undefined);
105
+ logger.error(`⚠️ HTTP Error ${problem.status} - ${problem.title}`, errorContext);
106
+ swal.error(translate.instant(problem.title || 'Error.NoConnection'), problem.detail ? translate.instant(problem.detail) : undefined);
88
107
  break;
89
108
  }
90
109
  }
91
110
  else {
92
- swal.error(translate.instant('Error.NoConnection' /* 'Error.Unexpected' */), error.message);
111
+ logger.error(`❌ Unknown Error - ${error.message}`, errorContext);
112
+ swal.error(translate.instant('Error.NoConnection'), error.message);
93
113
  }
94
114
  return throwError(() => problem ?? error);
95
115
  }), finalize(() => {
96
- // console.log(`✅ API request finished: ${req.method} ${req.url}`);
116
+ const duration = Date.now() - startTime;
117
+ // Only log successful requests in debug mode to avoid console spam
118
+ if (env['enableDebug']) {
119
+ logger.debug(`✅ HTTP SUCCESS: ${req.method} ${req.url} (${duration}ms)`);
120
+ }
97
121
  }));
98
122
  };
99
123
 
@@ -1 +1 @@
1
- {"version":3,"file":"elite.framework-ng.core-interceptors.mjs","sources":["../tmp-esm2022/interceptors/lib/interceptors-module.js","../tmp-esm2022/interceptors/lib/language.interceptor.js","../tmp-esm2022/interceptors/lib/api.interceptor.js","../tmp-esm2022/interceptors/elite.framework-ng.core-interceptors.js"],"sourcesContent":["import { NgModule } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport * as i0 from \"@angular/core\";\nexport class InterceptorsModule {\n static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: \"12.0.0\", version: \"20.1.8\", ngImport: i0, type: InterceptorsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });\n static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: \"14.0.0\", version: \"20.1.8\", ngImport: i0, type: InterceptorsModule, imports: [CommonModule] });\n static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: \"12.0.0\", version: \"20.1.8\", ngImport: i0, type: InterceptorsModule, imports: [CommonModule] });\n}\ni0.ɵɵngDeclareClassMetadata({ minVersion: \"12.0.0\", version: \"20.1.8\", ngImport: i0, type: InterceptorsModule, decorators: [{\n type: NgModule,\n args: [{\n imports: [CommonModule],\n }]\n }] });\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZXJjZXB0b3JzLW1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvbmcuY29yZS9pbnRlcmNlcHRvcnMvc3JjL2xpYi9pbnRlcmNlcHRvcnMtbW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDOztBQUsvQyxNQUFNLE9BQU8sa0JBQWtCO3VHQUFsQixrQkFBa0I7d0dBQWxCLGtCQUFrQixZQUZuQixZQUFZO3dHQUVYLGtCQUFrQixZQUZuQixZQUFZOzsyRkFFWCxrQkFBa0I7a0JBSDlCLFFBQVE7bUJBQUM7b0JBQ1IsT0FBTyxFQUFFLENBQUMsWUFBWSxDQUFDO2lCQUN4QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuXG5ATmdNb2R1bGUoe1xuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlXSxcbn0pXG5leHBvcnQgY2xhc3MgSW50ZXJjZXB0b3JzTW9kdWxlIHt9XG4iXX0=","// language.interceptor.fn.ts\nimport { inject } from '@angular/core';\nimport { TranslateService } from '@ngx-translate/core';\nexport function languageInterceptor(req, next) {\n const translateService = inject(TranslateService);\n // Get the current language (fallback to 'ar')\n const currentLanguage = translateService.currentLang || 'ar';\n // Clone request and add Accept-Language header\n const clonedReq = req.clone({\n setHeaders: {\n 'Accept-Language': currentLanguage\n }\n });\n return next(clonedReq);\n}\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGFuZ3VhZ2UuaW50ZXJjZXB0b3IuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL25nLmNvcmUvaW50ZXJjZXB0b3JzL3NyYy9saWIvbGFuZ3VhZ2UuaW50ZXJjZXB0b3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsNkJBQTZCO0FBQzdCLE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFHdkMsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFFdkQsTUFBTSxVQUFVLG1CQUFtQixDQUNqQyxHQUFxQixFQUNyQixJQUFtQjtJQUVuQixNQUFNLGdCQUFnQixHQUFHLE1BQU0sQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO0lBRWxELDhDQUE4QztJQUM5QyxNQUFNLGVBQWUsR0FBRyxnQkFBZ0IsQ0FBQyxXQUFXLElBQUksSUFBSSxDQUFDO0lBRTdELCtDQUErQztJQUMvQyxNQUFNLFNBQVMsR0FBRyxHQUFHLENBQUMsS0FBSyxDQUFDO1FBQzFCLFVBQVUsRUFBRTtZQUNWLGlCQUFpQixFQUFFLGVBQWU7U0FDbkM7S0FDRixDQUFDLENBQUM7SUFFSCxPQUFPLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQztBQUN6QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLy8gbGFuZ3VhZ2UuaW50ZXJjZXB0b3IuZm4udHNcclxuaW1wb3J0IHsgaW5qZWN0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IEh0dHBSZXF1ZXN0LCBIdHRwRXZlbnQsIEh0dHBIYW5kbGVyRm4gfSBmcm9tICdAYW5ndWxhci9jb21tb24vaHR0cCc7XHJcbmltcG9ydCB7IE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcclxuaW1wb3J0IHsgVHJhbnNsYXRlU2VydmljZSB9IGZyb20gJ0BuZ3gtdHJhbnNsYXRlL2NvcmUnO1xyXG5cclxuZXhwb3J0IGZ1bmN0aW9uIGxhbmd1YWdlSW50ZXJjZXB0b3IoXHJcbiAgcmVxOiBIdHRwUmVxdWVzdDxhbnk+LFxyXG4gIG5leHQ6IEh0dHBIYW5kbGVyRm5cclxuKTogT2JzZXJ2YWJsZTxIdHRwRXZlbnQ8YW55Pj4ge1xyXG4gIGNvbnN0IHRyYW5zbGF0ZVNlcnZpY2UgPSBpbmplY3QoVHJhbnNsYXRlU2VydmljZSk7XHJcblxyXG4gIC8vIEdldCB0aGUgY3VycmVudCBsYW5ndWFnZSAoZmFsbGJhY2sgdG8gJ2FyJylcclxuICBjb25zdCBjdXJyZW50TGFuZ3VhZ2UgPSB0cmFuc2xhdGVTZXJ2aWNlLmN1cnJlbnRMYW5nIHx8ICdhcic7XHJcblxyXG4gIC8vIENsb25lIHJlcXVlc3QgYW5kIGFkZCBBY2NlcHQtTGFuZ3VhZ2UgaGVhZGVyXHJcbiAgY29uc3QgY2xvbmVkUmVxID0gcmVxLmNsb25lKHtcclxuICAgIHNldEhlYWRlcnM6IHtcclxuICAgICAgJ0FjY2VwdC1MYW5ndWFnZSc6IGN1cnJlbnRMYW5ndWFnZVxyXG4gICAgfVxyXG4gIH0pO1xyXG5cclxuICByZXR1cm4gbmV4dChjbG9uZWRSZXEpO1xyXG59XHJcbiJdfQ==","import { inject } from '@angular/core';\nimport { Router } from '@angular/router';\nimport { SwalService } from '@elite.framework/ng.core/services';\nimport { ENVIRONMENT } from '@elite.framework/ng.core/tokens';\nimport { TranslateService } from '@ngx-translate/core';\nimport { throwError } from 'rxjs';\nimport { catchError, finalize } from 'rxjs/operators';\nexport const apiInterceptor = (req, next) => {\n const env = inject(ENVIRONMENT);\n const router = inject(Router);\n const swal = inject(SwalService);\n const translate = inject(TranslateService);\n const apiUrl = env.apiUrl;\n let newReq = req;\n // 🔹 Example: add base API url\n // if (!/^https?:\\/\\//i.test(req.url)) {\n // newReq = req.clone({\n // url: `${apiUrl}${req.url.startsWith('/') ? '' : '/'}${req.url}`\n // });\n // }\n // 🔹 Example: add JWT token\n // const token = localStorage.getItem('token');\n // if (token) {\n // newReq = newReq.clone({\n // setHeaders: { Authorization: `Bearer ${token}` }\n // });\n // }\n return next(newReq).pipe(catchError((error) => {\n let problem = null;\n if (error.error && typeof error.error === 'object') {\n problem = error.error;\n }\n else if (typeof error.error === 'string') {\n try {\n problem = JSON.parse(error.error);\n }\n catch {\n problem = null;\n }\n }\n if (problem) {\n switch (problem.status) {\n case 400:\n swal.error(translate.instant(problem.title || 'Error.BadRequest'), problem.detail ? translate.instant(problem.detail) : undefined);\n break;\n case 401:\n swal.error(translate.instant('Error.Unauthorized'), translate.instant('Error.SessionExpired'));\n localStorage.removeItem('token');\n router.navigate(['/login']);\n break;\n case 403:\n swal.error(translate.instant('Error.Forbidden'), problem.title || translate.instant('Error.NoPermission'));\n break;\n case 500:\n swal.error(translate.instant('Error.ServerError'), problem.detail || problem.title);\n break; // || error.status === 0\n default:\n swal.error(translate.instant(problem.title || 'Error.NoConnection' /* 'Error.Unexpected' */), problem.detail ? translate.instant(problem.detail) : undefined);\n break;\n }\n }\n else {\n swal.error(translate.instant('Error.NoConnection' /* 'Error.Unexpected' */), error.message);\n }\n return throwError(() => problem ?? error);\n }), finalize(() => {\n // console.log(`✅ API request finished: ${req.method} ${req.url}`);\n }));\n};\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"api.interceptor.js","sourceRoot":"","sources":["../../../../../../libs/ng.core/interceptors/src/lib/api.interceptor.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  HttpInterceptorFn,\r\n  HttpRequest,\r\n  HttpHandlerFn,\r\n  HttpEvent,\r\n  HttpErrorResponse\r\n} from '@angular/common/http';\r\nimport { inject } from '@angular/core';\r\nimport { Router } from '@angular/router';\r\nimport { SwalService } from '@elite.framework/ng.core/services';\r\nimport { ENVIRONMENT } from '@elite.framework/ng.core/tokens';\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport { Observable, throwError } from 'rxjs';\r\nimport { catchError, finalize } from 'rxjs/operators';\r\n\r\nexport interface ProblemDetailsResponse {\r\n  type?: string | null;\r\n  title: string;\r\n  status: number;\r\n  detail?: string | null;\r\n  instance?: string;\r\n  traceId?: string;\r\n}\r\n\r\nexport const apiInterceptor: HttpInterceptorFn = (\r\n  req: HttpRequest<any>,\r\n  next: HttpHandlerFn\r\n): Observable<HttpEvent<any>> => {\r\n  const env = inject(ENVIRONMENT);\r\n  const router = inject(Router);\r\n  const swal = inject(SwalService);\r\n  const translate = inject(TranslateService);\r\n\r\n  const apiUrl = env.apiUrl;\r\n  let newReq = req;\r\n\r\n  // 🔹 Example: add base API url\r\n  // if (!/^https?:\\/\\//i.test(req.url)) {\r\n  //   newReq = req.clone({\r\n  //     url: `${apiUrl}${req.url.startsWith('/') ? '' : '/'}${req.url}`\r\n  //   });\r\n  // }\r\n\r\n  // 🔹 Example: add JWT token\r\n  // const token = localStorage.getItem('token');\r\n  // if (token) {\r\n  //   newReq = newReq.clone({\r\n  //     setHeaders: { Authorization: `Bearer ${token}` }\r\n  //   });\r\n  // }\r\n\r\n  return next(newReq).pipe(\r\n    catchError((error: HttpErrorResponse) => {\r\n      let problem: ProblemDetailsResponse | null = null;\r\n\r\n      if (error.error && typeof error.error === 'object') {\r\n        problem = error.error as ProblemDetailsResponse;\r\n      } else if (typeof error.error === 'string') {\r\n        try {\r\n          problem = JSON.parse(error.error) as ProblemDetailsResponse;\r\n        } catch {\r\n          problem = null;\r\n        }\r\n      }\r\n\r\n      if (problem) {\r\n        switch (problem.status) {\r\n          case 400:\r\n            swal.error(\r\n              translate.instant(problem.title || 'Error.BadRequest'),\r\n              problem.detail ? translate.instant(problem.detail) : undefined\r\n            );\r\n            break;\r\n          case 401:\r\n            swal.error(\r\n              translate.instant('Error.Unauthorized'),\r\n              translate.instant('Error.SessionExpired')\r\n            );\r\n            localStorage.removeItem('token');\r\n            router.navigate(['/login']);\r\n            break;\r\n          case 403:\r\n            swal.error(\r\n              translate.instant('Error.Forbidden'),\r\n              problem.title || translate.instant('Error.NoPermission')\r\n            );\r\n            break;\r\n          case 500:\r\n            swal.error(\r\n              translate.instant('Error.ServerError'),\r\n              problem.detail || problem.title\r\n            );\r\n            break; // || error.status === 0\r\n          default:\r\n            swal.error(\r\n              translate.instant(problem.title ||'Error.NoConnection' /* 'Error.Unexpected' */),\r\n              problem.detail ? translate.instant(problem.detail) : undefined\r\n            );\r\n            break;\r\n        }\r\n      } else {\r\n        swal.error(\r\n          translate.instant('Error.NoConnection'/* 'Error.Unexpected' */),\r\n          error.message\r\n        );\r\n      }\r\n\r\n      return throwError(() => problem ?? error);\r\n    }),\r\n    finalize(() => {\r\n      // console.log(`✅ API request finished: ${req.method} ${req.url}`);\r\n    })\r\n  );\r\n};\r\n"]}","/**\n * Generated bundle index. Do not edit.\n */\nexport * from './index';\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxpdGUuZnJhbWV3b3JrLW5nLmNvcmUtaW50ZXJjZXB0b3JzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vbGlicy9uZy5jb3JlL2ludGVyY2VwdG9ycy9zcmMvZWxpdGUuZnJhbWV3b3JrLW5nLmNvcmUtaW50ZXJjZXB0b3JzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyxTQUFTLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEdlbmVyYXRlZCBidW5kbGUgaW5kZXguIERvIG5vdCBlZGl0LlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vaW5kZXgnO1xuIl19"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"elite.framework-ng.core-interceptors.mjs","sources":["../tmp-esm2022/interceptors/lib/interceptors-module.js","../tmp-esm2022/interceptors/lib/language.interceptor.js","../tmp-esm2022/interceptors/lib/api.interceptor.js","../tmp-esm2022/interceptors/elite.framework-ng.core-interceptors.js"],"sourcesContent":["import { NgModule } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport * as i0 from \"@angular/core\";\nexport class InterceptorsModule {\n static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: \"12.0.0\", version: \"20.1.8\", ngImport: i0, type: InterceptorsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });\n static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: \"14.0.0\", version: \"20.1.8\", ngImport: i0, type: InterceptorsModule, imports: [CommonModule] });\n static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: \"12.0.0\", version: \"20.1.8\", ngImport: i0, type: InterceptorsModule, imports: [CommonModule] });\n}\ni0.ɵɵngDeclareClassMetadata({ minVersion: \"12.0.0\", version: \"20.1.8\", ngImport: i0, type: InterceptorsModule, decorators: [{\n type: NgModule,\n args: [{\n imports: [CommonModule],\n }]\n }] });\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZXJjZXB0b3JzLW1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvbmcuY29yZS9pbnRlcmNlcHRvcnMvc3JjL2xpYi9pbnRlcmNlcHRvcnMtbW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDOztBQUsvQyxNQUFNLE9BQU8sa0JBQWtCO3VHQUFsQixrQkFBa0I7d0dBQWxCLGtCQUFrQixZQUZuQixZQUFZO3dHQUVYLGtCQUFrQixZQUZuQixZQUFZOzsyRkFFWCxrQkFBa0I7a0JBSDlCLFFBQVE7bUJBQUM7b0JBQ1IsT0FBTyxFQUFFLENBQUMsWUFBWSxDQUFDO2lCQUN4QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuXG5ATmdNb2R1bGUoe1xuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlXSxcbn0pXG5leHBvcnQgY2xhc3MgSW50ZXJjZXB0b3JzTW9kdWxlIHt9XG4iXX0=","// language.interceptor.fn.ts\nimport { inject } from '@angular/core';\nimport { TranslateService } from '@ngx-translate/core';\nexport function languageInterceptor(req, next) {\n const translateService = inject(TranslateService);\n // Get the current language (fallback to 'ar')\n const currentLanguage = translateService.currentLang || 'ar';\n // Clone request and add Accept-Language header\n const clonedReq = req.clone({\n setHeaders: {\n 'Accept-Language': currentLanguage\n }\n });\n return next(clonedReq);\n}\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGFuZ3VhZ2UuaW50ZXJjZXB0b3IuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL25nLmNvcmUvaW50ZXJjZXB0b3JzL3NyYy9saWIvbGFuZ3VhZ2UuaW50ZXJjZXB0b3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsNkJBQTZCO0FBQzdCLE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFHdkMsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFFdkQsTUFBTSxVQUFVLG1CQUFtQixDQUNqQyxHQUFxQixFQUNyQixJQUFtQjtJQUVuQixNQUFNLGdCQUFnQixHQUFHLE1BQU0sQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO0lBRWxELDhDQUE4QztJQUM5QyxNQUFNLGVBQWUsR0FBRyxnQkFBZ0IsQ0FBQyxXQUFXLElBQUksSUFBSSxDQUFDO0lBRTdELCtDQUErQztJQUMvQyxNQUFNLFNBQVMsR0FBRyxHQUFHLENBQUMsS0FBSyxDQUFDO1FBQzFCLFVBQVUsRUFBRTtZQUNWLGlCQUFpQixFQUFFLGVBQWU7U0FDbkM7S0FDRixDQUFDLENBQUM7SUFFSCxPQUFPLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQztBQUN6QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLy8gbGFuZ3VhZ2UuaW50ZXJjZXB0b3IuZm4udHNcclxuaW1wb3J0IHsgaW5qZWN0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IEh0dHBSZXF1ZXN0LCBIdHRwRXZlbnQsIEh0dHBIYW5kbGVyRm4gfSBmcm9tICdAYW5ndWxhci9jb21tb24vaHR0cCc7XHJcbmltcG9ydCB7IE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcclxuaW1wb3J0IHsgVHJhbnNsYXRlU2VydmljZSB9IGZyb20gJ0BuZ3gtdHJhbnNsYXRlL2NvcmUnO1xyXG5cclxuZXhwb3J0IGZ1bmN0aW9uIGxhbmd1YWdlSW50ZXJjZXB0b3IoXHJcbiAgcmVxOiBIdHRwUmVxdWVzdDxhbnk+LFxyXG4gIG5leHQ6IEh0dHBIYW5kbGVyRm5cclxuKTogT2JzZXJ2YWJsZTxIdHRwRXZlbnQ8YW55Pj4ge1xyXG4gIGNvbnN0IHRyYW5zbGF0ZVNlcnZpY2UgPSBpbmplY3QoVHJhbnNsYXRlU2VydmljZSk7XHJcblxyXG4gIC8vIEdldCB0aGUgY3VycmVudCBsYW5ndWFnZSAoZmFsbGJhY2sgdG8gJ2FyJylcclxuICBjb25zdCBjdXJyZW50TGFuZ3VhZ2UgPSB0cmFuc2xhdGVTZXJ2aWNlLmN1cnJlbnRMYW5nIHx8ICdhcic7XHJcblxyXG4gIC8vIENsb25lIHJlcXVlc3QgYW5kIGFkZCBBY2NlcHQtTGFuZ3VhZ2UgaGVhZGVyXHJcbiAgY29uc3QgY2xvbmVkUmVxID0gcmVxLmNsb25lKHtcclxuICAgIHNldEhlYWRlcnM6IHtcclxuICAgICAgJ0FjY2VwdC1MYW5ndWFnZSc6IGN1cnJlbnRMYW5ndWFnZVxyXG4gICAgfVxyXG4gIH0pO1xyXG5cclxuICByZXR1cm4gbmV4dChjbG9uZWRSZXEpO1xyXG59XHJcbiJdfQ==","import { inject } from '@angular/core';\nimport { Router } from '@angular/router';\nimport { LoggerService, SwalService } from '@elite.framework/ng.core/services';\nimport { ENVIRONMENT } from '@elite.framework/ng.core/tokens';\nimport { TranslateService } from '@ngx-translate/core';\nimport { throwError } from 'rxjs';\nimport { catchError, finalize } from 'rxjs/operators';\nexport const apiInterceptor = (req, next) => {\n const env = inject(ENVIRONMENT);\n const router = inject(Router);\n const swal = inject(SwalService);\n const translate = inject(TranslateService);\n const logger = inject(LoggerService);\n const apiUrl = env.apiUrl;\n let newReq = req;\n // Log request details (only in debug mode for performance)\n if (env['enableDebug']) {\n logger.debug(`➡️ HTTP REQUEST: ${req.method} ${req.url}`, {\n headers: Object.fromEntries(req.headers.keys().map(key => [key, req.headers.get(key)])),\n timestamp: new Date().toISOString()\n });\n }\n const startTime = Date.now();\n return next(newReq).pipe(catchError((error) => {\n const duration = Date.now() - startTime;\n let problem = null;\n if (error.error && typeof error.error === 'object') {\n problem = error.error;\n }\n else if (typeof error.error === 'string') {\n try {\n problem = JSON.parse(error.error);\n }\n catch {\n problem = null;\n }\n }\n // Structured error logging\n const errorContext = {\n url: req.url,\n method: req.method,\n duration: `${duration}ms`,\n status: error.status,\n statusText: error.statusText,\n problemDetails: problem,\n timestamp: new Date().toISOString()\n };\n if (problem) {\n switch (problem.status) {\n case 400:\n logger.warn(`🛑 Bad Request (400) - ${problem.title}`, errorContext);\n swal.error(translate.instant(problem.title || 'Error.BadRequest'), problem.detail ? translate.instant(problem.detail) : undefined);\n break;\n case 401:\n logger.warn(`🔐 Unauthorized (401) - Redirecting to login`, errorContext);\n swal.error(translate.instant('Error.Unauthorized'), translate.instant('Error.SessionExpired'));\n localStorage.removeItem('token');\n router.navigate(['/login']);\n break;\n case 403:\n logger.warn(`🚫 Forbidden (403) - Access denied`, errorContext);\n swal.error(translate.instant('Error.Forbidden'), problem.title || translate.instant('Error.NoPermission'));\n break;\n case 404:\n logger.warn(`❓ Not Found (404) - ${req.url}`, errorContext);\n break;\n case 500:\n logger.error(`💥 Server Error (500) - ${problem.title}`, errorContext);\n swal.error(translate.instant('Error.ServerError'), problem.detail || problem.title);\n break;\n case 0:\n logger.error(`🌐 Network Error - Cannot connect to server`, errorContext);\n swal.error(translate.instant('Error.NoConnection'), translate.instant('Error.NetworkUnavailable'));\n break;\n default:\n logger.error(`⚠️ HTTP Error ${problem.status} - ${problem.title}`, errorContext);\n swal.error(translate.instant(problem.title || 'Error.NoConnection'), problem.detail ? translate.instant(problem.detail) : undefined);\n break;\n }\n }\n else {\n logger.error(`❌ Unknown Error - ${error.message}`, errorContext);\n swal.error(translate.instant('Error.NoConnection'), error.message);\n }\n return throwError(() => problem ?? error);\n }), finalize(() => {\n const duration = Date.now() - startTime;\n // Only log successful requests in debug mode to avoid console spam\n if (env['enableDebug']) {\n logger.debug(`✅ HTTP SUCCESS: ${req.method} ${req.url} (${duration}ms)`);\n }\n }));\n};\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"api.interceptor.js","sourceRoot":"","sources":["../../../../../../libs/ng.core/interceptors/src/lib/api.interceptor.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  HttpInterceptorFn,\r\n  HttpRequest,\r\n  HttpHandlerFn,\r\n  HttpEvent,\r\n  HttpErrorResponse\r\n} from '@angular/common/http';\r\nimport { inject } from '@angular/core';\r\nimport { Router } from '@angular/router';\r\nimport { LoggerService, SwalService } from '@elite.framework/ng.core/services';\r\nimport { ENVIRONMENT } from '@elite.framework/ng.core/tokens';\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport { Observable, throwError } from 'rxjs';\r\nimport { catchError, finalize } from 'rxjs/operators';\r\n\r\nexport interface ProblemDetailsResponse {\r\n  type?: string | null;\r\n  title: string;\r\n  status: number;\r\n  detail?: string | null;\r\n  instance?: string;\r\n  traceId?: string;\r\n}\r\n\r\nexport const apiInterceptor: HttpInterceptorFn = (\r\n  req: HttpRequest<any>,\r\n  next: HttpHandlerFn\r\n): Observable<HttpEvent<any>> => {\r\n  const env = inject(ENVIRONMENT);\r\n  const router = inject(Router);\r\n  const swal = inject(SwalService);\r\n  const translate = inject(TranslateService);\r\n  const logger = inject(LoggerService);\r\n\r\n  const apiUrl = env.apiUrl;\r\n  let newReq = req;\r\n\r\n  // Log request details (only in debug mode for performance)\r\n  if (env['enableDebug']) {\r\n    logger.debug(`➡️ HTTP REQUEST: ${req.method} ${req.url}`, {\r\n      headers: Object.fromEntries(req.headers.keys().map(key => [key, req.headers.get(key)])),\r\n      timestamp: new Date().toISOString()\r\n    });\r\n  }\r\n\r\n  const startTime = Date.now();\r\n\r\n  return next(newReq).pipe(\r\n    catchError((error: HttpErrorResponse) => {\r\n      const duration = Date.now() - startTime;\r\n      let problem: ProblemDetailsResponse | null = null;\r\n\r\n      if (error.error && typeof error.error === 'object') {\r\n        problem = error.error as ProblemDetailsResponse;\r\n      } else if (typeof error.error === 'string') {\r\n        try {\r\n          problem = JSON.parse(error.error) as ProblemDetailsResponse;\r\n        } catch {\r\n          problem = null;\r\n        }\r\n      }\r\n\r\n      // Structured error logging\r\n      const errorContext = {\r\n        url: req.url,\r\n        method: req.method,\r\n        duration: `${duration}ms`,\r\n        status: error.status,\r\n        statusText: error.statusText,\r\n        problemDetails: problem,\r\n        timestamp: new Date().toISOString()\r\n      };\r\n\r\n      if (problem) {\r\n        switch (problem.status) {\r\n          case 400:\r\n            logger.warn(`🛑 Bad Request (400) - ${problem.title}`, errorContext);\r\n            swal.error(\r\n              translate.instant(problem.title || 'Error.BadRequest'),\r\n              problem.detail ? translate.instant(problem.detail) : undefined\r\n            );\r\n            break;\r\n          case 401:\r\n            logger.warn(`🔐 Unauthorized (401) - Redirecting to login`, errorContext);\r\n            swal.error(\r\n              translate.instant('Error.Unauthorized'),\r\n              translate.instant('Error.SessionExpired')\r\n            );\r\n            localStorage.removeItem('token');\r\n            router.navigate(['/login']);\r\n            break;\r\n          case 403:\r\n            logger.warn(`🚫 Forbidden (403) - Access denied`, errorContext);\r\n            swal.error(\r\n              translate.instant('Error.Forbidden'),\r\n              problem.title || translate.instant('Error.NoPermission')\r\n            );\r\n            break;\r\n          case 404:\r\n            logger.warn(`❓ Not Found (404) - ${req.url}`, errorContext);\r\n            break;\r\n          case 500:\r\n            logger.error(`💥 Server Error (500) - ${problem.title}`, errorContext);\r\n            swal.error(\r\n              translate.instant('Error.ServerError'),\r\n              problem.detail || problem.title\r\n            );\r\n            break;\r\n          case 0:\r\n            logger.error(`🌐 Network Error - Cannot connect to server`, errorContext);\r\n            swal.error(\r\n              translate.instant('Error.NoConnection'),\r\n              translate.instant('Error.NetworkUnavailable')\r\n            );\r\n            break;\r\n          default:\r\n            logger.error(`⚠️ HTTP Error ${problem.status} - ${problem.title}`, errorContext);\r\n            swal.error(\r\n              translate.instant(problem.title || 'Error.NoConnection'),\r\n              problem.detail ? translate.instant(problem.detail) : undefined\r\n            );\r\n            break;\r\n        }\r\n      } else {\r\n        logger.error(`❌ Unknown Error - ${error.message}`, errorContext);\r\n        swal.error(\r\n          translate.instant('Error.NoConnection'),\r\n          error.message\r\n        );\r\n      }\r\n\r\n      return throwError(() => problem ?? error);\r\n    }),\r\n    finalize(() => {\r\n      const duration = Date.now() - startTime;\r\n      // Only log successful requests in debug mode to avoid console spam\r\n      if (env['enableDebug']) {\r\n        logger.debug(`✅ HTTP SUCCESS: ${req.method} ${req.url} (${duration}ms)`);\r\n      }\r\n    })\r\n  );\r\n};\r\n"]}","/**\n * Generated bundle index. Do not edit.\n */\nexport * from './index';\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxpdGUuZnJhbWV3b3JrLW5nLmNvcmUtaW50ZXJjZXB0b3JzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vbGlicy9uZy5jb3JlL2ludGVyY2VwdG9ycy9zcmMvZWxpdGUuZnJhbWV3b3JrLW5nLmNvcmUtaW50ZXJjZXB0b3JzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyxTQUFTLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEdlbmVyYXRlZCBidW5kbGUgaW5kZXguIERvIG5vdCBlZGl0LlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vaW5kZXgnO1xuIl19"],"names":[],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@elite.framework/ng.core",
3
- "version": "2.0.12",
3
+ "version": "2.0.14",
4
4
  "peerDependencies": {
5
5
  "@angular/common": "^20.1.0",
6
6
  "@angular/core": "^20.1.0"
@@ -20,14 +20,14 @@
20
20
  "types": "./directives/index.d.ts",
21
21
  "default": "./fesm2022/elite.framework-ng.core-directives.mjs"
22
22
  },
23
- "./interceptors": {
24
- "types": "./interceptors/index.d.ts",
25
- "default": "./fesm2022/elite.framework-ng.core-interceptors.mjs"
26
- },
27
23
  "./models": {
28
24
  "types": "./models/index.d.ts",
29
25
  "default": "./fesm2022/elite.framework-ng.core-models.mjs"
30
26
  },
27
+ "./interceptors": {
28
+ "types": "./interceptors/index.d.ts",
29
+ "default": "./fesm2022/elite.framework-ng.core-interceptors.mjs"
30
+ },
31
31
  "./pipes": {
32
32
  "types": "./pipes/index.d.ts",
33
33
  "default": "./fesm2022/elite.framework-ng.core-pipes.mjs"