@tiba-spark/client-shared-lib 25.3.0-772 → 25.3.0-775

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.
@@ -13,13 +13,21 @@ export class LocalizationResolver {
13
13
  this.localizationService = localizationService;
14
14
  }
15
15
  resolve() {
16
- // Set the user language before resolve the route
16
+ // Determine the user's preferred language before resolving the route
17
17
  const userSettings = this.store.selectSnapshot(SessionState.mappedUserSettings);
18
18
  const lang = getCurrentLang(userSettings);
19
- this.translateService.use(lang);
19
+ // If the language is already registered in TranslateService, simply switch to it
20
20
  if (this.translateService.langs.includes(lang)) {
21
+ this.translateService.use(lang);
21
22
  return;
22
23
  }
24
+ // If ngx-translate believes the language is already loaded (even if it’s not),
25
+ // it will skip calling the loader’s getTranslation() method.
26
+ // Resetting the language forces ngx-translate to fetch translations again.
27
+ this.translateService.resetLang(lang);
28
+ // Apply the selected language and trigger translation loading
29
+ this.translateService.use(lang);
30
+ // Wait until the localization resources are fully loaded before resolving the route
23
31
  return new Promise((resolve, reject) => this.localizationService.resourceLoaded.asObservable().pipe(first())
24
32
  .subscribe({
25
33
  next: () => resolve(),
@@ -32,4 +40,4 @@ export class LocalizationResolver {
32
40
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LocalizationResolver, decorators: [{
33
41
  type: Injectable
34
42
  }], ctorParameters: () => [{ type: i1.Store }, { type: i2.TranslateService }, { type: i3.LocalizationService }] });
35
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9jYWxpemF0aW9uLnJlc29sdmVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY2xpZW50LXNoYXJlZC1saWIvc3JjL2xpYnJhcmllcy9yZXNvbHZlcnMvbG9jYWxpemF0aW9uLnJlc29sdmVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFHM0MsT0FBTyxFQUFFLEtBQUssRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBRXZDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUM3RCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sd0JBQXdCLENBQUM7Ozs7O0FBR3hELE1BQU0sT0FBTyxvQkFBb0I7SUFFL0IsWUFBb0IsS0FBWSxFQUFVLGdCQUFrQyxFQUFVLG1CQUF3QztRQUExRyxVQUFLLEdBQUwsS0FBSyxDQUFPO1FBQVUscUJBQWdCLEdBQWhCLGdCQUFnQixDQUFrQjtRQUFVLHdCQUFtQixHQUFuQixtQkFBbUIsQ0FBcUI7SUFDOUgsQ0FBQztJQUVELE9BQU87UUFDTCxpREFBaUQ7UUFDakQsTUFBTSxZQUFZLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxjQUFjLENBQUMsWUFBWSxDQUFDLGtCQUFrQixDQUFDLENBQUM7UUFDaEYsTUFBTSxJQUFJLEdBQUcsY0FBYyxDQUFDLFlBQVksQ0FBQyxDQUFDO1FBQzFDLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLENBQUM7UUFFaEMsSUFBSSxJQUFJLENBQUMsZ0JBQWdCLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDO1lBQy9DLE9BQU87UUFDVCxDQUFDO1FBRUQsT0FBTyxJQUFJLE9BQU8sQ0FBTyxDQUFDLE9BQU8sRUFBRSxNQUFNLEVBQUUsRUFBRSxDQUFDLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxjQUFjLENBQUMsWUFBWSxFQUFFLENBQUMsSUFBSSxDQUFDLEtBQUssRUFBRSxDQUFDO2FBQy9HLFNBQVMsQ0FBQztZQUNULElBQUksRUFBRSxHQUFHLEVBQUUsQ0FBQyxPQUFPLEVBQUU7WUFDckIsS0FBSyxFQUFFLENBQUMsQ0FBQyxFQUFFLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQztTQUN0QixDQUFDLENBQUMsQ0FBQztJQUNSLENBQUM7K0dBcEJVLG9CQUFvQjttSEFBcEIsb0JBQW9COzs0RkFBcEIsb0JBQW9CO2tCQURoQyxVQUFVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgVHJhbnNsYXRlU2VydmljZSB9IGZyb20gJ0BuZ3gtdHJhbnNsYXRlL2NvcmUnO1xuaW1wb3J0IHsgU3RvcmUgfSBmcm9tICdAbmd4cy9zdG9yZSc7XG5pbXBvcnQgeyBmaXJzdCB9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcbmltcG9ydCB7IExvY2FsaXphdGlvblNlcnZpY2UgfSBmcm9tICcuLi9sb2NhbGl6YXRpb24vbG9jYWxpemF0aW9uLnNlcnZpY2UnO1xuaW1wb3J0IHsgU2Vzc2lvblN0YXRlIH0gZnJvbSAnLi4vbW9kdWxlcy9hdXRoL3Nlc3Npb24uc3RhdGUnO1xuaW1wb3J0IHsgZ2V0Q3VycmVudExhbmcgfSBmcm9tICcuLi91dGlscy9sYW5ndWFnZS51dGlsJztcblxuQEluamVjdGFibGUoKVxuZXhwb3J0IGNsYXNzIExvY2FsaXphdGlvblJlc29sdmVyIHtcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHN0b3JlOiBTdG9yZSwgcHJpdmF0ZSB0cmFuc2xhdGVTZXJ2aWNlOiBUcmFuc2xhdGVTZXJ2aWNlLCBwcml2YXRlIGxvY2FsaXphdGlvblNlcnZpY2U6IExvY2FsaXphdGlvblNlcnZpY2UpIHtcbiAgfVxuXG4gIHJlc29sdmUoKSB7XG4gICAgLy8gU2V0IHRoZSB1c2VyIGxhbmd1YWdlIGJlZm9yZSByZXNvbHZlIHRoZSByb3V0ZVxuICAgIGNvbnN0IHVzZXJTZXR0aW5ncyA9IHRoaXMuc3RvcmUuc2VsZWN0U25hcHNob3QoU2Vzc2lvblN0YXRlLm1hcHBlZFVzZXJTZXR0aW5ncyk7XG4gICAgY29uc3QgbGFuZyA9IGdldEN1cnJlbnRMYW5nKHVzZXJTZXR0aW5ncyk7XG4gICAgdGhpcy50cmFuc2xhdGVTZXJ2aWNlLnVzZShsYW5nKTtcblxuICAgIGlmICh0aGlzLnRyYW5zbGF0ZVNlcnZpY2UubGFuZ3MuaW5jbHVkZXMobGFuZykpIHtcbiAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICByZXR1cm4gbmV3IFByb21pc2U8dm9pZD4oKHJlc29sdmUsIHJlamVjdCkgPT4gdGhpcy5sb2NhbGl6YXRpb25TZXJ2aWNlLnJlc291cmNlTG9hZGVkLmFzT2JzZXJ2YWJsZSgpLnBpcGUoZmlyc3QoKSlcbiAgICAgIC5zdWJzY3JpYmUoe1xuICAgICAgICBuZXh0OiAoKSA9PiByZXNvbHZlKCksXG4gICAgICAgIGVycm9yOiBlID0+IHJlamVjdChlKVxuICAgICAgfSkpO1xuICB9XG59XG4iXX0=
43
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9jYWxpemF0aW9uLnJlc29sdmVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY2xpZW50LXNoYXJlZC1saWIvc3JjL2xpYnJhcmllcy9yZXNvbHZlcnMvbG9jYWxpemF0aW9uLnJlc29sdmVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFHM0MsT0FBTyxFQUFFLEtBQUssRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBRXZDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUM3RCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sd0JBQXdCLENBQUM7Ozs7O0FBR3hELE1BQU0sT0FBTyxvQkFBb0I7SUFFL0IsWUFBb0IsS0FBWSxFQUFVLGdCQUFrQyxFQUFVLG1CQUF3QztRQUExRyxVQUFLLEdBQUwsS0FBSyxDQUFPO1FBQVUscUJBQWdCLEdBQWhCLGdCQUFnQixDQUFrQjtRQUFVLHdCQUFtQixHQUFuQixtQkFBbUIsQ0FBcUI7SUFDOUgsQ0FBQztJQUVELE9BQU87UUFDTCxxRUFBcUU7UUFDckUsTUFBTSxZQUFZLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxjQUFjLENBQUMsWUFBWSxDQUFDLGtCQUFrQixDQUFDLENBQUM7UUFDaEYsTUFBTSxJQUFJLEdBQUcsY0FBYyxDQUFDLFlBQVksQ0FBQyxDQUFDO1FBRTFDLGlGQUFpRjtRQUNqRixJQUFJLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUM7WUFDL0MsSUFBSSxDQUFDLGdCQUFnQixDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsQ0FBQztZQUNoQyxPQUFPO1FBQ1QsQ0FBQztRQUVELCtFQUErRTtRQUMvRSw2REFBNkQ7UUFDN0QsMkVBQTJFO1FBQzNFLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLENBQUM7UUFFdEMsOERBQThEO1FBQzlELElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLENBQUM7UUFFaEMsb0ZBQW9GO1FBQ3BGLE9BQU8sSUFBSSxPQUFPLENBQU8sQ0FBQyxPQUFPLEVBQUUsTUFBTSxFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUMsbUJBQW1CLENBQUMsY0FBYyxDQUFDLFlBQVksRUFBRSxDQUFDLElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQzthQUMvRyxTQUFTLENBQUM7WUFDVCxJQUFJLEVBQUUsR0FBRyxFQUFFLENBQUMsT0FBTyxFQUFFO1lBQ3JCLEtBQUssRUFBRSxDQUFDLENBQUMsRUFBRSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUM7U0FDdEIsQ0FBQyxDQUFDLENBQUM7SUFDUixDQUFDOytHQTlCVSxvQkFBb0I7bUhBQXBCLG9CQUFvQjs7NEZBQXBCLG9CQUFvQjtrQkFEaEMsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFRyYW5zbGF0ZVNlcnZpY2UgfSBmcm9tICdAbmd4LXRyYW5zbGF0ZS9jb3JlJztcbmltcG9ydCB7IFN0b3JlIH0gZnJvbSAnQG5neHMvc3RvcmUnO1xuaW1wb3J0IHsgZmlyc3QgfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XG5pbXBvcnQgeyBMb2NhbGl6YXRpb25TZXJ2aWNlIH0gZnJvbSAnLi4vbG9jYWxpemF0aW9uL2xvY2FsaXphdGlvbi5zZXJ2aWNlJztcbmltcG9ydCB7IFNlc3Npb25TdGF0ZSB9IGZyb20gJy4uL21vZHVsZXMvYXV0aC9zZXNzaW9uLnN0YXRlJztcbmltcG9ydCB7IGdldEN1cnJlbnRMYW5nIH0gZnJvbSAnLi4vdXRpbHMvbGFuZ3VhZ2UudXRpbCc7XG5cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBMb2NhbGl6YXRpb25SZXNvbHZlciB7XG5cbiAgY29uc3RydWN0b3IocHJpdmF0ZSBzdG9yZTogU3RvcmUsIHByaXZhdGUgdHJhbnNsYXRlU2VydmljZTogVHJhbnNsYXRlU2VydmljZSwgcHJpdmF0ZSBsb2NhbGl6YXRpb25TZXJ2aWNlOiBMb2NhbGl6YXRpb25TZXJ2aWNlKSB7XG4gIH1cblxuICByZXNvbHZlKCkge1xuICAgIC8vIERldGVybWluZSB0aGUgdXNlcidzIHByZWZlcnJlZCBsYW5ndWFnZSBiZWZvcmUgcmVzb2x2aW5nIHRoZSByb3V0ZVxuICAgIGNvbnN0IHVzZXJTZXR0aW5ncyA9IHRoaXMuc3RvcmUuc2VsZWN0U25hcHNob3QoU2Vzc2lvblN0YXRlLm1hcHBlZFVzZXJTZXR0aW5ncyk7XG4gICAgY29uc3QgbGFuZyA9IGdldEN1cnJlbnRMYW5nKHVzZXJTZXR0aW5ncyk7XG5cbiAgICAvLyBJZiB0aGUgbGFuZ3VhZ2UgaXMgYWxyZWFkeSByZWdpc3RlcmVkIGluIFRyYW5zbGF0ZVNlcnZpY2UsIHNpbXBseSBzd2l0Y2ggdG8gaXRcbiAgICBpZiAodGhpcy50cmFuc2xhdGVTZXJ2aWNlLmxhbmdzLmluY2x1ZGVzKGxhbmcpKSB7XG4gICAgICB0aGlzLnRyYW5zbGF0ZVNlcnZpY2UudXNlKGxhbmcpO1xuICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIC8vIElmIG5neC10cmFuc2xhdGUgYmVsaWV2ZXMgdGhlIGxhbmd1YWdlIGlzIGFscmVhZHkgbG9hZGVkIChldmVuIGlmIGl04oCZcyBub3QpLFxuICAgIC8vIGl0IHdpbGwgc2tpcCBjYWxsaW5nIHRoZSBsb2FkZXLigJlzIGdldFRyYW5zbGF0aW9uKCkgbWV0aG9kLlxuICAgIC8vIFJlc2V0dGluZyB0aGUgbGFuZ3VhZ2UgZm9yY2VzIG5neC10cmFuc2xhdGUgdG8gZmV0Y2ggdHJhbnNsYXRpb25zIGFnYWluLlxuICAgIHRoaXMudHJhbnNsYXRlU2VydmljZS5yZXNldExhbmcobGFuZyk7XG5cbiAgICAvLyBBcHBseSB0aGUgc2VsZWN0ZWQgbGFuZ3VhZ2UgYW5kIHRyaWdnZXIgdHJhbnNsYXRpb24gbG9hZGluZ1xuICAgIHRoaXMudHJhbnNsYXRlU2VydmljZS51c2UobGFuZyk7XG5cbiAgICAvLyBXYWl0IHVudGlsIHRoZSBsb2NhbGl6YXRpb24gcmVzb3VyY2VzIGFyZSBmdWxseSBsb2FkZWQgYmVmb3JlIHJlc29sdmluZyB0aGUgcm91dGVcbiAgICByZXR1cm4gbmV3IFByb21pc2U8dm9pZD4oKHJlc29sdmUsIHJlamVjdCkgPT4gdGhpcy5sb2NhbGl6YXRpb25TZXJ2aWNlLnJlc291cmNlTG9hZGVkLmFzT2JzZXJ2YWJsZSgpLnBpcGUoZmlyc3QoKSlcbiAgICAgIC5zdWJzY3JpYmUoe1xuICAgICAgICBuZXh0OiAoKSA9PiByZXNvbHZlKCksXG4gICAgICAgIGVycm9yOiBlID0+IHJlamVjdChlKVxuICAgICAgfSkpO1xuICB9XG59XG4iXX0=
@@ -4,13 +4,16 @@ import { filter, first } from 'rxjs';
4
4
  import { SessionState } from '../../modules/auth/session.state';
5
5
  import { SingleSignOnProvider } from '../../service-proxy/cloud-service-proxies';
6
6
  import { isNullOrEmpty } from '../../utils/custom-validator.util';
7
+ import { AppType } from '../../enums/app-type.enum';
7
8
  import * as i0 from "@angular/core";
8
9
  import * as i1 from "@ngxs/store";
9
10
  import * as i2 from "@azure/msal-angular";
11
+ import * as i3 from "../app-config.service";
10
12
  export class MSLAuthService {
11
- constructor(store, msalService) {
13
+ constructor(store, msalService, appConfig) {
12
14
  this.store = store;
13
15
  this.msalService = msalService;
16
+ this.appConfig = appConfig;
14
17
  }
15
18
  init() {
16
19
  return new Promise((resolve) => {
@@ -36,11 +39,12 @@ export class MSLAuthService {
36
39
  }
37
40
  createPublicClientApplication(clientId, authority, tenantName) {
38
41
  this.validateConfigurations(clientId, authority, tenantName);
42
+ const isBackofficeAppMode = this.appConfig.getConfig().appType === AppType.Backoffice;
39
43
  return new PublicClientApplication({
40
44
  auth: {
41
45
  clientId: clientId, // This is the ONLY mandatory field that you need to supply.
42
46
  authority: authority, // Defaults to "https://login.microsoftonline.com/common"
43
- redirectUri: `/account/login`,
47
+ redirectUri: isBackofficeAppMode ? `/account/login` : `/${tenantName}/account/login`,
44
48
  postLogoutRedirectUri: '/', // Indicates the page to navigate after logout.
45
49
  },
46
50
  cache: {
@@ -57,12 +61,12 @@ export class MSLAuthService {
57
61
  },
58
62
  });
59
63
  }
60
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MSLAuthService, deps: [{ token: i1.Store }, { token: i2.MsalService }], target: i0.ɵɵFactoryTarget.Injectable }); }
64
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MSLAuthService, deps: [{ token: i1.Store }, { token: i2.MsalService }, { token: i3.AppConfigService }], target: i0.ɵɵFactoryTarget.Injectable }); }
61
65
  static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MSLAuthService }); }
62
66
  }
63
67
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MSLAuthService, decorators: [{
64
68
  type: Injectable
65
- }], ctorParameters: () => [{ type: i1.Store }, { type: i2.MsalService }] });
69
+ }], ctorParameters: () => [{ type: i1.Store }, { type: i2.MsalService }, { type: i3.AppConfigService }] });
66
70
  function loggerCallback(logLevel, message) {
67
71
  console.log(message);
68
72
  }
@@ -103,4 +107,4 @@ export function MSALGuardConfigFactory() {
103
107
  loginFailedRoute: '/'
104
108
  };
105
109
  }
106
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"msl-auth-service.js","sourceRoot":"","sources":["../../../../../../projects/client-shared-lib/src/libraries/services/factories/msl-auth-service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { MsalGuardConfiguration, MsalInterceptorConfiguration, MsalService } from '@azure/msal-angular';\nimport { BrowserCacheLocation, IPublicClientApplication, InteractionType, LogLevel, PublicClientApplication } from '@azure/msal-browser';\nimport { Store } from '@ngxs/store';\nimport { filter, first } from 'rxjs';\nimport { TenantInfo } from '../../modules/auth/model/tenant-info.interface';\nimport { SessionState } from '../../modules/auth/session.state';\nimport { SingleSignOnProvider } from '../../service-proxy/cloud-service-proxies';\nimport { isNullOrEmpty } from '../../utils/custom-validator.util';\n\n@Injectable()\nexport class MSLAuthService {\n\n  constructor(private store: Store, private msalService: MsalService) {\n  }\n\n  public init(): Promise<boolean> {\n    return new Promise<boolean>((resolve) => {\n      this.store.select(SessionState.tenantInfo).pipe(filter(tenantInfo => tenantInfo != null), first()).subscribe(tenant => {\n        if (this.isSingleSignOnEnabledWithMSProvider(tenant)) {\n          const clientId = tenant.props.sso.configurations?.azure?.clientId;// This is the ONLY mandatory field that you need to supply.\n          const authority = `https://login.microsoftonline.com/${tenant.props.sso.configurations?.azure?.tenantId}`;\n          const publicClientApplication = this.createPublicClientApplication(clientId, authority, tenant.tenantName);\n          this.msalService.instance = publicClientApplication;\n          this.msalService.initialize().subscribe();\n        }\n      });\n\n      resolve(true);\n    });\n  }\n\n  private isSingleSignOnEnabledWithMSProvider(tenant: TenantInfo) {\n    return tenant.props?.sso?.enabled && tenant.props.sso?.provider === SingleSignOnProvider.Microsoft && tenant.props.sso?.configurations;\n  }\n\n  private validateConfigurations(clientId: string, authority: string, tenantName: string) {\n    if (isNullOrEmpty(clientId?.trim()) || isNullOrEmpty(authority?.trim()) || isNullOrEmpty(tenantName?.trim())) {\n      console.error(\"Error: One or more required parameters for SSO are missing or empty.\");\n    }\n  }\n\n  private createPublicClientApplication(clientId: string, authority: string, tenantName: string): IPublicClientApplication {\n    this.validateConfigurations(clientId, authority, tenantName);\n\n    return new PublicClientApplication({\n      auth: {\n        clientId: clientId, // This is the ONLY mandatory field that you need to supply.\n        authority: authority, // Defaults to \"https://login.microsoftonline.com/common\"\n        redirectUri: `/account/login`,\n        postLogoutRedirectUri: '/', // Indicates the page to navigate after logout.\n      },\n      cache: {\n        cacheLocation: BrowserCacheLocation.LocalStorage, // Configures cache location. \"sessionStorage\" is more secure, but \"localStorage\" gives you SSO between tabs.\n        //storeAuthStateInCookie: false, // Set this to \"true\" if you are having issues on IE11 or Edge\n      },\n      system: {\n        allowNativeBroker: false, // Disables WAM Broker\n        loggerOptions: {\n          loggerCallback,\n          logLevel: LogLevel.Error,\n          piiLoggingEnabled: false\n        }\n      },\n    });\n  }\n}\n\n\nfunction loggerCallback(logLevel: LogLevel, message: string) {\n  console.log(message);\n}\n\nexport function initializeMsal(authService: MSLAuthService): () => Promise<void> {\n  return async () => {\n    await authService.init();\n  };\n}\n\n/**\n * Here we pass the configuration parameters to create an MSAL instance.\n * For more info, visit: https://github.com/AzureAD/microsoft-authentication-library-for-js/blob/dev/lib/msal-angular/docs/v2-docs/configuration.md\n */\nexport function MSALInstanceFactory(): IPublicClientApplication {\n  return new PublicClientApplication({\n    auth: {\n      clientId: null\n    },\n  });\n}\n\nexport function MSALInterceptorConfigFactory(): MsalInterceptorConfiguration {\n  const protectedResourceMap = new Map<string, Array<string>>();\n  protectedResourceMap.set('https://graph.microsoft.com/v1.0/me', ['user.read']);\n  return {\n    interactionType: InteractionType.Redirect,\n    protectedResourceMap\n  };\n}\n/**\n * Set your default interaction type for MSALGuard here. If you have any\n * additional scopes you want the user to consent upon login, add them here as well.\n */\nexport function MSALGuardConfigFactory(): MsalGuardConfiguration {\n  return {\n    interactionType: InteractionType.Redirect,\n    authRequest: {\n      scopes: [...['user.read']]\n    },\n    loginFailedRoute: '/'\n  };\n}\n"]}
110
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"msl-auth-service.js","sourceRoot":"","sources":["../../../../../../projects/client-shared-lib/src/libraries/services/factories/msl-auth-service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { MsalGuardConfiguration, MsalInterceptorConfiguration, MsalService } from '@azure/msal-angular';\nimport { BrowserCacheLocation, IPublicClientApplication, InteractionType, LogLevel, PublicClientApplication } from '@azure/msal-browser';\nimport { Store } from '@ngxs/store';\nimport { filter, first } from 'rxjs';\nimport { TenantInfo } from '../../modules/auth/model/tenant-info.interface';\nimport { SessionState } from '../../modules/auth/session.state';\nimport { SingleSignOnProvider } from '../../service-proxy/cloud-service-proxies';\nimport { isNullOrEmpty } from '../../utils/custom-validator.util';\nimport { AppConfigService } from '../app-config.service';\nimport { AppType } from '../../enums/app-type.enum';\n\n@Injectable()\nexport class MSLAuthService {\n\n  constructor(private store: Store, private msalService: MsalService, private appConfig: AppConfigService) {\n  }\n\n  public init(): Promise<boolean> {\n    return new Promise<boolean>((resolve) => {\n      this.store.select(SessionState.tenantInfo).pipe(filter(tenantInfo => tenantInfo != null), first()).subscribe(tenant => {\n        if (this.isSingleSignOnEnabledWithMSProvider(tenant)) {\n          const clientId = tenant.props.sso.configurations?.azure?.clientId;// This is the ONLY mandatory field that you need to supply.\n          const authority = `https://login.microsoftonline.com/${tenant.props.sso.configurations?.azure?.tenantId}`;\n          const publicClientApplication = this.createPublicClientApplication(clientId, authority, tenant.tenantName);\n          this.msalService.instance = publicClientApplication;\n          this.msalService.initialize().subscribe();\n        }\n      });\n\n      resolve(true);\n    });\n  }\n\n  private isSingleSignOnEnabledWithMSProvider(tenant: TenantInfo) {\n    return tenant.props?.sso?.enabled && tenant.props.sso?.provider === SingleSignOnProvider.Microsoft && tenant.props.sso?.configurations;\n  }\n\n  private validateConfigurations(clientId: string, authority: string, tenantName: string) {\n    if (isNullOrEmpty(clientId?.trim()) || isNullOrEmpty(authority?.trim()) || isNullOrEmpty(tenantName?.trim())) {\n      console.error(\"Error: One or more required parameters for SSO are missing or empty.\");\n    }\n  }\n\n  private createPublicClientApplication(clientId: string, authority: string, tenantName: string): IPublicClientApplication {\n    this.validateConfigurations(clientId, authority, tenantName);\n    const isBackofficeAppMode = this.appConfig.getConfig().appType === AppType.Backoffice;\n\n    return new PublicClientApplication({\n      auth: {\n        clientId: clientId, // This is the ONLY mandatory field that you need to supply.\n        authority: authority, // Defaults to \"https://login.microsoftonline.com/common\"\n        redirectUri: isBackofficeAppMode ? `/account/login` : `/${tenantName}/account/login`,\n        postLogoutRedirectUri: '/', // Indicates the page to navigate after logout.\n      },\n      cache: {\n        cacheLocation: BrowserCacheLocation.LocalStorage, // Configures cache location. \"sessionStorage\" is more secure, but \"localStorage\" gives you SSO between tabs.\n        //storeAuthStateInCookie: false, // Set this to \"true\" if you are having issues on IE11 or Edge\n      },\n      system: {\n        allowNativeBroker: false, // Disables WAM Broker\n        loggerOptions: {\n          loggerCallback,\n          logLevel: LogLevel.Error,\n          piiLoggingEnabled: false\n        }\n      },\n    });\n  }\n}\n\n\nfunction loggerCallback(logLevel: LogLevel, message: string) {\n  console.log(message);\n}\n\nexport function initializeMsal(authService: MSLAuthService): () => Promise<void> {\n  return async () => {\n    await authService.init();\n  };\n}\n\n/**\n * Here we pass the configuration parameters to create an MSAL instance.\n * For more info, visit: https://github.com/AzureAD/microsoft-authentication-library-for-js/blob/dev/lib/msal-angular/docs/v2-docs/configuration.md\n */\nexport function MSALInstanceFactory(): IPublicClientApplication {\n  return new PublicClientApplication({\n    auth: {\n      clientId: null\n    },\n  });\n}\n\nexport function MSALInterceptorConfigFactory(): MsalInterceptorConfiguration {\n  const protectedResourceMap = new Map<string, Array<string>>();\n  protectedResourceMap.set('https://graph.microsoft.com/v1.0/me', ['user.read']);\n  return {\n    interactionType: InteractionType.Redirect,\n    protectedResourceMap\n  };\n}\n/**\n * Set your default interaction type for MSALGuard here. If you have any\n * additional scopes you want the user to consent upon login, add them here as well.\n */\nexport function MSALGuardConfigFactory(): MsalGuardConfiguration {\n  return {\n    interactionType: InteractionType.Redirect,\n    authRequest: {\n      scopes: [...['user.read']]\n    },\n    loginFailedRoute: '/'\n  };\n}\n"]}
@@ -107596,9 +107596,10 @@ class UpdateTenantSingleSignOnAction {
107596
107596
  }
107597
107597
 
107598
107598
  class MSLAuthService {
107599
- constructor(store, msalService) {
107599
+ constructor(store, msalService, appConfig) {
107600
107600
  this.store = store;
107601
107601
  this.msalService = msalService;
107602
+ this.appConfig = appConfig;
107602
107603
  }
107603
107604
  init() {
107604
107605
  return new Promise((resolve) => {
@@ -107624,11 +107625,12 @@ class MSLAuthService {
107624
107625
  }
107625
107626
  createPublicClientApplication(clientId, authority, tenantName) {
107626
107627
  this.validateConfigurations(clientId, authority, tenantName);
107628
+ const isBackofficeAppMode = this.appConfig.getConfig().appType === AppType.Backoffice;
107627
107629
  return new PublicClientApplication({
107628
107630
  auth: {
107629
107631
  clientId: clientId, // This is the ONLY mandatory field that you need to supply.
107630
107632
  authority: authority, // Defaults to "https://login.microsoftonline.com/common"
107631
- redirectUri: `/account/login`,
107633
+ redirectUri: isBackofficeAppMode ? `/account/login` : `/${tenantName}/account/login`,
107632
107634
  postLogoutRedirectUri: '/', // Indicates the page to navigate after logout.
107633
107635
  },
107634
107636
  cache: {
@@ -107645,12 +107647,12 @@ class MSLAuthService {
107645
107647
  },
107646
107648
  });
107647
107649
  }
107648
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MSLAuthService, deps: [{ token: i1$2.Store }, { token: i10.MsalService }], target: i0.ɵɵFactoryTarget.Injectable }); }
107650
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MSLAuthService, deps: [{ token: i1$2.Store }, { token: i10.MsalService }, { token: AppConfigService }], target: i0.ɵɵFactoryTarget.Injectable }); }
107649
107651
  static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MSLAuthService }); }
107650
107652
  }
107651
107653
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MSLAuthService, decorators: [{
107652
107654
  type: Injectable
107653
- }], ctorParameters: () => [{ type: i1$2.Store }, { type: i10.MsalService }] });
107655
+ }], ctorParameters: () => [{ type: i1$2.Store }, { type: i10.MsalService }, { type: AppConfigService }] });
107654
107656
  function loggerCallback(logLevel, message) {
107655
107657
  console.log(message);
107656
107658
  }
@@ -114868,13 +114870,21 @@ class LocalizationResolver {
114868
114870
  this.localizationService = localizationService;
114869
114871
  }
114870
114872
  resolve() {
114871
- // Set the user language before resolve the route
114873
+ // Determine the user's preferred language before resolving the route
114872
114874
  const userSettings = this.store.selectSnapshot(SessionState.mappedUserSettings);
114873
114875
  const lang = getCurrentLang(userSettings);
114874
- this.translateService.use(lang);
114876
+ // If the language is already registered in TranslateService, simply switch to it
114875
114877
  if (this.translateService.langs.includes(lang)) {
114878
+ this.translateService.use(lang);
114876
114879
  return;
114877
114880
  }
114881
+ // If ngx-translate believes the language is already loaded (even if it’s not),
114882
+ // it will skip calling the loader’s getTranslation() method.
114883
+ // Resetting the language forces ngx-translate to fetch translations again.
114884
+ this.translateService.resetLang(lang);
114885
+ // Apply the selected language and trigger translation loading
114886
+ this.translateService.use(lang);
114887
+ // Wait until the localization resources are fully loaded before resolving the route
114878
114888
  return new Promise((resolve, reject) => this.localizationService.resourceLoaded.asObservable().pipe(first())
114879
114889
  .subscribe({
114880
114890
  next: () => resolve(),