@alauda-fe/dynamic-plugin-shared 0.0.1-alpha.10 → 0.0.1-alpha.12

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,3 @@
1
+ {
2
+ "project_shared_namespace": "Project Shared Namespace"
3
+ }
@@ -30,3 +30,6 @@ export * from './disabled-container';
30
30
  export * from './upload-file/component';
31
31
  export * from './help-document';
32
32
  export * from './page-guard';
33
+ export * from './namespace-selector';
34
+ export * from './namespace-badge/component';
35
+ export * from './test-tag/component';
@@ -0,0 +1,6 @@
1
+ import * as i0 from "@angular/core";
2
+ export declare class NamespaceBadgeComponent {
3
+ name: string;
4
+ static ɵfac: i0.ɵɵFactoryDeclaration<NamespaceBadgeComponent, never>;
5
+ static ɵcmp: i0.ɵɵComponentDeclaration<NamespaceBadgeComponent, "acl-namespace-badge", never, { "name": { "alias": "name"; "required": false; }; }, {}, never, never, true, never>;
6
+ }
@@ -0,0 +1,28 @@
1
+ import { K8sApiService, ResourceSelectorPopupRef, ResourceSelectorPopupService } from '@alauda-fe/dynamic-plugin-sdk';
2
+ import { ChangeDetectorRef, ElementRef, EventEmitter, TemplateRef } from '@angular/core';
3
+ import { Observable } from 'rxjs';
4
+ import { KubernetesResource, Namespace } from '../../types';
5
+ import * as i0 from "@angular/core";
6
+ export declare class NamespaceSelectorComponent {
7
+ private readonly popupService;
8
+ private readonly k8sService;
9
+ private readonly cdr;
10
+ private readonly elementRef;
11
+ popupTemplate: TemplateRef<any>;
12
+ cluster: string;
13
+ cluster$: Observable<string>;
14
+ value: string;
15
+ value$: Observable<string>;
16
+ valueChange: EventEmitter<KubernetesResource>;
17
+ ALL_NAMESPACE_KEY: string;
18
+ isActive: boolean;
19
+ popupRef: ResourceSelectorPopupRef;
20
+ destroy$$: Observable<void>;
21
+ namespaces$: Observable<Namespace[]>;
22
+ constructor(popupService: ResourceSelectorPopupService, k8sService: K8sApiService, cdr: ChangeDetectorRef, elementRef: ElementRef);
23
+ openPopup(): void;
24
+ closePopup(): void;
25
+ onSelect(item: KubernetesResource): void;
26
+ static ɵfac: i0.ɵɵFactoryDeclaration<NamespaceSelectorComponent, never>;
27
+ static ɵcmp: i0.ɵɵComponentDeclaration<NamespaceSelectorComponent, "acl-namespace-selector", never, { "cluster": { "alias": "cluster"; "required": false; }; "value": { "alias": "value"; "required": false; }; }, { "valueChange": "valueChange"; }, never, never, true, never>;
28
+ }
@@ -0,0 +1,2 @@
1
+ export declare const DEV_NAMESPACE_KEY = "DEV_NAMESPACE";
2
+ export declare const ALL_NAMESPACE_KEY = "~all-namespaces~";
@@ -0,0 +1,3 @@
1
+ export * from './constants';
2
+ export * from './component';
3
+ export * from './types';
@@ -0,0 +1,46 @@
1
+ import { K8sUtilService } from '@alauda-fe/dynamic-plugin-sdk';
2
+ import { ChangeDetectorRef, ElementRef, EventEmitter } from '@angular/core';
3
+ import { BehaviorSubject, Observable, ReplaySubject, Subject } from 'rxjs';
4
+ import { KubernetesResource, Project } from '../../../types';
5
+ import * as i0 from "@angular/core";
6
+ export declare class NamespaceListComponent {
7
+ private readonly cdr;
8
+ private readonly k8sUtil;
9
+ grid: ElementRef<HTMLElement>;
10
+ namespaces: KubernetesResource[];
11
+ namespaces$: Observable<KubernetesResource[]>;
12
+ value: string;
13
+ cluster: string;
14
+ cluster$: Observable<string>;
15
+ selectItem: EventEmitter<KubernetesResource>;
16
+ loading: boolean;
17
+ reload$$: Subject<void>;
18
+ destroy$$: Observable<void>;
19
+ load$$: ReplaySubject<{
20
+ project: Project;
21
+ cluster: string;
22
+ }>;
23
+ keyword$$: BehaviorSubject<string>;
24
+ namespaceType$$: BehaviorSubject<string>;
25
+ private scrollInitialized;
26
+ namespaceTypes: {
27
+ value: string;
28
+ key: string;
29
+ }[];
30
+ statusIcon: Record<string, string>;
31
+ filteredList$: Observable<KubernetesResource[]>;
32
+ constructor(cdr: ChangeDetectorRef, k8sUtil: K8sUtilService);
33
+ reload(): void;
34
+ onSelect(selected: KubernetesResource): void;
35
+ getHighlightedNameStrs: (item: KubernetesResource) => {
36
+ text: string;
37
+ isHighlighted?: boolean;
38
+ }[];
39
+ getHighlightedDisplayNameStrs: (item: KubernetesResource) => {
40
+ text: string;
41
+ isHighlighted?: boolean;
42
+ }[];
43
+ private initScroll;
44
+ static ɵfac: i0.ɵɵFactoryDeclaration<NamespaceListComponent, never>;
45
+ static ɵcmp: i0.ɵɵComponentDeclaration<NamespaceListComponent, "acl-namespace-list", never, { "namespaces": { "alias": "namespaces"; "required": false; }; "value": { "alias": "value"; "required": false; }; "cluster": { "alias": "cluster"; "required": false; }; "loading": { "alias": "loading"; "required": false; }; }, { "selectItem": "selectItem"; }, never, never, true, never>;
46
+ }
@@ -0,0 +1,5 @@
1
+ export interface SelectedNamespaceValue {
2
+ project: string;
3
+ cluster: string;
4
+ name: string;
5
+ }
@@ -0,0 +1,5 @@
1
+ import * as i0 from "@angular/core";
2
+ export declare class TestTagComponent {
3
+ static ɵfac: i0.ɵɵFactoryDeclaration<TestTagComponent, never>;
4
+ static ɵcmp: i0.ɵɵComponentDeclaration<TestTagComponent, "acl-test-tag", never, {}, {}, never, never, true, never>;
5
+ }
@@ -30,4 +30,7 @@ export * from './disabled-container';
30
30
  export * from './upload-file/component';
31
31
  export * from './help-document';
32
32
  export * from './page-guard';
33
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2R5bmFtaWMtcGx1Z2luLXNoYXJlZC9zcmMvY29tcG9uZW50cy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLDJDQUEyQyxDQUFDO0FBQzFELGNBQWMsd0JBQXdCLENBQUM7QUFDdkMsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyx1Q0FBdUMsQ0FBQztBQUN0RCxjQUFjLGlDQUFpQyxDQUFDO0FBQ2hELGNBQWMsbUNBQW1DLENBQUM7QUFDbEQsY0FBYywyQkFBMkIsQ0FBQztBQUUxQyxjQUFjLDRCQUE0QixDQUFDO0FBQzNDLGNBQWMsb0NBQW9DLENBQUM7QUFDbkQsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLDJCQUEyQixDQUFDO0FBQzFDLGNBQWMsdUNBQXVDLENBQUM7QUFDdEQsY0FBYywwQkFBMEIsQ0FBQztBQUN6QyxjQUFjLDBCQUEwQixDQUFDO0FBQ3pDLGNBQWMscUJBQXFCLENBQUM7QUFDcEMsY0FBYyx3QkFBd0IsQ0FBQztBQUN2QyxjQUFjLHFDQUFxQyxDQUFDO0FBQ3BELGNBQWMsMkJBQTJCLENBQUM7QUFFMUMsY0FBYyw0QkFBNEIsQ0FBQztBQUMzQyxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUVwRSxPQUFPLEVBQUUsNEJBQTRCLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQztBQUNqRixPQUFPLEVBQ0wsV0FBVyxFQUNYLFNBQVMsRUFDVCxjQUFjLEdBQ2YsTUFBTSw4QkFBOEIsQ0FBQztBQUN0QyxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxzQ0FBc0MsQ0FBQztBQUMzRSxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUNoRSxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUUzRSxjQUFjLDBCQUEwQixDQUFDO0FBQ3pDLGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMsbUJBQW1CLENBQUM7QUFDbEMsY0FBYyxzQkFBc0IsQ0FBQztBQUNyQyxjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMsaUJBQWlCLENBQUM7QUFDaEMsY0FBYyxjQUFjLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2NvbmZpcm0tZGVsZXRlL2NvbmZpcm0tZGVsZXRlLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2NvbmZpcm0tZGVsZXRlL3V0aWxzJztcbmV4cG9ydCAqIGZyb20gJy4vZmllbGQtc2V0JztcbmV4cG9ydCAqIGZyb20gJy4vbG9hZGluZy1tYXNrL2xvYWRpbmctbWFzay5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9zZWxlY3QtcHJlZml4LWxhYmVsL2RpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL3plcm8tc3RhdGUvemVyby1zdGF0ZS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9yZWxhdGl2ZS10aW1lL2NvbXBvbmVudCc7XG5cbmV4cG9ydCAqIGZyb20gJy4vZm9sZGFibGUtYmxvY2svY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vZm9sZGFibGUtaXRlbS1pbi10YWJsZS9jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi90ZXJtaW5hdGluZy10YWcvY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vdGV4dC13aXRoLXVybC9jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9jYXJkLXNlY3Rpb24vY2FyZC1zZWN0aW9uLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2N1cnJlbnQtdGltZS9jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi90ZXh0LXRvb2x0aXAvZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vZGF0ZS1yYW5nZS1waWNrZXInO1xuZXhwb3J0ICogZnJvbSAnLi90YWdzLWxhYmVsL2NvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3N0YXR1cy1pY29uL3N0YXR1cy1pY29uLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3RleHQtZWxsaXBzaXMvY29tcG9uZW50JztcblxuZXhwb3J0ICogZnJvbSAnLi9wYXNzd29yZC1pbnB1dC9jb21wb25lbnQnO1xuZXhwb3J0IHsgUmVzb3VyY2VMYWJlbENvbXBvbmVudCB9IGZyb20gJy4vcmVzb3VyY2UtbGFiZWwvY29tcG9uZW50JztcblxuZXhwb3J0IHsgUmVzb3VyY2VNdWx0aVNlbGVjdENvbXBvbmVudCB9IGZyb20gJy4vcmVzb3VyY2UtbXVsdGktc2VsZWN0L2NvbXBvbmVudCc7XG5leHBvcnQge1xuICBpc1NlbGVjdEFsbCxcbiAgQUxMX1ZBTFVFLFxuICBjaGVja1ZhbHVlRXhpdCxcbn0gZnJvbSAnLi9yZXNvdXJjZS1tdWx0aS1zZWxlY3QvdXRpbCc7XG5leHBvcnQgeyBTZWFyY2hJdGVtQ29tcG9uZW50IH0gZnJvbSAnLi9zZWFyY2gtcGFuZWwvc2VhcmNoLWl0ZW0vY29tcG9uZW50JztcbmV4cG9ydCB7IFNlYXJjaFBhbmVsQ29tcG9uZW50IH0gZnJvbSAnLi9zZWFyY2gtcGFuZWwvY29tcG9uZW50JztcbmV4cG9ydCB7IFNlYXJjaEl0ZW1MYWJlbERpcmVjdGl2ZSB9IGZyb20gJy4vc2VhcmNoLXBhbmVsL2hlbHBlci5kaXJlY3RpdmUnO1xuXG5leHBvcnQgKiBmcm9tICcuL2N1c3RvbS1jb2x1bW5zLXNldHRpbmcnO1xuZXhwb3J0ICogZnJvbSAnLi9wb2Qtc3RhdHVzJztcbmV4cG9ydCAqIGZyb20gJy4vd29ya2xvYWQtc3RhdHVzJztcbmV4cG9ydCAqIGZyb20gJy4vZGlzYWJsZWQtY29udGFpbmVyJztcbmV4cG9ydCAqIGZyb20gJy4vdXBsb2FkLWZpbGUvY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vaGVscC1kb2N1bWVudCc7XG5leHBvcnQgKiBmcm9tICcuL3BhZ2UtZ3VhcmQnO1xuIl19
33
+ export * from './namespace-selector';
34
+ export * from './namespace-badge/component';
35
+ export * from './test-tag/component';
36
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2R5bmFtaWMtcGx1Z2luLXNoYXJlZC9zcmMvY29tcG9uZW50cy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLDJDQUEyQyxDQUFDO0FBQzFELGNBQWMsd0JBQXdCLENBQUM7QUFDdkMsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyx1Q0FBdUMsQ0FBQztBQUN0RCxjQUFjLGlDQUFpQyxDQUFDO0FBQ2hELGNBQWMsbUNBQW1DLENBQUM7QUFDbEQsY0FBYywyQkFBMkIsQ0FBQztBQUUxQyxjQUFjLDRCQUE0QixDQUFDO0FBQzNDLGNBQWMsb0NBQW9DLENBQUM7QUFDbkQsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLDJCQUEyQixDQUFDO0FBQzFDLGNBQWMsdUNBQXVDLENBQUM7QUFDdEQsY0FBYywwQkFBMEIsQ0FBQztBQUN6QyxjQUFjLDBCQUEwQixDQUFDO0FBQ3pDLGNBQWMscUJBQXFCLENBQUM7QUFDcEMsY0FBYyx3QkFBd0IsQ0FBQztBQUN2QyxjQUFjLHFDQUFxQyxDQUFDO0FBQ3BELGNBQWMsMkJBQTJCLENBQUM7QUFFMUMsY0FBYyw0QkFBNEIsQ0FBQztBQUMzQyxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUVwRSxPQUFPLEVBQUUsNEJBQTRCLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQztBQUNqRixPQUFPLEVBQ0wsV0FBVyxFQUNYLFNBQVMsRUFDVCxjQUFjLEdBQ2YsTUFBTSw4QkFBOEIsQ0FBQztBQUN0QyxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxzQ0FBc0MsQ0FBQztBQUMzRSxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUNoRSxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUUzRSxjQUFjLDBCQUEwQixDQUFDO0FBQ3pDLGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMsbUJBQW1CLENBQUM7QUFDbEMsY0FBYyxzQkFBc0IsQ0FBQztBQUNyQyxjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMsaUJBQWlCLENBQUM7QUFDaEMsY0FBYyxjQUFjLENBQUM7QUFFN0IsY0FBYyxzQkFBc0IsQ0FBQztBQUNyQyxjQUFjLDZCQUE2QixDQUFDO0FBRTVDLGNBQWMsc0JBQXNCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2NvbmZpcm0tZGVsZXRlL2NvbmZpcm0tZGVsZXRlLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2NvbmZpcm0tZGVsZXRlL3V0aWxzJztcbmV4cG9ydCAqIGZyb20gJy4vZmllbGQtc2V0JztcbmV4cG9ydCAqIGZyb20gJy4vbG9hZGluZy1tYXNrL2xvYWRpbmctbWFzay5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9zZWxlY3QtcHJlZml4LWxhYmVsL2RpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL3plcm8tc3RhdGUvemVyby1zdGF0ZS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9yZWxhdGl2ZS10aW1lL2NvbXBvbmVudCc7XG5cbmV4cG9ydCAqIGZyb20gJy4vZm9sZGFibGUtYmxvY2svY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vZm9sZGFibGUtaXRlbS1pbi10YWJsZS9jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi90ZXJtaW5hdGluZy10YWcvY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vdGV4dC13aXRoLXVybC9jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9jYXJkLXNlY3Rpb24vY2FyZC1zZWN0aW9uLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2N1cnJlbnQtdGltZS9jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi90ZXh0LXRvb2x0aXAvZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vZGF0ZS1yYW5nZS1waWNrZXInO1xuZXhwb3J0ICogZnJvbSAnLi90YWdzLWxhYmVsL2NvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3N0YXR1cy1pY29uL3N0YXR1cy1pY29uLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3RleHQtZWxsaXBzaXMvY29tcG9uZW50JztcblxuZXhwb3J0ICogZnJvbSAnLi9wYXNzd29yZC1pbnB1dC9jb21wb25lbnQnO1xuZXhwb3J0IHsgUmVzb3VyY2VMYWJlbENvbXBvbmVudCB9IGZyb20gJy4vcmVzb3VyY2UtbGFiZWwvY29tcG9uZW50JztcblxuZXhwb3J0IHsgUmVzb3VyY2VNdWx0aVNlbGVjdENvbXBvbmVudCB9IGZyb20gJy4vcmVzb3VyY2UtbXVsdGktc2VsZWN0L2NvbXBvbmVudCc7XG5leHBvcnQge1xuICBpc1NlbGVjdEFsbCxcbiAgQUxMX1ZBTFVFLFxuICBjaGVja1ZhbHVlRXhpdCxcbn0gZnJvbSAnLi9yZXNvdXJjZS1tdWx0aS1zZWxlY3QvdXRpbCc7XG5leHBvcnQgeyBTZWFyY2hJdGVtQ29tcG9uZW50IH0gZnJvbSAnLi9zZWFyY2gtcGFuZWwvc2VhcmNoLWl0ZW0vY29tcG9uZW50JztcbmV4cG9ydCB7IFNlYXJjaFBhbmVsQ29tcG9uZW50IH0gZnJvbSAnLi9zZWFyY2gtcGFuZWwvY29tcG9uZW50JztcbmV4cG9ydCB7IFNlYXJjaEl0ZW1MYWJlbERpcmVjdGl2ZSB9IGZyb20gJy4vc2VhcmNoLXBhbmVsL2hlbHBlci5kaXJlY3RpdmUnO1xuXG5leHBvcnQgKiBmcm9tICcuL2N1c3RvbS1jb2x1bW5zLXNldHRpbmcnO1xuZXhwb3J0ICogZnJvbSAnLi9wb2Qtc3RhdHVzJztcbmV4cG9ydCAqIGZyb20gJy4vd29ya2xvYWQtc3RhdHVzJztcbmV4cG9ydCAqIGZyb20gJy4vZGlzYWJsZWQtY29udGFpbmVyJztcbmV4cG9ydCAqIGZyb20gJy4vdXBsb2FkLWZpbGUvY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vaGVscC1kb2N1bWVudCc7XG5leHBvcnQgKiBmcm9tICcuL3BhZ2UtZ3VhcmQnO1xuXG5leHBvcnQgKiBmcm9tICcuL25hbWVzcGFjZS1zZWxlY3Rvcic7XG5leHBvcnQgKiBmcm9tICcuL25hbWVzcGFjZS1iYWRnZS9jb21wb25lbnQnO1xuXG5leHBvcnQgKiBmcm9tICcuL3Rlc3QtdGFnL2NvbXBvbmVudCc7XG4iXX0=
@@ -0,0 +1,14 @@
1
+ import { IconComponent } from '@alauda/ui';
2
+ import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
3
+ import * as i0 from "@angular/core";
4
+ export class NamespaceBadgeComponent {
5
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.1", ngImport: i0, type: NamespaceBadgeComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
6
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.1", type: NamespaceBadgeComponent, isStandalone: true, selector: "acl-namespace-badge", inputs: { name: "name" }, ngImport: i0, template: "<div>\n <aui-icon\n icon=\"prod:namespace\"\n class=\"tw-mr-4\"\n ></aui-icon>\n <span\n class=\"text-truncate\"\n [attr.title]=\"name\"\n >{{ name }}</span\n >\n</div>\n", styles: [":host{display:flex;max-width:220px}.with-colon{display:inline-flex;word-break:keep-all;flex-shrink:0;font-weight:500}.with-colon:after{content:\":\";margin-right:8px}.text-truncate{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}\n"], dependencies: [{ kind: "component", type: IconComponent, selector: "aui-icon", inputs: ["icon", "light", "dark", "link", "margin", "size", "color", "background", "backgroundColor"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
7
+ }
8
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.1", ngImport: i0, type: NamespaceBadgeComponent, decorators: [{
9
+ type: Component,
10
+ args: [{ selector: 'acl-namespace-badge', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [IconComponent], template: "<div>\n <aui-icon\n icon=\"prod:namespace\"\n class=\"tw-mr-4\"\n ></aui-icon>\n <span\n class=\"text-truncate\"\n [attr.title]=\"name\"\n >{{ name }}</span\n >\n</div>\n", styles: [":host{display:flex;max-width:220px}.with-colon{display:inline-flex;word-break:keep-all;flex-shrink:0;font-weight:500}.with-colon:after{content:\":\";margin-right:8px}.text-truncate{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}\n"] }]
11
+ }], propDecorators: { name: [{
12
+ type: Input
13
+ }] } });
14
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9keW5hbWljLXBsdWdpbi1zaGFyZWQvc3JjL2NvbXBvbmVudHMvbmFtZXNwYWNlLWJhZGdlL2NvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvZHluYW1pYy1wbHVnaW4tc2hhcmVkL3NyYy9jb21wb25lbnRzL25hbWVzcGFjZS1iYWRnZS90ZW1wbGF0ZS5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxZQUFZLENBQUM7QUFDM0MsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBVTFFLE1BQU0sT0FBTyx1QkFBdUI7OEdBQXZCLHVCQUF1QjtrR0FBdkIsdUJBQXVCLHlHQ1hwQywrTEFXQSwyU0RGWSxhQUFhOzsyRkFFWix1QkFBdUI7a0JBUm5DLFNBQVM7K0JBQ0UscUJBQXFCLG1CQUdkLHVCQUF1QixDQUFDLE1BQU0sY0FDbkMsSUFBSSxXQUNQLENBQUMsYUFBYSxDQUFDOzhCQUdmLElBQUk7c0JBQVosS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEljb25Db21wb25lbnQgfSBmcm9tICdAYWxhdWRhL3VpJztcbmltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2FjbC1uYW1lc3BhY2UtYmFkZ2UnLFxuICB0ZW1wbGF0ZVVybDogJ3RlbXBsYXRlLmh0bWwnLFxuICBzdHlsZVVybDogJ3N0eWxlcy5zY3NzJyxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtJY29uQ29tcG9uZW50XSxcbn0pXG5leHBvcnQgY2xhc3MgTmFtZXNwYWNlQmFkZ2VDb21wb25lbnQge1xuICBASW5wdXQoKSBuYW1lOiBzdHJpbmc7XG59XG4iLCI8ZGl2PlxuICA8YXVpLWljb25cbiAgICBpY29uPVwicHJvZDpuYW1lc3BhY2VcIlxuICAgIGNsYXNzPVwidHctbXItNFwiXG4gID48L2F1aS1pY29uPlxuICA8c3BhblxuICAgIGNsYXNzPVwidGV4dC10cnVuY2F0ZVwiXG4gICAgW2F0dHIudGl0bGVdPVwibmFtZVwiXG4gICAgPnt7IG5hbWUgfX08L3NwYW5cbiAgPlxuPC9kaXY+XG4iXX0=
@@ -0,0 +1,126 @@
1
+ import { __decorate, __metadata } from "tslib";
2
+ import { IconComponent, TOOLTIP_MODULE } from '@alauda/ui';
3
+ import { COMMON_RESOURCE_DEFINITIONS, K8sApiService, ResourceSelectorPopupService, } from '@alauda-fe/dynamic-plugin-sdk';
4
+ import { AsyncPipe, NgClass } from '@angular/common';
5
+ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, EventEmitter, Input, Output, TemplateRef, ViewChild, } from '@angular/core';
6
+ import { filter, map, Observable, switchMap, takeUntil } from 'rxjs';
7
+ import { matchExpressionsToString } from '../../k8s-resource-list';
8
+ import { ObservableInput, onDestroy, publishRef, skipError } from '../../utils';
9
+ import { ALL_NAMESPACE_KEY, DEV_NAMESPACE_KEY } from './constants';
10
+ import { NamespaceListComponent } from './namespace-list/component';
11
+ import * as i0 from "@angular/core";
12
+ import * as i1 from "@alauda-fe/dynamic-plugin-sdk";
13
+ export class NamespaceSelectorComponent {
14
+ constructor(popupService, k8sService, cdr, elementRef) {
15
+ this.popupService = popupService;
16
+ this.k8sService = k8sService;
17
+ this.cdr = cdr;
18
+ this.elementRef = elementRef;
19
+ this.valueChange = new EventEmitter();
20
+ this.ALL_NAMESPACE_KEY = ALL_NAMESPACE_KEY;
21
+ this.isActive = false;
22
+ this.destroy$$ = onDestroy();
23
+ this.namespaces$ = this.cluster$.pipe(switchMap(cluster => this.k8sService
24
+ .getResourceList({
25
+ definition: COMMON_RESOURCE_DEFINITIONS.NAMESPACE,
26
+ cluster,
27
+ queryParams: {
28
+ limit: '0',
29
+ labelSelector: matchExpressionsToString([
30
+ {
31
+ key: 'namespace-type',
32
+ operator: '!=',
33
+ values: ['system'],
34
+ },
35
+ {
36
+ key: 'cpaas.io/project',
37
+ operator: '!=',
38
+ values: ['cpaas-system'],
39
+ },
40
+ ]),
41
+ },
42
+ })
43
+ .pipe(map(list => list.items), skipError([]), takeUntil(this.destroy$$))), publishRef());
44
+ this.namespaces$.pipe(takeUntil(this.destroy$$)).subscribe(data => {
45
+ if (!data.length) {
46
+ return;
47
+ }
48
+ if (!this.value || this.value === ALL_NAMESPACE_KEY) {
49
+ let selected = null;
50
+ const cached = localStorage.getItem(DEV_NAMESPACE_KEY);
51
+ const cachedNamespace = data.find(item => item.metadata.name === cached);
52
+ selected = cachedNamespace || data[0];
53
+ this.onSelect(selected);
54
+ }
55
+ else {
56
+ const current = data.find(item => item.metadata.name === this.value);
57
+ if (!current && data[0]) {
58
+ this.onSelect(data[0]);
59
+ }
60
+ }
61
+ });
62
+ this.value$
63
+ .pipe(takeUntil(this.destroy$$), filter(Boolean))
64
+ .subscribe(value => {
65
+ localStorage.setItem(DEV_NAMESPACE_KEY, value);
66
+ });
67
+ }
68
+ openPopup() {
69
+ if (this.isActive) {
70
+ this.closePopup();
71
+ }
72
+ else {
73
+ this.isActive = true;
74
+ this.popupRef = this.popupService.open({
75
+ origin: this.elementRef,
76
+ content: this.popupTemplate,
77
+ });
78
+ this.popupRef.afterClosed().subscribe(() => {
79
+ this.isActive = false;
80
+ this.cdr.markForCheck();
81
+ });
82
+ }
83
+ }
84
+ closePopup() {
85
+ this.isActive = false;
86
+ this.popupRef.close();
87
+ }
88
+ onSelect(item) {
89
+ this.value = item.metadata.name;
90
+ // localStorage.setItem(DEV_NAMESPACE_KEY, item.metadata.name);
91
+ this.valueChange.emit(item);
92
+ if (this.isActive) {
93
+ this.closePopup();
94
+ }
95
+ }
96
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.1", ngImport: i0, type: NamespaceSelectorComponent, deps: [{ token: i1.ResourceSelectorPopupService }, { token: i1.K8sApiService }, { token: i0.ChangeDetectorRef }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
97
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.1", type: NamespaceSelectorComponent, isStandalone: true, selector: "acl-namespace-selector", inputs: { cluster: "cluster", value: "value" }, outputs: { valueChange: "valueChange" }, viewQueries: [{ propertyName: "popupTemplate", first: true, predicate: ["popup"], descendants: true, static: true }], ngImport: i0, template: "<!-- <div\n class=\"acl-resource-selector\"\n [ngClass]=\"{\n 'acl-resource-selector--active': isActive,\n 'acl-resource-selector--lite': true,\n }\"\n [auiTooltip]=\"popup\"\n auiTooltipTrigger=\"click\"\n auiTooltipType=\"info\"\n auiTooltipPosition=\"bottom start\"\n auiTooltipClass=\"scale-width\"\n [auiTooltipHideOnClick]=\"false\"\n>\n <div class=\"acl-resource-selector__item namespace\">\n <span class=\"icon-wrapper\">\n <aui-icon icon=\"prod:namespace\"></aui-icon>\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<div\n [hidden]=\"value === ALL_NAMESPACE_KEY\"\n class=\"acl-resource-selector\"\n [ngClass]=\"{\n 'acl-resource-selector--active': isActive,\n 'acl-resource-selector--lite': true,\n }\"\n (click)=\"openPopup()\"\n>\n <div class=\"acl-resource-selector__item namespace\">\n <span class=\"icon-wrapper\">\n <aui-icon icon=\"prod:namespace\"></aui-icon>\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-namespace-list\n [namespaces]=\"namespaces$ | async\"\n (selectItem)=\"onSelect($event)\"\n [value]=\"value\"\n ></acl-namespace-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 .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;color:rgb(var(--aui-color-n-2))}: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:24px}:host::ng-deep .acl-resource-selector--lite:hover,: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:hover aui-icon,:host::ng-deep .acl-resource-selector--lite:hover .with-colon,:host::ng-deep .acl-resource-selector--lite:hover .selected-name,:host::ng-deep .acl-resource-selector--lite:hover .acl-resource-selector__arrow,:host::ng-deep .acl-resource-selector--lite.acl-resource-selector--active aui-icon,:host::ng-deep .acl-resource-selector--lite.acl-resource-selector--active .with-colon,: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 aui-icon,:host::ng-deep .acl-resource-selector--lite.acl-resource-selector--active:hover .with-colon,: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 (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 (width <= 1280px){:host::ng-deep .acl-resource-selector__arrow{margin-left:-4px}}:host::ng-deep .acl-resource-selector__tooltip{max-width:unset}\n"], dependencies: [{ kind: "component", type: IconComponent, selector: "aui-icon", inputs: ["icon", "light", "dark", "link", "margin", "size", "color", "background", "backgroundColor"] }, { kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: NamespaceListComponent, selector: "acl-namespace-list", inputs: ["namespaces", "value", "cluster", "loading"], outputs: ["selectItem"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
98
+ }
99
+ __decorate([
100
+ ObservableInput(),
101
+ __metadata("design:type", Observable)
102
+ ], NamespaceSelectorComponent.prototype, "cluster$", void 0);
103
+ __decorate([
104
+ ObservableInput(),
105
+ __metadata("design:type", Observable)
106
+ ], NamespaceSelectorComponent.prototype, "value$", void 0);
107
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.1", ngImport: i0, type: NamespaceSelectorComponent, decorators: [{
108
+ type: Component,
109
+ args: [{ selector: 'acl-namespace-selector', standalone: true, imports: [
110
+ IconComponent,
111
+ AsyncPipe,
112
+ NgClass,
113
+ NamespaceListComponent,
114
+ TOOLTIP_MODULE,
115
+ ], changeDetection: ChangeDetectionStrategy.OnPush, template: "<!-- <div\n class=\"acl-resource-selector\"\n [ngClass]=\"{\n 'acl-resource-selector--active': isActive,\n 'acl-resource-selector--lite': true,\n }\"\n [auiTooltip]=\"popup\"\n auiTooltipTrigger=\"click\"\n auiTooltipType=\"info\"\n auiTooltipPosition=\"bottom start\"\n auiTooltipClass=\"scale-width\"\n [auiTooltipHideOnClick]=\"false\"\n>\n <div class=\"acl-resource-selector__item namespace\">\n <span class=\"icon-wrapper\">\n <aui-icon icon=\"prod:namespace\"></aui-icon>\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<div\n [hidden]=\"value === ALL_NAMESPACE_KEY\"\n class=\"acl-resource-selector\"\n [ngClass]=\"{\n 'acl-resource-selector--active': isActive,\n 'acl-resource-selector--lite': true,\n }\"\n (click)=\"openPopup()\"\n>\n <div class=\"acl-resource-selector__item namespace\">\n <span class=\"icon-wrapper\">\n <aui-icon icon=\"prod:namespace\"></aui-icon>\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-namespace-list\n [namespaces]=\"namespaces$ | async\"\n (selectItem)=\"onSelect($event)\"\n [value]=\"value\"\n ></acl-namespace-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 .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;color:rgb(var(--aui-color-n-2))}: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:24px}:host::ng-deep .acl-resource-selector--lite:hover,: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:hover aui-icon,:host::ng-deep .acl-resource-selector--lite:hover .with-colon,:host::ng-deep .acl-resource-selector--lite:hover .selected-name,:host::ng-deep .acl-resource-selector--lite:hover .acl-resource-selector__arrow,:host::ng-deep .acl-resource-selector--lite.acl-resource-selector--active aui-icon,:host::ng-deep .acl-resource-selector--lite.acl-resource-selector--active .with-colon,: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 aui-icon,:host::ng-deep .acl-resource-selector--lite.acl-resource-selector--active:hover .with-colon,: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 (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 (width <= 1280px){:host::ng-deep .acl-resource-selector__arrow{margin-left:-4px}}:host::ng-deep .acl-resource-selector__tooltip{max-width:unset}\n"] }]
116
+ }], ctorParameters: () => [{ type: i1.ResourceSelectorPopupService }, { type: i1.K8sApiService }, { type: i0.ChangeDetectorRef }, { type: i0.ElementRef }], propDecorators: { popupTemplate: [{
117
+ type: ViewChild,
118
+ args: ['popup', { static: true }]
119
+ }], cluster: [{
120
+ type: Input
121
+ }], cluster$: [], value: [{
122
+ type: Input
123
+ }], value$: [], valueChange: [{
124
+ type: Output
125
+ }] } });
126
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"component.js","sourceRoot":"","sources":["../../../../../../libs/dynamic-plugin-shared/src/components/namespace-selector/component.ts","../../../../../../libs/dynamic-plugin-shared/src/components/namespace-selector/template.html"],"names":[],"mappings":"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","sourcesContent":["import { IconComponent, TOOLTIP_MODULE } from '@alauda/ui';\nimport {\n  COMMON_RESOURCE_DEFINITIONS,\n  K8sApiService,\n  ResourceSelectorPopupRef,\n  ResourceSelectorPopupService,\n} from '@alauda-fe/dynamic-plugin-sdk';\nimport { AsyncPipe, NgClass } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  Output,\n  TemplateRef,\n  ViewChild,\n} from '@angular/core';\nimport { filter, map, Observable, switchMap, takeUntil } from 'rxjs';\n\nimport { matchExpressionsToString } from '../../k8s-resource-list';\nimport { KubernetesResource, Namespace } from '../../types';\nimport { ObservableInput, onDestroy, publishRef, skipError } from '../../utils';\n\nimport { ALL_NAMESPACE_KEY, DEV_NAMESPACE_KEY } from './constants';\nimport { NamespaceListComponent } from './namespace-list/component';\n\n@Component({\n  selector: 'acl-namespace-selector',\n  templateUrl: './template.html',\n  styleUrls: ['style.scss'],\n  standalone: true,\n  imports: [\n    IconComponent,\n    AsyncPipe,\n    NgClass,\n    NamespaceListComponent,\n    TOOLTIP_MODULE,\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class NamespaceSelectorComponent {\n  @ViewChild('popup', { static: true })\n  popupTemplate: TemplateRef<any>;\n\n  @Input() cluster: string;\n  @ObservableInput()\n  cluster$!: Observable<string>;\n\n  @Input()\n  value: string;\n\n  @ObservableInput()\n  value$: Observable<string>;\n\n  @Output()\n  valueChange = new EventEmitter<KubernetesResource>();\n\n  ALL_NAMESPACE_KEY = ALL_NAMESPACE_KEY;\n\n  isActive = false;\n\n  popupRef: ResourceSelectorPopupRef;\n\n  destroy$$ = onDestroy();\n\n  namespaces$ = this.cluster$.pipe(\n    switchMap(cluster =>\n      this.k8sService\n        .getResourceList<Namespace>({\n          definition: COMMON_RESOURCE_DEFINITIONS.NAMESPACE,\n          cluster,\n          queryParams: {\n            limit: '0',\n            labelSelector: matchExpressionsToString([\n              {\n                key: 'namespace-type',\n                operator: '!=',\n                values: ['system'],\n              },\n              {\n                key: 'cpaas.io/project',\n                operator: '!=',\n                values: ['cpaas-system'],\n              },\n            ]),\n          },\n        })\n        .pipe(\n          map(list => list.items),\n          skipError([] as Namespace[]),\n          takeUntil(this.destroy$$),\n        ),\n    ),\n    publishRef(),\n  );\n\n  constructor(\n    private readonly popupService: ResourceSelectorPopupService,\n    private readonly k8sService: K8sApiService,\n    private readonly cdr: ChangeDetectorRef,\n    private readonly elementRef: ElementRef,\n  ) {\n    this.namespaces$.pipe(takeUntil(this.destroy$$)).subscribe(data => {\n      if (!data.length) {\n        return;\n      }\n      if (!this.value || this.value === ALL_NAMESPACE_KEY) {\n        let selected = null;\n        const cached = localStorage.getItem(DEV_NAMESPACE_KEY);\n        const cachedNamespace = data.find(\n          item => item.metadata.name === cached,\n        );\n        selected = cachedNamespace || data[0];\n        this.onSelect(selected);\n      } else {\n        const current = data.find(item => item.metadata.name === this.value);\n        if (!current && data[0]) {\n          this.onSelect(data[0]);\n        }\n      }\n    });\n    this.value$\n      .pipe(takeUntil(this.destroy$$), filter(Boolean))\n      .subscribe(value => {\n        localStorage.setItem(DEV_NAMESPACE_KEY, value);\n      });\n  }\n\n  openPopup() {\n    if (this.isActive) {\n      this.closePopup();\n    } else {\n      this.isActive = true;\n      this.popupRef = this.popupService.open({\n        origin: this.elementRef,\n        content: this.popupTemplate,\n      });\n      this.popupRef.afterClosed().subscribe(() => {\n        this.isActive = false;\n        this.cdr.markForCheck();\n      });\n    }\n  }\n\n  closePopup() {\n    this.isActive = false;\n    this.popupRef.close();\n  }\n\n  onSelect(item: KubernetesResource) {\n    this.value = item.metadata.name;\n    // localStorage.setItem(DEV_NAMESPACE_KEY, item.metadata.name);\n    this.valueChange.emit(item);\n    if (this.isActive) {\n      this.closePopup();\n    }\n  }\n}\n","<!-- <div\n  class=\"acl-resource-selector\"\n  [ngClass]=\"{\n    'acl-resource-selector--active': isActive,\n    'acl-resource-selector--lite': true,\n  }\"\n  [auiTooltip]=\"popup\"\n  auiTooltipTrigger=\"click\"\n  auiTooltipType=\"info\"\n  auiTooltipPosition=\"bottom start\"\n  auiTooltipClass=\"scale-width\"\n  [auiTooltipHideOnClick]=\"false\"\n>\n  <div class=\"acl-resource-selector__item namespace\">\n    <span class=\"icon-wrapper\">\n      <aui-icon icon=\"prod:namespace\"></aui-icon>\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<div\n  [hidden]=\"value === ALL_NAMESPACE_KEY\"\n  class=\"acl-resource-selector\"\n  [ngClass]=\"{\n    'acl-resource-selector--active': isActive,\n    'acl-resource-selector--lite': true,\n  }\"\n  (click)=\"openPopup()\"\n>\n  <div class=\"acl-resource-selector__item namespace\">\n    <span class=\"icon-wrapper\">\n      <aui-icon icon=\"prod:namespace\"></aui-icon>\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-namespace-list\n    [namespaces]=\"namespaces$ | async\"\n    (selectItem)=\"onSelect($event)\"\n    [value]=\"value\"\n  ></acl-namespace-list>\n</ng-template>\n"]}
@@ -0,0 +1,3 @@
1
+ export const DEV_NAMESPACE_KEY = 'DEV_NAMESPACE';
2
+ export const ALL_NAMESPACE_KEY = '~all-namespaces~';
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RhbnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9keW5hbWljLXBsdWdpbi1zaGFyZWQvc3JjL2NvbXBvbmVudHMvbmFtZXNwYWNlLXNlbGVjdG9yL2NvbnN0YW50cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQUMsTUFBTSxpQkFBaUIsR0FBRyxlQUFlLENBQUM7QUFDakQsTUFBTSxDQUFDLE1BQU0saUJBQWlCLEdBQUcsa0JBQWtCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY29uc3QgREVWX05BTUVTUEFDRV9LRVkgPSAnREVWX05BTUVTUEFDRSc7XG5leHBvcnQgY29uc3QgQUxMX05BTUVTUEFDRV9LRVkgPSAnfmFsbC1uYW1lc3BhY2Vzfic7XG4iXX0=
@@ -0,0 +1,4 @@
1
+ export * from './constants';
2
+ export * from './component';
3
+ export * from './types';
4
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL2R5bmFtaWMtcGx1Z2luLXNoYXJlZC9zcmMvY29tcG9uZW50cy9uYW1lc3BhY2Utc2VsZWN0b3IvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyxTQUFTLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2NvbnN0YW50cyc7XG5leHBvcnQgKiBmcm9tICcuL2NvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3R5cGVzJztcbiJdfQ==