@alauda-fe/common 1.4.7 → 1.4.9
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/api/platform-ui.service.d.ts +1 -2
- package/api/project-api.service.d.ts +2 -0
- package/api/types.d.ts +3 -0
- package/business/public-api.d.ts +0 -1
- package/core/module.d.ts +23 -23
- package/core/pipes/marked.pipe.d.ts +1 -1
- package/core/types/k8s/core.d.ts +1 -2
- package/core/types/k8s/crd.d.ts +201 -91
- package/core/types/k8s/raw.d.ts +1 -0
- package/core/types/resource-definitions.d.ts +91 -11
- package/core/utils/operators.d.ts +5 -2
- package/esm2022/api/platform-ui.service.mjs +1 -7
- package/esm2022/api/project-api.service.mjs +11 -1
- package/esm2022/api/types.mjs +1 -1
- package/esm2022/business/public-api.mjs +1 -2
- package/esm2022/core/constants/tokens.mjs +2 -2
- package/esm2022/core/module.mjs +8 -8
- package/esm2022/core/pipes/marked.pipe.mjs +3 -2
- package/esm2022/core/types/k8s/core.mjs +1 -1
- package/esm2022/core/types/k8s/crd.mjs +28 -1
- package/esm2022/core/types/k8s/raw.mjs +2 -1
- package/esm2022/core/types/resource-definitions.mjs +46 -6
- package/esm2022/core/utils/operators.mjs +8 -2
- package/esm2022/grid-layout/components/grid/component.mjs +2 -2
- package/esm2022/k8s-shared/k8s-shared-util.service.mjs +6 -6
- package/esm2022/k8s-shared/update-description-dialog/component.mjs +17 -11
- package/esm2022/k8s-shared/update-display-name-dialog/component.mjs +16 -10
- package/esm2022/page-scaffold/navigation/nav-menu/nav-menu.component.mjs +3 -3
- package/esm2022/page-scaffold/navigation/navconfig-loader/navconfig-loader.service.mjs +6 -6
- package/esm2022/page-scaffold/page-header/account-menu/component/component.mjs +47 -56
- package/esm2022/page-scaffold/page-header/account-menu/module.mjs +4 -5
- package/esm2022/page-scaffold/page-header/common-layout/product-select/component.mjs +27 -42
- package/esm2022/page-scaffold/page-header/common-layout/store.service.mjs +2 -2
- package/esm2022/page-scaffold/page-header/component.mjs +16 -17
- package/esm2022/page-scaffold/page-header/enterprise-support-status/component.mjs +4 -4
- package/esm2022/page-scaffold/page-header/help-menu/component/component.mjs +48 -65
- package/esm2022/page-scaffold/page-header/help-menu/module.mjs +4 -5
- package/esm2022/page-scaffold/page-header/module.mjs +7 -8
- package/k8s-shared/k8s-shared-util.service.d.ts +11 -3
- package/k8s-shared/update-description-dialog/component.d.ts +9 -0
- package/k8s-shared/update-display-name-dialog/component.d.ts +9 -1
- package/package.json +1 -1
- package/page-scaffold/navigation/navconfig-loader/navconfig-loader.service.d.ts +2 -2
- package/page-scaffold/page-header/account-menu/component/component.d.ts +1 -2
- package/page-scaffold/page-header/account-menu/module.d.ts +2 -2
- package/page-scaffold/page-header/common-layout/product-select/component.d.ts +1 -3
- package/page-scaffold/page-header/component.d.ts +1 -4
- package/styles/tailwind-preset.scss +1 -1
- package/business/module-info/api.service.d.ts +0 -24
- package/business/module-info/public-api.d.ts +0 -1
- package/esm2022/business/module-info/api.service.mjs +0 -39
- package/esm2022/business/module-info/public-api.mjs +0 -2
|
@@ -5,14 +5,14 @@ import { FormsModule } from '@angular/forms';
|
|
|
5
5
|
import { snakeCase } from 'lodash-es';
|
|
6
6
|
import { BehaviorSubject, finalize } from 'rxjs';
|
|
7
7
|
import { K8sApiService } from '../../api/k8s-api.service';
|
|
8
|
-
import {
|
|
9
|
-
import {
|
|
8
|
+
import { K8S_UTIL_PIPES_MODULE, DESCRIPTION, K8sUtilService, } from '../../core/public-api';
|
|
9
|
+
import { TRANSLATE_MODULE } from '../../translate/public-api';
|
|
10
10
|
import * as i0 from "@angular/core";
|
|
11
11
|
import * as i1 from "@alauda/ui";
|
|
12
12
|
import * as i2 from "../../api/k8s-api.service";
|
|
13
13
|
import * as i3 from "../../core/public-api";
|
|
14
|
-
import * as i4 from "
|
|
15
|
-
import * as i5 from "
|
|
14
|
+
import * as i4 from "@angular/forms";
|
|
15
|
+
import * as i5 from "../../translate/translate.pipe";
|
|
16
16
|
import * as i6 from "../../core/pipes/k8s-util.pipe";
|
|
17
17
|
export class UpdateDescriptionDialogComponent {
|
|
18
18
|
constructor(dialogRef, k8sApi, k8sUtil, data) {
|
|
@@ -27,8 +27,14 @@ export class UpdateDescriptionDialogComponent {
|
|
|
27
27
|
this.confirming$$.next(true);
|
|
28
28
|
this.k8sApi
|
|
29
29
|
.patchResource({
|
|
30
|
-
|
|
31
|
-
|
|
30
|
+
...(this.data.definition
|
|
31
|
+
? {
|
|
32
|
+
definition: this.data.definition,
|
|
33
|
+
}
|
|
34
|
+
: {
|
|
35
|
+
type: this.data.type ||
|
|
36
|
+
snakeCase(this.data.resource.kind).toUpperCase(),
|
|
37
|
+
}),
|
|
32
38
|
cluster: this.data.cluster,
|
|
33
39
|
resource: this.data.resource,
|
|
34
40
|
part: {
|
|
@@ -91,7 +97,7 @@ export class UpdateDescriptionDialogComponent {
|
|
|
91
97
|
i0.ɵɵadvance(3);
|
|
92
98
|
i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(23, 23, "cancel"), " ");
|
|
93
99
|
} }, dependencies: [AsyncPipe,
|
|
94
|
-
ButtonModule, i1.ButtonComponent, DialogModule, i1.DialogHeaderComponent, i1.DialogContentComponent, i1.DialogFooterComponent, i1.DialogCloseDirective, InputModule, i1.InputComponent,
|
|
100
|
+
ButtonModule, i1.ButtonComponent, DialogModule, i1.DialogHeaderComponent, i1.DialogContentComponent, i1.DialogFooterComponent, i1.DialogCloseDirective, InputModule, i1.InputComponent, FormModule, i1.FormItemComponent, i1.FormItemLabelDirective, FormsModule, i4.DefaultValueAccessor, i4.NgControlStatus, i4.NgModel, i5.TranslatePipe, i6.K8sNamePipe], encapsulation: 2, changeDetection: 0 }); }
|
|
95
101
|
}
|
|
96
102
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(UpdateDescriptionDialogComponent, [{
|
|
97
103
|
type: Component,
|
|
@@ -100,14 +106,14 @@ export class UpdateDescriptionDialogComponent {
|
|
|
100
106
|
ButtonModule,
|
|
101
107
|
DialogModule,
|
|
102
108
|
InputModule,
|
|
103
|
-
TranslateModule,
|
|
104
109
|
FormModule,
|
|
105
110
|
FormsModule,
|
|
106
|
-
|
|
111
|
+
TRANSLATE_MODULE,
|
|
112
|
+
K8S_UTIL_PIPES_MODULE,
|
|
107
113
|
], template: "<aui-dialog-header>\n {{ 'update_description' | translate }}\n</aui-dialog-header>\n<aui-dialog-content>\n <aui-form-item>\n <label auiFormItemLabel>\n {{ 'name' | translate }}\n </label>\n {{ data.resource | aclName }}\n </aui-form-item>\n <aui-form-item class=\"last-form-item-no-margin\">\n <label auiFormItemLabel>\n {{ 'description' | translate }}\n </label>\n <textarea\n aui-input\n name=\"description\"\n [(ngModel)]=\"description\"\n ></textarea>\n </aui-form-item>\n</aui-dialog-content>\n<aui-dialog-footer>\n <button\n aui-button=\"primary\"\n [loading]=\"confirming$$ | async\"\n [disabled]=\"confirming$$ | async\"\n (click)=\"confirm()\"\n >\n {{ 'update' | translate }}\n </button>\n <button\n aui-button\n auiDialogClose\n >\n {{ 'cancel' | translate }}\n </button>\n</aui-dialog-footer>\n" }]
|
|
108
114
|
}], () => [{ type: i1.DialogRef }, { type: i2.K8sApiService }, { type: i3.K8sUtilService }, { type: undefined, decorators: [{
|
|
109
115
|
type: Inject,
|
|
110
116
|
args: [DIALOG_DATA]
|
|
111
117
|
}] }], null); })();
|
|
112
|
-
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(UpdateDescriptionDialogComponent, { className: "UpdateDescriptionDialogComponent", filePath: "k8s-shared/update-description-dialog/component.ts", lineNumber:
|
|
113
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
118
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(UpdateDescriptionDialogComponent, { className: "UpdateDescriptionDialogComponent", filePath: "k8s-shared/update-description-dialog/component.ts", lineNumber: 43 }); })();
|
|
119
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"component.js","sourceRoot":"","sources":["../../../../../../libs/common/src/k8s-shared/update-description-dialog/component.ts","../../../../../../libs/common/src/k8s-shared/update-description-dialog/template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  DialogRef,\n  DIALOG_DATA,\n  DialogModule,\n  FormModule,\n  ButtonModule,\n  InputModule,\n} from '@alauda/ui';\nimport { AsyncPipe } from '@angular/common';\nimport { ChangeDetectionStrategy, Component, Inject } from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { snakeCase } from 'lodash-es';\nimport { BehaviorSubject, finalize } from 'rxjs';\nimport { DeepPartial } from 'ts-essentials/dist/deep-partial';\n\nimport { K8sApiService } from '../../api/k8s-api.service';\nimport { K8sResourceDefinition } from '../../api/types';\nimport {\n  K8S_UTIL_PIPES_MODULE,\n  DESCRIPTION,\n  K8sUtilService,\n  KubernetesResource,\n  ResourceType,\n} from '../../core/public-api';\nimport { TRANSLATE_MODULE } from '../../translate/public-api';\n\n@Component({\n  standalone: true,\n  templateUrl: 'template.html',\n  preserveWhitespaces: false,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [\n    AsyncPipe,\n    ButtonModule,\n    DialogModule,\n    InputModule,\n    FormModule,\n    FormsModule,\n    TRANSLATE_MODULE,\n    K8S_UTIL_PIPES_MODULE,\n  ],\n})\nexport class UpdateDescriptionDialogComponent<T extends KubernetesResource> {\n  description = this.k8sUtil.getDescription(this.data.resource);\n\n  confirming$$ = new BehaviorSubject(false);\n\n  constructor(\n    private readonly dialogRef: DialogRef,\n    private readonly k8sApi: K8sApiService<ResourceType>,\n    private readonly k8sUtil: K8sUtilService,\n    @Inject(DIALOG_DATA)\n    public data: {\n      definition?: K8sResourceDefinition;\n      /**\n       * @deprecated use `definition` instead\n       */\n      type?: ResourceType;\n      cluster?: string;\n      resource: T;\n    },\n  ) {}\n\n  confirm() {\n    this.confirming$$.next(true);\n    this.k8sApi\n      .patchResource<T>({\n        ...(this.data.definition\n          ? {\n              definition: this.data.definition,\n            }\n          : {\n              type:\n                this.data.type ||\n                (snakeCase(\n                  this.data.resource.kind,\n                ).toUpperCase() as ResourceType),\n            }),\n        cluster: this.data.cluster,\n        resource: this.data.resource,\n        part: {\n          metadata: {\n            annotations: {\n              [this.k8sUtil.normalizeType(DESCRIPTION)]: this.description,\n            },\n          },\n        } as DeepPartial<T>,\n      })\n      .pipe(finalize(() => this.confirming$$.next(false)))\n      .subscribe(resource => this.dialogRef.close(resource));\n  }\n}\n","<aui-dialog-header>\n  {{ 'update_description' | translate }}\n</aui-dialog-header>\n<aui-dialog-content>\n  <aui-form-item>\n    <label auiFormItemLabel>\n      {{ 'name' | translate }}\n    </label>\n    {{ data.resource | aclName }}\n  </aui-form-item>\n  <aui-form-item class=\"last-form-item-no-margin\">\n    <label auiFormItemLabel>\n      {{ 'description' | translate }}\n    </label>\n    <textarea\n      aui-input\n      name=\"description\"\n      [(ngModel)]=\"description\"\n    ></textarea>\n  </aui-form-item>\n</aui-dialog-content>\n<aui-dialog-footer>\n  <button\n    aui-button=\"primary\"\n    [loading]=\"confirming$$ | async\"\n    [disabled]=\"confirming$$ | async\"\n    (click)=\"confirm()\"\n  >\n    {{ 'update' | translate }}\n  </button>\n  <button\n    aui-button\n    auiDialogClose\n  >\n    {{ 'cancel' | translate }}\n  </button>\n</aui-dialog-footer>\n"]}
|
|
@@ -5,14 +5,14 @@ import { FormsModule } from '@angular/forms';
|
|
|
5
5
|
import { snakeCase } from 'lodash-es';
|
|
6
6
|
import { BehaviorSubject, finalize } from 'rxjs';
|
|
7
7
|
import { K8sApiService } from '../../api/public-api';
|
|
8
|
-
import {
|
|
9
|
-
import {
|
|
8
|
+
import { DISPLAY_NAME, K8sUtilService, K8S_UTIL_PIPES_MODULE, } from '../../core/public-api';
|
|
9
|
+
import { TRANSLATE_MODULE } from '../../translate/public-api';
|
|
10
10
|
import * as i0 from "@angular/core";
|
|
11
11
|
import * as i1 from "@alauda/ui";
|
|
12
12
|
import * as i2 from "../../api/public-api";
|
|
13
13
|
import * as i3 from "../../core/public-api";
|
|
14
|
-
import * as i4 from "
|
|
15
|
-
import * as i5 from "
|
|
14
|
+
import * as i4 from "@angular/forms";
|
|
15
|
+
import * as i5 from "../../translate/translate.pipe";
|
|
16
16
|
import * as i6 from "../../core/pipes/k8s-util.pipe";
|
|
17
17
|
function UpdateDisplayNameDialogComponent_input_14_Template(rf, ctx) { if (rf & 1) {
|
|
18
18
|
const _r2 = i0.ɵɵgetCurrentView();
|
|
@@ -46,8 +46,14 @@ export class UpdateDisplayNameDialogComponent {
|
|
|
46
46
|
this.confirming$$.next(true);
|
|
47
47
|
this.k8sApi
|
|
48
48
|
.patchResource({
|
|
49
|
-
|
|
50
|
-
|
|
49
|
+
...(this.data.definition
|
|
50
|
+
? {
|
|
51
|
+
definition: this.data.definition,
|
|
52
|
+
}
|
|
53
|
+
: {
|
|
54
|
+
type: this.data.type ||
|
|
55
|
+
snakeCase(this.data.resource.kind).toUpperCase(),
|
|
56
|
+
}),
|
|
51
57
|
cluster: this.data.cluster,
|
|
52
58
|
resource: this.data.resource,
|
|
53
59
|
part: {
|
|
@@ -112,7 +118,7 @@ export class UpdateDisplayNameDialogComponent {
|
|
|
112
118
|
i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(25, 24, "cancel"), " ");
|
|
113
119
|
} }, dependencies: [AsyncPipe,
|
|
114
120
|
ButtonModule, i1.ButtonComponent, DialogModule, i1.DialogHeaderComponent, i1.DialogContentComponent, i1.DialogFooterComponent, i1.DialogCloseDirective, NgIf,
|
|
115
|
-
InputModule, i1.InputComponent,
|
|
121
|
+
InputModule, i1.InputComponent, FormModule, i1.FormItemComponent, i1.FormItemLabelDirective, FormsModule, i4.DefaultValueAccessor, i4.NgControlStatus, i4.MaxLengthValidator, i4.NgModel, i5.TranslatePipe, i6.K8sNamePipe], encapsulation: 2, changeDetection: 0 }); }
|
|
116
122
|
}
|
|
117
123
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(UpdateDisplayNameDialogComponent, [{
|
|
118
124
|
type: Component,
|
|
@@ -122,14 +128,14 @@ export class UpdateDisplayNameDialogComponent {
|
|
|
122
128
|
DialogModule,
|
|
123
129
|
NgIf,
|
|
124
130
|
InputModule,
|
|
125
|
-
TranslateModule,
|
|
126
131
|
FormModule,
|
|
127
132
|
FormsModule,
|
|
128
|
-
|
|
133
|
+
TRANSLATE_MODULE,
|
|
134
|
+
K8S_UTIL_PIPES_MODULE,
|
|
129
135
|
], template: "<aui-dialog-header>\n {{ 'update_display_name' | translate }}\n</aui-dialog-header>\n<aui-dialog-content>\n <aui-form-item>\n <label auiFormItemLabel>\n {{ 'name' | translate }}\n </label>\n {{ data.resource | aclName }}\n </aui-form-item>\n <aui-form-item class=\"last-form-item-no-margin\">\n <label auiFormItemLabel>\n {{ 'display_name' | translate }}\n </label>\n <input\n *ngIf=\"!data.validateMaxLength; else validateMaxLength\"\n aui-input\n name=\"displayName\"\n autocomplete=\"off\"\n [(ngModel)]=\"displayName\"\n />\n <ng-template #validateMaxLength>\n <input\n aui-input\n name=\"displayName\"\n autocomplete=\"off\"\n [(ngModel)]=\"displayName\"\n [maxlength]=\"64\"\n />\n </ng-template>\n </aui-form-item>\n</aui-dialog-content>\n<aui-dialog-footer>\n <button\n aui-button=\"primary\"\n [loading]=\"confirming$$ | async\"\n [disabled]=\"confirming$$ | async\"\n (click)=\"confirm()\"\n >\n {{ 'update' | translate }}\n </button>\n <button\n aui-button\n auiDialogClose\n >\n {{ 'cancel' | translate }}\n </button>\n</aui-dialog-footer>\n" }]
|
|
130
136
|
}], () => [{ type: i1.DialogRef }, { type: i2.K8sApiService }, { type: i3.K8sUtilService }, { type: undefined, decorators: [{
|
|
131
137
|
type: Inject,
|
|
132
138
|
args: [DIALOG_DATA]
|
|
133
139
|
}] }], null); })();
|
|
134
140
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(UpdateDisplayNameDialogComponent, { className: "UpdateDisplayNameDialogComponent", filePath: "k8s-shared/update-display-name-dialog/component.ts", lineNumber: 43 }); })();
|
|
135
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
141
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"component.js","sourceRoot":"","sources":["../../../../../../libs/common/src/k8s-shared/update-display-name-dialog/component.ts","../../../../../../libs/common/src/k8s-shared/update-display-name-dialog/template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  DialogRef,\n  DIALOG_DATA,\n  ButtonModule,\n  DialogModule,\n  InputModule,\n  FormModule,\n} from '@alauda/ui';\nimport { AsyncPipe, NgIf } from '@angular/common';\nimport { ChangeDetectionStrategy, Component, Inject } from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { snakeCase } from 'lodash-es';\nimport { BehaviorSubject, finalize } from 'rxjs';\nimport { DeepPartial } from 'ts-essentials/dist/deep-partial';\n\nimport { K8sApiService, K8sResourceDefinition } from '../../api/public-api';\nimport {\n  DISPLAY_NAME,\n  K8sUtilService,\n  KubernetesResource,\n  ResourceType,\n  K8S_UTIL_PIPES_MODULE,\n} from '../../core/public-api';\nimport { TRANSLATE_MODULE } from '../../translate/public-api';\n\n@Component({\n  standalone: true,\n  templateUrl: 'template.html',\n  preserveWhitespaces: false,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [\n    AsyncPipe,\n    ButtonModule,\n    DialogModule,\n    NgIf,\n    InputModule,\n    FormModule,\n    FormsModule,\n    TRANSLATE_MODULE,\n    K8S_UTIL_PIPES_MODULE,\n  ],\n})\nexport class UpdateDisplayNameDialogComponent<T extends KubernetesResource> {\n  displayName = this.k8sUtil.getDisplayName(this.data.resource);\n\n  confirming$$ = new BehaviorSubject(false);\n\n  constructor(\n    private readonly dialogRef: DialogRef,\n    private readonly k8sApi: K8sApiService<ResourceType>,\n    private readonly k8sUtil: K8sUtilService,\n    @Inject(DIALOG_DATA)\n    public data: {\n      definition?: K8sResourceDefinition;\n      /**\n       * @deprecated use `definition` instead\n       */\n      type?: ResourceType;\n      cluster?: string;\n      resource: T;\n      validateMaxLength?: boolean;\n    },\n  ) {}\n\n  confirm() {\n    this.confirming$$.next(true);\n    this.k8sApi\n      .patchResource<T>({\n        ...(this.data.definition\n          ? {\n              definition: this.data.definition,\n            }\n          : {\n              type:\n                this.data.type ||\n                (snakeCase(\n                  this.data.resource.kind,\n                ).toUpperCase() as ResourceType),\n            }),\n        cluster: this.data.cluster,\n        resource: this.data.resource,\n        part: {\n          metadata: {\n            annotations: {\n              [this.k8sUtil.normalizeType(DISPLAY_NAME)]: this.displayName,\n            },\n          },\n        } as DeepPartial<T>,\n      })\n      .pipe(finalize(() => this.confirming$$.next(false)))\n      .subscribe(resource => this.dialogRef.close(resource));\n  }\n}\n","<aui-dialog-header>\n  {{ 'update_display_name' | translate }}\n</aui-dialog-header>\n<aui-dialog-content>\n  <aui-form-item>\n    <label auiFormItemLabel>\n      {{ 'name' | translate }}\n    </label>\n    {{ data.resource | aclName }}\n  </aui-form-item>\n  <aui-form-item class=\"last-form-item-no-margin\">\n    <label auiFormItemLabel>\n      {{ 'display_name' | translate }}\n    </label>\n    <input\n      *ngIf=\"!data.validateMaxLength; else validateMaxLength\"\n      aui-input\n      name=\"displayName\"\n      autocomplete=\"off\"\n      [(ngModel)]=\"displayName\"\n    />\n    <ng-template #validateMaxLength>\n      <input\n        aui-input\n        name=\"displayName\"\n        autocomplete=\"off\"\n        [(ngModel)]=\"displayName\"\n        [maxlength]=\"64\"\n      />\n    </ng-template>\n  </aui-form-item>\n</aui-dialog-content>\n<aui-dialog-footer>\n  <button\n    aui-button=\"primary\"\n    [loading]=\"confirming$$ | async\"\n    [disabled]=\"confirming$$ | async\"\n    (click)=\"confirm()\"\n  >\n    {{ 'update' | translate }}\n  </button>\n  <button\n    aui-button\n    auiDialogClose\n  >\n    {{ 'cancel' | translate }}\n  </button>\n</aui-dialog-footer>\n"]}
|
|
@@ -122,7 +122,7 @@ export class NavMenuComponent {
|
|
|
122
122
|
let _t;
|
|
123
123
|
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.container = _t.first);
|
|
124
124
|
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.content = _t.first);
|
|
125
|
-
} }, inputs: { activatedKey: "activatedKey", isCollapse: "isCollapse", triggerType: "triggerType", configs: "configs", groups: "groups", disableAniIcon: "disableAniIcon" }, decls: 9, vars: 11, consts: [["container", ""], ["content", ""], [1, "acl-nav-menu__container", "tw-h-full", 3, "scrollBorder", "aclScrollBorderObserver"], [4, "ngIf"], [1, "acl-nav-menu", "tw-flex", "tw-flex-col", "tw-select-none", "tw-relative", 3, "ngClass"], [3, "items", "groups"], ["class", "acl-nav-menu__collapse-button tw-flex tw-
|
|
125
|
+
} }, inputs: { activatedKey: "activatedKey", isCollapse: "isCollapse", triggerType: "triggerType", configs: "configs", groups: "groups", disableAniIcon: "disableAniIcon" }, decls: 9, vars: 11, consts: [["container", ""], ["content", ""], [1, "acl-nav-menu__container", "tw-h-full", 3, "scrollBorder", "aclScrollBorderObserver"], [4, "ngIf"], [1, "acl-nav-menu", "tw-flex", "tw-flex-col", "tw-select-none", "tw-relative", 3, "ngClass"], [3, "items", "groups"], ["class", "acl-nav-menu__collapse-button tw-flex tw-justify-end", 3, "ngClass", "click", 4, "ngIf"], [1, "acl-nav-menu__collapse-button", "tw-flex", "tw-justify-end", 3, "click", "ngClass"], [3, "icon"]], template: function NavMenuComponent_Template(rf, ctx) { if (rf & 1) {
|
|
126
126
|
const _r1 = i0.ɵɵgetCurrentView();
|
|
127
127
|
i0.ɵɵelementStart(0, "div", 2, 0);
|
|
128
128
|
i0.ɵɵlistener("scrollBorder", function NavMenuComponent_Template_div_scrollBorder_0_listener($event) { i0.ɵɵrestoreView(_r1); return i0.ɵɵresetView(ctx.scroll($event)); });
|
|
@@ -163,7 +163,7 @@ __decorate([
|
|
|
163
163
|
], NavMenuComponent.prototype, "groups$", void 0);
|
|
164
164
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(NavMenuComponent, [{
|
|
165
165
|
type: Component,
|
|
166
|
-
args: [{ selector: 'acl-nav-menu', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, preserveWhitespaces: false, template: "<div\n class=\"acl-nav-menu__container tw-h-full\"\n #container\n [aclScrollBorderObserver]=\"{\n
|
|
166
|
+
args: [{ selector: 'acl-nav-menu', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, preserveWhitespaces: false, template: "<div\n class=\"acl-nav-menu__container tw-h-full\"\n #container\n [aclScrollBorderObserver]=\"{\n bottomDistance: 20,\n }\"\n (scrollBorder)=\"scroll($event)\"\n>\n <acl-nav-skeleton\n *ngIf=\"!configs?.length && !groups?.length\"\n ></acl-nav-skeleton>\n\n <div\n #content\n class=\"acl-nav-menu tw-flex tw-flex-col tw-select-none tw-relative\"\n [ngClass]=\"(isCollapse$ | async) ? 'collapse' : 'expand'\"\n >\n <acl-nav-item-ul\n [items]=\"filteredConfigs$ | async\"\n [groups]=\"groups\"\n ></acl-nav-item-ul>\n </div>\n</div>\n\n<div\n *ngIf=\"!(!configs?.length && !groups?.length)\"\n class=\"acl-nav-menu__collapse-button tw-flex tw-justify-end\"\n [ngClass]=\"{\n 'acl-nav-menu__collapse-button-shadow': showShadow$ | async,\n }\"\n (click)=\"toggleCollapse()\"\n>\n <aui-icon\n [icon]=\"isCollapse ? 'prod:list_expand_right' : 'prod:list_fold_left'\"\n ></aui-icon>\n</div>\n", styles: [".cdk-overlay-container,.cdk-global-overlay-wrapper{pointer-events:none;top:0;left:0;height:100%;width:100%}.cdk-overlay-container{position:fixed;z-index:1000}.cdk-overlay-container:empty{display:none}.cdk-global-overlay-wrapper{display:flex;position:absolute;z-index:1000}.cdk-overlay-pane{position:absolute;pointer-events:auto;box-sizing:border-box;z-index:1000;display:flex;max-width:100%;max-height:100%}.cdk-overlay-backdrop{position:absolute;top:0;bottom:0;left:0;right:0;z-index:1000;pointer-events:auto;-webkit-tap-highlight-color:rgba(0,0,0,0);transition:opacity .4s cubic-bezier(.25,.8,.25,1);opacity:0}.cdk-overlay-backdrop.cdk-overlay-backdrop-showing{opacity:1}.cdk-high-contrast-active .cdk-overlay-backdrop.cdk-overlay-backdrop-showing{opacity:.6}.cdk-overlay-dark-backdrop{background:#00000052}.cdk-overlay-transparent-backdrop{transition:visibility 1ms linear,opacity 1ms linear;visibility:hidden;opacity:1}.cdk-overlay-transparent-backdrop.cdk-overlay-backdrop-showing{opacity:0;visibility:visible}.cdk-overlay-backdrop-noop-animation{transition:none}.cdk-overlay-connected-position-bounding-box{position:absolute;z-index:1000;display:flex;flex-direction:column;min-width:1px;min-height:1px}.cdk-global-scrollblock{position:fixed;width:100%;overflow-y:scroll}acl-nav-item-ul:not([hidden]){display:block}acl-nav-item-li{position:relative}.acl-nav-menu{width:220px;padding-bottom:72px}.acl-nav-menu-content>acl-nav-item-ul>.acl-nav-item-ul>acl-nav-item-li+acl-nav-item-li{margin-top:4px}.acl-nav-menu .acl-nav-item{word-break:keep-all}.acl-nav-menu.collapse{width:40px;overflow:hidden}.acl-nav-menu.collapse .acl-nav-item__icon{transform:translate(-8px)}.acl-nav-menu.collapse .acl-nav-item-group__title,.acl-nav-menu.collapse .acl-nav-item-li__sub-items{display:none}.acl-nav-menu.collapse .acl-nav-item-li__content{max-height:40px}.acl-nav-menu.collapse .acl-nav-item-li__content .acl-nav-item__content,.acl-nav-menu.collapse .acl-nav-item-li__content .acl-nav-item-li__expansion-indicator{opacity:0}.acl-nav-menu.collapse .acl-nav-item-li__content.isActive{background-color:var(--acl-nav-active-background-color)}.sidenav-ani .acl-nav-menu,.sidenav-ani .acl-nav-menu .acl-nav-item,.sidenav-ani .acl-nav-menu__icon,.sidenav-ani .acl-nav-menu-li__sub-items,.sidenav-ani .acl-nav-menu .acl-nav-item__icon,.sidenav-ani .acl-nav-menu .acl-nav-item-li__sub-items{transition:width,opacity,transform;transition-duration:.3s;transition-timing-function:cubic-bezier(.38,0,.24,1)}.sidenav-ani .acl-nav-menu-li__content .acl-nav-item__content,.sidenav-ani .acl-nav-menu-li__content .acl-nav-item-li__expansion-indicator,.sidenav-ani .acl-nav-menu .acl-nav-item-li__content .acl-nav-item__content,.sidenav-ani .acl-nav-menu .acl-nav-item-li__content .acl-nav-item-li__expansion-indicator{transition:opacity;transition-duration:.2s;transition-timing-function:cubic-bezier(.38,0,.24,1)}.acl-nav-menu__collapse-button{position:fixed;bottom:0;left:20px;line-height:52px;background-color:var(--acl-nav-background-color);cursor:pointer;color:rgb(var(--aui-color-n-3));width:220px;padding:0 20px}.sidenav-collapse .acl-nav-menu__collapse-button{width:40px;padding:0 12px}.sidenav-ani .acl-nav-menu__collapse-button{transition:width padding;transition-duration:.3s;transition-timing-function:cubic-bezier(.38,0,.24,1)}.acl-nav-menu__collapse-button .aui-icon{font-size:var(--aui-icon-size-m)}.acl-nav-menu__collapse-button:hover{color:var(--acl-nav-active-text-color)}.acl-nav-menu__collapse-button-shadow{clip-path:inset(-15px 0 0 0)}:root .acl-nav-menu__collapse-button-shadow{box-shadow:0 -9px 8px -8px rgba(var(--aui-color-origin-shadow),.15)}html[aui-theme-mode=light] .acl-nav-menu__collapse-button-shadow{box-shadow:0 -9px 8px -8px rgba(var(--aui-color-origin-shadow),.15)}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] .acl-nav-menu__collapse-button-shadow{box-shadow:0 -9px 8px -8px rgba(var(--aui-color-n-8),.75)}}html[aui-theme-mode=dark] .acl-nav-menu__collapse-button-shadow{box-shadow:0 -9px 8px -8px rgba(var(--aui-color-n-8),.75)}.nav-menu-overlay-pane{color:rgb(var(--aui-color-main-text));background-color:var(--acl-nav-popper-background-color);padding:0 0 6px;overflow-y:auto;border-radius:4px}:root .nav-menu-overlay-pane{box-shadow:0 2px 8px rgba(var(--aui-color-origin-shadow),.2)}html[aui-theme-mode=light] .nav-menu-overlay-pane{box-shadow:0 2px 8px rgba(var(--aui-color-origin-shadow),.2)}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] .nav-menu-overlay-pane{box-shadow:0 2px 8px rgba(var(--aui-color-origin-shadow),.75)}}html[aui-theme-mode=dark] .nav-menu-overlay-pane{box-shadow:0 2px 8px rgba(var(--aui-color-origin-shadow),.75)}.nav-menu-overlay-pane::-webkit-scrollbar{width:8px;height:4px}.nav-menu-overlay-pane::-webkit-scrollbar-thumb{border-radius:4px;background-color:rgb(var(--aui-color-n-7))}.nav-menu-overlay-pane::-webkit-scrollbar-thumb:hover{background-color:rgb(var(--aui-color-n-5))}.nav-menu-overlay-pane::-webkit-scrollbar-corner{background-color:transparent}.nav-menu-overlay-pane>.acl-nav-item-li.depth-0.hasSubItem{width:220px;height:100%}.nav-menu-overlay-pane>.acl-nav-item-li.depth-0.hasSubItem .acl-nav-item-li__content[data-set-depth=\"0\"]{background-color:var(--acl-nav-popper-background-color)}.nav-menu-overlay-pane>.acl-nav-item-li.depth-0:not(.hasSubItem) .acl-nav-item-li__content[data-set-depth=\"0\"]{padding:10px;margin:6px 6px 0}.nav-menu-overlay-pane .acl-nav-item__content{max-width:120px;width:initial}.nav-menu-overlay-pane .acl-nav-item-li__content{padding-left:var(--aui-spacing-l);padding-right:var(--aui-spacing-l)}.nav-menu-overlay-pane .acl-nav-item-li__content[data-set-depth=\"0\"]{padding:16px 0 10px;margin-left:var(--aui-spacing-xl);position:sticky;top:0;z-index:9}.nav-menu-overlay-pane .acl-nav-item-li__content[data-set-depth=\"0\"].no-link{pointer-events:none;user-select:none}.nav-menu-overlay-pane .acl-nav-item-li__content[data-set-depth=\"1\"]{padding-left:28px;margin:0 var(--aui-spacing-xl)}.nav-menu-overlay-pane .acl-nav-item-li__content[data-set-depth=\"2\"]{padding-left:44px;margin:0 var(--aui-spacing-xl)}\n"] }]
|
|
167
167
|
}], () => [{ type: i1.PageComponent }, { type: i2.IframeConfigService }], { activatedKey: [{
|
|
168
168
|
type: Input
|
|
169
169
|
}], activatedKey$: [], isCollapse: [{
|
|
@@ -184,4 +184,4 @@ __decorate([
|
|
|
184
184
|
args: ['content', { read: ElementRef }]
|
|
185
185
|
}] }); })();
|
|
186
186
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(NavMenuComponent, { className: "NavMenuComponent", filePath: "page-scaffold/navigation/nav-menu/nav-menu.component.ts", lineNumber: 42 }); })();
|
|
187
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nav-menu.component.js","sourceRoot":"","sources":["../../../../../../../libs/common/src/page-scaffold/navigation/nav-menu/nav-menu.component.ts","../../../../../../../libs/common/src/page-scaffold/navigation/nav-menu/nav-menu.component.html"],"names":[],"mappings":"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","sourcesContent":["import { TooltipTrigger } from '@alauda/ui';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  Input,\n  ViewEncapsulation,\n  OnInit,\n  OnDestroy,\n  AfterViewInit,\n  ViewChild,\n  ElementRef,\n} from '@angular/core';\nimport { once } from 'lodash-es';\nimport {\n  BehaviorSubject,\n  combineLatest,\n  merge,\n  Observable,\n  ReplaySubject,\n  distinctUntilChanged,\n  map,\n} from 'rxjs';\n\nimport { IframeConfigService } from '../../..//iframe-config/config.service';\nimport { ObservableInput, publishRef } from '../../../core/public-api';\nimport { COLLAPSE_MENU_KEY } from '../../../iframe-config/constants';\nimport { PageComponent } from '../../public-api';\nimport { filterEmptyNode } from '../utils';\n\nimport { NavGroupConfig, NavItemConfig } from './nav-menu.types';\n\nconst SIDENAV_ANI = 'sidenav-ani';\n\n@Component({\n  selector: 'acl-nav-menu',\n  templateUrl: './nav-menu.component.html',\n  styleUrls: ['./nav-menu.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  preserveWhitespaces: false,\n})\nexport class NavMenuComponent implements OnInit, OnDestroy, AfterViewInit {\n  private readonly expandedKey$$ = new ReplaySubject<string>(1);\n  private readonly focusedRootKey$$ = new BehaviorSubject<string>(null);\n\n  @Input()\n  activatedKey: string;\n\n  @ObservableInput()\n  activatedKey$!: Observable<string>;\n\n  @Input()\n  isCollapse = this.iframeConfigService.isCollapseMenu;\n\n  @ObservableInput()\n  isCollapse$!: Observable<boolean>;\n\n  @Input()\n  triggerType: TooltipTrigger = TooltipTrigger.Hover;\n\n  @Input()\n  configs: NavItemConfig[];\n\n  @ObservableInput()\n  configs$!: Observable<NavItemConfig[]>;\n\n  @Input()\n  groups: NavGroupConfig[];\n\n  @ObservableInput()\n  groups$!: Observable<NavGroupConfig[]>;\n\n  @Input()\n  disableAniIcon = false;\n\n  @ViewChild('container')\n  container: ElementRef;\n\n  @ViewChild('content', { read: ElementRef })\n  content: ElementRef;\n\n  filteredConfigs$ = this.configs$.pipe(map(filterEmptyNode), publishRef());\n  showShadow$ = new BehaviorSubject(false);\n  isIntersecting: boolean;\n  items$ = combineLatest([this.filteredConfigs$, this.groups$]).pipe(\n    // 处理成NavItemConfig数组\n    map(\n      ([items, groups]) =>\n        items ||\n        (groups\n          ? groups.reduce<NavItemConfig[]>(\n              (prev, cur) => [...prev, ...cur.items],\n              [],\n            )\n          : []),\n    ),\n    publishRef(),\n  );\n\n  paths$ = this.items$.pipe(\n    map(items => this.getPaths(items)),\n    publishRef(),\n  );\n\n  activeKeys$ = combineLatest([this.paths$, this.activatedKey$]).pipe(\n    map(([paths, key]) => this.findPathByLastKey(paths, key)),\n    publishRef(),\n  );\n\n  expandedKeys$ = combineLatest([\n    this.paths$,\n    merge(this.activatedKey$, this.expandedKey$$),\n  ]).pipe(\n    map(([paths, key]) => this.findPathByLastKey(paths, key)),\n    publishRef(),\n  );\n\n  focusedRootKey$ = this.focusedRootKey$$.pipe(\n    distinctUntilChanged(),\n    publishRef(),\n  );\n\n  constructor(\n    private readonly pageCpt: PageComponent,\n    private readonly iframeConfigService: IframeConfigService,\n  ) {}\n\n  ngOnInit() {\n    this.updateCollapseClass();\n  }\n\n  ngOnDestroy() {\n    this.pageCpt.removeClass(SIDENAV_ANI);\n  }\n\n  ngAfterViewInit() {\n    const ob = new IntersectionObserver(\n      entries => {\n        const { isIntersecting } = entries[0];\n        this.isIntersecting = isIntersecting;\n        this.showShadow$.next(!isIntersecting);\n      },\n      {\n        root: this.container.nativeElement,\n        threshold: 1,\n        // 因为 .acl-nav-menu 底部有额外的 20px 间距\n        rootMargin: '0px 0px 20px 0px',\n      },\n    );\n    ob.observe(this.content.nativeElement);\n  }\n\n  scroll(type: string) {\n    if (!this.isIntersecting) {\n      this.showShadow$.next(type !== 'bottom');\n    }\n  }\n\n  // 通过key找到他及其父的path路径\n  private findPathByLastKey(paths: string[][], key: string) {\n    return paths.find(path => [...path].pop() === key);\n  }\n\n  // 以NavItemConfig的key组成自上而下的path路径，类似['a', 'a/b']\n  private getPaths(items: NavItemConfig[], parent?: string[]): string[][] {\n    if (!items?.length) {\n      return [];\n    }\n    const pre = parent ? [...parent] : [];\n    return items.reduce(\n      (prev, cur) => [\n        ...prev,\n        ...this.getPaths(cur.children, [...pre, cur.key]),\n      ],\n      items.map(item => [...pre, item.key]),\n    );\n  }\n\n  expandedKeyChanged(key: string) {\n    this.expandedKey$$.next(key);\n  }\n\n  focusedRootKeyChange(key: string) {\n    this.focusedRootKey$$.next(key);\n  }\n\n  private readonly addSidenavAni = once(() => {\n    this.pageCpt.addClass(SIDENAV_ANI);\n  });\n\n  toggleCollapse() {\n    this.isCollapse = !this.isCollapse;\n    localStorage.setItem(COLLAPSE_MENU_KEY, String(this.isCollapse));\n    this.addSidenavAni(); // 当用户第一次主动切换状态时添加动效类，而不是一开始就有，避免初始化时其他样式切换带来的过度动效\n    this.updateCollapseClass();\n  }\n\n  updateCollapseClass() {\n    this.pageCpt[this.isCollapse ? 'addClass' : 'removeClass'](\n      'sidenav-collapse',\n    );\n  }\n}\n","<div\n  class=\"acl-nav-menu__container tw-h-full\"\n  #container\n  [aclScrollBorderObserver]=\"{\n         bottomDistance: 20,\n     }\"\n  (scrollBorder)=\"scroll($event)\"\n>\n  <acl-nav-skeleton\n    *ngIf=\"!configs?.length && !groups?.length\"\n  ></acl-nav-skeleton>\n\n  <div\n    #content\n    class=\"acl-nav-menu tw-flex tw-flex-col tw-select-none tw-relative\"\n    [ngClass]=\"(isCollapse$ | async) ? 'collapse' : 'expand'\"\n  >\n    <acl-nav-item-ul\n      [items]=\"filteredConfigs$ | async\"\n      [groups]=\"groups\"\n    ></acl-nav-item-ul>\n  </div>\n</div>\n\n<div\n  *ngIf=\"!(!configs?.length && !groups?.length)\"\n  class=\"acl-nav-menu__collapse-button tw-flex tw-w-full tw-justify-end\"\n  [ngClass]=\"{\n    'acl-nav-menu__collapse-button-shadow': showShadow$ | async\n  }\"\n  (click)=\"toggleCollapse()\"\n>\n  <aui-icon\n    [icon]=\"isCollapse ? 'prod:list_expand_right' : 'prod:list_fold_left'\"\n  ></aui-icon>\n</div>\n"]}
|
|
187
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nav-menu.component.js","sourceRoot":"","sources":["../../../../../../../libs/common/src/page-scaffold/navigation/nav-menu/nav-menu.component.ts","../../../../../../../libs/common/src/page-scaffold/navigation/nav-menu/nav-menu.component.html"],"names":[],"mappings":"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","sourcesContent":["import { TooltipTrigger } from '@alauda/ui';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  Input,\n  ViewEncapsulation,\n  OnInit,\n  OnDestroy,\n  AfterViewInit,\n  ViewChild,\n  ElementRef,\n} from '@angular/core';\nimport { once } from 'lodash-es';\nimport {\n  BehaviorSubject,\n  combineLatest,\n  merge,\n  Observable,\n  ReplaySubject,\n  distinctUntilChanged,\n  map,\n} from 'rxjs';\n\nimport { IframeConfigService } from '../../..//iframe-config/config.service';\nimport { ObservableInput, publishRef } from '../../../core/public-api';\nimport { COLLAPSE_MENU_KEY } from '../../../iframe-config/constants';\nimport { PageComponent } from '../../public-api';\nimport { filterEmptyNode } from '../utils';\n\nimport { NavGroupConfig, NavItemConfig } from './nav-menu.types';\n\nconst SIDENAV_ANI = 'sidenav-ani';\n\n@Component({\n  selector: 'acl-nav-menu',\n  templateUrl: './nav-menu.component.html',\n  styleUrls: ['./nav-menu.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  preserveWhitespaces: false,\n})\nexport class NavMenuComponent implements OnInit, OnDestroy, AfterViewInit {\n  private readonly expandedKey$$ = new ReplaySubject<string>(1);\n  private readonly focusedRootKey$$ = new BehaviorSubject<string>(null);\n\n  @Input()\n  activatedKey: string;\n\n  @ObservableInput()\n  activatedKey$!: Observable<string>;\n\n  @Input()\n  isCollapse = this.iframeConfigService.isCollapseMenu;\n\n  @ObservableInput()\n  isCollapse$!: Observable<boolean>;\n\n  @Input()\n  triggerType: TooltipTrigger = TooltipTrigger.Hover;\n\n  @Input()\n  configs: NavItemConfig[];\n\n  @ObservableInput()\n  configs$!: Observable<NavItemConfig[]>;\n\n  @Input()\n  groups: NavGroupConfig[];\n\n  @ObservableInput()\n  groups$!: Observable<NavGroupConfig[]>;\n\n  @Input()\n  disableAniIcon = false;\n\n  @ViewChild('container')\n  container: ElementRef;\n\n  @ViewChild('content', { read: ElementRef })\n  content: ElementRef;\n\n  filteredConfigs$ = this.configs$.pipe(map(filterEmptyNode), publishRef());\n  showShadow$ = new BehaviorSubject(false);\n  isIntersecting: boolean;\n  items$ = combineLatest([this.filteredConfigs$, this.groups$]).pipe(\n    // 处理成NavItemConfig数组\n    map(\n      ([items, groups]) =>\n        items ||\n        (groups\n          ? groups.reduce<NavItemConfig[]>(\n              (prev, cur) => [...prev, ...cur.items],\n              [],\n            )\n          : []),\n    ),\n    publishRef(),\n  );\n\n  paths$ = this.items$.pipe(\n    map(items => this.getPaths(items)),\n    publishRef(),\n  );\n\n  activeKeys$ = combineLatest([this.paths$, this.activatedKey$]).pipe(\n    map(([paths, key]) => this.findPathByLastKey(paths, key)),\n    publishRef(),\n  );\n\n  expandedKeys$ = combineLatest([\n    this.paths$,\n    merge(this.activatedKey$, this.expandedKey$$),\n  ]).pipe(\n    map(([paths, key]) => this.findPathByLastKey(paths, key)),\n    publishRef(),\n  );\n\n  focusedRootKey$ = this.focusedRootKey$$.pipe(\n    distinctUntilChanged(),\n    publishRef(),\n  );\n\n  constructor(\n    private readonly pageCpt: PageComponent,\n    private readonly iframeConfigService: IframeConfigService,\n  ) {}\n\n  ngOnInit() {\n    this.updateCollapseClass();\n  }\n\n  ngOnDestroy() {\n    this.pageCpt.removeClass(SIDENAV_ANI);\n  }\n\n  ngAfterViewInit() {\n    const ob = new IntersectionObserver(\n      entries => {\n        const { isIntersecting } = entries[0];\n        this.isIntersecting = isIntersecting;\n        this.showShadow$.next(!isIntersecting);\n      },\n      {\n        root: this.container.nativeElement,\n        threshold: 1,\n        // 因为 .acl-nav-menu 底部有额外的 20px 间距\n        rootMargin: '0px 0px 20px 0px',\n      },\n    );\n    ob.observe(this.content.nativeElement);\n  }\n\n  scroll(type: string) {\n    if (!this.isIntersecting) {\n      this.showShadow$.next(type !== 'bottom');\n    }\n  }\n\n  // 通过key找到他及其父的path路径\n  private findPathByLastKey(paths: string[][], key: string) {\n    return paths.find(path => [...path].pop() === key);\n  }\n\n  // 以NavItemConfig的key组成自上而下的path路径，类似['a', 'a/b']\n  private getPaths(items: NavItemConfig[], parent?: string[]): string[][] {\n    if (!items?.length) {\n      return [];\n    }\n    const pre = parent ? [...parent] : [];\n    return items.reduce(\n      (prev, cur) => [\n        ...prev,\n        ...this.getPaths(cur.children, [...pre, cur.key]),\n      ],\n      items.map(item => [...pre, item.key]),\n    );\n  }\n\n  expandedKeyChanged(key: string) {\n    this.expandedKey$$.next(key);\n  }\n\n  focusedRootKeyChange(key: string) {\n    this.focusedRootKey$$.next(key);\n  }\n\n  private readonly addSidenavAni = once(() => {\n    this.pageCpt.addClass(SIDENAV_ANI);\n  });\n\n  toggleCollapse() {\n    this.isCollapse = !this.isCollapse;\n    localStorage.setItem(COLLAPSE_MENU_KEY, String(this.isCollapse));\n    this.addSidenavAni(); // 当用户第一次主动切换状态时添加动效类，而不是一开始就有，避免初始化时其他样式切换带来的过度动效\n    this.updateCollapseClass();\n  }\n\n  updateCollapseClass() {\n    this.pageCpt[this.isCollapse ? 'addClass' : 'removeClass'](\n      'sidenav-collapse',\n    );\n  }\n}\n","<div\n  class=\"acl-nav-menu__container tw-h-full\"\n  #container\n  [aclScrollBorderObserver]=\"{\n    bottomDistance: 20,\n  }\"\n  (scrollBorder)=\"scroll($event)\"\n>\n  <acl-nav-skeleton\n    *ngIf=\"!configs?.length && !groups?.length\"\n  ></acl-nav-skeleton>\n\n  <div\n    #content\n    class=\"acl-nav-menu tw-flex tw-flex-col tw-select-none tw-relative\"\n    [ngClass]=\"(isCollapse$ | async) ? 'collapse' : 'expand'\"\n  >\n    <acl-nav-item-ul\n      [items]=\"filteredConfigs$ | async\"\n      [groups]=\"groups\"\n    ></acl-nav-item-ul>\n  </div>\n</div>\n\n<div\n  *ngIf=\"!(!configs?.length && !groups?.length)\"\n  class=\"acl-nav-menu__collapse-button tw-flex tw-justify-end\"\n  [ngClass]=\"{\n    'acl-nav-menu__collapse-button-shadow': showShadow$ | async,\n  }\"\n  (click)=\"toggleCollapse()\"\n>\n  <aui-icon\n    [icon]=\"isCollapse ? 'prod:list_expand_right' : 'prod:list_fold_left'\"\n  ></aui-icon>\n</div>\n"]}
|
|
@@ -16,7 +16,7 @@ import * as i2 from "../../../translate/public-api";
|
|
|
16
16
|
import * as i3 from "@alauda/ui";
|
|
17
17
|
import * as i4 from "../../../api/k8s-api.service";
|
|
18
18
|
export const NAV_CONFIG_LOCAL_STORAGE_KEY = new InjectionToken('nav config local storage key');
|
|
19
|
-
const configTree = (tree, config) => tree
|
|
19
|
+
const configTree = (tree, config) => (tree || [])
|
|
20
20
|
.map(item => {
|
|
21
21
|
item.label = config.buildIn[item.name]?.label;
|
|
22
22
|
return item.children && !config.buildIn[item.name]?.hidden // 父节点被 hidden 跳过 config 子节点
|
|
@@ -48,18 +48,18 @@ export class NavConfigLoaderService {
|
|
|
48
48
|
}
|
|
49
49
|
return this.cachedConfig.get(address);
|
|
50
50
|
}
|
|
51
|
-
loadNavTree(address, cmConfigName, withGroup = false) {
|
|
51
|
+
loadNavTree(address, cmConfigName, withGroup = false, enjoyEmpty = false) {
|
|
52
52
|
return combineLatest([
|
|
53
53
|
this.loadNavConfig(address).pipe(this.parseYaml()),
|
|
54
54
|
this.loadCmConfig(cmConfigName),
|
|
55
55
|
]).pipe(map(([tree, config]) => withGroup
|
|
56
|
-
? this.configTreeWithGroup(tree, config)
|
|
56
|
+
? this.configTreeWithGroup(tree, config, enjoyEmpty)
|
|
57
57
|
: this.configTree(tree, config)), this.mapToAuiNav(withGroup));
|
|
58
58
|
}
|
|
59
59
|
configTree(treeItemConfig, config) {
|
|
60
60
|
return filterNavTrees(tree => !(tree.children && !tree.children.length))(configTree(treeItemConfig, config).concat(config.customs.filter(item => !item.hidden)));
|
|
61
61
|
}
|
|
62
|
-
configTreeWithGroup(treeGroupConfig, config) {
|
|
62
|
+
configTreeWithGroup(treeGroupConfig, config, enjoyEmpty = false) {
|
|
63
63
|
return treeGroupConfig
|
|
64
64
|
.map(t => ({
|
|
65
65
|
...t,
|
|
@@ -67,7 +67,7 @@ export class NavConfigLoaderService {
|
|
|
67
67
|
// 过滤存在子节点,但子节点为空的节点
|
|
68
68
|
tree => !(tree.children && !tree.children.length))(configTree(t.items, config).concat(config.customs.filter(item => !item.hidden))),
|
|
69
69
|
}))
|
|
70
|
-
.filter(item => item.items.length);
|
|
70
|
+
.filter(item => enjoyEmpty || item.items.length);
|
|
71
71
|
}
|
|
72
72
|
parseYaml() {
|
|
73
73
|
return map((yaml) => {
|
|
@@ -173,4 +173,4 @@ export class NavConfigLoaderService {
|
|
|
173
173
|
}, {
|
|
174
174
|
type: Optional
|
|
175
175
|
}] }, { type: i4.K8sApiService }], null); })();
|
|
176
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"navconfig-loader.service.js","sourceRoot":"","sources":["../../../../../../../libs/common/src/page-scaffold/navigation/navconfig-loader/navconfig-loader.service.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @packageDocumentation\n * @module navconfig-loader\n */\n\nimport { NotificationService } from '@alauda/ui';\nimport { HttpClient } from '@angular/common/http';\nimport { Inject, Injectable, InjectionToken, Optional } from '@angular/core';\nimport {\n  Observable,\n  concat,\n  of,\n  combineLatest,\n  filter,\n  map,\n  shareReplay,\n  switchMap,\n  tap,\n} from 'rxjs';\n\nimport { K8sApiService } from '../../../api/k8s-api.service';\nimport {\n  KubernetesResource,\n  parse,\n  parseJson,\n  skipError,\n} from '../../../core/public-api';\nimport { TranslateService } from '../../../translate/public-api';\nimport { NavGroupConfig, NavItemConfig } from '../nav-menu/public-api';\nimport { filterNavTrees, mapNavTrees } from '../utils';\n\ninterface NavigationConfigConfigMapData {\n  buildIn: {\n    [name: string]: {\n      label: string;\n      hidden: boolean;\n    };\n  };\n  customs: Array<{\n    label: string;\n    icon?: string;\n    iconData?: string;\n    hidden: boolean;\n    href: string;\n  }>;\n}\n\ninterface NavigationConfigConfigMap extends KubernetesResource {\n  data: {\n    buildIn: string;\n    customs: string;\n  };\n}\n\nexport const NAV_CONFIG_LOCAL_STORAGE_KEY = new InjectionToken<string>(\n  'nav config local storage key',\n);\n\nexport type Nav = NavItemConfig | NavGroupConfig;\n\nconst configTree = (\n  tree: NavItemConfig[],\n  config: NavigationConfigConfigMapData,\n): NavItemConfig[] =>\n  tree\n    .map(item => {\n      item.label = config.buildIn[item.name]?.label;\n      return item.children && !config.buildIn[item.name]?.hidden // 父节点被 hidden 跳过 config 子节点\n        ? {\n            ...item,\n            children: configTree(item.children, config),\n          }\n        : item;\n    })\n    .filter(item => !config.buildIn[item.name]?.hidden); // 过滤 hidden 节点\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class NavConfigLoaderService {\n  private readonly cachedConfig = new Map<string, Observable<string>>();\n\n  constructor(\n    private readonly http: HttpClient,\n    private readonly translate: TranslateService,\n    private readonly notification: NotificationService,\n    @Inject(NAV_CONFIG_LOCAL_STORAGE_KEY)\n    @Optional()\n    private readonly localStorageKey: string = '',\n    private readonly k8sApi: K8sApiService,\n  ) {}\n\n  loadNavConfig(address: string) {\n    if (!this.cachedConfig.has(address)) {\n      this.cachedConfig.set(address, this.buildLoadStream(address));\n    }\n    return this.cachedConfig.get(address);\n  }\n\n  loadNavTree(address: string, cmConfigName: string, withGroup = false) {\n    return combineLatest([\n      this.loadNavConfig(address).pipe(this.parseYaml()),\n      this.loadCmConfig(cmConfigName),\n    ]).pipe(\n      map(([tree, config]) =>\n        withGroup\n          ? this.configTreeWithGroup(tree as NavGroupConfig[], config)\n          : this.configTree(tree, config),\n      ),\n      this.mapToAuiNav(withGroup),\n    );\n  }\n\n  configTree(\n    treeItemConfig: NavItemConfig[],\n    config: NavigationConfigConfigMapData,\n  ) {\n    return filterNavTrees(tree => !(tree.children && !tree.children.length))(\n      configTree(treeItemConfig, config).concat(\n        config.customs.filter(item => !item.hidden), // 添加自定义的左导航\n      ),\n    );\n  }\n\n  configTreeWithGroup(\n    treeGroupConfig: NavGroupConfig[],\n    config: NavigationConfigConfigMapData,\n  ) {\n    return treeGroupConfig\n      .map(t => ({\n        ...t,\n        items: filterNavTrees<NavItemConfig>( // 过滤存在子节点，但子节点为空的节点\n          tree => !(tree.children && !tree.children.length),\n        )(\n          configTree(t.items, config).concat(\n            config.customs.filter(item => !item.hidden), // 添加自定义的左导航\n          ),\n        ),\n      }))\n      .filter(item => item.items.length);\n  }\n\n  parseYaml() {\n    return map<string, Nav[]>((yaml: string) => {\n      let data: Nav[] = [];\n      try {\n        data = parse(yaml);\n      } catch (err) {\n        console.error(err);\n        this.toastParseError();\n      }\n      return data;\n    });\n  }\n\n  mapToAuiNav(withGroup = false) {\n    return switchMap<Nav[], Observable<Nav[]>>(items =>\n      this.translate.locale$.pipe(\n        map(() => {\n          let data: Nav[] = [];\n          try {\n            data = withGroup\n              ? items.map(item => ({\n                  ...item,\n                  title: item.title ? this.translate.get(item.title) : '',\n                  items: mapNavTrees(this.mapToAuiNavItem)(item.items),\n                }))\n              : mapNavTrees(this.mapToAuiNavItem)(items);\n          } catch (err) {\n            console.error(err);\n            this.toastParseError();\n          }\n          return data;\n        }),\n      ),\n    );\n  }\n\n  /**\n   * @param name\n   * 加载左导航配置 todo: 添加文档链接\n   */\n  loadCmConfig(name: string) {\n    const defaultConfig: NavigationConfigConfigMapData = {\n      buildIn: {},\n      customs: [],\n    };\n    return this.k8sApi\n      .getGlobalResource<NavigationConfigConfigMap>({\n        definition: {\n          type: 'configmaps',\n          apiVersion: 'v1',\n        },\n        name,\n        namespaced: true,\n      })\n      .pipe(\n        map(cm => {\n          try {\n            return {\n              buildIn: parseJson(cm.data?.buildIn) || {},\n              customs: parseJson(cm.data?.customs) || [],\n            } as NavigationConfigConfigMapData;\n          } catch (e) {\n            console.error(e);\n            return defaultConfig;\n          }\n        }),\n        skipError(defaultConfig),\n      );\n  }\n\n  private buildLoadStream(path: string): Observable<string> {\n    return concat(\n      of(this.getLocal(path)),\n      this.http\n        .get(path, {\n          responseType: 'text',\n          headers: { 'Cache-Control': 'no-cache' },\n        })\n        .pipe(\n          tap(config => {\n            this.setLocal(path, config);\n          }),\n        ),\n    ).pipe(\n      filter(config => !!config),\n      shareReplay(1),\n    );\n  }\n\n  private readonly mapToAuiNavItem = (\n    item: NavItemConfig,\n    parents: NavItemConfig[],\n  ): NavItemConfig => ({\n    ...item,\n    children: null,\n    key: item.key ?? [...parents.map(({ name }) => name), item.name].join('/'),\n    label: item.label || this.translate.get(item.name),\n  });\n\n  private toastParseError() {\n    this.notification.error(this.translate.get('nav_config_error'));\n  }\n\n  private localKey(path: string) {\n    const nodes = path.split('/');\n    return `${this.localStorageKey}.${nodes.at(-1)}`;\n  }\n\n  private setLocal(path: string, value: string) {\n    if (this.localStorageKey) {\n      localStorage.setItem(this.localKey(path), value);\n    }\n  }\n\n  private getLocal(path: string): string {\n    return this.localStorageKey\n      ? localStorage.getItem(this.localKey(path)) || ''\n      : '';\n  }\n}\n"]}
|
|
176
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"navconfig-loader.service.js","sourceRoot":"","sources":["../../../../../../../libs/common/src/page-scaffold/navigation/navconfig-loader/navconfig-loader.service.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @packageDocumentation\n * @module navconfig-loader\n */\n\nimport { NotificationService } from '@alauda/ui';\nimport { HttpClient } from '@angular/common/http';\nimport { Inject, Injectable, InjectionToken, Optional } from '@angular/core';\nimport {\n  Observable,\n  concat,\n  of,\n  combineLatest,\n  filter,\n  map,\n  shareReplay,\n  switchMap,\n  tap,\n} from 'rxjs';\n\nimport { K8sApiService } from '../../../api/k8s-api.service';\nimport {\n  KubernetesResource,\n  parse,\n  parseJson,\n  skipError,\n} from '../../../core/public-api';\nimport { TranslateService } from '../../../translate/public-api';\nimport { NavGroupConfig, NavItemConfig } from '../nav-menu/public-api';\nimport { filterNavTrees, mapNavTrees } from '../utils';\n\ninterface NavigationConfigConfigMapData {\n  buildIn: {\n    [name: string]: {\n      label: string;\n      hidden: boolean;\n    };\n  };\n  customs: Array<{\n    label: string;\n    icon?: string;\n    iconData?: string;\n    hidden: boolean;\n    href: string;\n  }>;\n}\n\ninterface NavigationConfigConfigMap extends KubernetesResource {\n  data: {\n    buildIn: string;\n    customs: string;\n  };\n}\n\nexport const NAV_CONFIG_LOCAL_STORAGE_KEY = new InjectionToken<string>(\n  'nav config local storage key',\n);\n\nexport type Nav = NavItemConfig | NavGroupConfig;\n\nconst configTree = (\n  tree: NavItemConfig[],\n  config: NavigationConfigConfigMapData,\n): NavItemConfig[] =>\n  (tree || [])\n    .map(item => {\n      item.label = config.buildIn[item.name]?.label;\n      return item.children && !config.buildIn[item.name]?.hidden // 父节点被 hidden 跳过 config 子节点\n        ? {\n            ...item,\n            children: configTree(item.children, config),\n          }\n        : item;\n    })\n    .filter(item => !config.buildIn[item.name]?.hidden); // 过滤 hidden 节点\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class NavConfigLoaderService {\n  private readonly cachedConfig = new Map<string, Observable<string>>();\n\n  constructor(\n    private readonly http: HttpClient,\n    private readonly translate: TranslateService,\n    private readonly notification: NotificationService,\n    @Inject(NAV_CONFIG_LOCAL_STORAGE_KEY)\n    @Optional()\n    private readonly localStorageKey: string = '',\n    private readonly k8sApi: K8sApiService,\n  ) {}\n\n  loadNavConfig(address: string) {\n    if (!this.cachedConfig.has(address)) {\n      this.cachedConfig.set(address, this.buildLoadStream(address));\n    }\n    return this.cachedConfig.get(address);\n  }\n\n  loadNavTree(\n    address: string,\n    cmConfigName: string,\n    withGroup = false,\n    enjoyEmpty = false,\n  ) {\n    return combineLatest([\n      this.loadNavConfig(address).pipe(this.parseYaml()),\n      this.loadCmConfig(cmConfigName),\n    ]).pipe(\n      map(([tree, config]) =>\n        withGroup\n          ? this.configTreeWithGroup(\n              tree as NavGroupConfig[],\n              config,\n              enjoyEmpty,\n            )\n          : this.configTree(tree, config),\n      ),\n      this.mapToAuiNav(withGroup),\n    );\n  }\n\n  configTree(\n    treeItemConfig: NavItemConfig[],\n    config: NavigationConfigConfigMapData,\n  ) {\n    return filterNavTrees(tree => !(tree.children && !tree.children.length))(\n      configTree(treeItemConfig, config).concat(\n        config.customs.filter(item => !item.hidden), // 添加自定义的左导航\n      ),\n    );\n  }\n\n  configTreeWithGroup(\n    treeGroupConfig: NavGroupConfig[],\n    config: NavigationConfigConfigMapData,\n    enjoyEmpty = false,\n  ) {\n    return treeGroupConfig\n      .map(t => ({\n        ...t,\n        items: filterNavTrees<NavItemConfig>( // 过滤存在子节点，但子节点为空的节点\n          tree => !(tree.children && !tree.children.length),\n        )(\n          configTree(t.items, config).concat(\n            config.customs.filter(item => !item.hidden), // 添加自定义的左导航\n          ),\n        ),\n      }))\n      .filter(item => enjoyEmpty || item.items.length);\n  }\n\n  parseYaml() {\n    return map<string, Nav[]>((yaml: string) => {\n      let data: Nav[] = [];\n      try {\n        data = parse(yaml);\n      } catch (err) {\n        console.error(err);\n        this.toastParseError();\n      }\n      return data;\n    });\n  }\n\n  mapToAuiNav(withGroup = false) {\n    return switchMap<Nav[], Observable<Nav[]>>(items =>\n      this.translate.locale$.pipe(\n        map(() => {\n          let data: Nav[] = [];\n          try {\n            data = withGroup\n              ? items.map(item => ({\n                  ...item,\n                  title: item.title ? this.translate.get(item.title) : '',\n                  items: mapNavTrees(this.mapToAuiNavItem)(item.items),\n                }))\n              : mapNavTrees(this.mapToAuiNavItem)(items);\n          } catch (err) {\n            console.error(err);\n            this.toastParseError();\n          }\n          return data;\n        }),\n      ),\n    );\n  }\n\n  /**\n   * @param name\n   * 加载左导航配置 todo: 添加文档链接\n   */\n  loadCmConfig(name: string) {\n    const defaultConfig: NavigationConfigConfigMapData = {\n      buildIn: {},\n      customs: [],\n    };\n    return this.k8sApi\n      .getGlobalResource<NavigationConfigConfigMap>({\n        definition: {\n          type: 'configmaps',\n          apiVersion: 'v1',\n        },\n        name,\n        namespaced: true,\n      })\n      .pipe(\n        map(cm => {\n          try {\n            return {\n              buildIn: parseJson(cm.data?.buildIn) || {},\n              customs: parseJson(cm.data?.customs) || [],\n            } as NavigationConfigConfigMapData;\n          } catch (e) {\n            console.error(e);\n            return defaultConfig;\n          }\n        }),\n        skipError(defaultConfig),\n      );\n  }\n\n  private buildLoadStream(path: string): Observable<string> {\n    return concat(\n      of(this.getLocal(path)),\n      this.http\n        .get(path, {\n          responseType: 'text',\n          headers: { 'Cache-Control': 'no-cache' },\n        })\n        .pipe(\n          tap(config => {\n            this.setLocal(path, config);\n          }),\n        ),\n    ).pipe(\n      filter(config => !!config),\n      shareReplay(1),\n    );\n  }\n\n  private readonly mapToAuiNavItem = (\n    item: NavItemConfig,\n    parents: NavItemConfig[],\n  ): NavItemConfig => ({\n    ...item,\n    children: null,\n    key: item.key ?? [...parents.map(({ name }) => name), item.name].join('/'),\n    label: item.label || this.translate.get(item.name),\n  });\n\n  private toastParseError() {\n    this.notification.error(this.translate.get('nav_config_error'));\n  }\n\n  private localKey(path: string) {\n    const nodes = path.split('/');\n    return `${this.localStorageKey}.${nodes.at(-1)}`;\n  }\n\n  private setLocal(path: string, value: string) {\n    if (this.localStorageKey) {\n      localStorage.setItem(this.localKey(path), value);\n    }\n  }\n\n  private getLocal(path: string): string {\n    return this.localStorageKey\n      ? localStorage.getItem(this.localKey(path)) || ''\n      : '';\n  }\n}\n"]}
|