@alauda-fe/common 1.4.28-beta.0 → 1.4.28-beta.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/code/code-editor-configs.d.ts +2 -0
- package/code/managed-fields-folder.util.d.ts +35 -0
- package/code/public-api.d.ts +4 -0
- package/code/resource-yaml-display/component.d.ts +62 -6
- package/code/resource-yaml-editor/component.d.ts +93 -0
- package/code/yaml-examples.d.ts +8 -0
- package/code/yaml-sidebar/component.d.ts +57 -0
- package/code/yaml-sidebar/types.d.ts +21 -0
- package/core/directives/scroll-to-first-invalid.directive.d.ts +1 -1
- package/core/services/feature-gate.service.d.ts +1 -1
- package/core/services/kubernetes-schema.service.d.ts +43 -0
- package/core/services/public-api.d.ts +1 -0
- package/core/types/openapi.d.ts +37 -0
- package/core/types/public-api.d.ts +1 -0
- package/esm2022/code/code-editor-configs.mjs +12 -2
- package/esm2022/code/managed-fields-folder.util.mjs +136 -0
- package/esm2022/code/public-api.mjs +5 -1
- package/esm2022/code/resource-yaml-display/component.mjs +247 -43
- package/esm2022/code/resource-yaml-editor/component.mjs +379 -0
- package/esm2022/code/yaml-examples.mjs +337 -0
- package/esm2022/code/yaml-sidebar/component.mjs +482 -0
- package/esm2022/code/yaml-sidebar/types.mjs +2 -0
- package/esm2022/core/services/kubernetes-schema.service.mjs +125 -0
- package/esm2022/core/services/public-api.mjs +2 -1
- package/esm2022/core/types/openapi.mjs +2 -0
- package/esm2022/core/types/public-api.mjs +2 -1
- package/package.json +1 -1
- package/styles/global.scss +4 -0
- package/table/component.d.ts +1 -1
- package/view-chart/view-chart.component.d.ts +1 -1
|
@@ -9,4 +9,8 @@ export * from './code-display-dialog/component';
|
|
|
9
9
|
export * from './code-editor-configs';
|
|
10
10
|
export * from './k8s-yaml-display-dialog/component';
|
|
11
11
|
export * from './resource-yaml-display/component';
|
|
12
|
-
|
|
12
|
+
export * from './resource-yaml-editor/component';
|
|
13
|
+
export * from './yaml-sidebar/component';
|
|
14
|
+
export * from './yaml-sidebar/types';
|
|
15
|
+
export * from './yaml-examples';
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYnMvY29tbW9uL3NyYy9jb2RlL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7R0FJRztBQUNILGNBQWM7QUFDZCxjQUFjLGVBQWUsQ0FBQztBQUM5QixjQUFjLGlDQUFpQyxDQUFDO0FBQ2hELGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYyxxQ0FBcUMsQ0FBQztBQUNwRCxjQUFjLG1DQUFtQyxDQUFDO0FBQ2xELGNBQWMsa0NBQWtDLENBQUM7QUFDakQsY0FBYywwQkFBMEIsQ0FBQztBQUN6QyxjQUFjLHNCQUFzQixDQUFDO0FBQ3JDLGNBQWMsaUJBQWlCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIFtbaW5jbHVkZTpjb2RlL1JFQURNRS5tZF1dXG4gKiBAbW9kdWxlIGNvZGVcbiAqIEBwcmVmZXJyZWRcbiAqL1xuLyoqIGltcG9ydHMgKi9cbmV4cG9ydCAqIGZyb20gJy4vY29kZS5tb2R1bGUnO1xuZXhwb3J0ICogZnJvbSAnLi9jb2RlLWRpc3BsYXktZGlhbG9nL2NvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2NvZGUtZWRpdG9yLWNvbmZpZ3MnO1xuZXhwb3J0ICogZnJvbSAnLi9rOHMteWFtbC1kaXNwbGF5LWRpYWxvZy9jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9yZXNvdXJjZS15YW1sLWRpc3BsYXkvY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vcmVzb3VyY2UteWFtbC1lZGl0b3IvY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4veWFtbC1zaWRlYmFyL2NvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3lhbWwtc2lkZWJhci90eXBlcyc7XG5leHBvcnQgKiBmcm9tICcuL3lhbWwtZXhhbXBsZXMnO1xuIl19
|
|
@@ -1,25 +1,32 @@
|
|
|
1
1
|
import { __decorate, __metadata } from "tslib";
|
|
2
|
-
import { CodeEditorModule } from '@alauda/code-editor';
|
|
3
|
-
import { CARD_MODULE, CHECKBOX_MODULE } from '@alauda/ui';
|
|
2
|
+
import { CodeEditorModule, MonacoLanguageService, } from '@alauda/code-editor';
|
|
3
|
+
import { CARD_MODULE, CHECKBOX_MODULE, ButtonModule, IconModule, } from '@alauda/ui';
|
|
4
4
|
import { AsyncPipe, NgIf, NgTemplateOutlet } from '@angular/common';
|
|
5
|
-
import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
|
|
5
|
+
import { ChangeDetectionStrategy, Component, Input, ViewChild, } from '@angular/core';
|
|
6
6
|
import { FormsModule } from '@angular/forms';
|
|
7
|
-
import {
|
|
8
|
-
import {
|
|
7
|
+
import { yamlDefaults, setDiagnosticsOptions } from 'monaco-yaml';
|
|
8
|
+
import { BehaviorSubject, combineLatest, Observable, map, distinctUntilChanged, of, switchMap, shareReplay, takeUntil, Subject, } from 'rxjs';
|
|
9
|
+
import { KubernetesSchemaService } from '../../core/services/kubernetes-schema.service';
|
|
10
|
+
import { YamlUtilService } from '../../core/services/yaml-util.service';
|
|
11
|
+
import { ObservableInput } from '../../core/utils/decorators';
|
|
9
12
|
import { TranslateModule } from '../../translate/translate.module';
|
|
10
|
-
import { viewActions, yamlReadOptions } from '../code-editor-configs';
|
|
13
|
+
import { viewActions, yamlReadMinimapOptions, yamlReadOptions, } from '../code-editor-configs';
|
|
14
|
+
import { foldManagedFields, } from '../managed-fields-folder.util';
|
|
15
|
+
import { ResourceYamlSidebarComponent } from '../yaml-sidebar/component';
|
|
11
16
|
import * as i0 from "@angular/core";
|
|
12
|
-
import * as i1 from "../../core/
|
|
13
|
-
import * as i2 from "
|
|
14
|
-
import * as i3 from "@
|
|
15
|
-
import * as i4 from "@alauda/
|
|
16
|
-
import * as i5 from "
|
|
17
|
+
import * as i1 from "../../core/services/yaml-util.service";
|
|
18
|
+
import * as i2 from "../../core/services/kubernetes-schema.service";
|
|
19
|
+
import * as i3 from "@alauda/code-editor";
|
|
20
|
+
import * as i4 from "@alauda/ui";
|
|
21
|
+
import * as i5 from "@angular/forms";
|
|
22
|
+
import * as i6 from "../../translate/translate.pipe";
|
|
23
|
+
const _c0 = ["codeEditorRef"];
|
|
17
24
|
function ResourceYamlDisplayComponent_aui_card_0_ng_container_1_Template(rf, ctx) { if (rf & 1) {
|
|
18
25
|
i0.ɵɵelementContainer(0);
|
|
19
26
|
} }
|
|
20
27
|
function ResourceYamlDisplayComponent_aui_card_0_Template(rf, ctx) { if (rf & 1) {
|
|
21
28
|
i0.ɵɵelementStart(0, "aui-card");
|
|
22
|
-
i0.ɵɵtemplate(1, ResourceYamlDisplayComponent_aui_card_0_ng_container_1_Template, 1, 0, "ng-container",
|
|
29
|
+
i0.ɵɵtemplate(1, ResourceYamlDisplayComponent_aui_card_0_ng_container_1_Template, 1, 0, "ng-container", 3);
|
|
23
30
|
i0.ɵɵelementEnd();
|
|
24
31
|
} if (rf & 2) {
|
|
25
32
|
i0.ɵɵnextContext();
|
|
@@ -27,11 +34,11 @@ function ResourceYamlDisplayComponent_aui_card_0_Template(rf, ctx) { if (rf & 1)
|
|
|
27
34
|
i0.ɵɵadvance();
|
|
28
35
|
i0.ɵɵproperty("ngTemplateOutlet", content_r1);
|
|
29
36
|
} }
|
|
30
|
-
function
|
|
37
|
+
function ResourceYamlDisplayComponent_ng_template_1_aui_checkbox_7_Template(rf, ctx) { if (rf & 1) {
|
|
31
38
|
const _r2 = i0.ɵɵgetCurrentView();
|
|
32
|
-
i0.ɵɵelementStart(0, "aui-checkbox",
|
|
39
|
+
i0.ɵɵelementStart(0, "aui-checkbox", 12);
|
|
33
40
|
i0.ɵɵpipe(1, "async");
|
|
34
|
-
i0.ɵɵlistener("ngModelChange", function
|
|
41
|
+
i0.ɵɵlistener("ngModelChange", function ResourceYamlDisplayComponent_ng_template_1_aui_checkbox_7_Template_aui_checkbox_ngModelChange_0_listener($event) { i0.ɵɵrestoreView(_r2); const ctx_r2 = i0.ɵɵnextContext(2); return i0.ɵɵresetView(ctx_r2.conciseChange($event)); });
|
|
35
42
|
i0.ɵɵtext(2);
|
|
36
43
|
i0.ɵɵpipe(3, "translate");
|
|
37
44
|
i0.ɵɵelementEnd();
|
|
@@ -41,72 +48,249 @@ function ResourceYamlDisplayComponent_ng_template_1_aui_checkbox_3_Template(rf,
|
|
|
41
48
|
i0.ɵɵadvance(2);
|
|
42
49
|
i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(3, 4, "preview_concise_yaml"), " ");
|
|
43
50
|
} }
|
|
44
|
-
function
|
|
51
|
+
function ResourceYamlDisplayComponent_ng_template_1_button_9_Template(rf, ctx) { if (rf & 1) {
|
|
45
52
|
const _r4 = i0.ɵɵgetCurrentView();
|
|
46
|
-
i0.ɵɵelementStart(0, "
|
|
53
|
+
i0.ɵɵelementStart(0, "button", 13);
|
|
47
54
|
i0.ɵɵpipe(1, "async");
|
|
48
55
|
i0.ɵɵpipe(2, "async");
|
|
49
|
-
i0.ɵɵ
|
|
50
|
-
i0.ɵɵtext(3);
|
|
56
|
+
i0.ɵɵpipe(3, "async");
|
|
51
57
|
i0.ɵɵpipe(4, "translate");
|
|
58
|
+
i0.ɵɵlistener("click", function ResourceYamlDisplayComponent_ng_template_1_button_9_Template_button_click_0_listener() { i0.ɵɵrestoreView(_r4); const ctx_r2 = i0.ɵɵnextContext(2); return i0.ɵɵresetView(ctx_r2.toggleSidebar()); });
|
|
59
|
+
i0.ɵɵelement(5, "aui-icon", 14);
|
|
60
|
+
i0.ɵɵpipe(6, "async");
|
|
52
61
|
i0.ɵɵelementEnd();
|
|
53
62
|
} if (rf & 2) {
|
|
54
63
|
const ctx_r2 = i0.ɵɵnextContext(2);
|
|
55
|
-
i0.ɵɵproperty("
|
|
56
|
-
i0.ɵɵadvance(
|
|
57
|
-
i0.ɵɵ
|
|
64
|
+
i0.ɵɵproperty("type", i0.ɵɵpipeBind1(1, 4, ctx_r2.showSidebar$$) ? "primary" : "text")("disabled", !i0.ɵɵpipeBind1(2, 6, ctx_r2.finalSchema$))("title", i0.ɵɵpipeBind1(3, 8, ctx_r2.finalSchema$) ? "" : i0.ɵɵpipeBind1(4, 10, "schema_not_available"));
|
|
65
|
+
i0.ɵɵadvance(5);
|
|
66
|
+
i0.ɵɵproperty("icon", i0.ɵɵpipeBind1(6, 12, ctx_r2.showSidebar$$) ? "prod:expand_sidebar" : "prod:collapse_sidebar");
|
|
67
|
+
} }
|
|
68
|
+
function ResourceYamlDisplayComponent_ng_template_1_div_10_Template(rf, ctx) { if (rf & 1) {
|
|
69
|
+
const _r5 = i0.ɵɵgetCurrentView();
|
|
70
|
+
i0.ɵɵelementStart(0, "div", 15)(1, "acl-resource-yaml-sidebar", 16);
|
|
71
|
+
i0.ɵɵpipe(2, "async");
|
|
72
|
+
i0.ɵɵlistener("close", function ResourceYamlDisplayComponent_ng_template_1_div_10_Template_acl_resource_yaml_sidebar_close_1_listener() { i0.ɵɵrestoreView(_r5); const ctx_r2 = i0.ɵɵnextContext(2); return i0.ɵɵresetView(ctx_r2.toggleSidebar()); });
|
|
73
|
+
i0.ɵɵelementEnd()();
|
|
74
|
+
} if (rf & 2) {
|
|
75
|
+
const ctx_r2 = i0.ɵɵnextContext(2);
|
|
76
|
+
i0.ɵɵadvance();
|
|
77
|
+
i0.ɵɵproperty("resource", ctx_r2.getCurrentResource())("schema", i0.ɵɵpipeBind1(2, 4, ctx_r2.finalSchema$))("schemaEnable", ctx_r2.schemaEnable)("exampleEnable", false);
|
|
58
78
|
} }
|
|
59
79
|
function ResourceYamlDisplayComponent_ng_template_1_Template(rf, ctx) { if (rf & 1) {
|
|
60
|
-
i0.ɵɵelementStart(0, "
|
|
80
|
+
i0.ɵɵelementStart(0, "div", 4);
|
|
61
81
|
i0.ɵɵpipe(1, "async");
|
|
62
|
-
i0.ɵɵ
|
|
63
|
-
i0.ɵɵ
|
|
82
|
+
i0.ɵɵelementStart(2, "div", 5)(3, "aui-code-editor", 6, 1);
|
|
83
|
+
i0.ɵɵpipe(5, "async");
|
|
84
|
+
i0.ɵɵelementContainerStart(6, 7);
|
|
85
|
+
i0.ɵɵtemplate(7, ResourceYamlDisplayComponent_ng_template_1_aui_checkbox_7_Template, 4, 6, "aui-checkbox", 8);
|
|
86
|
+
i0.ɵɵelementContainerEnd();
|
|
87
|
+
i0.ɵɵelementContainerStart(8, 9);
|
|
88
|
+
i0.ɵɵtemplate(9, ResourceYamlDisplayComponent_ng_template_1_button_9_Template, 7, 14, "button", 10);
|
|
64
89
|
i0.ɵɵelementContainerEnd();
|
|
90
|
+
i0.ɵɵelementEnd()();
|
|
91
|
+
i0.ɵɵtemplate(10, ResourceYamlDisplayComponent_ng_template_1_div_10_Template, 3, 6, "div", 11);
|
|
92
|
+
i0.ɵɵpipe(11, "async");
|
|
65
93
|
i0.ɵɵelementEnd();
|
|
66
94
|
} if (rf & 2) {
|
|
67
95
|
const ctx_r2 = i0.ɵɵnextContext();
|
|
68
|
-
i0.ɵɵ
|
|
96
|
+
i0.ɵɵclassProp("with-sidebar", i0.ɵɵpipeBind1(1, 9, ctx_r2.showSidebar$$));
|
|
69
97
|
i0.ɵɵadvance(3);
|
|
98
|
+
i0.ɵɵproperty("ngModel", i0.ɵɵpipeBind1(5, 11, ctx_r2.yaml$))("options", ctx_r2.editorOptions)("actionsConfig", ctx_r2.viewActions)("modelUri", ctx_r2.modelUri);
|
|
99
|
+
i0.ɵɵadvance(4);
|
|
70
100
|
i0.ɵɵproperty("ngIf", ctx_r2.conciseEnable);
|
|
101
|
+
i0.ɵɵadvance(2);
|
|
102
|
+
i0.ɵɵproperty("ngIf", ctx_r2.sidebarEnable);
|
|
71
103
|
i0.ɵɵadvance();
|
|
72
|
-
i0.ɵɵproperty("ngIf", ctx_r2.
|
|
104
|
+
i0.ɵɵproperty("ngIf", i0.ɵɵpipeBind1(11, 13, ctx_r2.showSidebar$$));
|
|
73
105
|
} }
|
|
74
106
|
export class ResourceYamlDisplayComponent {
|
|
75
|
-
constructor(yamlUtil) {
|
|
107
|
+
constructor(yamlUtil, schemaService, monacoLanguageService) {
|
|
76
108
|
this.yamlUtil = yamlUtil;
|
|
109
|
+
this.schemaService = schemaService;
|
|
110
|
+
this.monacoLanguageService = monacoLanguageService;
|
|
111
|
+
this.destroy$ = new Subject();
|
|
77
112
|
this.concise$$ = new BehaviorSubject(false);
|
|
78
|
-
this.reduce$$ = new BehaviorSubject(
|
|
113
|
+
this.reduce$$ = new BehaviorSubject(false);
|
|
114
|
+
this.showSidebar$$ = new BehaviorSubject(false);
|
|
115
|
+
this.showDebugPanel$$ = new BehaviorSubject(false);
|
|
116
|
+
this.monacoEditor = null;
|
|
117
|
+
this.registeredSchemas = new Set();
|
|
79
118
|
this.hasWrapper = true;
|
|
119
|
+
this.showDebugInfo = false;
|
|
80
120
|
this.conciseEnable = true;
|
|
81
121
|
this.manageFieldActionEnable = true;
|
|
122
|
+
this.sidebarEnable = true;
|
|
123
|
+
this.schemaEnable = true;
|
|
124
|
+
this.exampleEnable = true;
|
|
125
|
+
this.autoFoldManagedFields = true;
|
|
126
|
+
this.minimap = true;
|
|
127
|
+
this.yamlReadMinimapOptions = yamlReadMinimapOptions;
|
|
128
|
+
this.yamlReadOptions = yamlReadOptions;
|
|
129
|
+
/**
|
|
130
|
+
* 自动获取的 schema,当没有手动提供 schema 时使用
|
|
131
|
+
*/
|
|
132
|
+
this.autoSchema$ = this.resource$.pipe(switchMap(resource => {
|
|
133
|
+
if (!resource) {
|
|
134
|
+
return of(null);
|
|
135
|
+
}
|
|
136
|
+
const firstResource = (Array.isArray(resource) ? resource[0] : resource);
|
|
137
|
+
if (!firstResource?.apiVersion || !firstResource?.kind) {
|
|
138
|
+
return of(null);
|
|
139
|
+
}
|
|
140
|
+
return this.schemaService.getResourceSchema(firstResource.apiVersion, firstResource.kind);
|
|
141
|
+
}), shareReplay(1));
|
|
142
|
+
/**
|
|
143
|
+
* 最终使用的 schema,优先使用手动提供的,否则使用自动获取的
|
|
144
|
+
*/
|
|
145
|
+
this.finalSchema$ = combineLatest([this.schema$, this.autoSchema$]).pipe(map(([manualSchema, autoSchema]) => manualSchema || autoSchema), distinctUntilChanged(), shareReplay(1));
|
|
82
146
|
this.yaml$ = combineLatest([
|
|
83
147
|
this.resource$,
|
|
84
148
|
this.concise$$,
|
|
85
149
|
this.reduce$$.pipe(distinctUntilChanged()),
|
|
86
150
|
]).pipe(map(([resource, concise, reduce]) => this.yamlUtil.generateFilteredYamlResource(resource, concise, reduce)));
|
|
87
|
-
this.editorOptions = yamlReadOptions;
|
|
88
151
|
this.viewActions = viewActions;
|
|
152
|
+
this.yamlSchemaService =
|
|
153
|
+
this.monacoLanguageService.getLanguageSchemaService(['yaml', 'yamlDefaults'], yamlDefaults);
|
|
154
|
+
// 启用 YAML 语法提示功能
|
|
155
|
+
setDiagnosticsOptions({
|
|
156
|
+
validate: true,
|
|
157
|
+
format: true,
|
|
158
|
+
completion: true,
|
|
159
|
+
hover: true,
|
|
160
|
+
});
|
|
161
|
+
// 自动设置 schema
|
|
162
|
+
combineLatest([this.resource$, this.finalSchema$])
|
|
163
|
+
.pipe(takeUntil(this.destroy$))
|
|
164
|
+
.subscribe(([resource, schema]) => {
|
|
165
|
+
if (resource && schema) {
|
|
166
|
+
const firstResource = Array.isArray(resource)
|
|
167
|
+
? resource[0]
|
|
168
|
+
: resource;
|
|
169
|
+
if (firstResource && !Array.isArray(firstResource)) {
|
|
170
|
+
this.setYamlSchema(firstResource, schema);
|
|
171
|
+
}
|
|
172
|
+
}
|
|
173
|
+
});
|
|
174
|
+
this.finalSchema$.pipe(takeUntil(this.destroy$)).subscribe();
|
|
175
|
+
}
|
|
176
|
+
get editorOptions() {
|
|
177
|
+
return this.minimap ? yamlReadMinimapOptions : yamlReadOptions;
|
|
89
178
|
}
|
|
90
179
|
conciseChange(value) {
|
|
91
180
|
this.concise$$.next(value);
|
|
92
|
-
|
|
93
|
-
|
|
181
|
+
}
|
|
182
|
+
toggleSidebar() {
|
|
183
|
+
this.showSidebar$$.next(!this.showSidebar$$.value);
|
|
184
|
+
}
|
|
185
|
+
toggleDebugInfo() {
|
|
186
|
+
this.showDebugPanel$$.next(!this.showDebugPanel$$.value);
|
|
187
|
+
}
|
|
188
|
+
getCurrentResource() {
|
|
189
|
+
const resource = this.resource;
|
|
190
|
+
if (Array.isArray(resource)) {
|
|
191
|
+
return resource.length > 0 ? resource[0] : null;
|
|
192
|
+
}
|
|
193
|
+
return resource || null;
|
|
194
|
+
}
|
|
195
|
+
getCurrentSchema() {
|
|
196
|
+
return this.schema || null;
|
|
197
|
+
}
|
|
198
|
+
/**
|
|
199
|
+
* 设置 YAML schema 以提供 hover 提示和自动完成
|
|
200
|
+
*/
|
|
201
|
+
setYamlSchema(resource, schema) {
|
|
202
|
+
if (!schema) {
|
|
203
|
+
return;
|
|
204
|
+
}
|
|
205
|
+
// 使用 apiVersion + kind 组合作为标识
|
|
206
|
+
const apiVersion = resource?.apiVersion || 'unknown';
|
|
207
|
+
const kind = resource?.kind || 'unknown';
|
|
208
|
+
const schemaKey = `${apiVersion}/${kind}`;
|
|
209
|
+
this.modelUri = `${schemaKey}.yaml`;
|
|
210
|
+
// 检查是否已经注册过相同的 schema,避免重复注册
|
|
211
|
+
if (this.registeredSchemas.has(schemaKey)) {
|
|
212
|
+
return;
|
|
213
|
+
}
|
|
214
|
+
// 获取完整的 definitions 以支持 $ref 引用
|
|
215
|
+
const definitions = this.schemaService.definitions || {};
|
|
216
|
+
// 创建包含完整 definitions 的 schema 对象
|
|
217
|
+
const fullSchema = {
|
|
218
|
+
...schema,
|
|
219
|
+
definitions,
|
|
220
|
+
};
|
|
221
|
+
// 确保schema被正确注册,并启用自动完成功能
|
|
222
|
+
this.yamlSchemaService.addSchema({
|
|
223
|
+
uri: `k8s://${schemaKey}.schema.json`,
|
|
224
|
+
fileMatch: [this.modelUri],
|
|
225
|
+
schema: fullSchema,
|
|
226
|
+
});
|
|
227
|
+
this.registeredSchemas.add(schemaKey);
|
|
228
|
+
}
|
|
229
|
+
ngAfterViewInit() {
|
|
230
|
+
// 监听 YAML 内容变化,自动折叠 managedFields
|
|
231
|
+
if (this.autoFoldManagedFields) {
|
|
232
|
+
// 使用更短的延迟时间,减少视觉闪烁
|
|
233
|
+
setTimeout(() => {
|
|
234
|
+
const editor = this.getEditorInstance();
|
|
235
|
+
if (editor) {
|
|
236
|
+
foldManagedFields(editor);
|
|
237
|
+
}
|
|
238
|
+
}, 0);
|
|
239
|
+
}
|
|
240
|
+
}
|
|
241
|
+
/**
|
|
242
|
+
* 获取 Monaco Editor 实例
|
|
243
|
+
*/
|
|
244
|
+
getEditorInstance() {
|
|
245
|
+
if (this.codeEditorRef && !this.monacoEditor) {
|
|
246
|
+
// 尝试从 ViewChild 获取编辑器实例
|
|
247
|
+
const editorComponent = this.codeEditorRef;
|
|
248
|
+
if (editorComponent.editor) {
|
|
249
|
+
this.monacoEditor = editorComponent.editor;
|
|
250
|
+
}
|
|
251
|
+
}
|
|
252
|
+
return this.monacoEditor;
|
|
253
|
+
}
|
|
254
|
+
/**
|
|
255
|
+
* 自动折叠 managedFields 字段
|
|
256
|
+
*/
|
|
257
|
+
foldManagedFields() {
|
|
258
|
+
const editor = this.getEditorInstance();
|
|
259
|
+
if (editor) {
|
|
260
|
+
foldManagedFields(editor);
|
|
94
261
|
}
|
|
95
262
|
}
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
263
|
+
ngOnDestroy() {
|
|
264
|
+
this.destroy$.next();
|
|
265
|
+
this.destroy$.complete();
|
|
266
|
+
this.monacoEditor = null;
|
|
267
|
+
}
|
|
268
|
+
static { this.ɵfac = function ResourceYamlDisplayComponent_Factory(t) { return new (t || ResourceYamlDisplayComponent)(i0.ɵɵdirectiveInject(i1.YamlUtilService), i0.ɵɵdirectiveInject(i2.KubernetesSchemaService), i0.ɵɵdirectiveInject(i3.MonacoLanguageService)); }; }
|
|
269
|
+
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: ResourceYamlDisplayComponent, selectors: [["acl-resource-yaml-display"]], viewQuery: function ResourceYamlDisplayComponent_Query(rf, ctx) { if (rf & 1) {
|
|
270
|
+
i0.ɵɵviewQuery(_c0, 5);
|
|
271
|
+
} if (rf & 2) {
|
|
272
|
+
let _t;
|
|
273
|
+
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.codeEditorRef = _t.first);
|
|
274
|
+
} }, inputs: { hasWrapper: "hasWrapper", showDebugInfo: "showDebugInfo", conciseEnable: "conciseEnable", manageFieldActionEnable: "manageFieldActionEnable", sidebarEnable: "sidebarEnable", schemaEnable: "schemaEnable", exampleEnable: "exampleEnable", autoFoldManagedFields: "autoFoldManagedFields", schema: "schema", resource: "resource", minimap: "minimap" }, standalone: true, features: [i0.ɵɵStandaloneFeature], decls: 3, vars: 2, consts: [["content", ""], ["codeEditorRef", ""], [4, "ngIf", "ngIfElse"], [4, "ngTemplateOutlet"], [1, "yaml-display-container"], [1, "yaml-editor-section"], ["name", "yaml", 3, "ngModel", "options", "actionsConfig", "modelUri"], ["auiCodeEditorToolbarLeft", ""], ["class", "aui-code-editor-toolbar__control-button", 3, "ngModel", "ngModelChange", 4, "ngIf"], ["auiCodeEditorToolbarRightSide", ""], ["auiButton", "", "class", "aui-code-editor-toolbar__control-button", "size", "small", 3, "type", "disabled", "title", "click", 4, "ngIf"], ["class", "yaml-sidebar-section", 4, "ngIf"], [1, "aui-code-editor-toolbar__control-button", 3, "ngModelChange", "ngModel"], ["auiButton", "", "size", "small", 1, "aui-code-editor-toolbar__control-button", 3, "click", "type", "disabled", "title"], [3, "icon"], [1, "yaml-sidebar-section"], [3, "close", "resource", "schema", "schemaEnable", "exampleEnable"]], template: function ResourceYamlDisplayComponent_Template(rf, ctx) { if (rf & 1) {
|
|
275
|
+
i0.ɵɵtemplate(0, ResourceYamlDisplayComponent_aui_card_0_Template, 2, 1, "aui-card", 2)(1, ResourceYamlDisplayComponent_ng_template_1_Template, 12, 15, "ng-template", null, 0, i0.ɵɵtemplateRefExtractor);
|
|
99
276
|
} if (rf & 2) {
|
|
100
277
|
const content_r1 = i0.ɵɵreference(2);
|
|
101
278
|
i0.ɵɵproperty("ngIf", ctx.hasWrapper)("ngIfElse", content_r1);
|
|
102
|
-
} }, dependencies: [
|
|
103
|
-
FormsModule,
|
|
104
|
-
|
|
279
|
+
} }, dependencies: [i4.CardComponent, NgIf,
|
|
280
|
+
FormsModule, i5.NgControlStatus, i5.NgModel, i4.CheckboxComponent, ButtonModule,
|
|
281
|
+
CodeEditorModule, i3.CodeEditorComponent, TranslateModule, i6.TranslatePipe, AsyncPipe,
|
|
282
|
+
NgTemplateOutlet,
|
|
283
|
+
ResourceYamlSidebarComponent,
|
|
284
|
+
IconModule, i4.IconComponent], styles: ["[_nghost-%COMP%]:not(.dialog-content){display:block;height:calc(100vh - (var(--acl-page-header-height) + 44px) - 147px)}[_nghost-%COMP%]:not(.dialog-content) .aui-code-editor{min-height:100%}[_nghost-%COMP%]:not(.dialog-content) > .aui-card[_ngcontent-%COMP%]{height:100%}[_nghost-%COMP%]:not(.dialog-content) > .aui-card[_ngcontent-%COMP%] .aui-card__content[_ngcontent-%COMP%], [_nghost-%COMP%]:not(.dialog-content) > .aui-card[_ngcontent-%COMP%] aui-code-editor[_ngcontent-%COMP%], [_nghost-%COMP%]:not(.dialog-content) > .aui-card[_ngcontent-%COMP%] .aui-code-editor[_ngcontent-%COMP%]{height:100%;min-height:100%}[_nghost-%COMP%]{display:block}[_nghost-%COMP%] aui-card, [_nghost-%COMP%] .aui-card, [_nghost-%COMP%] .aui-card__content{height:100%}[_nghost-%COMP%] .aui-checkbox{margin-right:0}[_nghost-%COMP%] aui-code-editor[_ngcontent-%COMP%]{height:100%}.yaml-display-container[_ngcontent-%COMP%]{display:flex;height:100%}.yaml-display-container.with-sidebar[_ngcontent-%COMP%] .yaml-editor-section[_ngcontent-%COMP%]{flex:1;min-width:0}.yaml-display-container.with-sidebar[_ngcontent-%COMP%] .yaml-sidebar-section[_ngcontent-%COMP%]{width:400px;flex-shrink:0}.yaml-display-container[_ngcontent-%COMP%]:not(.with-sidebar) .yaml-editor-section[_ngcontent-%COMP%]{flex:1}.yaml-editor-section[_ngcontent-%COMP%]{display:flex;flex-direction:column;height:100%}.yaml-editor-section[_ngcontent-%COMP%] aui-code-editor[_ngcontent-%COMP%]{flex:1;height:100%}.yaml-sidebar-section[_ngcontent-%COMP%]{display:flex;flex-direction:column;height:100%}.yaml-sidebar-section[_ngcontent-%COMP%] acl-resource-yaml-sidebar[_ngcontent-%COMP%]{flex:1;height:100%}.yaml-debug-section[_ngcontent-%COMP%]{position:absolute;top:0;right:0;width:350px;height:100%;background:var(--aui-color-bg-container);border-left:1px solid var(--aui-color-border-default);z-index:1000;overflow-y:auto}.debug-panel[_ngcontent-%COMP%]{padding:16px;font-size:12px}.debug-panel[_ngcontent-%COMP%] h4[_ngcontent-%COMP%]{margin:0 0 12px;font-size:14px;color:var(--aui-color-text-primary)}.debug-panel[_ngcontent-%COMP%] .debug-item[_ngcontent-%COMP%]{margin-bottom:16px}.debug-panel[_ngcontent-%COMP%] .debug-item[_ngcontent-%COMP%] strong[_ngcontent-%COMP%]{color:var(--aui-color-text-primary);display:block;margin-bottom:4px}.debug-panel[_ngcontent-%COMP%] .debug-item[_ngcontent-%COMP%] ul[_ngcontent-%COMP%]{margin:0;padding-left:16px}.debug-panel[_ngcontent-%COMP%] .debug-item[_ngcontent-%COMP%] ul[_ngcontent-%COMP%] li[_ngcontent-%COMP%]{margin-bottom:2px;color:var(--aui-color-text-secondary)}.debug-panel[_ngcontent-%COMP%] .debug-actions[_ngcontent-%COMP%]{border-top:1px solid var(--aui-color-border-default);padding-top:12px;text-align:right}@media (max-width: 1200px){.yaml-display-container.with-sidebar[_ngcontent-%COMP%] .yaml-sidebar-section[_ngcontent-%COMP%]{width:350px}}@media (max-width: 992px){.yaml-display-container.with-sidebar[_ngcontent-%COMP%]{flex-direction:column}.yaml-display-container.with-sidebar[_ngcontent-%COMP%] .yaml-editor-section[_ngcontent-%COMP%]{flex:1;min-height:50%}.yaml-display-container.with-sidebar[_ngcontent-%COMP%] .yaml-sidebar-section[_ngcontent-%COMP%]{width:100%;height:50%;border-top:1px solid var(--aui-color-border, #e0e0e0);border-left:none}}"], changeDetection: 0 }); }
|
|
105
285
|
}
|
|
106
286
|
__decorate([
|
|
107
287
|
ObservableInput(),
|
|
108
288
|
__metadata("design:type", Observable)
|
|
109
289
|
], ResourceYamlDisplayComponent.prototype, "resource$", void 0);
|
|
290
|
+
__decorate([
|
|
291
|
+
ObservableInput(),
|
|
292
|
+
__metadata("design:type", Observable)
|
|
293
|
+
], ResourceYamlDisplayComponent.prototype, "schema$", void 0);
|
|
110
294
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ResourceYamlDisplayComponent, [{
|
|
111
295
|
type: Component,
|
|
112
296
|
args: [{ selector: 'acl-resource-yaml-display', preserveWhitespaces: false, standalone: true, imports: [
|
|
@@ -114,19 +298,39 @@ __decorate([
|
|
|
114
298
|
NgIf,
|
|
115
299
|
FormsModule,
|
|
116
300
|
CHECKBOX_MODULE,
|
|
301
|
+
ButtonModule,
|
|
117
302
|
CodeEditorModule,
|
|
118
303
|
TranslateModule,
|
|
119
304
|
AsyncPipe,
|
|
120
305
|
NgTemplateOutlet,
|
|
121
|
-
|
|
122
|
-
|
|
306
|
+
ResourceYamlSidebarComponent,
|
|
307
|
+
IconModule,
|
|
308
|
+
], changeDetection: ChangeDetectionStrategy.OnPush, template: "<aui-card *ngIf=\"hasWrapper; else content\">\n <ng-container *ngTemplateOutlet=\"content\" />\n</aui-card>\n<ng-template #content>\n <div\n class=\"yaml-display-container\"\n [class.with-sidebar]=\"showSidebar$$ | async\"\n >\n <div class=\"yaml-editor-section\">\n <aui-code-editor\n #codeEditorRef\n name=\"yaml\"\n [ngModel]=\"yaml$ | async\"\n [options]=\"editorOptions\"\n [actionsConfig]=\"viewActions\"\n [modelUri]=\"modelUri\"\n >\n <ng-container auiCodeEditorToolbarLeft>\n <aui-checkbox\n *ngIf=\"conciseEnable\"\n class=\"aui-code-editor-toolbar__control-button\"\n [ngModel]=\"concise$$ | async\"\n (ngModelChange)=\"conciseChange($event)\"\n >\n {{ 'preview_concise_yaml' | translate }}\n </aui-checkbox>\n </ng-container>\n <ng-container auiCodeEditorToolbarRightSide>\n <!-- Schema \u6309\u94AE\uFF1A\u5F53\u542F\u7528\u4FA7\u8FB9\u680F\u65F6\u663E\u793A -->\n <button\n auiButton\n *ngIf=\"sidebarEnable\"\n class=\"aui-code-editor-toolbar__control-button\"\n [type]=\"(showSidebar$$ | async) ? 'primary' : 'text'\"\n [disabled]=\"!(finalSchema$ | async)\"\n size=\"small\"\n (click)=\"toggleSidebar()\"\n [title]=\"\n (finalSchema$ | async) ? '' : ('schema_not_available' | translate)\n \"\n >\n <aui-icon\n [icon]=\"\n (showSidebar$$ | async)\n ? 'prod:expand_sidebar'\n : 'prod:collapse_sidebar'\n \"\n ></aui-icon>\n </button>\n </ng-container>\n </aui-code-editor>\n </div>\n\n <div\n class=\"yaml-sidebar-section\"\n *ngIf=\"showSidebar$$ | async\"\n >\n <acl-resource-yaml-sidebar\n [resource]=\"getCurrentResource()\"\n [schema]=\"finalSchema$ | async\"\n (close)=\"toggleSidebar()\"\n [schemaEnable]=\"schemaEnable\"\n [exampleEnable]=\"false\"\n ></acl-resource-yaml-sidebar>\n </div>\n </div>\n</ng-template>\n", styles: [":host(:not(.dialog-content)){display:block;height:calc(100vh - (var(--acl-page-header-height) + 44px) - 147px)}:host(:not(.dialog-content)) ::ng-deep .aui-code-editor{min-height:100%}:host(:not(.dialog-content))>.aui-card{height:100%}:host(:not(.dialog-content))>.aui-card .aui-card__content,:host(:not(.dialog-content))>.aui-card aui-code-editor,:host(:not(.dialog-content))>.aui-card .aui-code-editor{height:100%;min-height:100%}:host{display:block}:host ::ng-deep aui-card,:host ::ng-deep .aui-card,:host ::ng-deep .aui-card__content{height:100%}:host ::ng-deep .aui-checkbox{margin-right:0}:host aui-code-editor{height:100%}.yaml-display-container{display:flex;height:100%}.yaml-display-container.with-sidebar .yaml-editor-section{flex:1;min-width:0}.yaml-display-container.with-sidebar .yaml-sidebar-section{width:400px;flex-shrink:0}.yaml-display-container:not(.with-sidebar) .yaml-editor-section{flex:1}.yaml-editor-section{display:flex;flex-direction:column;height:100%}.yaml-editor-section aui-code-editor{flex:1;height:100%}.yaml-sidebar-section{display:flex;flex-direction:column;height:100%}.yaml-sidebar-section acl-resource-yaml-sidebar{flex:1;height:100%}.yaml-debug-section{position:absolute;top:0;right:0;width:350px;height:100%;background:var(--aui-color-bg-container);border-left:1px solid var(--aui-color-border-default);z-index:1000;overflow-y:auto}.debug-panel{padding:16px;font-size:12px}.debug-panel h4{margin:0 0 12px;font-size:14px;color:var(--aui-color-text-primary)}.debug-panel .debug-item{margin-bottom:16px}.debug-panel .debug-item strong{color:var(--aui-color-text-primary);display:block;margin-bottom:4px}.debug-panel .debug-item ul{margin:0;padding-left:16px}.debug-panel .debug-item ul li{margin-bottom:2px;color:var(--aui-color-text-secondary)}.debug-panel .debug-actions{border-top:1px solid var(--aui-color-border-default);padding-top:12px;text-align:right}@media (max-width: 1200px){.yaml-display-container.with-sidebar .yaml-sidebar-section{width:350px}}@media (max-width: 992px){.yaml-display-container.with-sidebar{flex-direction:column}.yaml-display-container.with-sidebar .yaml-editor-section{flex:1;min-height:50%}.yaml-display-container.with-sidebar .yaml-sidebar-section{width:100%;height:50%;border-top:1px solid var(--aui-color-border, #e0e0e0);border-left:none}}\n"] }]
|
|
309
|
+
}], () => [{ type: i1.YamlUtilService }, { type: i2.KubernetesSchemaService }, { type: i3.MonacoLanguageService }], { codeEditorRef: [{
|
|
310
|
+
type: ViewChild,
|
|
311
|
+
args: ['codeEditorRef']
|
|
312
|
+
}], hasWrapper: [{
|
|
313
|
+
type: Input
|
|
314
|
+
}], showDebugInfo: [{
|
|
123
315
|
type: Input
|
|
124
316
|
}], conciseEnable: [{
|
|
125
317
|
type: Input
|
|
126
318
|
}], manageFieldActionEnable: [{
|
|
127
319
|
type: Input
|
|
320
|
+
}], sidebarEnable: [{
|
|
321
|
+
type: Input
|
|
322
|
+
}], schemaEnable: [{
|
|
323
|
+
type: Input
|
|
324
|
+
}], exampleEnable: [{
|
|
325
|
+
type: Input
|
|
326
|
+
}], autoFoldManagedFields: [{
|
|
327
|
+
type: Input
|
|
328
|
+
}], schema: [{
|
|
329
|
+
type: Input
|
|
128
330
|
}], resource: [{
|
|
129
331
|
type: Input
|
|
130
|
-
}], resource$: []
|
|
131
|
-
|
|
132
|
-
|
|
332
|
+
}], resource$: [], schema$: [], minimap: [{
|
|
333
|
+
type: Input
|
|
334
|
+
}] }); })();
|
|
335
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(ResourceYamlDisplayComponent, { className: "ResourceYamlDisplayComponent", filePath: "code/resource-yaml-display/component.ts", lineNumber: 76 }); })();
|
|
336
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"component.js","sourceRoot":"","sources":["../../../../../../libs/common/src/code/resource-yaml-display/component.ts","../../../../../../libs/common/src/code/resource-yaml-display/template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  CodeEditorModule,\n  LanguageSchemaService,\n  MonacoLanguageService,\n} from '@alauda/code-editor';\nimport {\n  CARD_MODULE,\n  CHECKBOX_MODULE,\n  ButtonModule,\n  IconModule,\n} from '@alauda/ui';\nimport { AsyncPipe, NgIf, NgTemplateOutlet } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  Input,\n  OnDestroy,\n  AfterViewInit,\n  ViewChild,\n} from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { editor } from 'monaco-editor/esm/vs/editor/editor.api';\nimport { yamlDefaults, setDiagnosticsOptions } from 'monaco-yaml';\nimport {\n  BehaviorSubject,\n  combineLatest,\n  Observable,\n  map,\n  distinctUntilChanged,\n  of,\n  switchMap,\n  shareReplay,\n  takeUntil,\n  Subject,\n} from 'rxjs';\n\nimport { KubernetesSchemaService } from '../../core/services/kubernetes-schema.service';\nimport { YamlUtilService } from '../../core/services/yaml-util.service';\nimport { Arrayable } from '../../core/types/helpers';\nimport { KubernetesResource } from '../../core/types/k8s/core';\nimport { OpenAPIV3SchemaObject } from '../../core/types/schema';\nimport { ObservableInput } from '../../core/utils/decorators';\nimport { TranslateModule } from '../../translate/translate.module';\nimport {\n  viewActions,\n  yamlReadMinimapOptions,\n  yamlReadOptions,\n} from '../code-editor-configs';\nimport {\n  foldManagedFields,\n  EditorInstanceProvider,\n} from '../managed-fields-folder.util';\nimport { ResourceYamlSidebarComponent } from '../yaml-sidebar/component';\n\n@Component({\n  selector: 'acl-resource-yaml-display',\n  templateUrl: 'template.html',\n  styleUrls: ['styles.scss'],\n  preserveWhitespaces: false,\n  standalone: true,\n  imports: [\n    CARD_MODULE,\n    NgIf,\n    FormsModule,\n    CHECKBOX_MODULE,\n    ButtonModule,\n    CodeEditorModule,\n    TranslateModule,\n    AsyncPipe,\n    NgTemplateOutlet,\n    ResourceYamlSidebarComponent,\n    IconModule,\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ResourceYamlDisplayComponent<T extends KubernetesResource>\n  implements OnDestroy, AfterViewInit, EditorInstanceProvider\n{\n  private destroy$ = new Subject<void>();\n  concise$$ = new BehaviorSubject(false);\n\n  reduce$$ = new BehaviorSubject(false);\n\n  showSidebar$$ = new BehaviorSubject(false);\n\n  showDebugPanel$$ = new BehaviorSubject(false);\n\n  modelUri: string;\n  private yamlSchemaService: LanguageSchemaService;\n  private monacoEditor: editor.IStandaloneCodeEditor | null = null;\n  private registeredSchemas = new Set<string>();\n\n  @ViewChild('codeEditorRef')\n  codeEditorRef!: { editor: editor.IStandaloneCodeEditor };\n\n  @Input()\n  hasWrapper = true;\n\n  @Input()\n  showDebugInfo = false;\n\n  @Input()\n  conciseEnable = true;\n\n  @Input()\n  manageFieldActionEnable = true;\n\n  @Input()\n  sidebarEnable = true;\n\n  @Input()\n  schemaEnable = true;\n\n  @Input()\n  exampleEnable = true;\n\n  @Input()\n  autoFoldManagedFields = true;\n\n  @Input()\n  schema: OpenAPIV3SchemaObject;\n\n  @Input()\n  resource: Arrayable<T>;\n\n  @ObservableInput()\n  readonly resource$!: Observable<Arrayable<T>>;\n\n  @ObservableInput()\n  readonly schema$!: Observable<OpenAPIV3SchemaObject>;\n\n  @Input()\n  minimap = true;\n\n  yamlReadMinimapOptions = yamlReadMinimapOptions;\n  yamlReadOptions = yamlReadOptions;\n\n  /**\n   * 自动获取的 schema，当没有手动提供 schema 时使用\n   */\n  autoSchema$ = this.resource$.pipe(\n    switchMap(resource => {\n      if (!resource) {\n        return of(null);\n      }\n\n      const firstResource = (\n        Array.isArray(resource) ? resource[0] : resource\n      ) as T;\n      if (!firstResource?.apiVersion || !firstResource?.kind) {\n        return of(null);\n      }\n\n      return this.schemaService.getResourceSchema(\n        firstResource.apiVersion,\n        firstResource.kind,\n      );\n    }),\n    shareReplay(1),\n  );\n\n  /**\n   * 最终使用的 schema，优先使用手动提供的，否则使用自动获取的\n   */\n  finalSchema$ = combineLatest([this.schema$, this.autoSchema$]).pipe(\n    map(([manualSchema, autoSchema]) => manualSchema || autoSchema),\n    distinctUntilChanged(),\n    shareReplay(1),\n  );\n\n  constructor(\n    public readonly yamlUtil: YamlUtilService,\n    public readonly schemaService: KubernetesSchemaService,\n    private readonly monacoLanguageService: MonacoLanguageService,\n  ) {\n    this.yamlSchemaService =\n      this.monacoLanguageService.getLanguageSchemaService(\n        ['yaml', 'yamlDefaults'],\n        yamlDefaults,\n      );\n\n    // 启用 YAML 语法提示功能\n    setDiagnosticsOptions({\n      validate: true,\n      format: true,\n      completion: true,\n      hover: true,\n    });\n\n    // 自动设置 schema\n    combineLatest([this.resource$, this.finalSchema$])\n      .pipe(takeUntil(this.destroy$))\n      .subscribe(([resource, schema]) => {\n        if (resource && schema) {\n          const firstResource = Array.isArray(resource)\n            ? resource[0]\n            : resource;\n          if (firstResource && !Array.isArray(firstResource)) {\n            this.setYamlSchema(firstResource as T, schema);\n          }\n        }\n      });\n\n    this.finalSchema$.pipe(takeUntil(this.destroy$)).subscribe();\n  }\n\n  yaml$ = combineLatest([\n    this.resource$,\n    this.concise$$,\n    this.reduce$$.pipe(distinctUntilChanged()),\n  ]).pipe(\n    map(([resource, concise, reduce]) =>\n      this.yamlUtil.generateFilteredYamlResource(resource, concise, reduce),\n    ),\n  );\n\n  get editorOptions() {\n    return this.minimap ? yamlReadMinimapOptions : yamlReadOptions;\n  }\n\n  viewActions = viewActions;\n\n  conciseChange(value: boolean) {\n    this.concise$$.next(value);\n  }\n\n  toggleSidebar() {\n    this.showSidebar$$.next(!this.showSidebar$$.value);\n  }\n\n  toggleDebugInfo() {\n    this.showDebugPanel$$.next(!this.showDebugPanel$$.value);\n  }\n\n  getCurrentResource(): T | null {\n    const resource = this.resource;\n    if (Array.isArray(resource)) {\n      return resource.length > 0 ? resource[0] : null;\n    }\n    return (resource as T) || null;\n  }\n\n  getCurrentSchema(): OpenAPIV3SchemaObject | null {\n    return this.schema || null;\n  }\n\n  /**\n   * 设置 YAML schema 以提供 hover 提示和自动完成\n   */\n  setYamlSchema(resource: T, schema: OpenAPIV3SchemaObject) {\n    if (!schema) {\n      return;\n    }\n\n    // 使用 apiVersion + kind 组合作为标识\n    const apiVersion = resource?.apiVersion || 'unknown';\n    const kind = resource?.kind || 'unknown';\n    const schemaKey = `${apiVersion}/${kind}`;\n\n    this.modelUri = `${schemaKey}.yaml`;\n\n    // 检查是否已经注册过相同的 schema，避免重复注册\n    if (this.registeredSchemas.has(schemaKey)) {\n      return;\n    }\n\n    // 获取完整的 definitions 以支持 $ref 引用\n    const definitions = this.schemaService.definitions || {};\n\n    // 创建包含完整 definitions 的 schema 对象\n    const fullSchema = {\n      ...schema,\n      definitions,\n    };\n\n    // 确保schema被正确注册，并启用自动完成功能\n    this.yamlSchemaService.addSchema({\n      uri: `k8s://${schemaKey}.schema.json`,\n      fileMatch: [this.modelUri],\n      schema: fullSchema,\n    });\n\n    this.registeredSchemas.add(schemaKey);\n  }\n\n  ngAfterViewInit() {\n    // 监听 YAML 内容变化，自动折叠 managedFields\n    if (this.autoFoldManagedFields) {\n      // 使用更短的延迟时间，减少视觉闪烁\n      setTimeout(() => {\n        const editor = this.getEditorInstance();\n        if (editor) {\n          foldManagedFields(editor);\n        }\n      }, 0);\n    }\n  }\n\n  /**\n   * 获取 Monaco Editor 实例\n   */\n  getEditorInstance(): editor.IStandaloneCodeEditor | null {\n    if (this.codeEditorRef && !this.monacoEditor) {\n      // 尝试从 ViewChild 获取编辑器实例\n      const editorComponent = this.codeEditorRef;\n      if (editorComponent.editor) {\n        this.monacoEditor = editorComponent.editor;\n      }\n    }\n    return this.monacoEditor;\n  }\n\n  /**\n   * 自动折叠 managedFields 字段\n   */\n  foldManagedFields(): void {\n    const editor = this.getEditorInstance();\n    if (editor) {\n      foldManagedFields(editor);\n    }\n  }\n\n  ngOnDestroy() {\n    this.destroy$.next();\n    this.destroy$.complete();\n    this.monacoEditor = null;\n  }\n}\n","<aui-card *ngIf=\"hasWrapper; else content\">\n  <ng-container *ngTemplateOutlet=\"content\" />\n</aui-card>\n<ng-template #content>\n  <div\n    class=\"yaml-display-container\"\n    [class.with-sidebar]=\"showSidebar$$ | async\"\n  >\n    <div class=\"yaml-editor-section\">\n      <aui-code-editor\n        #codeEditorRef\n        name=\"yaml\"\n        [ngModel]=\"yaml$ | async\"\n        [options]=\"editorOptions\"\n        [actionsConfig]=\"viewActions\"\n        [modelUri]=\"modelUri\"\n      >\n        <ng-container auiCodeEditorToolbarLeft>\n          <aui-checkbox\n            *ngIf=\"conciseEnable\"\n            class=\"aui-code-editor-toolbar__control-button\"\n            [ngModel]=\"concise$$ | async\"\n            (ngModelChange)=\"conciseChange($event)\"\n          >\n            {{ 'preview_concise_yaml' | translate }}\n          </aui-checkbox>\n        </ng-container>\n        <ng-container auiCodeEditorToolbarRightSide>\n          <!-- Schema 按钮：当启用侧边栏时显示 -->\n          <button\n            auiButton\n            *ngIf=\"sidebarEnable\"\n            class=\"aui-code-editor-toolbar__control-button\"\n            [type]=\"(showSidebar$$ | async) ? 'primary' : 'text'\"\n            [disabled]=\"!(finalSchema$ | async)\"\n            size=\"small\"\n            (click)=\"toggleSidebar()\"\n            [title]=\"\n              (finalSchema$ | async) ? '' : ('schema_not_available' | translate)\n            \"\n          >\n            <aui-icon\n              [icon]=\"\n                (showSidebar$$ | async)\n                  ? 'prod:expand_sidebar'\n                  : 'prod:collapse_sidebar'\n              \"\n            ></aui-icon>\n          </button>\n        </ng-container>\n      </aui-code-editor>\n    </div>\n\n    <div\n      class=\"yaml-sidebar-section\"\n      *ngIf=\"showSidebar$$ | async\"\n    >\n      <acl-resource-yaml-sidebar\n        [resource]=\"getCurrentResource()\"\n        [schema]=\"finalSchema$ | async\"\n        (close)=\"toggleSidebar()\"\n        [schemaEnable]=\"schemaEnable\"\n        [exampleEnable]=\"false\"\n      ></acl-resource-yaml-sidebar>\n    </div>\n  </div>\n</ng-template>\n"]}
|