@alauda-fe/dynamic-plugin-shared 0.0.1-alpha.1 → 0.0.1-alpha.11
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.
- package/array-form-table/form/component.d.ts +1 -1
- package/array-form-table/form/index.d.ts +3 -2
- package/array-form-table/index.d.ts +1 -1
- package/assets/i18n/en/dynamic-plugin-shared.json +3 -0
- package/components/field-set/item/component.d.ts +1 -1
- package/components/index.d.ts +4 -0
- package/components/namespace-badge/component.d.ts +6 -0
- package/components/namespace-selector/component.d.ts +28 -0
- package/components/namespace-selector/constants.d.ts +2 -0
- package/components/namespace-selector/index.d.ts +4 -0
- package/components/namespace-selector/namespace-list/component.d.ts +46 -0
- package/components/namespace-selector/selector-popup/component.d.ts +13 -0
- package/components/namespace-selector/selector-popup/ref.d.ts +10 -0
- package/components/namespace-selector/selector-popup/service.d.ts +20 -0
- package/components/namespace-selector/types.d.ts +5 -0
- package/components/test-tag/component.d.ts +5 -0
- package/components/workload-status/component.d.ts +37 -0
- package/components/workload-status/index.d.ts +1 -0
- package/directives/scroll-border-observer.directive.d.ts +1 -1
- package/directives/scroll-to-first-invalid.directive.d.ts +1 -1
- package/esm2022/array-form-table/form/index.mjs +2 -1
- package/esm2022/array-form-table/index.mjs +2 -2
- package/esm2022/components/index.mjs +5 -1
- package/esm2022/components/namespace-badge/component.mjs +14 -0
- package/esm2022/components/namespace-selector/component.mjs +122 -0
- package/esm2022/components/namespace-selector/constants.mjs +3 -0
- package/esm2022/components/namespace-selector/index.mjs +5 -0
- package/esm2022/components/namespace-selector/namespace-list/component.mjs +191 -0
- package/esm2022/components/namespace-selector/selector-popup/component.mjs +24 -0
- package/esm2022/components/namespace-selector/selector-popup/ref.mjs +20 -0
- package/esm2022/components/namespace-selector/selector-popup/service.mjs +61 -0
- package/esm2022/components/namespace-selector/types.mjs +2 -0
- package/esm2022/components/page-guard/component/component.mjs +2 -2
- package/esm2022/components/test-tag/component.mjs +24 -0
- package/esm2022/components/workload-status/component.mjs +33 -0
- package/esm2022/components/workload-status/index.mjs +2 -0
- package/esm2022/components/zero-state/zero-state.component.mjs +3 -3
- package/esm2022/types/index.mjs +2 -1
- package/fesm2022/alauda-fe-dynamic-plugin-shared.mjs +449 -7
- package/fesm2022/alauda-fe-dynamic-plugin-shared.mjs.map +1 -1
- package/form/base-nested-form-control.d.ts +1 -1
- package/k8s-resource-list/k8s-resource-paged-list.d.ts +2 -2
- package/package.json +1 -1
- package/styles/lib.scss +1 -1
- package/types/index.d.ts +1 -0
|
@@ -82,7 +82,7 @@ export declare class ArrayFormTableComponent implements OnDestroy {
|
|
|
82
82
|
addDisabled: boolean | '';
|
|
83
83
|
actionColumnDivider: boolean | '';
|
|
84
84
|
showZeroState: boolean;
|
|
85
|
-
get formDirective():
|
|
85
|
+
get formDirective(): FormGroupDirective | NgForm;
|
|
86
86
|
/**
|
|
87
87
|
* 自定义是否展示错误内容
|
|
88
88
|
* 例如 control 是 FormGroup,只有在内部子 control 错误时才需要展示错误内容
|
|
@@ -1,2 +1,3 @@
|
|
|
1
|
-
import { ArrayFormTableComponent, ArrayFormTableHeaderDirective } from './component';
|
|
2
|
-
export
|
|
1
|
+
import { ArrayFormTableComponent, ArrayFormTableFooterDirective, ArrayFormTableHeaderDirective, ArrayFormTableRowControlDirective, ArrayFormTableRowDirective, ArrayFormTableRowErrorDirective, ArrayFormTableZeroStateDirective, ArrayFormTableRowSeparatorDirective } from './component';
|
|
2
|
+
export * from './component';
|
|
3
|
+
export declare const ARRAY_FORM_TABLE_MODULE: readonly [typeof ArrayFormTableComponent, typeof ArrayFormTableFooterDirective, typeof ArrayFormTableHeaderDirective, typeof ArrayFormTableRowControlDirective, typeof ArrayFormTableRowDirective, typeof ArrayFormTableRowErrorDirective, typeof ArrayFormTableZeroStateDirective, typeof ArrayFormTableRowSeparatorDirective];
|
|
@@ -3,7 +3,7 @@ export declare class FieldSetItemComponent {
|
|
|
3
3
|
allowFullWidth: boolean;
|
|
4
4
|
allowOverflow: boolean;
|
|
5
5
|
allowWrap: boolean;
|
|
6
|
-
get align(): "
|
|
6
|
+
get align(): "center" | "flex-start";
|
|
7
7
|
static ɵfac: i0.ɵɵFactoryDeclaration<FieldSetItemComponent, never>;
|
|
8
8
|
static ɵcmp: i0.ɵɵComponentDeclaration<FieldSetItemComponent, "acl-field-set-item", never, { "allowFullWidth": { "alias": "allowFullWidth"; "required": false; }; "allowOverflow": { "alias": "allowOverflow"; "required": false; }; "allowWrap": { "alias": "allowWrap"; "required": false; }; }, {}, never, ["label", "*", "[aclFieldSetItemAction]"], true, never>;
|
|
9
9
|
}
|
package/components/index.d.ts
CHANGED
|
@@ -25,7 +25,11 @@ export { SearchPanelComponent } from './search-panel/component';
|
|
|
25
25
|
export { SearchItemLabelDirective } from './search-panel/helper.directive';
|
|
26
26
|
export * from './custom-columns-setting';
|
|
27
27
|
export * from './pod-status';
|
|
28
|
+
export * from './workload-status';
|
|
28
29
|
export * from './disabled-container';
|
|
29
30
|
export * from './upload-file/component';
|
|
30
31
|
export * from './help-document';
|
|
31
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 } 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 { ResourceSelectorPopupRef } from './selector-popup/ref';
|
|
6
|
+
import { ResourceSelectorPopupService } from './selector-popup/service';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
export declare class NamespaceSelectorComponent {
|
|
9
|
+
private readonly popupService;
|
|
10
|
+
private readonly k8sService;
|
|
11
|
+
private readonly cdr;
|
|
12
|
+
private readonly elementRef;
|
|
13
|
+
popupTemplate: TemplateRef<any>;
|
|
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, { "value": { "alias": "value"; "required": false; }; }, { "valueChange": "valueChange"; }, never, never, true, never>;
|
|
28
|
+
}
|
|
@@ -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,13 @@
|
|
|
1
|
+
import { CdkPortalOutlet, TemplatePortal } from '@angular/cdk/portal';
|
|
2
|
+
import { TemplateRef, ViewContainerRef } from '@angular/core';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export declare class ResourceSelectorPopupComponent {
|
|
5
|
+
private readonly viewContainerRef;
|
|
6
|
+
portalOutlet: CdkPortalOutlet;
|
|
7
|
+
container: ViewContainerRef;
|
|
8
|
+
templatePortal: TemplatePortal;
|
|
9
|
+
constructor(viewContainerRef: ViewContainerRef);
|
|
10
|
+
attachContent(template: TemplateRef<any>): void;
|
|
11
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<ResourceSelectorPopupComponent, never>;
|
|
12
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<ResourceSelectorPopupComponent, "acl-resource-selector-popup", never, {}, {}, never, never, true, never>;
|
|
13
|
+
}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { OverlayRef } from '@angular/cdk/overlay';
|
|
2
|
+
import { Subscription } from 'rxjs';
|
|
3
|
+
export declare class ResourceSelectorPopupRef {
|
|
4
|
+
private readonly overlayRef;
|
|
5
|
+
private readonly subs;
|
|
6
|
+
private readonly afterClosed$;
|
|
7
|
+
constructor(overlayRef: OverlayRef, subs: Subscription[]);
|
|
8
|
+
close(): void;
|
|
9
|
+
afterClosed(): import("rxjs").Observable<void>;
|
|
10
|
+
}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { Overlay } from '@angular/cdk/overlay';
|
|
2
|
+
import { ElementRef, TemplateRef } from '@angular/core';
|
|
3
|
+
import { Subscription } from 'rxjs';
|
|
4
|
+
import { ResourceSelectorPopupRef } from './ref';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
export interface ResourceSelectorPopupConfig {
|
|
7
|
+
origin: ElementRef;
|
|
8
|
+
content: TemplateRef<any>;
|
|
9
|
+
}
|
|
10
|
+
export declare class ResourceSelectorPopupService {
|
|
11
|
+
private readonly overlay;
|
|
12
|
+
subs: Subscription[];
|
|
13
|
+
constructor(overlay: Overlay);
|
|
14
|
+
open(config: ResourceSelectorPopupConfig): ResourceSelectorPopupRef;
|
|
15
|
+
private createOverlay;
|
|
16
|
+
private getOverlayConfig;
|
|
17
|
+
private readonly isEventTargetInTooltip;
|
|
18
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<ResourceSelectorPopupService, never>;
|
|
19
|
+
static ɵprov: i0.ɵɵInjectableDeclaration<ResourceSelectorPopupService>;
|
|
20
|
+
}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { Job, KubernetesResource } from '../../types';
|
|
2
|
+
import { GenericWorkloadStatus, getJobStatus, getWorkloadStatus, parseToWorkloadStatus } from '../../utils';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export declare class WorkloadStatusIconComponent {
|
|
5
|
+
resource: KubernetesResource;
|
|
6
|
+
getWorkloadStatus: typeof getWorkloadStatus;
|
|
7
|
+
parseToWorkloadStatus: typeof parseToWorkloadStatus;
|
|
8
|
+
WorkloadStatusColorMapper: {
|
|
9
|
+
running: import("@alauda-fe/dynamic-plugin-shared").GenericStatusColor;
|
|
10
|
+
pending: import("@alauda-fe/dynamic-plugin-shared").GenericStatusColor;
|
|
11
|
+
stopped: import("@alauda-fe/dynamic-plugin-shared").GenericStatusColor;
|
|
12
|
+
killed: import("@alauda-fe/dynamic-plugin-shared").GenericStatusColor;
|
|
13
|
+
};
|
|
14
|
+
WorkloadStatusIconMapper: {
|
|
15
|
+
running: import("@alauda-fe/dynamic-plugin-shared").GenericStatusIcon;
|
|
16
|
+
pending: import("@alauda-fe/dynamic-plugin-shared").GenericStatusIcon;
|
|
17
|
+
stopped: import("@alauda-fe/dynamic-plugin-shared").GenericStatusIcon;
|
|
18
|
+
killed: import("@alauda-fe/dynamic-plugin-shared").GenericStatusIcon;
|
|
19
|
+
};
|
|
20
|
+
getJobStatus: typeof getJobStatus;
|
|
21
|
+
JobStatusColorMapper: {
|
|
22
|
+
executing: import("@alauda-fe/dynamic-plugin-shared").GenericStatusColor;
|
|
23
|
+
execute_succeeded: import("@alauda-fe/dynamic-plugin-shared").GenericStatusColor;
|
|
24
|
+
execute_failed: import("@alauda-fe/dynamic-plugin-shared").GenericStatusColor;
|
|
25
|
+
unknown: import("@alauda-fe/dynamic-plugin-shared").GenericStatusColor;
|
|
26
|
+
};
|
|
27
|
+
JobStatusIconMapper: {
|
|
28
|
+
executing: import("@alauda-fe/dynamic-plugin-shared").GenericStatusIcon;
|
|
29
|
+
execute_succeeded: import("@alauda-fe/dynamic-plugin-shared").GenericStatusIcon;
|
|
30
|
+
execute_failed: import("@alauda-fe/dynamic-plugin-shared").GenericStatusIcon;
|
|
31
|
+
unknown: import("@alauda-fe/dynamic-plugin-shared").GenericStatusIcon;
|
|
32
|
+
};
|
|
33
|
+
getInstancesText(status: GenericWorkloadStatus): string;
|
|
34
|
+
isJob: (resource: KubernetesResource) => resource is Job;
|
|
35
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<WorkloadStatusIconComponent, never>;
|
|
36
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<WorkloadStatusIconComponent, "acl-workload-status", never, { "resource": { "alias": "resource"; "required": false; }; }, {}, never, never, true, never>;
|
|
37
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './component';
|
|
@@ -7,7 +7,7 @@ interface Option {
|
|
|
7
7
|
}
|
|
8
8
|
export declare class ScrollBorderObserverDirective implements OnInit, OnDestroy {
|
|
9
9
|
option: Option | '' | false | number;
|
|
10
|
-
scrollBorder: EventEmitter<"
|
|
10
|
+
scrollBorder: EventEmitter<"bottom" | "top">;
|
|
11
11
|
scrollBottomBorder: EventEmitter<any>;
|
|
12
12
|
scrollEl: HTMLElement | Window;
|
|
13
13
|
readonly destroy$$: Subject<void>;
|
|
@@ -13,7 +13,7 @@ export declare class ScrollToFirstInvalidDirective {
|
|
|
13
13
|
private readonly cdkScrollable;
|
|
14
14
|
labelOffset: number;
|
|
15
15
|
aclScrollToFirstInvalid: boolean | '';
|
|
16
|
-
get containerEl():
|
|
16
|
+
get containerEl(): (Window & typeof globalThis) | HTMLElement;
|
|
17
17
|
onSubmit(): void;
|
|
18
18
|
constructor(elRef: ElementRef<HTMLElement>, controlContainer: ControlContainer, cdkScrollable: CdkScrollable);
|
|
19
19
|
scrollToFirstInvalid(): void;
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { ArrayFormTableComponent, ArrayFormTableFooterDirective, ArrayFormTableHeaderDirective, ArrayFormTableRowControlDirective, ArrayFormTableRowDirective, ArrayFormTableRowErrorDirective, ArrayFormTableZeroStateDirective, ArrayFormTableRowSeparatorDirective, } from './component';
|
|
2
|
+
export * from './component';
|
|
2
3
|
export const ARRAY_FORM_TABLE_MODULE = [
|
|
3
4
|
ArrayFormTableComponent,
|
|
4
5
|
ArrayFormTableFooterDirective,
|
|
@@ -9,4 +10,4 @@ export const ARRAY_FORM_TABLE_MODULE = [
|
|
|
9
10
|
ArrayFormTableZeroStateDirective,
|
|
10
11
|
ArrayFormTableRowSeparatorDirective,
|
|
11
12
|
];
|
|
12
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
13
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL2R5bmFtaWMtcGx1Z2luLXNoYXJlZC9zcmMvYXJyYXktZm9ybS10YWJsZS9mb3JtL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCx1QkFBdUIsRUFDdkIsNkJBQTZCLEVBQzdCLDZCQUE2QixFQUM3QixpQ0FBaUMsRUFDakMsMEJBQTBCLEVBQzFCLCtCQUErQixFQUMvQixnQ0FBZ0MsRUFDaEMsbUNBQW1DLEdBQ3BDLE1BQU0sYUFBYSxDQUFDO0FBRXJCLGNBQWMsYUFBYSxDQUFDO0FBRTVCLE1BQU0sQ0FBQyxNQUFNLHVCQUF1QixHQUFHO0lBQ3JDLHVCQUF1QjtJQUN2Qiw2QkFBNkI7SUFDN0IsNkJBQTZCO0lBQzdCLGlDQUFpQztJQUNqQywwQkFBMEI7SUFDMUIsK0JBQStCO0lBQy9CLGdDQUFnQztJQUNoQyxtQ0FBbUM7Q0FDM0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIEFycmF5Rm9ybVRhYmxlQ29tcG9uZW50LFxuICBBcnJheUZvcm1UYWJsZUZvb3RlckRpcmVjdGl2ZSxcbiAgQXJyYXlGb3JtVGFibGVIZWFkZXJEaXJlY3RpdmUsXG4gIEFycmF5Rm9ybVRhYmxlUm93Q29udHJvbERpcmVjdGl2ZSxcbiAgQXJyYXlGb3JtVGFibGVSb3dEaXJlY3RpdmUsXG4gIEFycmF5Rm9ybVRhYmxlUm93RXJyb3JEaXJlY3RpdmUsXG4gIEFycmF5Rm9ybVRhYmxlWmVyb1N0YXRlRGlyZWN0aXZlLFxuICBBcnJheUZvcm1UYWJsZVJvd1NlcGFyYXRvckRpcmVjdGl2ZSxcbn0gZnJvbSAnLi9jb21wb25lbnQnO1xuXG5leHBvcnQgKiBmcm9tICcuL2NvbXBvbmVudCc7XG5cbmV4cG9ydCBjb25zdCBBUlJBWV9GT1JNX1RBQkxFX01PRFVMRSA9IFtcbiAgQXJyYXlGb3JtVGFibGVDb21wb25lbnQsXG4gIEFycmF5Rm9ybVRhYmxlRm9vdGVyRGlyZWN0aXZlLFxuICBBcnJheUZvcm1UYWJsZUhlYWRlckRpcmVjdGl2ZSxcbiAgQXJyYXlGb3JtVGFibGVSb3dDb250cm9sRGlyZWN0aXZlLFxuICBBcnJheUZvcm1UYWJsZVJvd0RpcmVjdGl2ZSxcbiAgQXJyYXlGb3JtVGFibGVSb3dFcnJvckRpcmVjdGl2ZSxcbiAgQXJyYXlGb3JtVGFibGVaZXJvU3RhdGVEaXJlY3RpdmUsXG4gIEFycmF5Rm9ybVRhYmxlUm93U2VwYXJhdG9yRGlyZWN0aXZlLFxuXSBhcyBjb25zdDtcbiJdfQ==
|
|
@@ -3,9 +3,9 @@
|
|
|
3
3
|
* @module array-form-table
|
|
4
4
|
* @preferred
|
|
5
5
|
*/
|
|
6
|
-
export * from './form
|
|
6
|
+
export * from './form';
|
|
7
7
|
export * from './key-value-form/component';
|
|
8
8
|
export * from './key-value-table/component';
|
|
9
9
|
export * from './string-array-form/component';
|
|
10
10
|
export * from './base-string-map-form.component';
|
|
11
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
11
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2R5bmFtaWMtcGx1Z2luLXNoYXJlZC9zcmMvYXJyYXktZm9ybS10YWJsZS9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7OztHQUlHO0FBRUgsY0FBYyxRQUFRLENBQUM7QUFDdkIsY0FBYyw0QkFBNEIsQ0FBQztBQUMzQyxjQUFjLDZCQUE2QixDQUFDO0FBQzVDLGNBQWMsK0JBQStCLENBQUM7QUFDOUMsY0FBYyxrQ0FBa0MsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQHBhY2thZ2VEb2N1bWVudGF0aW9uXG4gKiBAbW9kdWxlIGFycmF5LWZvcm0tdGFibGVcbiAqIEBwcmVmZXJyZWRcbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2Zvcm0nO1xuZXhwb3J0ICogZnJvbSAnLi9rZXktdmFsdWUtZm9ybS9jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9rZXktdmFsdWUtdGFibGUvY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vc3RyaW5nLWFycmF5LWZvcm0vY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vYmFzZS1zdHJpbmctbWFwLWZvcm0uY29tcG9uZW50JztcbiJdfQ==
|
|
@@ -25,8 +25,12 @@ export { SearchPanelComponent } from './search-panel/component';
|
|
|
25
25
|
export { SearchItemLabelDirective } from './search-panel/helper.directive';
|
|
26
26
|
export * from './custom-columns-setting';
|
|
27
27
|
export * from './pod-status';
|
|
28
|
+
export * from './workload-status';
|
|
28
29
|
export * from './disabled-container';
|
|
29
30
|
export * from './upload-file/component';
|
|
30
31
|
export * from './help-document';
|
|
31
32
|
export * from './page-guard';
|
|
32
|
-
|
|
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,122 @@
|
|
|
1
|
+
import { __decorate, __metadata } from "tslib";
|
|
2
|
+
import { IconComponent, TOOLTIP_MODULE } from '@alauda/ui';
|
|
3
|
+
import { COMMON_RESOURCE_DEFINITIONS, K8sApiService, } 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, 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 { ResourceSelectorPopupService } from './selector-popup/service';
|
|
12
|
+
import * as i0 from "@angular/core";
|
|
13
|
+
import * as i1 from "./selector-popup/service";
|
|
14
|
+
import * as i2 from "@alauda-fe/dynamic-plugin-sdk";
|
|
15
|
+
export class NamespaceSelectorComponent {
|
|
16
|
+
constructor(popupService, k8sService, cdr, elementRef) {
|
|
17
|
+
this.popupService = popupService;
|
|
18
|
+
this.k8sService = k8sService;
|
|
19
|
+
this.cdr = cdr;
|
|
20
|
+
this.elementRef = elementRef;
|
|
21
|
+
this.valueChange = new EventEmitter();
|
|
22
|
+
this.ALL_NAMESPACE_KEY = ALL_NAMESPACE_KEY;
|
|
23
|
+
this.isActive = false;
|
|
24
|
+
this.destroy$$ = onDestroy();
|
|
25
|
+
this.namespaces$ = this.k8sService
|
|
26
|
+
.getResourceList({
|
|
27
|
+
definition: COMMON_RESOURCE_DEFINITIONS.NAMESPACE,
|
|
28
|
+
cluster: window.__clusterName,
|
|
29
|
+
queryParams: {
|
|
30
|
+
limit: '0',
|
|
31
|
+
labelSelector: matchExpressionsToString([
|
|
32
|
+
{
|
|
33
|
+
key: 'namespace-type',
|
|
34
|
+
operator: '!=',
|
|
35
|
+
values: ['system'],
|
|
36
|
+
},
|
|
37
|
+
{
|
|
38
|
+
key: 'cpaas.io/project',
|
|
39
|
+
operator: '!=',
|
|
40
|
+
values: ['cpaas-system'],
|
|
41
|
+
},
|
|
42
|
+
]),
|
|
43
|
+
},
|
|
44
|
+
})
|
|
45
|
+
.pipe(map(list => list.items), skipError([]), takeUntil(this.destroy$$), publishRef());
|
|
46
|
+
this.namespaces$.pipe(takeUntil(this.destroy$$)).subscribe(data => {
|
|
47
|
+
if (!data.length) {
|
|
48
|
+
return;
|
|
49
|
+
}
|
|
50
|
+
if (!this.value || this.value === ALL_NAMESPACE_KEY) {
|
|
51
|
+
let selected = null;
|
|
52
|
+
const cached = localStorage.getItem(DEV_NAMESPACE_KEY);
|
|
53
|
+
const cachedNamespace = data.find(item => item.metadata.name === cached);
|
|
54
|
+
selected = cachedNamespace || data[0];
|
|
55
|
+
this.onSelect(selected);
|
|
56
|
+
}
|
|
57
|
+
else {
|
|
58
|
+
const current = data.find(item => item.metadata.name === this.value);
|
|
59
|
+
if (!current && data[0]) {
|
|
60
|
+
this.onSelect(data[0]);
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
});
|
|
64
|
+
this.value$
|
|
65
|
+
.pipe(takeUntil(this.destroy$$), filter(Boolean))
|
|
66
|
+
.subscribe(value => {
|
|
67
|
+
localStorage.setItem(DEV_NAMESPACE_KEY, value);
|
|
68
|
+
});
|
|
69
|
+
}
|
|
70
|
+
openPopup() {
|
|
71
|
+
if (this.isActive) {
|
|
72
|
+
this.closePopup();
|
|
73
|
+
}
|
|
74
|
+
else {
|
|
75
|
+
this.isActive = true;
|
|
76
|
+
this.popupRef = this.popupService.open({
|
|
77
|
+
origin: this.elementRef,
|
|
78
|
+
content: this.popupTemplate,
|
|
79
|
+
});
|
|
80
|
+
this.popupRef.afterClosed().subscribe(() => {
|
|
81
|
+
this.isActive = false;
|
|
82
|
+
this.cdr.markForCheck();
|
|
83
|
+
});
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
closePopup() {
|
|
87
|
+
this.isActive = false;
|
|
88
|
+
this.popupRef.close();
|
|
89
|
+
}
|
|
90
|
+
onSelect(item) {
|
|
91
|
+
this.value = item.metadata.name;
|
|
92
|
+
// localStorage.setItem(DEV_NAMESPACE_KEY, item.metadata.name);
|
|
93
|
+
this.valueChange.emit(item);
|
|
94
|
+
if (this.isActive) {
|
|
95
|
+
this.closePopup();
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.1", ngImport: i0, type: NamespaceSelectorComponent, deps: [{ token: i1.ResourceSelectorPopupService }, { token: i2.K8sApiService }, { token: i0.ChangeDetectorRef }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
99
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.1", type: NamespaceSelectorComponent, isStandalone: true, selector: "acl-namespace-selector", inputs: { value: "value" }, outputs: { valueChange: "valueChange" }, providers: [ResourceSelectorPopupService], 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 }); }
|
|
100
|
+
}
|
|
101
|
+
__decorate([
|
|
102
|
+
ObservableInput(),
|
|
103
|
+
__metadata("design:type", Observable)
|
|
104
|
+
], NamespaceSelectorComponent.prototype, "value$", void 0);
|
|
105
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.1", ngImport: i0, type: NamespaceSelectorComponent, decorators: [{
|
|
106
|
+
type: Component,
|
|
107
|
+
args: [{ selector: 'acl-namespace-selector', standalone: true, imports: [
|
|
108
|
+
IconComponent,
|
|
109
|
+
AsyncPipe,
|
|
110
|
+
NgClass,
|
|
111
|
+
NamespaceListComponent,
|
|
112
|
+
TOOLTIP_MODULE,
|
|
113
|
+
], providers: [ResourceSelectorPopupService], 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"] }]
|
|
114
|
+
}], ctorParameters: () => [{ type: i1.ResourceSelectorPopupService }, { type: i2.K8sApiService }, { type: i0.ChangeDetectorRef }, { type: i0.ElementRef }], propDecorators: { popupTemplate: [{
|
|
115
|
+
type: ViewChild,
|
|
116
|
+
args: ['popup', { static: true }]
|
|
117
|
+
}], value: [{
|
|
118
|
+
type: Input
|
|
119
|
+
}], value$: [], valueChange: [{
|
|
120
|
+
type: Output
|
|
121
|
+
}] } });
|
|
122
|
+
//# 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} 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, 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';\nimport { ResourceSelectorPopupRef } from './selector-popup/ref';\nimport { ResourceSelectorPopupService } from './selector-popup/service';\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  providers: [ResourceSelectorPopupService],\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.k8sService\n    .getResourceList<Namespace>({\n      definition: COMMON_RESOURCE_DEFINITIONS.NAMESPACE,\n      cluster: (window as any).__clusterName,\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      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,5 @@
|
|
|
1
|
+
export * from './constants';
|
|
2
|
+
export * from './component';
|
|
3
|
+
export * from './types';
|
|
4
|
+
export * from './selector-popup/service';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL2R5bmFtaWMtcGx1Z2luLXNoYXJlZC9zcmMvY29tcG9uZW50cy9uYW1lc3BhY2Utc2VsZWN0b3IvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyxTQUFTLENBQUM7QUFDeEIsY0FBYywwQkFBMEIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vY29uc3RhbnRzJztcbmV4cG9ydCAqIGZyb20gJy4vY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vdHlwZXMnO1xuZXhwb3J0ICogZnJvbSAnLi9zZWxlY3Rvci1wb3B1cC9zZXJ2aWNlJztcbiJdfQ==
|