@alauda-fe/common 1.2.1 → 1.3.0-beta.1

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.
Files changed (94) hide show
  1. package/api/api-gateway.service.d.ts +1 -11
  2. package/api/public-api.d.ts +0 -1
  3. package/array-form-table/key-value-form/component.d.ts +3 -2
  4. package/async-data/async-data.module.d.ts +6 -0
  5. package/authorization/public-api.d.ts +1 -0
  6. package/authorization/state.service.d.ts +13 -20
  7. package/authorization/storage-token.d.ts +11 -0
  8. package/chart/common/tooltip/tooltip.component.d.ts +2 -1
  9. package/core/abstract/base-form-container.d.ts +1 -1
  10. package/core/constants/tokens.d.ts +0 -18
  11. package/core/module.d.ts +16 -15
  12. package/core/services/k8s-util.service.d.ts +0 -5
  13. package/core/types/k8s/crd.d.ts +2 -1
  14. package/core/utils/common.d.ts +2 -1
  15. package/esm2022/api/api-gateway.service.mjs +10 -20
  16. package/esm2022/api/product.service.mjs +4 -4
  17. package/esm2022/api/project-api.service.mjs +4 -4
  18. package/esm2022/api/public-api.mjs +1 -2
  19. package/esm2022/array-form-table/key-value-form/component.mjs +65 -43
  20. package/esm2022/async-data/async-data.module.mjs +17 -5
  21. package/esm2022/authorization/public-api.mjs +2 -1
  22. package/esm2022/authorization/state.service.mjs +86 -115
  23. package/esm2022/authorization/storage-token.mjs +82 -0
  24. package/esm2022/business/resource-select/exports/cluster-selector/component.mjs +2 -2
  25. package/esm2022/business/resource-select/exports/mesh-group-selector/component.mjs +2 -2
  26. package/esm2022/business/resource-select/exports/namespace-selector/component.mjs +2 -2
  27. package/esm2022/business/resource-select/exports/project-selector/component.mjs +2 -2
  28. package/esm2022/business/resource-select/module.mjs +9 -9
  29. package/esm2022/chart/chart.module.mjs +1 -1
  30. package/esm2022/chart/common/tooltip/tooltip.component.mjs +5 -2
  31. package/esm2022/core/abstract/base-form-container.mjs +1 -1
  32. package/esm2022/core/abstract/base-nested-form-control.mjs +2 -2
  33. package/esm2022/core/constants/tokens.mjs +1 -46
  34. package/esm2022/core/module.mjs +10 -3
  35. package/esm2022/core/pipes/page-env.pipe.mjs +6 -3
  36. package/esm2022/core/services/feature-gate.service.mjs +3 -3
  37. package/esm2022/core/services/k8s-util.service.mjs +1 -13
  38. package/esm2022/core/types/k8s/crd.mjs +1 -1
  39. package/esm2022/core/utils/common.mjs +11 -9
  40. package/esm2022/disabled-container/disabled-container.component.mjs +2 -2
  41. package/esm2022/form/validators/utils.mjs +37 -34
  42. package/esm2022/graph-canvas/graph-store.service.mjs +2 -2
  43. package/esm2022/help-document/service.mjs +3 -2
  44. package/esm2022/lazy-component/lazy-load-component.mjs +138 -0
  45. package/esm2022/lazy-component/public-api.mjs +14 -0
  46. package/esm2022/lazy-component/visibility.service.mjs +37 -0
  47. package/esm2022/list-display/component.mjs +159 -0
  48. package/esm2022/list-display/public-api.mjs +2 -0
  49. package/esm2022/metric-chart/metric-chart.component.mjs +2 -2
  50. package/esm2022/multi-search/action-input/component.mjs +2 -2
  51. package/esm2022/notification/feedback-notification/component.mjs +10 -4
  52. package/esm2022/notification/public-api.mjs +1 -2
  53. package/esm2022/page-scaffold/navigation/lottie-icons/animation-data.mjs +3 -1
  54. package/esm2022/page-scaffold/navigation/lottie-icons/animations/dashboard.json +1 -0
  55. package/esm2022/page-scaffold/navigation/nav-menu/nav-menu.types.mjs +1 -1
  56. package/esm2022/page-scaffold/page-header/common-layout/product-select/component.mjs +10 -13
  57. package/esm2022/page-scaffold/page-header/help-menu/component/component.mjs +3 -3
  58. package/esm2022/public-api.mjs +4 -4
  59. package/esm2022/table/component.mjs +5 -5
  60. package/esm2022/table/types.mjs +1 -1
  61. package/esm2022/translate/translate.service.mjs +7 -1
  62. package/esm2022/view-chart/view-chart.module.mjs +1 -1
  63. package/esm2022/view-zchart/custom-template/dropdown-legend.mjs +3 -3
  64. package/esm2022/view-zchart/legend/legend.component.mjs +8 -8
  65. package/esm2022/view-zchart/units.mjs +13 -1
  66. package/esm2022/view-zchart/view-zchart.component.mjs +2 -2
  67. package/esm2022/view-zchart/view-zchart.module.mjs +1 -1
  68. package/esm2022/widget/foldable-item-in-table/component.mjs +2 -2
  69. package/esm2022/widget/search-panel/component.mjs +4 -4
  70. package/esm2022/window-channel/plugin-window-channel.service.mjs +8 -3
  71. package/esm2022/xterm/xterm-terminal/xterm-terminal.component.mjs +66 -69
  72. package/esm2022/xterm/xterm.component.mjs +11 -3
  73. package/form/validators/utils.d.ts +7 -0
  74. package/lazy-component/lazy-load-component.d.ts +25 -0
  75. package/lazy-component/public-api.d.ts +9 -0
  76. package/lazy-component/visibility.service.d.ts +11 -0
  77. package/list-display/component.d.ts +15 -0
  78. package/list-display/public-api.d.ts +1 -0
  79. package/notification/feedback-notification/component.d.ts +1 -5
  80. package/notification/public-api.d.ts +0 -1
  81. package/package.json +1 -1
  82. package/page-scaffold/navigation/nav-menu/nav-menu.types.d.ts +1 -0
  83. package/page-scaffold/page-header/common-layout/product-select/component.d.ts +1 -2
  84. package/public-api.d.ts +3 -3
  85. package/styles/global.scss +6 -0
  86. package/styles/mixins.scss +20 -0
  87. package/styles/reset-browser.scss +4 -0
  88. package/styles/tailwind-preset.scss +1 -1
  89. package/table/types.d.ts +2 -0
  90. package/translate/translate.service.d.ts +2 -0
  91. package/view-zchart/custom-template/dropdown-legend.d.ts +1 -1
  92. package/view-zchart/units.d.ts +3 -0
  93. package/xterm/xterm-terminal/xterm-terminal.component.d.ts +4 -3
  94. package/xterm/xterm.component.d.ts +4 -2
@@ -3,25 +3,25 @@
3
3
  * @module authorization
4
4
  */
5
5
  import { HttpClient } from '@angular/common/http';
6
- import { Inject, Injectable } from '@angular/core';
6
+ import { Injectable, inject } from '@angular/core';
7
7
  import { decodeUrl } from 'ab64';
8
- import { EMPTY, Subject, concat, of, catchError, map, shareReplay, switchMap, takeUntil, tap, } from 'rxjs';
9
- import { API_GATEWAY, CODE_KEY, ID_TOKEN_KEY, NOT_NOTIFY_ON_ERROR_HEADERS, REFRESH_TOKEN_KEY, TOKEN_CALLBACK_API, TOKEN_INFO_API, TOKEN_LOGIN_API, TOKEN_REFRESH_API, publishRef, getTopWindow, } from '../core/public-api';
8
+ import { EMPTY, Subject, concat, of, catchError, map, shareReplay, switchMap, tap, pipe, from, } from 'rxjs';
9
+ import { API_GATEWAY, NOT_NOTIFY_ON_ERROR_HEADERS, publishRef, getTopWindow, } from '../core/public-api';
10
10
  import { getInitUrl } from './app-init-url';
11
+ import { asyncReadStorageToken, cleanStorageToken, readStorageToken, readStorageType, writeStorageToken, } from './storage-token';
11
12
  import * as i0 from "@angular/core";
12
- import * as i1 from "@angular/common/http";
13
+ export const STORAGE_TYPE_KEY = 'token_storage';
14
+ export const ID_TOKEN_KEY = 'id_token';
15
+ export const REFRESH_TOKEN_KEY = 'refresh_token';
16
+ export const CODE_KEY = 'code';
17
+ const LOGIN_API = '/console/api/v1/token/login';
18
+ const CALLBACK_API = '/console/api/v1/token/callback';
19
+ const TOKEN_REFRESH_API = '/console/api/v1/token/refresh';
20
+ const TOKEN_INFO_API = '/console/api/v1/token/info';
13
21
  const REDIRECT_URIS = new Set(['redirect_uri', 'post_logout_redirect_uri']);
14
22
  export class AuthorizationStateService {
15
- constructor(http, idTokenKey, refreshTokenKey, codeKey, apiTokenLogin, apiTokenCallback, apiRefreshToken, apiTokenInfo) {
16
- this.http = http;
17
- this.idTokenKey = idTokenKey;
18
- this.refreshTokenKey = refreshTokenKey;
19
- this.codeKey = codeKey;
20
- this.apiTokenLogin = apiTokenLogin;
21
- this.apiTokenCallback = apiTokenCallback;
22
- this.apiRefreshToken = apiRefreshToken;
23
- this.apiTokenInfo = apiTokenInfo;
24
- this.destroy$$ = new Subject();
23
+ constructor() {
24
+ this.http = inject(HttpClient);
25
25
  this.refreshToken$$ = new Subject();
26
26
  this.state$ = this.getAuthConfiguration().pipe(switchMap(config => concat(this.getExistedToken(config), this.refreshToken$$).pipe(map(token => ({ ...config, ...token })))), tap(state => {
27
27
  this.stateSnapshot = state;
@@ -29,50 +29,47 @@ export class AuthorizationStateService {
29
29
  this.logout(true);
30
30
  }
31
31
  this.payloadSnapshot = getAccountInfo(state);
32
- }), takeUntil(this.destroy$$), shareReplay(1));
32
+ }), shareReplay(1));
33
33
  this.checkTokenCache = {};
34
34
  this.stateSnapshot = null;
35
35
  }
36
36
  logout(specificUrl = false) {
37
- localStorage.removeItem(this.idTokenKey);
38
- localStorage.removeItem(this.refreshTokenKey);
39
- this.redirectToUrl(specificUrl && location.href);
37
+ cleanStorageToken();
38
+ this.redirectToDex(specificUrl && location.href);
40
39
  }
41
40
  logoutAudit() {
42
41
  return this.http.post(`${API_GATEWAY}/auth/v1/logout`, {}, {
43
42
  headers: NOT_NOTIFY_ON_ERROR_HEADERS,
44
43
  });
45
44
  }
46
- redirectToUrl(href = '') {
47
- if (this.stateSnapshot) {
48
- let url = '';
49
- /**
50
- * 已存在授权信息(logoutUrl idToken 都存在)场景:
51
- * 1、主动登出(退出登录,此时 href 为空)时不记录任何信息,再次登录后重定向到平台首页。
52
- * 2、被动登出(token 过期、失效,此时 href 不为空)时替换 post_logout_redirect_uri 为 href,再次登录后重定向到 href 页面。
53
- * 不存在授权信息场景:
54
- * 1、存在 href(未登录时直接访问 href)授权后重定向到 href 页面。
55
- * 2、不存在 href(登录页进入)否则授权后重定向到平台首页。
56
- */
57
- if (this.stateSnapshot.logoutUrl && this.stateSnapshot.idToken) {
58
- const logoutUrl = `${this.stateSnapshot.logoutUrl}&id_token_hint=${this.stateSnapshot.idToken}`;
59
- url = href ? this.replaceRedirectUrl(logoutUrl, href) : logoutUrl;
60
- }
61
- else {
62
- const authUrl = this.stateSnapshot.authUrl;
63
- url = href ? this.replaceRedirectUrl(authUrl, href) : authUrl;
64
- }
45
+ async redirectToDex(redirectUrl = null) {
46
+ if (!this.stateSnapshot) {
47
+ return;
48
+ }
49
+ // 主动退出或 session 模式跳转到 dex 前需要主动清除 `user_login` cookie 防止自动授权
50
+ if (!!this.stateSnapshot.idToken || readStorageType() === 'session') {
65
51
  try {
66
- getTopWindow().location.href = url;
52
+ await fetch(`${this.stateSnapshot.logoutUrl}&id_token_hint=${
53
+ // 主动退出时禁用现有 token
54
+ this.stateSnapshot.idToken || ''}`);
67
55
  }
68
- catch {
69
- // should never happen, just for robustness in case of cross-origin iframe
70
- location.href = url;
56
+ catch (e) {
57
+ console.error(e);
71
58
  }
72
59
  }
60
+ const href = redirectUrl
61
+ ? replaceRedirectUrl(this.stateSnapshot.authUrl, redirectUrl)
62
+ : this.stateSnapshot.authUrl;
63
+ try {
64
+ getTopWindow().location.href = href;
65
+ }
66
+ catch {
67
+ // should never happen, just for robustness in case of cross-origin iframe
68
+ location.href = href;
69
+ }
73
70
  }
74
71
  refreshToken() {
75
- const refreshToken = localStorage.getItem(this.refreshTokenKey);
72
+ const refreshToken = readStorageToken()?.refreshToken;
76
73
  if (refreshToken) {
77
74
  if (!this.refreshTokenCache$) {
78
75
  this.refreshTokenCache$ = this.getTokenByRefreshToken(refreshToken).pipe(tap(token => {
@@ -91,7 +88,7 @@ export class AuthorizationStateService {
91
88
  checkToken(token) {
92
89
  if (!this.checkTokenCache[token]) {
93
90
  this.checkTokenCache[token] = this.http
94
- .get(this.apiTokenInfo, {
91
+ .get(TOKEN_INFO_API, {
95
92
  headers: {
96
93
  Authorization: `Bearer ${token}`,
97
94
  },
@@ -119,13 +116,9 @@ export class AuthorizationStateService {
119
116
  }
120
117
  return this.state$.pipe(map(state => getAccountInfo(state) || {}));
121
118
  }
122
- ngOnDestroy() {
123
- this.destroy$$.next();
124
- this.destroy$$.complete();
125
- }
126
119
  getAuthConfiguration() {
127
120
  return this.http
128
- .get(this.apiTokenLogin)
121
+ .get(LOGIN_API)
129
122
  .pipe(map(res => ({
130
123
  authUrl: res.auth_url,
131
124
  state: res.state,
@@ -140,48 +133,38 @@ export class AuthorizationStateService {
140
133
  }
141
134
  getTokenFromLocal(config) {
142
135
  const { queryParams, hashParams } = this.getParams();
143
- const code = queryParams[this.codeKey] || hashParams[this.codeKey];
136
+ const code = queryParams[CODE_KEY] || hashParams[CODE_KEY];
144
137
  if (code) {
145
138
  return this.getTokenByCode(code, config.state);
146
139
  }
147
- const refreshToken = queryParams[this.refreshTokenKey] || hashParams[this.refreshTokenKey];
140
+ const refreshToken = queryParams[REFRESH_TOKEN_KEY] || hashParams[REFRESH_TOKEN_KEY];
148
141
  if (refreshToken) {
149
142
  return this.getTokenByRefreshToken(refreshToken);
150
143
  }
151
- const idToken = queryParams[this.idTokenKey] || hashParams[this.idTokenKey];
144
+ const idToken = queryParams[ID_TOKEN_KEY] || hashParams[ID_TOKEN_KEY];
152
145
  if (idToken) {
153
- localStorage.setItem(this.idTokenKey, idToken);
146
+ writeStorageToken({
147
+ storageType: (queryParams[STORAGE_TYPE_KEY] ||
148
+ hashParams[STORAGE_TYPE_KEY]),
149
+ idToken,
150
+ refreshToken: '',
151
+ });
154
152
  }
155
- return of({
156
- idToken: idToken ?? localStorage.getItem(this.idTokenKey) ?? '',
157
- refreshToken: localStorage.getItem(this.refreshTokenKey) ?? '',
158
- });
153
+ return from(asyncReadStorageToken());
159
154
  }
160
155
  getTokenByRefreshToken(refreshToken) {
161
156
  return this.http
162
- .get(this.apiRefreshToken, {
157
+ .get(TOKEN_REFRESH_API, {
163
158
  params: { refresh_token: refreshToken },
164
159
  })
165
- .pipe(tap(({ id_token, refresh_token }) => {
166
- localStorage.setItem(this.idTokenKey, id_token);
167
- localStorage.setItem(this.refreshTokenKey, refresh_token);
168
- }), map(({ id_token, refresh_token }) => ({
169
- idToken: id_token,
170
- refreshToken: refresh_token,
171
- })));
160
+ .pipe(mapTokenResponse());
172
161
  }
173
162
  getTokenByCode(code, state) {
174
163
  return this.http
175
- .get(this.apiTokenCallback, {
164
+ .get(CALLBACK_API, {
176
165
  params: { code, state },
177
166
  })
178
- .pipe(tap(({ id_token, refresh_token }) => {
179
- localStorage.setItem(this.idTokenKey, id_token);
180
- localStorage.setItem(this.refreshTokenKey, refresh_token);
181
- }), map(({ id_token, refresh_token }) => ({
182
- idToken: id_token,
183
- refreshToken: refresh_token,
184
- })));
167
+ .pipe(mapTokenResponse());
185
168
  }
186
169
  getParams() {
187
170
  const initUrl = getInitUrl();
@@ -190,47 +173,26 @@ export class AuthorizationStateService {
190
173
  const hashParams = parseParams(initLocation.hash ? initLocation.hash.slice(1) : '');
191
174
  return { queryParams, hashParams };
192
175
  }
193
- replaceRedirectUrl(authUrl, href) {
194
- const [path, queryParams] = authUrl.split('?');
195
- const replacedQueryParams = queryParams
196
- .split('&')
197
- .map(pair => {
198
- const [key, value] = pair.split('=');
199
- return REDIRECT_URIS.has(key)
200
- ? `${key}=${encodeURIComponent(href) || value}`
201
- : `${key}=${value}`;
202
- })
203
- .join('&');
204
- return `${path}?${replacedQueryParams}`;
205
- }
206
- static { this.ɵfac = function AuthorizationStateService_Factory(t) { return new (t || AuthorizationStateService)(i0.ɵɵinject(i1.HttpClient), i0.ɵɵinject(ID_TOKEN_KEY), i0.ɵɵinject(REFRESH_TOKEN_KEY), i0.ɵɵinject(CODE_KEY), i0.ɵɵinject(TOKEN_LOGIN_API), i0.ɵɵinject(TOKEN_CALLBACK_API), i0.ɵɵinject(TOKEN_REFRESH_API), i0.ɵɵinject(TOKEN_INFO_API)); }; }
176
+ static { this.ɵfac = function AuthorizationStateService_Factory(t) { return new (t || AuthorizationStateService)(); }; }
207
177
  static { this.ɵprov = /*@__PURE__*/ i0.ɵɵdefineInjectable({ token: AuthorizationStateService, factory: AuthorizationStateService.ɵfac, providedIn: 'root' }); }
208
178
  }
209
179
  (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(AuthorizationStateService, [{
210
180
  type: Injectable,
211
181
  args: [{ providedIn: 'root' }]
212
- }], function () { return [{ type: i1.HttpClient }, { type: undefined, decorators: [{
213
- type: Inject,
214
- args: [ID_TOKEN_KEY]
215
- }] }, { type: undefined, decorators: [{
216
- type: Inject,
217
- args: [REFRESH_TOKEN_KEY]
218
- }] }, { type: undefined, decorators: [{
219
- type: Inject,
220
- args: [CODE_KEY]
221
- }] }, { type: undefined, decorators: [{
222
- type: Inject,
223
- args: [TOKEN_LOGIN_API]
224
- }] }, { type: undefined, decorators: [{
225
- type: Inject,
226
- args: [TOKEN_CALLBACK_API]
227
- }] }, { type: undefined, decorators: [{
228
- type: Inject,
229
- args: [TOKEN_REFRESH_API]
230
- }] }, { type: undefined, decorators: [{
231
- type: Inject,
232
- args: [TOKEN_INFO_API]
233
- }] }]; }, null); })();
182
+ }], null, null); })();
183
+ function replaceRedirectUrl(dexUrl, redirectUrl) {
184
+ const [path, queryParams] = dexUrl.split('?');
185
+ const replacedQueryParams = queryParams
186
+ .split('&')
187
+ .map(pair => {
188
+ const [key, value] = pair.split('=');
189
+ return REDIRECT_URIS.has(key)
190
+ ? `${key}=${encodeURIComponent(redirectUrl)}`
191
+ : `${key}=${value}`;
192
+ })
193
+ .join('&');
194
+ return `${path}?${replacedQueryParams}`;
195
+ }
234
196
  function parseParams(query) {
235
197
  if (!query) {
236
198
  return {};
@@ -244,11 +206,20 @@ function parseParams(query) {
244
206
  }, {});
245
207
  }
246
208
  function getAccountInfo(state) {
247
- let accountInfo;
248
- try {
249
- accountInfo = JSON.parse(decodeUrl(state.idToken.split('.')[1]));
250
- }
251
- catch { }
252
- return accountInfo;
209
+ return state.idToken
210
+ ? JSON.parse(decodeUrl(state.idToken.split('.')[1]))
211
+ : null;
212
+ }
213
+ function mapTokenResponse() {
214
+ return pipe(tap(({ token_storage, id_token, refresh_token }) => {
215
+ writeStorageToken({
216
+ storageType: token_storage,
217
+ idToken: id_token,
218
+ refreshToken: refresh_token,
219
+ });
220
+ }), map(({ id_token, refresh_token }) => ({
221
+ idToken: id_token,
222
+ refreshToken: refresh_token,
223
+ })));
253
224
  }
254
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"state.service.js","sourceRoot":"","sources":["../../../../../libs/common/src/authorization/state.service.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @packageDocumentation\n * @module authorization\n */\n\nimport { HttpClient } from '@angular/common/http';\nimport { Inject, Injectable, OnDestroy } from '@angular/core';\nimport { decodeUrl } from 'ab64';\nimport {\n  EMPTY,\n  Observable,\n  Subject,\n  concat,\n  of,\n  catchError,\n  map,\n  shareReplay,\n  switchMap,\n  takeUntil,\n  tap,\n} from 'rxjs';\n\nimport {\n  StringMap,\n  API_GATEWAY,\n  CODE_KEY,\n  ID_TOKEN_KEY,\n  NOT_NOTIFY_ON_ERROR_HEADERS,\n  REFRESH_TOKEN_KEY,\n  TOKEN_CALLBACK_API,\n  TOKEN_INFO_API,\n  TOKEN_LOGIN_API,\n  TOKEN_REFRESH_API,\n  publishRef,\n  getTopWindow,\n} from '../core/public-api';\nimport { AccountInfo } from '../page-scaffold/public-api';\n\nimport { getInitUrl } from './app-init-url';\n\nexport interface AuthorizationState {\n  idToken?: string;\n  refreshToken?: string;\n  authUrl?: string;\n  state?: string;\n  logoutUrl?: string;\n}\n\nconst REDIRECT_URIS = new Set(['redirect_uri', 'post_logout_redirect_uri']);\n@Injectable({ providedIn: 'root' })\nexport class AuthorizationStateService implements OnDestroy {\n  private readonly destroy$$ = new Subject<void>();\n  private readonly refreshToken$$ = new Subject<{\n    idToken: string;\n    refreshToken: string;\n  }>();\n\n  private readonly state$ = this.getAuthConfiguration().pipe(\n    switchMap(config =>\n      concat(this.getExistedToken(config), this.refreshToken$$).pipe(\n        map(token => ({ ...config, ...token })),\n      ),\n    ),\n    tap(state => {\n      this.stateSnapshot = state;\n      if (!state.idToken) {\n        this.logout(true);\n      }\n      this.payloadSnapshot = getAccountInfo(state);\n    }),\n    takeUntil(this.destroy$$),\n    shareReplay(1),\n  );\n\n  private checkTokenCache: Record<string, Observable<unknown>> = {};\n  private refreshTokenCache$: Observable<string>;\n\n  stateSnapshot: AuthorizationState = null;\n\n  payloadSnapshot: AccountInfo;\n\n  constructor(\n    private readonly http: HttpClient,\n    @Inject(ID_TOKEN_KEY) private readonly idTokenKey: string,\n    @Inject(REFRESH_TOKEN_KEY) private readonly refreshTokenKey: string,\n    @Inject(CODE_KEY) private readonly codeKey: string,\n    @Inject(TOKEN_LOGIN_API) private readonly apiTokenLogin: string,\n    @Inject(TOKEN_CALLBACK_API) private readonly apiTokenCallback: string,\n    @Inject(TOKEN_REFRESH_API) private readonly apiRefreshToken: string,\n    @Inject(TOKEN_INFO_API) private readonly apiTokenInfo: string,\n  ) {}\n\n  logout(specificUrl = false) {\n    localStorage.removeItem(this.idTokenKey);\n    localStorage.removeItem(this.refreshTokenKey);\n    this.redirectToUrl(specificUrl && location.href);\n  }\n\n  logoutAudit() {\n    return this.http.post(\n      `${API_GATEWAY}/auth/v1/logout`,\n      {},\n      {\n        headers: NOT_NOTIFY_ON_ERROR_HEADERS,\n      },\n    );\n  }\n\n  redirectToUrl(href = '') {\n    if (this.stateSnapshot) {\n      let url = '';\n      /**\n       * 已存在授权信息（logoutUrl 和 idToken 都存在）场景：\n       * 1、主动登出（退出登录，此时 href 为空）时不记录任何信息，再次登录后重定向到平台首页。\n       * 2、被动登出（token 过期、失效，此时 href 不为空）时替换 post_logout_redirect_uri 为 href，再次登录后重定向到 href 页面。\n       * 不存在授权信息场景：\n       * 1、存在 href（未登录时直接访问 href）授权后重定向到 href 页面。\n       * 2、不存在 href（登录页进入）否则授权后重定向到平台首页。\n       */\n      if (this.stateSnapshot.logoutUrl && this.stateSnapshot.idToken) {\n        const logoutUrl = `${this.stateSnapshot.logoutUrl}&id_token_hint=${this.stateSnapshot.idToken}`;\n        url = href ? this.replaceRedirectUrl(logoutUrl, href) : logoutUrl;\n      } else {\n        const authUrl = this.stateSnapshot.authUrl;\n        url = href ? this.replaceRedirectUrl(authUrl, href) : authUrl;\n      }\n      try {\n        getTopWindow().location.href = url;\n      } catch {\n        // should never happen, just for robustness in case of cross-origin iframe\n        location.href = url;\n      }\n    }\n  }\n\n  refreshToken() {\n    const refreshToken = localStorage.getItem(this.refreshTokenKey);\n    if (refreshToken) {\n      if (!this.refreshTokenCache$) {\n        this.refreshTokenCache$ = this.getTokenByRefreshToken(\n          refreshToken,\n        ).pipe(\n          tap(token => {\n            this.refreshTokenCache$ = null;\n            this.refreshToken$$.next(token);\n          }),\n          map(({ idToken }) => idToken),\n          catchError(() => {\n            this.logout(true);\n            return EMPTY;\n          }),\n          publishRef(),\n        );\n      }\n      return this.refreshTokenCache$;\n    }\n    this.logout(true);\n    return EMPTY;\n  }\n\n  checkToken(token: string) {\n    if (!this.checkTokenCache[token]) {\n      this.checkTokenCache[token] = this.http\n        .get(this.apiTokenInfo, {\n          headers: {\n            Authorization: `Bearer ${token}`,\n          },\n        })\n        .pipe(\n          tap({\n            next: () => {\n              this.checkTokenCache[token] = null;\n            },\n            error: () => {\n              this.checkTokenCache[token] = null;\n            },\n          }),\n          publishRef(),\n        );\n    }\n    return this.checkTokenCache[token];\n  }\n\n  getToken() {\n    return this.state$.pipe(map(state => state.idToken));\n  }\n\n  getTokenPayload<T>() {\n    return this.state$.pipe(map(state => getAccountInfo(state) as T));\n  }\n\n  getAccountInfo() {\n    if (this.payloadSnapshot) {\n      return of(this.payloadSnapshot);\n    }\n    return this.state$.pipe(map(state => getAccountInfo(state) || {}));\n  }\n\n  ngOnDestroy() {\n    this.destroy$$.next();\n    this.destroy$$.complete();\n  }\n\n  private getAuthConfiguration() {\n    return this.http\n      .get<{ auth_url: string; state: string; logout_url: string }>(\n        this.apiTokenLogin,\n      )\n      .pipe(\n        map(res => ({\n          authUrl: res.auth_url,\n          state: res.state,\n          logoutUrl: res.logout_url || '',\n        })),\n      );\n  }\n\n  private getExistedToken(config: AuthorizationState) {\n    return this.getTokenFromLocal(config).pipe(\n      catchError(error => {\n        console.error(error);\n        return of({ idToken: '', refreshToken: '' });\n      }),\n    );\n  }\n\n  private getTokenFromLocal(config: AuthorizationState) {\n    const { queryParams, hashParams } = this.getParams();\n\n    const code = queryParams[this.codeKey] || hashParams[this.codeKey];\n\n    if (code) {\n      return this.getTokenByCode(code, config.state);\n    }\n\n    const refreshToken =\n      queryParams[this.refreshTokenKey] || hashParams[this.refreshTokenKey];\n    if (refreshToken) {\n      return this.getTokenByRefreshToken(refreshToken);\n    }\n\n    const idToken = queryParams[this.idTokenKey] || hashParams[this.idTokenKey];\n    if (idToken) {\n      localStorage.setItem(this.idTokenKey, idToken);\n    }\n\n    return of({\n      idToken: idToken ?? localStorage.getItem(this.idTokenKey) ?? '',\n      refreshToken: localStorage.getItem(this.refreshTokenKey) ?? '',\n    });\n  }\n\n  private getTokenByRefreshToken(refreshToken: string) {\n    return this.http\n      .get<{ id_token: string; refresh_token: string }>(this.apiRefreshToken, {\n        params: { refresh_token: refreshToken },\n      })\n      .pipe(\n        tap(({ id_token, refresh_token }) => {\n          localStorage.setItem(this.idTokenKey, id_token);\n          localStorage.setItem(this.refreshTokenKey, refresh_token);\n        }),\n        map(({ id_token, refresh_token }) => ({\n          idToken: id_token,\n          refreshToken: refresh_token,\n        })),\n      );\n  }\n\n  private getTokenByCode(code: string, state: string) {\n    return this.http\n      .get<{ id_token: string; refresh_token: string }>(this.apiTokenCallback, {\n        params: { code, state },\n      })\n      .pipe(\n        tap(({ id_token, refresh_token }) => {\n          localStorage.setItem(this.idTokenKey, id_token);\n          localStorage.setItem(this.refreshTokenKey, refresh_token);\n        }),\n        map(({ id_token, refresh_token }) => ({\n          idToken: id_token,\n          refreshToken: refresh_token,\n        })),\n      );\n  }\n\n  private getParams() {\n    const initUrl = getInitUrl();\n\n    const initLocation = new URL(initUrl);\n\n    const queryParams = parseParams(\n      initLocation.search ? initLocation.search.slice(1) : '',\n    );\n\n    const hashParams = parseParams(\n      initLocation.hash ? initLocation.hash.slice(1) : '',\n    );\n\n    return { queryParams, hashParams };\n  }\n\n  private replaceRedirectUrl(authUrl: string, href: string) {\n    const [path, queryParams] = authUrl.split('?');\n\n    const replacedQueryParams = queryParams\n      .split('&')\n      .map(pair => {\n        const [key, value] = pair.split('=');\n        return REDIRECT_URIS.has(key)\n          ? `${key}=${encodeURIComponent(href) || value}`\n          : `${key}=${value}`;\n      })\n      .join('&');\n\n    return `${path}?${replacedQueryParams}`;\n  }\n}\n\nfunction parseParams(query: string): StringMap {\n  if (!query) {\n    return {};\n  }\n\n  return query.split('&').reduce((acc, param) => {\n    const [key, value] = param.split('=');\n\n    return {\n      ...acc,\n      [key]: value,\n    };\n  }, {});\n}\n\nfunction getAccountInfo(state: AuthorizationState) {\n  let accountInfo;\n  try {\n    accountInfo = JSON.parse(\n      decodeUrl(state.idToken.split('.')[1]),\n    ) as AccountInfo;\n  } catch { }\n  return accountInfo;\n}\n"]}
225
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"state.service.js","sourceRoot":"","sources":["../../../../../libs/common/src/authorization/state.service.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @packageDocumentation\n * @module authorization\n */\n\nimport { HttpClient } from '@angular/common/http';\nimport { Injectable, inject } from '@angular/core';\nimport { decodeUrl } from 'ab64';\nimport {\n  EMPTY,\n  Observable,\n  Subject,\n  concat,\n  of,\n  catchError,\n  map,\n  shareReplay,\n  switchMap,\n  tap,\n  pipe,\n  from,\n} from 'rxjs';\n\nimport {\n  StringMap,\n  API_GATEWAY,\n  NOT_NOTIFY_ON_ERROR_HEADERS,\n  publishRef,\n  getTopWindow,\n} from '../core/public-api';\nimport { AccountInfo } from '../page-scaffold/public-api';\n\nimport { getInitUrl } from './app-init-url';\nimport {\n  asyncReadStorageToken,\n  cleanStorageToken,\n  readStorageToken,\n  readStorageType,\n  writeStorageToken,\n} from './storage-token';\n\nexport interface AuthorizationState {\n  idToken?: string;\n  refreshToken?: string;\n  state?: string;\n  authUrl?: string;\n  logoutUrl?: string;\n}\n\nexport interface TokenResponse {\n  token_storage: StorageType;\n  id_token: string;\n  refresh_token: string;\n}\n\nexport type StorageType = 'local' | 'session';\n\nexport const STORAGE_TYPE_KEY = 'token_storage';\nexport const ID_TOKEN_KEY = 'id_token';\nexport const REFRESH_TOKEN_KEY = 'refresh_token';\nexport const CODE_KEY = 'code';\n\nconst LOGIN_API = '/console/api/v1/token/login';\nconst CALLBACK_API = '/console/api/v1/token/callback';\nconst TOKEN_REFRESH_API = '/console/api/v1/token/refresh';\nconst TOKEN_INFO_API = '/console/api/v1/token/info';\n\nconst REDIRECT_URIS = new Set(['redirect_uri', 'post_logout_redirect_uri']);\n\n@Injectable({ providedIn: 'root' })\nexport class AuthorizationStateService {\n  private readonly http = inject(HttpClient);\n\n  private readonly refreshToken$$ = new Subject<{\n    idToken: string;\n    refreshToken: string;\n  }>();\n\n  private readonly state$ = this.getAuthConfiguration().pipe(\n    switchMap(config =>\n      concat(this.getExistedToken(config), this.refreshToken$$).pipe(\n        map(token => ({ ...config, ...token })),\n      ),\n    ),\n    tap(state => {\n      this.stateSnapshot = state;\n      if (!state.idToken) {\n        this.logout(true);\n      }\n      this.payloadSnapshot = getAccountInfo(state);\n    }),\n    shareReplay(1),\n  );\n\n  private checkTokenCache: Record<string, Observable<unknown>> = {};\n  private refreshTokenCache$: Observable<string>;\n\n  stateSnapshot: AuthorizationState = null;\n\n  payloadSnapshot: AccountInfo;\n\n  logout(specificUrl = false) {\n    cleanStorageToken();\n    this.redirectToDex(specificUrl && location.href);\n  }\n\n  logoutAudit() {\n    return this.http.post(\n      `${API_GATEWAY}/auth/v1/logout`,\n      {},\n      {\n        headers: NOT_NOTIFY_ON_ERROR_HEADERS,\n      },\n    );\n  }\n\n  async redirectToDex(redirectUrl: string = null) {\n    if (!this.stateSnapshot) {\n      return;\n    }\n\n    // 主动退出或 session 模式跳转到 dex 前需要主动清除 `user_login` cookie 防止自动授权\n    if (!!this.stateSnapshot.idToken || readStorageType() === 'session') {\n      try {\n        await fetch(\n          `${this.stateSnapshot.logoutUrl}&id_token_hint=${\n            // 主动退出时禁用现有 token\n            this.stateSnapshot.idToken || ''\n          }`,\n        );\n      } catch (e) {\n        console.error(e);\n      }\n    }\n\n    const href = redirectUrl\n      ? replaceRedirectUrl(this.stateSnapshot.authUrl, redirectUrl)\n      : this.stateSnapshot.authUrl;\n\n    try {\n      getTopWindow().location.href = href;\n    } catch {\n      // should never happen, just for robustness in case of cross-origin iframe\n      location.href = href;\n    }\n  }\n\n  refreshToken() {\n    const refreshToken = readStorageToken()?.refreshToken;\n    if (refreshToken) {\n      if (!this.refreshTokenCache$) {\n        this.refreshTokenCache$ = this.getTokenByRefreshToken(\n          refreshToken,\n        ).pipe(\n          tap(token => {\n            this.refreshTokenCache$ = null;\n            this.refreshToken$$.next(token);\n          }),\n          map(({ idToken }) => idToken),\n          catchError(() => {\n            this.logout(true);\n            return EMPTY;\n          }),\n          publishRef(),\n        );\n      }\n      return this.refreshTokenCache$;\n    }\n    this.logout(true);\n    return EMPTY;\n  }\n\n  checkToken(token: string) {\n    if (!this.checkTokenCache[token]) {\n      this.checkTokenCache[token] = this.http\n        .get(TOKEN_INFO_API, {\n          headers: {\n            Authorization: `Bearer ${token}`,\n          },\n        })\n        .pipe(\n          tap({\n            next: () => {\n              this.checkTokenCache[token] = null;\n            },\n            error: () => {\n              this.checkTokenCache[token] = null;\n            },\n          }),\n          publishRef(),\n        );\n    }\n    return this.checkTokenCache[token];\n  }\n\n  getToken() {\n    return this.state$.pipe(map(state => state.idToken));\n  }\n\n  getTokenPayload<T>() {\n    return this.state$.pipe(map(state => getAccountInfo(state) as T));\n  }\n\n  getAccountInfo() {\n    if (this.payloadSnapshot) {\n      return of(this.payloadSnapshot);\n    }\n    return this.state$.pipe(map(state => getAccountInfo(state) || {}));\n  }\n\n  private getAuthConfiguration() {\n    return this.http\n      .get<{ auth_url: string; state: string; logout_url: string }>(LOGIN_API)\n      .pipe(\n        map(res => ({\n          authUrl: res.auth_url,\n          state: res.state,\n          logoutUrl: res.logout_url || '',\n        })),\n      );\n  }\n\n  private getExistedToken(config: AuthorizationState) {\n    return this.getTokenFromLocal(config).pipe(\n      catchError(error => {\n        console.error(error);\n        return of({ idToken: '', refreshToken: '' });\n      }),\n    );\n  }\n\n  private getTokenFromLocal(\n    config: AuthorizationState,\n  ): Observable<{ idToken?: string; refreshToken?: string }> {\n    const { queryParams, hashParams } = this.getParams();\n\n    const code = queryParams[CODE_KEY] || hashParams[CODE_KEY];\n\n    if (code) {\n      return this.getTokenByCode(code, config.state);\n    }\n\n    const refreshToken =\n      queryParams[REFRESH_TOKEN_KEY] || hashParams[REFRESH_TOKEN_KEY];\n\n    if (refreshToken) {\n      return this.getTokenByRefreshToken(refreshToken);\n    }\n\n    const idToken = queryParams[ID_TOKEN_KEY] || hashParams[ID_TOKEN_KEY];\n\n    if (idToken) {\n      writeStorageToken({\n        storageType: (queryParams[STORAGE_TYPE_KEY] ||\n          hashParams[STORAGE_TYPE_KEY]) as TokenResponse['token_storage'],\n        idToken,\n        refreshToken: '',\n      });\n    }\n\n    return from(asyncReadStorageToken());\n  }\n\n  private getTokenByRefreshToken(refreshToken: string) {\n    return this.http\n      .get<TokenResponse>(TOKEN_REFRESH_API, {\n        params: { refresh_token: refreshToken },\n      })\n      .pipe(mapTokenResponse());\n  }\n\n  private getTokenByCode(code: string, state: string) {\n    return this.http\n      .get<TokenResponse>(CALLBACK_API, {\n        params: { code, state },\n      })\n      .pipe(mapTokenResponse());\n  }\n\n  private getParams() {\n    const initUrl = getInitUrl();\n\n    const initLocation = new URL(initUrl);\n\n    const queryParams = parseParams(\n      initLocation.search ? initLocation.search.slice(1) : '',\n    );\n\n    const hashParams = parseParams(\n      initLocation.hash ? initLocation.hash.slice(1) : '',\n    );\n\n    return { queryParams, hashParams };\n  }\n}\n\nfunction replaceRedirectUrl(dexUrl: string, redirectUrl: string) {\n  const [path, queryParams] = dexUrl.split('?');\n\n  const replacedQueryParams = queryParams\n    .split('&')\n    .map(pair => {\n      const [key, value] = pair.split('=');\n      return REDIRECT_URIS.has(key)\n        ? `${key}=${encodeURIComponent(redirectUrl)}`\n        : `${key}=${value}`;\n    })\n    .join('&');\n\n  return `${path}?${replacedQueryParams}`;\n}\n\nfunction parseParams(query: string): StringMap {\n  if (!query) {\n    return {};\n  }\n\n  return query.split('&').reduce((acc, param) => {\n    const [key, value] = param.split('=');\n\n    return {\n      ...acc,\n      [key]: value,\n    };\n  }, {});\n}\n\nfunction getAccountInfo(state: AuthorizationState): AccountInfo {\n  return state.idToken\n    ? JSON.parse(decodeUrl(state.idToken.split('.')[1]))\n    : null;\n}\n\nfunction mapTokenResponse() {\n  return pipe(\n    tap(({ token_storage, id_token, refresh_token }: TokenResponse) => {\n      writeStorageToken({\n        storageType: token_storage,\n        idToken: id_token,\n        refreshToken: refresh_token,\n      });\n    }),\n    map(({ id_token, refresh_token }) => ({\n      idToken: id_token,\n      refreshToken: refresh_token,\n    })),\n  );\n}\n"]}
@@ -0,0 +1,82 @@
1
+ import { ID_TOKEN_KEY, REFRESH_TOKEN_KEY, STORAGE_TYPE_KEY, } from './state.service';
2
+ const getStorage = (storageType) => storageType === 'session' ? sessionStorage : localStorage;
3
+ let sessionTokenShareChannel;
4
+ const SESSION_TOKEN_SHARE_CHANNEL = 'SESSION_TOKEN_SHARE_CHANNEL';
5
+ export function readStorageType() {
6
+ return (localStorage.getItem(STORAGE_TYPE_KEY) === 'session' ? 'session' : 'local');
7
+ }
8
+ export function cleanStorageToken() {
9
+ localStorage.removeItem(ID_TOKEN_KEY);
10
+ localStorage.removeItem(REFRESH_TOKEN_KEY);
11
+ sessionStorage.removeItem(ID_TOKEN_KEY);
12
+ sessionStorage.removeItem(REFRESH_TOKEN_KEY);
13
+ }
14
+ export function writeStorageToken(token) {
15
+ cleanStorageToken();
16
+ localStorage.setItem(STORAGE_TYPE_KEY, token.storageType);
17
+ const storage = getStorage(token.storageType);
18
+ storage.setItem(ID_TOKEN_KEY, token.idToken);
19
+ storage.setItem(REFRESH_TOKEN_KEY, token.refreshToken);
20
+ if (token.storageType === 'session') {
21
+ setupRequestSessionTokenChannel();
22
+ }
23
+ else {
24
+ closeRequestSessionTokenChannel();
25
+ }
26
+ }
27
+ export function readStorageToken() {
28
+ const storageType = readStorageType();
29
+ if (storageType === 'session') {
30
+ setupRequestSessionTokenChannel();
31
+ }
32
+ const storage = getStorage(storageType);
33
+ return {
34
+ storageType,
35
+ idToken: storage.getItem(ID_TOKEN_KEY),
36
+ refreshToken: storage.getItem(REFRESH_TOKEN_KEY),
37
+ };
38
+ }
39
+ export function asyncReadStorageToken() {
40
+ const storageToken = readStorageToken();
41
+ if (storageToken.storageType === 'session' && !storageToken.idToken) {
42
+ return new Promise(resolve => {
43
+ const timer = window.setTimeout(() => {
44
+ console.warn('request session token timeout');
45
+ sessionTokenShareChannel.removeEventListener('message', receiveSessionToken);
46
+ resolve({});
47
+ }, 50);
48
+ function receiveSessionToken({ data, }) {
49
+ if (data.type === 'provide') {
50
+ window.clearTimeout(timer);
51
+ sessionTokenShareChannel.removeEventListener('message', receiveSessionToken);
52
+ writeStorageToken(data.token);
53
+ resolve(data.token);
54
+ }
55
+ }
56
+ sessionTokenShareChannel.addEventListener('message', receiveSessionToken);
57
+ sessionTokenShareChannel.postMessage({ type: 'request' });
58
+ });
59
+ }
60
+ return Promise.resolve(storageToken);
61
+ }
62
+ function setupRequestSessionTokenChannel() {
63
+ if (sessionTokenShareChannel) {
64
+ return;
65
+ }
66
+ sessionTokenShareChannel = new BroadcastChannel(SESSION_TOKEN_SHARE_CHANNEL);
67
+ sessionTokenShareChannel.addEventListener('message', ({ data }) => {
68
+ if (data.type === 'request') {
69
+ sessionTokenShareChannel.postMessage({
70
+ type: 'provide',
71
+ token: readStorageToken(),
72
+ });
73
+ }
74
+ });
75
+ }
76
+ function closeRequestSessionTokenChannel() {
77
+ if (sessionTokenShareChannel) {
78
+ sessionTokenShareChannel.close();
79
+ sessionTokenShareChannel = null;
80
+ }
81
+ }
82
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"storage-token.js","sourceRoot":"","sources":["../../../../../libs/common/src/authorization/storage-token.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ID_TOKEN_KEY,\n  REFRESH_TOKEN_KEY,\n  STORAGE_TYPE_KEY,\n  StorageType,\n} from './state.service';\n\nconst getStorage = (storageType: StorageType): Storage =>\n  storageType === 'session' ? sessionStorage : localStorage;\n\nlet sessionTokenShareChannel: BroadcastChannel;\n\nconst SESSION_TOKEN_SHARE_CHANNEL = 'SESSION_TOKEN_SHARE_CHANNEL';\n\ntype SessionTokenShareData =\n  | {\n      type: 'provide';\n      token: StorageToken;\n    }\n  | { type: 'request' };\n\nexport interface StorageToken {\n  storageType: StorageType;\n  idToken: string;\n  refreshToken: string;\n}\n\nexport function readStorageType() {\n  return (\n    localStorage.getItem(STORAGE_TYPE_KEY) === 'session' ? 'session' : 'local'\n  ) as StorageType;\n}\n\nexport function cleanStorageToken() {\n  localStorage.removeItem(ID_TOKEN_KEY);\n  localStorage.removeItem(REFRESH_TOKEN_KEY);\n\n  sessionStorage.removeItem(ID_TOKEN_KEY);\n  sessionStorage.removeItem(REFRESH_TOKEN_KEY);\n}\n\nexport function writeStorageToken(token: StorageToken) {\n  cleanStorageToken();\n\n  localStorage.setItem(STORAGE_TYPE_KEY, token.storageType);\n\n  const storage = getStorage(token.storageType);\n\n  storage.setItem(ID_TOKEN_KEY, token.idToken);\n  storage.setItem(REFRESH_TOKEN_KEY, token.refreshToken);\n\n  if (token.storageType === 'session') {\n    setupRequestSessionTokenChannel();\n  } else {\n    closeRequestSessionTokenChannel();\n  }\n}\n\nexport function readStorageToken(): Partial<StorageToken> {\n  const storageType = readStorageType();\n\n  if (storageType === 'session') {\n    setupRequestSessionTokenChannel();\n  }\n\n  const storage = getStorage(storageType);\n\n  return {\n    storageType,\n    idToken: storage.getItem(ID_TOKEN_KEY),\n    refreshToken: storage.getItem(REFRESH_TOKEN_KEY),\n  };\n}\n\nexport function asyncReadStorageToken(): Promise<Partial<StorageToken>> {\n  const storageToken = readStorageToken();\n\n  if (storageToken.storageType === 'session' && !storageToken.idToken) {\n    return new Promise(resolve => {\n      const timer = window.setTimeout(() => {\n        console.warn('request session token timeout');\n        sessionTokenShareChannel.removeEventListener(\n          'message',\n          receiveSessionToken,\n        );\n        resolve({});\n      }, 50);\n\n      function receiveSessionToken({\n        data,\n      }: MessageEvent<SessionTokenShareData>) {\n        if (data.type === 'provide') {\n          window.clearTimeout(timer);\n          sessionTokenShareChannel.removeEventListener(\n            'message',\n            receiveSessionToken,\n          );\n\n          writeStorageToken(data.token);\n          resolve(data.token);\n        }\n      }\n\n      sessionTokenShareChannel.addEventListener('message', receiveSessionToken);\n\n      sessionTokenShareChannel.postMessage({ type: 'request' });\n    });\n  }\n\n  return Promise.resolve(storageToken);\n}\n\nfunction setupRequestSessionTokenChannel() {\n  if (sessionTokenShareChannel) {\n    return;\n  }\n\n  sessionTokenShareChannel = new BroadcastChannel(SESSION_TOKEN_SHARE_CHANNEL);\n\n  sessionTokenShareChannel.addEventListener(\n    'message',\n    ({ data }: MessageEvent<SessionTokenShareData>) => {\n      if (data.type === 'request') {\n        sessionTokenShareChannel.postMessage({\n          type: 'provide',\n          token: readStorageToken(),\n        } as SessionTokenShareData);\n      }\n    },\n  );\n}\n\nfunction closeRequestSessionTokenChannel() {\n  if (sessionTokenShareChannel) {\n    sessionTokenShareChannel.close();\n    sessionTokenShareChannel = null;\n  }\n}\n"]}
@@ -80,11 +80,11 @@ export class ClusterSelectorComponent {
80
80
  i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(6, 3, "cluster"), " ");
81
81
  i0.ɵɵadvance(3);
82
82
  i0.ɵɵtextInterpolate(ctx.value);
83
- } }, styles: ["[_nghost-%COMP%]{display:flex}[_nghost-%COMP%] .icon-wrapper{position:relative;display:flex;justify-content:center;align-items:center;width:16px;height:16px;flex-shrink:0;font-size:var(--aui-icon-size-m)}:root [_nghost-%COMP%] .icon-wrapper{--bicolor-main: rgb(var(--aui-color-primary));--bicolor-secondary: rgb(var(--aui-color-p-3))}html[aui-theme-mode=light] [_nghost-%COMP%] .icon-wrapper{--bicolor-main: rgb(var(--aui-color-primary));--bicolor-secondary: rgb(var(--aui-color-p-3))}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] [_nghost-%COMP%] .icon-wrapper{--bicolor-main: rgb(var(--aui-color-primary));--bicolor-secondary: rgb(var(--aui-color-p-3))}}html[aui-theme-mode=dark] [_nghost-%COMP%] .icon-wrapper{--bicolor-main: rgb(var(--aui-color-primary));--bicolor-secondary: rgb(var(--aui-color-p-3))}[_nghost-%COMP%] .with-colon{display:inline-flex;word-break:keep-all;flex-shrink:0;font-weight:500}[_nghost-%COMP%] .with-colon:after{content:\":\";margin-right:8px}[_nghost-%COMP%] .text-truncate{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}[_nghost-%COMP%] .acl-resource-selector{user-select:none;display:flex;color:var(--acl-page-header-title-color);cursor:pointer;padding:0 8px}[_nghost-%COMP%] .acl-resource-selector .selected-name{color:var(--acl-page-header-text-color)}[_nghost-%COMP%] .acl-resource-selector--active, [_nghost-%COMP%] .acl-resource-selector:hover{background-color:rgb(var(--aui-color-primary));color:#fff;border-radius:2px}:root [_nghost-%COMP%] .acl-resource-selector--active .icon-wrapper, :root [_nghost-%COMP%] .acl-resource-selector:hover .icon-wrapper{--bicolor-main: white;--bicolor-secondary: rgb(var(--aui-color-p-4))}html[aui-theme-mode=light] [_nghost-%COMP%] .acl-resource-selector--active .icon-wrapper, html[aui-theme-mode=light] [_nghost-%COMP%] .acl-resource-selector:hover .icon-wrapper{--bicolor-main: white;--bicolor-secondary: rgb(var(--aui-color-p-4))}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] [_nghost-%COMP%] .acl-resource-selector--active .icon-wrapper, html[aui-theme-mode=system] [_nghost-%COMP%] .acl-resource-selector:hover .icon-wrapper{--bicolor-main: white;--bicolor-secondary: #b3d7fc}}html[aui-theme-mode=dark] [_nghost-%COMP%] .acl-resource-selector--active .icon-wrapper, html[aui-theme-mode=dark] [_nghost-%COMP%] .acl-resource-selector:hover .icon-wrapper{--bicolor-main: white;--bicolor-secondary: #b3d7fc}[_nghost-%COMP%] .acl-resource-selector--active .selected-name, [_nghost-%COMP%] .acl-resource-selector:hover .selected-name{color:#fff}[_nghost-%COMP%] .acl-resource-selector--lite{padding:0 4px}[_nghost-%COMP%] .acl-resource-selector--lite:hover{background-color:rgb(var(--aui-color-b-6))}[_nghost-%COMP%] .acl-resource-selector--lite:hover .selected-name, [_nghost-%COMP%] .acl-resource-selector--lite:hover .acl-resource-selector__arrow{color:rgb(var(--aui-color-n-2))}[_nghost-%COMP%] .acl-resource-selector--lite .acl-resource-selector__item{height:20px}[_nghost-%COMP%] .acl-resource-selector--lite.acl-resource-selector--active, [_nghost-%COMP%] .acl-resource-selector--lite.acl-resource-selector--active:hover{background-color:rgb(var(--aui-color-b-5))}[_nghost-%COMP%] .acl-resource-selector--lite.acl-resource-selector--active .selected-name, [_nghost-%COMP%] .acl-resource-selector--lite.acl-resource-selector--active .acl-resource-selector__arrow, [_nghost-%COMP%] .acl-resource-selector--lite.acl-resource-selector--active:hover .selected-name, [_nghost-%COMP%] .acl-resource-selector--lite.acl-resource-selector--active:hover .acl-resource-selector__arrow{color:rgb(var(--aui-color-primary))}[_nghost-%COMP%] .acl-resource-selector__item{margin-right:20px;height:32px;display:inline-flex;align-items:center;font-size:12px;max-width:270px}@media screen and (max-width: 1280px){[_nghost-%COMP%] .acl-resource-selector__item{max-width:178px;margin-right:8px}}[_nghost-%COMP%] .acl-resource-selector__item .icon-wrapper{margin-right:4px}[_nghost-%COMP%] .acl-resource-selector__arrow{margin-left:-16px;align-items:center;display:inline-flex;width:16px;justify-content:center}"], changeDetection: 0 }); }
83
+ } }, styles: ["[_nghost-%COMP%]{display:flex}[_nghost-%COMP%] .icon-wrapper{position:relative;display:flex;justify-content:center;align-items:center;width:16px;height:16px;flex-shrink:0;font-size:var(--aui-icon-size-m)}:root [_nghost-%COMP%] .icon-wrapper{--bicolor-main: rgb(var(--aui-color-primary));--bicolor-secondary: rgb(var(--aui-color-p-3))}html[aui-theme-mode=light] [_nghost-%COMP%] .icon-wrapper{--bicolor-main: rgb(var(--aui-color-primary));--bicolor-secondary: rgb(var(--aui-color-p-3))}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] [_nghost-%COMP%] .icon-wrapper{--bicolor-main: rgb(var(--aui-color-primary));--bicolor-secondary: rgb(var(--aui-color-p-3))}}html[aui-theme-mode=dark] [_nghost-%COMP%] .icon-wrapper{--bicolor-main: rgb(var(--aui-color-primary));--bicolor-secondary: rgb(var(--aui-color-p-3))}[_nghost-%COMP%] .with-colon{display:inline-flex;word-break:keep-all;flex-shrink:0;font-weight:500}[_nghost-%COMP%] .with-colon:after{content:\":\";margin-right:8px}[_nghost-%COMP%] .text-truncate{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}[_nghost-%COMP%] .acl-resource-selector{user-select:none;display:flex;color:var(--acl-page-header-title-color);cursor:pointer;padding:0 8px}[_nghost-%COMP%] .acl-resource-selector .selected-name{color:var(--acl-page-header-text-color)}[_nghost-%COMP%] .acl-resource-selector--active, [_nghost-%COMP%] .acl-resource-selector:hover{background-color:rgb(var(--aui-color-primary));color:#fff;border-radius:2px}:root [_nghost-%COMP%] .acl-resource-selector--active .icon-wrapper, :root [_nghost-%COMP%] .acl-resource-selector:hover .icon-wrapper{--bicolor-main: white;--bicolor-secondary: rgb(var(--aui-color-p-4))}html[aui-theme-mode=light] [_nghost-%COMP%] .acl-resource-selector--active .icon-wrapper, html[aui-theme-mode=light] [_nghost-%COMP%] .acl-resource-selector:hover .icon-wrapper{--bicolor-main: white;--bicolor-secondary: rgb(var(--aui-color-p-4))}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] [_nghost-%COMP%] .acl-resource-selector--active .icon-wrapper, html[aui-theme-mode=system] [_nghost-%COMP%] .acl-resource-selector:hover .icon-wrapper{--bicolor-main: white;--bicolor-secondary: #b3d7fc}}html[aui-theme-mode=dark] [_nghost-%COMP%] .acl-resource-selector--active .icon-wrapper, html[aui-theme-mode=dark] [_nghost-%COMP%] .acl-resource-selector:hover .icon-wrapper{--bicolor-main: white;--bicolor-secondary: #b3d7fc}[_nghost-%COMP%] .acl-resource-selector--active .selected-name, [_nghost-%COMP%] .acl-resource-selector:hover .selected-name{color:#fff}[_nghost-%COMP%] .acl-resource-selector--lite{padding:0 4px}[_nghost-%COMP%] .acl-resource-selector--lite:hover{background-color:rgb(var(--aui-color-b-6))}[_nghost-%COMP%] .acl-resource-selector--lite:hover .selected-name, [_nghost-%COMP%] .acl-resource-selector--lite:hover .acl-resource-selector__arrow{color:rgb(var(--aui-color-n-2))}[_nghost-%COMP%] .acl-resource-selector--lite .acl-resource-selector__item{height:20px}[_nghost-%COMP%] .acl-resource-selector--lite.acl-resource-selector--active, [_nghost-%COMP%] .acl-resource-selector--lite.acl-resource-selector--active:hover{background-color:rgb(var(--aui-color-b-5))}[_nghost-%COMP%] .acl-resource-selector--lite.acl-resource-selector--active .selected-name, [_nghost-%COMP%] .acl-resource-selector--lite.acl-resource-selector--active .acl-resource-selector__arrow, [_nghost-%COMP%] .acl-resource-selector--lite.acl-resource-selector--active:hover .selected-name, [_nghost-%COMP%] .acl-resource-selector--lite.acl-resource-selector--active:hover .acl-resource-selector__arrow{color:rgb(var(--aui-color-primary))}[_nghost-%COMP%] .acl-resource-selector__item{margin-right:20px;height:32px;display:inline-flex;align-items:center;font-size:12px;max-width:270px}@media screen and (max-width: 1280px){[_nghost-%COMP%] .acl-resource-selector__item{max-width:178px;margin-right:8px}}[_nghost-%COMP%] .acl-resource-selector__item .icon-wrapper{margin-right:4px}[_nghost-%COMP%] .acl-resource-selector__arrow{margin-left:-16px;align-items:center;display:inline-flex;width:16px;justify-content:center}@media screen and (max-width: 1280px){[_nghost-%COMP%] .acl-resource-selector__arrow{margin-left:-4px}}"], changeDetection: 0 }); }
84
84
  }
85
85
  (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ClusterSelectorComponent, [{
86
86
  type: Component,
87
- args: [{ selector: 'acl-cluster-selector', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\n class=\"acl-resource-selector\"\n [ngClass]=\"{ 'acl-resource-selector--active': isActive }\"\n (click)=\"openPopup()\"\n>\n <div class=\"acl-resource-selector__item project\">\n <span class=\"icon-wrapper tw-flex\">\n <aui-icon icon=\"bicolor:server\"></aui-icon>\n </span>\n <span class=\"with-colon\">\n {{ 'cluster' | translate }}\n </span>\n <span class=\"selected-name text-truncate\">{{ value }}</span>\n </div>\n <div class=\"acl-resource-selector__arrow\">\n <aui-icon icon=\"caret_down_s\"></aui-icon>\n </div>\n</div>\n\n<ng-template #popup>\n <acl-cluster-list\n [context]=\"'popup'\"\n [fields]=\"fields || displayFields\"\n (selectItem)=\"onSelect($event)\"\n [value]=\"value\"\n ></acl-cluster-list>\n</ng-template>\n", styles: [":host{display:flex}:host::ng-deep .icon-wrapper{position:relative;display:flex;justify-content:center;align-items:center;width:16px;height:16px;flex-shrink:0;font-size:var(--aui-icon-size-m)}:root :host::ng-deep .icon-wrapper{--bicolor-main: rgb(var(--aui-color-primary));--bicolor-secondary: rgb(var(--aui-color-p-3))}html[aui-theme-mode=light] :host::ng-deep .icon-wrapper{--bicolor-main: rgb(var(--aui-color-primary));--bicolor-secondary: rgb(var(--aui-color-p-3))}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] :host::ng-deep .icon-wrapper{--bicolor-main: rgb(var(--aui-color-primary));--bicolor-secondary: rgb(var(--aui-color-p-3))}}html[aui-theme-mode=dark] :host::ng-deep .icon-wrapper{--bicolor-main: rgb(var(--aui-color-primary));--bicolor-secondary: rgb(var(--aui-color-p-3))}:host::ng-deep .with-colon{display:inline-flex;word-break:keep-all;flex-shrink:0;font-weight:500}:host::ng-deep .with-colon:after{content:\":\";margin-right:8px}:host::ng-deep .text-truncate{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}:host::ng-deep .acl-resource-selector{user-select:none;display:flex;color:var(--acl-page-header-title-color);cursor:pointer;padding:0 8px}:host::ng-deep .acl-resource-selector .selected-name{color:var(--acl-page-header-text-color)}:host::ng-deep .acl-resource-selector--active,:host::ng-deep .acl-resource-selector:hover{background-color:rgb(var(--aui-color-primary));color:#fff;border-radius:2px}:root :host::ng-deep .acl-resource-selector--active .icon-wrapper,:root :host::ng-deep .acl-resource-selector:hover .icon-wrapper{--bicolor-main: white;--bicolor-secondary: rgb(var(--aui-color-p-4))}html[aui-theme-mode=light] :host::ng-deep .acl-resource-selector--active .icon-wrapper,html[aui-theme-mode=light] :host::ng-deep .acl-resource-selector:hover .icon-wrapper{--bicolor-main: white;--bicolor-secondary: rgb(var(--aui-color-p-4))}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] :host::ng-deep .acl-resource-selector--active .icon-wrapper,html[aui-theme-mode=system] :host::ng-deep .acl-resource-selector:hover .icon-wrapper{--bicolor-main: white;--bicolor-secondary: #b3d7fc}}html[aui-theme-mode=dark] :host::ng-deep .acl-resource-selector--active .icon-wrapper,html[aui-theme-mode=dark] :host::ng-deep .acl-resource-selector:hover .icon-wrapper{--bicolor-main: white;--bicolor-secondary: #b3d7fc}:host::ng-deep .acl-resource-selector--active .selected-name,:host::ng-deep .acl-resource-selector:hover .selected-name{color:#fff}:host::ng-deep .acl-resource-selector--lite{padding:0 4px}:host::ng-deep .acl-resource-selector--lite:hover{background-color:rgb(var(--aui-color-b-6))}:host::ng-deep .acl-resource-selector--lite:hover .selected-name,:host::ng-deep .acl-resource-selector--lite:hover .acl-resource-selector__arrow{color:rgb(var(--aui-color-n-2))}:host::ng-deep .acl-resource-selector--lite .acl-resource-selector__item{height:20px}:host::ng-deep .acl-resource-selector--lite.acl-resource-selector--active,:host::ng-deep .acl-resource-selector--lite.acl-resource-selector--active:hover{background-color:rgb(var(--aui-color-b-5))}:host::ng-deep .acl-resource-selector--lite.acl-resource-selector--active .selected-name,:host::ng-deep .acl-resource-selector--lite.acl-resource-selector--active .acl-resource-selector__arrow,:host::ng-deep .acl-resource-selector--lite.acl-resource-selector--active:hover .selected-name,:host::ng-deep .acl-resource-selector--lite.acl-resource-selector--active:hover .acl-resource-selector__arrow{color:rgb(var(--aui-color-primary))}:host::ng-deep .acl-resource-selector__item{margin-right:20px;height:32px;display:inline-flex;align-items:center;font-size:12px;max-width:270px}@media screen and (max-width: 1280px){:host::ng-deep .acl-resource-selector__item{max-width:178px;margin-right:8px}}:host::ng-deep .acl-resource-selector__item .icon-wrapper{margin-right:4px}:host::ng-deep .acl-resource-selector__arrow{margin-left:-16px;align-items:center;display:inline-flex;width:16px;justify-content:center}\n"] }]
87
+ args: [{ selector: 'acl-cluster-selector', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\n class=\"acl-resource-selector\"\n [ngClass]=\"{ 'acl-resource-selector--active': isActive }\"\n (click)=\"openPopup()\"\n>\n <div class=\"acl-resource-selector__item project\">\n <span class=\"icon-wrapper tw-flex\">\n <aui-icon icon=\"bicolor:server\"></aui-icon>\n </span>\n <span class=\"with-colon\">\n {{ 'cluster' | translate }}\n </span>\n <span class=\"selected-name text-truncate\">{{ value }}</span>\n </div>\n <div class=\"acl-resource-selector__arrow\">\n <aui-icon icon=\"caret_down_s\"></aui-icon>\n </div>\n</div>\n\n<ng-template #popup>\n <acl-cluster-list\n [context]=\"'popup'\"\n [fields]=\"fields || displayFields\"\n (selectItem)=\"onSelect($event)\"\n [value]=\"value\"\n ></acl-cluster-list>\n</ng-template>\n", styles: [":host{display:flex}:host::ng-deep .icon-wrapper{position:relative;display:flex;justify-content:center;align-items:center;width:16px;height:16px;flex-shrink:0;font-size:var(--aui-icon-size-m)}:root :host::ng-deep .icon-wrapper{--bicolor-main: rgb(var(--aui-color-primary));--bicolor-secondary: rgb(var(--aui-color-p-3))}html[aui-theme-mode=light] :host::ng-deep .icon-wrapper{--bicolor-main: rgb(var(--aui-color-primary));--bicolor-secondary: rgb(var(--aui-color-p-3))}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] :host::ng-deep .icon-wrapper{--bicolor-main: rgb(var(--aui-color-primary));--bicolor-secondary: rgb(var(--aui-color-p-3))}}html[aui-theme-mode=dark] :host::ng-deep .icon-wrapper{--bicolor-main: rgb(var(--aui-color-primary));--bicolor-secondary: rgb(var(--aui-color-p-3))}:host::ng-deep .with-colon{display:inline-flex;word-break:keep-all;flex-shrink:0;font-weight:500}:host::ng-deep .with-colon:after{content:\":\";margin-right:8px}:host::ng-deep .text-truncate{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}:host::ng-deep .acl-resource-selector{user-select:none;display:flex;color:var(--acl-page-header-title-color);cursor:pointer;padding:0 8px}:host::ng-deep .acl-resource-selector .selected-name{color:var(--acl-page-header-text-color)}:host::ng-deep .acl-resource-selector--active,:host::ng-deep .acl-resource-selector:hover{background-color:rgb(var(--aui-color-primary));color:#fff;border-radius:2px}:root :host::ng-deep .acl-resource-selector--active .icon-wrapper,:root :host::ng-deep .acl-resource-selector:hover .icon-wrapper{--bicolor-main: white;--bicolor-secondary: rgb(var(--aui-color-p-4))}html[aui-theme-mode=light] :host::ng-deep .acl-resource-selector--active .icon-wrapper,html[aui-theme-mode=light] :host::ng-deep .acl-resource-selector:hover .icon-wrapper{--bicolor-main: white;--bicolor-secondary: rgb(var(--aui-color-p-4))}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] :host::ng-deep .acl-resource-selector--active .icon-wrapper,html[aui-theme-mode=system] :host::ng-deep .acl-resource-selector:hover .icon-wrapper{--bicolor-main: white;--bicolor-secondary: #b3d7fc}}html[aui-theme-mode=dark] :host::ng-deep .acl-resource-selector--active .icon-wrapper,html[aui-theme-mode=dark] :host::ng-deep .acl-resource-selector:hover .icon-wrapper{--bicolor-main: white;--bicolor-secondary: #b3d7fc}:host::ng-deep .acl-resource-selector--active .selected-name,:host::ng-deep .acl-resource-selector:hover .selected-name{color:#fff}:host::ng-deep .acl-resource-selector--lite{padding:0 4px}:host::ng-deep .acl-resource-selector--lite:hover{background-color:rgb(var(--aui-color-b-6))}:host::ng-deep .acl-resource-selector--lite:hover .selected-name,:host::ng-deep .acl-resource-selector--lite:hover .acl-resource-selector__arrow{color:rgb(var(--aui-color-n-2))}:host::ng-deep .acl-resource-selector--lite .acl-resource-selector__item{height:20px}:host::ng-deep .acl-resource-selector--lite.acl-resource-selector--active,:host::ng-deep .acl-resource-selector--lite.acl-resource-selector--active:hover{background-color:rgb(var(--aui-color-b-5))}:host::ng-deep .acl-resource-selector--lite.acl-resource-selector--active .selected-name,:host::ng-deep .acl-resource-selector--lite.acl-resource-selector--active .acl-resource-selector__arrow,:host::ng-deep .acl-resource-selector--lite.acl-resource-selector--active:hover .selected-name,:host::ng-deep .acl-resource-selector--lite.acl-resource-selector--active:hover .acl-resource-selector__arrow{color:rgb(var(--aui-color-primary))}:host::ng-deep .acl-resource-selector__item{margin-right:20px;height:32px;display:inline-flex;align-items:center;font-size:12px;max-width:270px}@media screen and (max-width: 1280px){:host::ng-deep .acl-resource-selector__item{max-width:178px;margin-right:8px}}:host::ng-deep .acl-resource-selector__item .icon-wrapper{margin-right:4px}:host::ng-deep .acl-resource-selector__arrow{margin-left:-16px;align-items:center;display:inline-flex;width:16px;justify-content:center}@media screen and (max-width: 1280px){:host::ng-deep .acl-resource-selector__arrow{margin-left:-4px}}\n"] }]
88
88
  }], function () { return [{ type: i1.ResourceSelectorPopupService }, { type: i0.ChangeDetectorRef }, { type: i0.ElementRef }]; }, { popupTemplate: [{
89
89
  type: ViewChild,
90
90
  args: ['popup', { static: true }]
@@ -78,11 +78,11 @@ export class ServiceMeshGroupSelectorComponent {
78
78
  i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(6, 3, "service_meshes"), " ");
79
79
  i0.ɵɵadvance(3);
80
80
  i0.ɵɵtextInterpolate(i0.ɵɵpipeBind1(9, 5, ctx.value));
81
- } }, styles: ["[_nghost-%COMP%]{display:flex}[_nghost-%COMP%] .icon-wrapper{position:relative;display:flex;justify-content:center;align-items:center;width:16px;height:16px;flex-shrink:0;font-size:var(--aui-icon-size-m)}:root [_nghost-%COMP%] .icon-wrapper{--bicolor-main: rgb(var(--aui-color-primary));--bicolor-secondary: rgb(var(--aui-color-p-3))}html[aui-theme-mode=light] [_nghost-%COMP%] .icon-wrapper{--bicolor-main: rgb(var(--aui-color-primary));--bicolor-secondary: rgb(var(--aui-color-p-3))}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] [_nghost-%COMP%] .icon-wrapper{--bicolor-main: rgb(var(--aui-color-primary));--bicolor-secondary: rgb(var(--aui-color-p-3))}}html[aui-theme-mode=dark] [_nghost-%COMP%] .icon-wrapper{--bicolor-main: rgb(var(--aui-color-primary));--bicolor-secondary: rgb(var(--aui-color-p-3))}[_nghost-%COMP%] .with-colon{display:inline-flex;word-break:keep-all;flex-shrink:0;font-weight:500}[_nghost-%COMP%] .with-colon:after{content:\":\";margin-right:8px}[_nghost-%COMP%] .text-truncate{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}[_nghost-%COMP%] .acl-resource-selector{user-select:none;display:flex;color:var(--acl-page-header-title-color);cursor:pointer;padding:0 8px}[_nghost-%COMP%] .acl-resource-selector .selected-name{color:var(--acl-page-header-text-color)}[_nghost-%COMP%] .acl-resource-selector--active, [_nghost-%COMP%] .acl-resource-selector:hover{background-color:rgb(var(--aui-color-primary));color:#fff;border-radius:2px}:root [_nghost-%COMP%] .acl-resource-selector--active .icon-wrapper, :root [_nghost-%COMP%] .acl-resource-selector:hover .icon-wrapper{--bicolor-main: white;--bicolor-secondary: rgb(var(--aui-color-p-4))}html[aui-theme-mode=light] [_nghost-%COMP%] .acl-resource-selector--active .icon-wrapper, html[aui-theme-mode=light] [_nghost-%COMP%] .acl-resource-selector:hover .icon-wrapper{--bicolor-main: white;--bicolor-secondary: rgb(var(--aui-color-p-4))}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] [_nghost-%COMP%] .acl-resource-selector--active .icon-wrapper, html[aui-theme-mode=system] [_nghost-%COMP%] .acl-resource-selector:hover .icon-wrapper{--bicolor-main: white;--bicolor-secondary: #b3d7fc}}html[aui-theme-mode=dark] [_nghost-%COMP%] .acl-resource-selector--active .icon-wrapper, html[aui-theme-mode=dark] [_nghost-%COMP%] .acl-resource-selector:hover .icon-wrapper{--bicolor-main: white;--bicolor-secondary: #b3d7fc}[_nghost-%COMP%] .acl-resource-selector--active .selected-name, [_nghost-%COMP%] .acl-resource-selector:hover .selected-name{color:#fff}[_nghost-%COMP%] .acl-resource-selector--lite{padding:0 4px}[_nghost-%COMP%] .acl-resource-selector--lite:hover{background-color:rgb(var(--aui-color-b-6))}[_nghost-%COMP%] .acl-resource-selector--lite:hover .selected-name, [_nghost-%COMP%] .acl-resource-selector--lite:hover .acl-resource-selector__arrow{color:rgb(var(--aui-color-n-2))}[_nghost-%COMP%] .acl-resource-selector--lite .acl-resource-selector__item{height:20px}[_nghost-%COMP%] .acl-resource-selector--lite.acl-resource-selector--active, [_nghost-%COMP%] .acl-resource-selector--lite.acl-resource-selector--active:hover{background-color:rgb(var(--aui-color-b-5))}[_nghost-%COMP%] .acl-resource-selector--lite.acl-resource-selector--active .selected-name, [_nghost-%COMP%] .acl-resource-selector--lite.acl-resource-selector--active .acl-resource-selector__arrow, [_nghost-%COMP%] .acl-resource-selector--lite.acl-resource-selector--active:hover .selected-name, [_nghost-%COMP%] .acl-resource-selector--lite.acl-resource-selector--active:hover .acl-resource-selector__arrow{color:rgb(var(--aui-color-primary))}[_nghost-%COMP%] .acl-resource-selector__item{margin-right:20px;height:32px;display:inline-flex;align-items:center;font-size:12px;max-width:270px}@media screen and (max-width: 1280px){[_nghost-%COMP%] .acl-resource-selector__item{max-width:178px;margin-right:8px}}[_nghost-%COMP%] .acl-resource-selector__item .icon-wrapper{margin-right:4px}[_nghost-%COMP%] .acl-resource-selector__arrow{margin-left:-16px;align-items:center;display:inline-flex;width:16px;justify-content:center}"], changeDetection: 0 }); }
81
+ } }, styles: ["[_nghost-%COMP%]{display:flex}[_nghost-%COMP%] .icon-wrapper{position:relative;display:flex;justify-content:center;align-items:center;width:16px;height:16px;flex-shrink:0;font-size:var(--aui-icon-size-m)}:root [_nghost-%COMP%] .icon-wrapper{--bicolor-main: rgb(var(--aui-color-primary));--bicolor-secondary: rgb(var(--aui-color-p-3))}html[aui-theme-mode=light] [_nghost-%COMP%] .icon-wrapper{--bicolor-main: rgb(var(--aui-color-primary));--bicolor-secondary: rgb(var(--aui-color-p-3))}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] [_nghost-%COMP%] .icon-wrapper{--bicolor-main: rgb(var(--aui-color-primary));--bicolor-secondary: rgb(var(--aui-color-p-3))}}html[aui-theme-mode=dark] [_nghost-%COMP%] .icon-wrapper{--bicolor-main: rgb(var(--aui-color-primary));--bicolor-secondary: rgb(var(--aui-color-p-3))}[_nghost-%COMP%] .with-colon{display:inline-flex;word-break:keep-all;flex-shrink:0;font-weight:500}[_nghost-%COMP%] .with-colon:after{content:\":\";margin-right:8px}[_nghost-%COMP%] .text-truncate{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}[_nghost-%COMP%] .acl-resource-selector{user-select:none;display:flex;color:var(--acl-page-header-title-color);cursor:pointer;padding:0 8px}[_nghost-%COMP%] .acl-resource-selector .selected-name{color:var(--acl-page-header-text-color)}[_nghost-%COMP%] .acl-resource-selector--active, [_nghost-%COMP%] .acl-resource-selector:hover{background-color:rgb(var(--aui-color-primary));color:#fff;border-radius:2px}:root [_nghost-%COMP%] .acl-resource-selector--active .icon-wrapper, :root [_nghost-%COMP%] .acl-resource-selector:hover .icon-wrapper{--bicolor-main: white;--bicolor-secondary: rgb(var(--aui-color-p-4))}html[aui-theme-mode=light] [_nghost-%COMP%] .acl-resource-selector--active .icon-wrapper, html[aui-theme-mode=light] [_nghost-%COMP%] .acl-resource-selector:hover .icon-wrapper{--bicolor-main: white;--bicolor-secondary: rgb(var(--aui-color-p-4))}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] [_nghost-%COMP%] .acl-resource-selector--active .icon-wrapper, html[aui-theme-mode=system] [_nghost-%COMP%] .acl-resource-selector:hover .icon-wrapper{--bicolor-main: white;--bicolor-secondary: #b3d7fc}}html[aui-theme-mode=dark] [_nghost-%COMP%] .acl-resource-selector--active .icon-wrapper, html[aui-theme-mode=dark] [_nghost-%COMP%] .acl-resource-selector:hover .icon-wrapper{--bicolor-main: white;--bicolor-secondary: #b3d7fc}[_nghost-%COMP%] .acl-resource-selector--active .selected-name, [_nghost-%COMP%] .acl-resource-selector:hover .selected-name{color:#fff}[_nghost-%COMP%] .acl-resource-selector--lite{padding:0 4px}[_nghost-%COMP%] .acl-resource-selector--lite:hover{background-color:rgb(var(--aui-color-b-6))}[_nghost-%COMP%] .acl-resource-selector--lite:hover .selected-name, [_nghost-%COMP%] .acl-resource-selector--lite:hover .acl-resource-selector__arrow{color:rgb(var(--aui-color-n-2))}[_nghost-%COMP%] .acl-resource-selector--lite .acl-resource-selector__item{height:20px}[_nghost-%COMP%] .acl-resource-selector--lite.acl-resource-selector--active, [_nghost-%COMP%] .acl-resource-selector--lite.acl-resource-selector--active:hover{background-color:rgb(var(--aui-color-b-5))}[_nghost-%COMP%] .acl-resource-selector--lite.acl-resource-selector--active .selected-name, [_nghost-%COMP%] .acl-resource-selector--lite.acl-resource-selector--active .acl-resource-selector__arrow, [_nghost-%COMP%] .acl-resource-selector--lite.acl-resource-selector--active:hover .selected-name, [_nghost-%COMP%] .acl-resource-selector--lite.acl-resource-selector--active:hover .acl-resource-selector__arrow{color:rgb(var(--aui-color-primary))}[_nghost-%COMP%] .acl-resource-selector__item{margin-right:20px;height:32px;display:inline-flex;align-items:center;font-size:12px;max-width:270px}@media screen and (max-width: 1280px){[_nghost-%COMP%] .acl-resource-selector__item{max-width:178px;margin-right:8px}}[_nghost-%COMP%] .acl-resource-selector__item .icon-wrapper{margin-right:4px}[_nghost-%COMP%] .acl-resource-selector__arrow{margin-left:-16px;align-items:center;display:inline-flex;width:16px;justify-content:center}@media screen and (max-width: 1280px){[_nghost-%COMP%] .acl-resource-selector__arrow{margin-left:-4px}}"], changeDetection: 0 }); }
82
82
  }
83
83
  (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ServiceMeshGroupSelectorComponent, [{
84
84
  type: Component,
85
- args: [{ selector: 'acl-servicemesh-selector', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\n class=\"acl-resource-selector\"\n [ngClass]=\"{ 'acl-resource-selector--active': isActive }\"\n (click)=\"openPopup()\"\n>\n <div class=\"acl-resource-selector__item project\">\n <span class=\"icon-wrapper tw-flex\">\n <aui-icon icon=\"bicolor:service_mesh\"></aui-icon>\n </span>\n <span class=\"with-colon\">\n {{ 'service_meshes' | translate }}\n </span>\n <span class=\"selected-name text-truncate\">{{\n value | aclFieldNotAvailable\n }}</span>\n </div>\n <div class=\"acl-resource-selector__arrow\">\n <aui-icon icon=\"caret_down_s\"></aui-icon>\n </div>\n</div>\n\n<ng-template #popup>\n <acl-mesh-group-list\n [context]=\"'popup'\"\n [fields]=\"fields || displayFields\"\n (selectItem)=\"onSelect($event)\"\n [value]=\"value\"\n ></acl-mesh-group-list>\n</ng-template>\n", styles: [":host{display:flex}:host::ng-deep .icon-wrapper{position:relative;display:flex;justify-content:center;align-items:center;width:16px;height:16px;flex-shrink:0;font-size:var(--aui-icon-size-m)}:root :host::ng-deep .icon-wrapper{--bicolor-main: rgb(var(--aui-color-primary));--bicolor-secondary: rgb(var(--aui-color-p-3))}html[aui-theme-mode=light] :host::ng-deep .icon-wrapper{--bicolor-main: rgb(var(--aui-color-primary));--bicolor-secondary: rgb(var(--aui-color-p-3))}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] :host::ng-deep .icon-wrapper{--bicolor-main: rgb(var(--aui-color-primary));--bicolor-secondary: rgb(var(--aui-color-p-3))}}html[aui-theme-mode=dark] :host::ng-deep .icon-wrapper{--bicolor-main: rgb(var(--aui-color-primary));--bicolor-secondary: rgb(var(--aui-color-p-3))}:host::ng-deep .with-colon{display:inline-flex;word-break:keep-all;flex-shrink:0;font-weight:500}:host::ng-deep .with-colon:after{content:\":\";margin-right:8px}:host::ng-deep .text-truncate{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}:host::ng-deep .acl-resource-selector{user-select:none;display:flex;color:var(--acl-page-header-title-color);cursor:pointer;padding:0 8px}:host::ng-deep .acl-resource-selector .selected-name{color:var(--acl-page-header-text-color)}:host::ng-deep .acl-resource-selector--active,:host::ng-deep .acl-resource-selector:hover{background-color:rgb(var(--aui-color-primary));color:#fff;border-radius:2px}:root :host::ng-deep .acl-resource-selector--active .icon-wrapper,:root :host::ng-deep .acl-resource-selector:hover .icon-wrapper{--bicolor-main: white;--bicolor-secondary: rgb(var(--aui-color-p-4))}html[aui-theme-mode=light] :host::ng-deep .acl-resource-selector--active .icon-wrapper,html[aui-theme-mode=light] :host::ng-deep .acl-resource-selector:hover .icon-wrapper{--bicolor-main: white;--bicolor-secondary: rgb(var(--aui-color-p-4))}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] :host::ng-deep .acl-resource-selector--active .icon-wrapper,html[aui-theme-mode=system] :host::ng-deep .acl-resource-selector:hover .icon-wrapper{--bicolor-main: white;--bicolor-secondary: #b3d7fc}}html[aui-theme-mode=dark] :host::ng-deep .acl-resource-selector--active .icon-wrapper,html[aui-theme-mode=dark] :host::ng-deep .acl-resource-selector:hover .icon-wrapper{--bicolor-main: white;--bicolor-secondary: #b3d7fc}:host::ng-deep .acl-resource-selector--active .selected-name,:host::ng-deep .acl-resource-selector:hover .selected-name{color:#fff}:host::ng-deep .acl-resource-selector--lite{padding:0 4px}:host::ng-deep .acl-resource-selector--lite:hover{background-color:rgb(var(--aui-color-b-6))}:host::ng-deep .acl-resource-selector--lite:hover .selected-name,:host::ng-deep .acl-resource-selector--lite:hover .acl-resource-selector__arrow{color:rgb(var(--aui-color-n-2))}:host::ng-deep .acl-resource-selector--lite .acl-resource-selector__item{height:20px}:host::ng-deep .acl-resource-selector--lite.acl-resource-selector--active,:host::ng-deep .acl-resource-selector--lite.acl-resource-selector--active:hover{background-color:rgb(var(--aui-color-b-5))}:host::ng-deep .acl-resource-selector--lite.acl-resource-selector--active .selected-name,:host::ng-deep .acl-resource-selector--lite.acl-resource-selector--active .acl-resource-selector__arrow,:host::ng-deep .acl-resource-selector--lite.acl-resource-selector--active:hover .selected-name,:host::ng-deep .acl-resource-selector--lite.acl-resource-selector--active:hover .acl-resource-selector__arrow{color:rgb(var(--aui-color-primary))}:host::ng-deep .acl-resource-selector__item{margin-right:20px;height:32px;display:inline-flex;align-items:center;font-size:12px;max-width:270px}@media screen and (max-width: 1280px){:host::ng-deep .acl-resource-selector__item{max-width:178px;margin-right:8px}}:host::ng-deep .acl-resource-selector__item .icon-wrapper{margin-right:4px}:host::ng-deep .acl-resource-selector__arrow{margin-left:-16px;align-items:center;display:inline-flex;width:16px;justify-content:center}\n"] }]
85
+ args: [{ selector: 'acl-servicemesh-selector', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\n class=\"acl-resource-selector\"\n [ngClass]=\"{ 'acl-resource-selector--active': isActive }\"\n (click)=\"openPopup()\"\n>\n <div class=\"acl-resource-selector__item project\">\n <span class=\"icon-wrapper tw-flex\">\n <aui-icon icon=\"bicolor:service_mesh\"></aui-icon>\n </span>\n <span class=\"with-colon\">\n {{ 'service_meshes' | translate }}\n </span>\n <span class=\"selected-name text-truncate\">{{\n value | aclFieldNotAvailable\n }}</span>\n </div>\n <div class=\"acl-resource-selector__arrow\">\n <aui-icon icon=\"caret_down_s\"></aui-icon>\n </div>\n</div>\n\n<ng-template #popup>\n <acl-mesh-group-list\n [context]=\"'popup'\"\n [fields]=\"fields || displayFields\"\n (selectItem)=\"onSelect($event)\"\n [value]=\"value\"\n ></acl-mesh-group-list>\n</ng-template>\n", styles: [":host{display:flex}:host::ng-deep .icon-wrapper{position:relative;display:flex;justify-content:center;align-items:center;width:16px;height:16px;flex-shrink:0;font-size:var(--aui-icon-size-m)}:root :host::ng-deep .icon-wrapper{--bicolor-main: rgb(var(--aui-color-primary));--bicolor-secondary: rgb(var(--aui-color-p-3))}html[aui-theme-mode=light] :host::ng-deep .icon-wrapper{--bicolor-main: rgb(var(--aui-color-primary));--bicolor-secondary: rgb(var(--aui-color-p-3))}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] :host::ng-deep .icon-wrapper{--bicolor-main: rgb(var(--aui-color-primary));--bicolor-secondary: rgb(var(--aui-color-p-3))}}html[aui-theme-mode=dark] :host::ng-deep .icon-wrapper{--bicolor-main: rgb(var(--aui-color-primary));--bicolor-secondary: rgb(var(--aui-color-p-3))}:host::ng-deep .with-colon{display:inline-flex;word-break:keep-all;flex-shrink:0;font-weight:500}:host::ng-deep .with-colon:after{content:\":\";margin-right:8px}:host::ng-deep .text-truncate{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}:host::ng-deep .acl-resource-selector{user-select:none;display:flex;color:var(--acl-page-header-title-color);cursor:pointer;padding:0 8px}:host::ng-deep .acl-resource-selector .selected-name{color:var(--acl-page-header-text-color)}:host::ng-deep .acl-resource-selector--active,:host::ng-deep .acl-resource-selector:hover{background-color:rgb(var(--aui-color-primary));color:#fff;border-radius:2px}:root :host::ng-deep .acl-resource-selector--active .icon-wrapper,:root :host::ng-deep .acl-resource-selector:hover .icon-wrapper{--bicolor-main: white;--bicolor-secondary: rgb(var(--aui-color-p-4))}html[aui-theme-mode=light] :host::ng-deep .acl-resource-selector--active .icon-wrapper,html[aui-theme-mode=light] :host::ng-deep .acl-resource-selector:hover .icon-wrapper{--bicolor-main: white;--bicolor-secondary: rgb(var(--aui-color-p-4))}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] :host::ng-deep .acl-resource-selector--active .icon-wrapper,html[aui-theme-mode=system] :host::ng-deep .acl-resource-selector:hover .icon-wrapper{--bicolor-main: white;--bicolor-secondary: #b3d7fc}}html[aui-theme-mode=dark] :host::ng-deep .acl-resource-selector--active .icon-wrapper,html[aui-theme-mode=dark] :host::ng-deep .acl-resource-selector:hover .icon-wrapper{--bicolor-main: white;--bicolor-secondary: #b3d7fc}:host::ng-deep .acl-resource-selector--active .selected-name,:host::ng-deep .acl-resource-selector:hover .selected-name{color:#fff}:host::ng-deep .acl-resource-selector--lite{padding:0 4px}:host::ng-deep .acl-resource-selector--lite:hover{background-color:rgb(var(--aui-color-b-6))}:host::ng-deep .acl-resource-selector--lite:hover .selected-name,:host::ng-deep .acl-resource-selector--lite:hover .acl-resource-selector__arrow{color:rgb(var(--aui-color-n-2))}:host::ng-deep .acl-resource-selector--lite .acl-resource-selector__item{height:20px}:host::ng-deep .acl-resource-selector--lite.acl-resource-selector--active,:host::ng-deep .acl-resource-selector--lite.acl-resource-selector--active:hover{background-color:rgb(var(--aui-color-b-5))}:host::ng-deep .acl-resource-selector--lite.acl-resource-selector--active .selected-name,:host::ng-deep .acl-resource-selector--lite.acl-resource-selector--active .acl-resource-selector__arrow,:host::ng-deep .acl-resource-selector--lite.acl-resource-selector--active:hover .selected-name,:host::ng-deep .acl-resource-selector--lite.acl-resource-selector--active:hover .acl-resource-selector__arrow{color:rgb(var(--aui-color-primary))}:host::ng-deep .acl-resource-selector__item{margin-right:20px;height:32px;display:inline-flex;align-items:center;font-size:12px;max-width:270px}@media screen and (max-width: 1280px){:host::ng-deep .acl-resource-selector__item{max-width:178px;margin-right:8px}}:host::ng-deep .acl-resource-selector__item .icon-wrapper{margin-right:4px}:host::ng-deep .acl-resource-selector__arrow{margin-left:-16px;align-items:center;display:inline-flex;width:16px;justify-content:center}@media screen and (max-width: 1280px){:host::ng-deep .acl-resource-selector__arrow{margin-left:-4px}}\n"] }]
86
86
  }], function () { return [{ type: i1.ResourceSelectorPopupService }, { type: i0.ChangeDetectorRef }, { type: i0.ElementRef }]; }, { popupTemplate: [{
87
87
  type: ViewChild,
88
88
  args: ['popup', { static: true }]