@alauda-fe/common 1.4.27 → 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.
Files changed (30) hide show
  1. package/code/code-editor-configs.d.ts +2 -0
  2. package/code/managed-fields-folder.util.d.ts +35 -0
  3. package/code/public-api.d.ts +4 -0
  4. package/code/resource-yaml-display/component.d.ts +62 -6
  5. package/code/resource-yaml-editor/component.d.ts +93 -0
  6. package/code/yaml-examples.d.ts +8 -0
  7. package/code/yaml-sidebar/component.d.ts +57 -0
  8. package/code/yaml-sidebar/types.d.ts +21 -0
  9. package/core/directives/scroll-to-first-invalid.directive.d.ts +1 -1
  10. package/core/services/feature-gate.service.d.ts +1 -1
  11. package/core/services/kubernetes-schema.service.d.ts +43 -0
  12. package/core/services/public-api.d.ts +1 -0
  13. package/core/types/openapi.d.ts +37 -0
  14. package/core/types/public-api.d.ts +1 -0
  15. package/esm2022/code/code-editor-configs.mjs +12 -2
  16. package/esm2022/code/managed-fields-folder.util.mjs +136 -0
  17. package/esm2022/code/public-api.mjs +5 -1
  18. package/esm2022/code/resource-yaml-display/component.mjs +247 -43
  19. package/esm2022/code/resource-yaml-editor/component.mjs +379 -0
  20. package/esm2022/code/yaml-examples.mjs +337 -0
  21. package/esm2022/code/yaml-sidebar/component.mjs +482 -0
  22. package/esm2022/code/yaml-sidebar/types.mjs +2 -0
  23. package/esm2022/core/services/kubernetes-schema.service.mjs +125 -0
  24. package/esm2022/core/services/public-api.mjs +2 -1
  25. package/esm2022/core/types/openapi.mjs +2 -0
  26. package/esm2022/core/types/public-api.mjs +2 -1
  27. package/package.json +1 -1
  28. package/styles/global.scss +4 -0
  29. package/table/component.d.ts +1 -1
  30. package/view-chart/view-chart.component.d.ts +1 -1
@@ -0,0 +1,379 @@
1
+ import { __decorate, __metadata } from "tslib";
2
+ import { CodeEditorModule, MonacoLanguageService, } from '@alauda/code-editor';
3
+ import { CARD_MODULE, CHECKBOX_MODULE, ButtonModule, IconModule, } from '@alauda/ui';
4
+ import { AsyncPipe, NgIf, NgTemplateOutlet } from '@angular/common';
5
+ import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, ViewChild, forwardRef, } from '@angular/core';
6
+ import { FormsModule, NG_VALUE_ACCESSOR, } from '@angular/forms';
7
+ import { yamlDefaults } 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';
12
+ import { publishRef } from '../../core/utils/operators';
13
+ import { parseAll, stringify } from '../../core/utils/yaml';
14
+ import { TRANSLATE_MODULE } from '../../translate/translate.module';
15
+ import { updateActions, yamlWriteMinimapOptions } from '../code-editor-configs';
16
+ import { foldManagedFields, } from '../managed-fields-folder.util';
17
+ import { ResourceYamlSidebarComponent } from '../yaml-sidebar/component';
18
+ import * as i0 from "@angular/core";
19
+ import * as i1 from "../../core/services/yaml-util.service";
20
+ import * as i2 from "../../core/services/kubernetes-schema.service";
21
+ import * as i3 from "@alauda/code-editor";
22
+ import * as i4 from "@alauda/ui";
23
+ import * as i5 from "@angular/forms";
24
+ import * as i6 from "../../translate/translate.pipe";
25
+ const _c0 = ["codeEditor"];
26
+ function ResourceYamlEditorComponent_aui_card_0_ng_container_1_Template(rf, ctx) { if (rf & 1) {
27
+ i0.ɵɵelementContainer(0);
28
+ } }
29
+ function ResourceYamlEditorComponent_aui_card_0_Template(rf, ctx) { if (rf & 1) {
30
+ i0.ɵɵelementStart(0, "aui-card");
31
+ i0.ɵɵtemplate(1, ResourceYamlEditorComponent_aui_card_0_ng_container_1_Template, 1, 0, "ng-container", 3);
32
+ i0.ɵɵelementEnd();
33
+ } if (rf & 2) {
34
+ i0.ɵɵnextContext();
35
+ const content_r1 = i0.ɵɵreference(2);
36
+ i0.ɵɵadvance();
37
+ i0.ɵɵproperty("ngTemplateOutlet", content_r1);
38
+ } }
39
+ function ResourceYamlEditorComponent_ng_template_1_button_6_Template(rf, ctx) { if (rf & 1) {
40
+ const _r4 = i0.ɵɵgetCurrentView();
41
+ i0.ɵɵelementStart(0, "button", 10);
42
+ i0.ɵɵpipe(1, "async");
43
+ i0.ɵɵpipe(2, "async");
44
+ i0.ɵɵpipe(3, "async");
45
+ i0.ɵɵpipe(4, "translate");
46
+ i0.ɵɵlistener("click", function ResourceYamlEditorComponent_ng_template_1_button_6_Template_button_click_0_listener() { i0.ɵɵrestoreView(_r4); const ctx_r2 = i0.ɵɵnextContext(2); return i0.ɵɵresetView(ctx_r2.toggleSidebar()); });
47
+ i0.ɵɵelement(5, "aui-icon", 11);
48
+ i0.ɵɵpipe(6, "async");
49
+ i0.ɵɵelementEnd();
50
+ } if (rf & 2) {
51
+ const ctx_r2 = i0.ɵɵnextContext(2);
52
+ 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"));
53
+ i0.ɵɵadvance(5);
54
+ i0.ɵɵproperty("icon", i0.ɵɵpipeBind1(6, 12, ctx_r2.showSidebar$$) ? "prod:expand_sidebar" : "prod:collapse_sidebar");
55
+ } }
56
+ function ResourceYamlEditorComponent_ng_template_1_div_7_Template(rf, ctx) { if (rf & 1) {
57
+ const _r5 = i0.ɵɵgetCurrentView();
58
+ i0.ɵɵelementStart(0, "div", 12)(1, "acl-resource-yaml-sidebar", 13);
59
+ i0.ɵɵpipe(2, "async");
60
+ i0.ɵɵlistener("close", function ResourceYamlEditorComponent_ng_template_1_div_7_Template_acl_resource_yaml_sidebar_close_1_listener() { i0.ɵɵrestoreView(_r5); const ctx_r2 = i0.ɵɵnextContext(2); return i0.ɵɵresetView(ctx_r2.toggleSidebar()); })("tryYaml", function ResourceYamlEditorComponent_ng_template_1_div_7_Template_acl_resource_yaml_sidebar_tryYaml_1_listener($event) { i0.ɵɵrestoreView(_r5); const ctx_r2 = i0.ɵɵnextContext(2); return i0.ɵɵresetView(ctx_r2.onTryYaml($event)); });
61
+ i0.ɵɵelementEnd()();
62
+ } if (rf & 2) {
63
+ const ctx_r2 = i0.ɵɵnextContext(2);
64
+ i0.ɵɵadvance();
65
+ i0.ɵɵproperty("resource", ctx_r2.getCurrentResource())("schema", i0.ɵɵpipeBind1(2, 5, ctx_r2.finalSchema$))("schemaEnable", ctx_r2.schemaEnable)("exampleEnable", ctx_r2.exampleEnable)("extraExamples", ctx_r2.extraExamples);
66
+ } }
67
+ function ResourceYamlEditorComponent_ng_template_1_Template(rf, ctx) { if (rf & 1) {
68
+ const _r2 = i0.ɵɵgetCurrentView();
69
+ i0.ɵɵelementStart(0, "div", 4);
70
+ i0.ɵɵpipe(1, "async");
71
+ i0.ɵɵelementStart(2, "div", 5)(3, "aui-code-editor", 6, 1);
72
+ i0.ɵɵtwoWayListener("ngModelChange", function ResourceYamlEditorComponent_ng_template_1_Template_aui_code_editor_ngModelChange_3_listener($event) { i0.ɵɵrestoreView(_r2); const ctx_r2 = i0.ɵɵnextContext(); i0.ɵɵtwoWayBindingSet(ctx_r2.value, $event) || (ctx_r2.value = $event); return i0.ɵɵresetView($event); });
73
+ i0.ɵɵelementContainerStart(5, 7);
74
+ i0.ɵɵtemplate(6, ResourceYamlEditorComponent_ng_template_1_button_6_Template, 7, 14, "button", 8);
75
+ i0.ɵɵelementContainerEnd();
76
+ i0.ɵɵelementEnd()();
77
+ i0.ɵɵtemplate(7, ResourceYamlEditorComponent_ng_template_1_div_7_Template, 3, 7, "div", 9);
78
+ i0.ɵɵpipe(8, "async");
79
+ i0.ɵɵelementEnd();
80
+ } if (rf & 2) {
81
+ const ctx_r2 = i0.ɵɵnextContext();
82
+ i0.ɵɵclassProp("with-sidebar", i0.ɵɵpipeBind1(1, 9, ctx_r2.showSidebar$$));
83
+ i0.ɵɵadvance(3);
84
+ i0.ɵɵproperty("originalValue", ctx_r2.originalValue);
85
+ i0.ɵɵtwoWayProperty("ngModel", ctx_r2.value);
86
+ i0.ɵɵproperty("options", ctx_r2.options)("actionsConfig", ctx_r2.actionsConfig)("modelUri", ctx_r2.modelUri);
87
+ i0.ɵɵadvance(3);
88
+ i0.ɵɵproperty("ngIf", ctx_r2.sidebarEnable);
89
+ i0.ɵɵadvance();
90
+ i0.ɵɵproperty("ngIf", i0.ɵɵpipeBind1(8, 11, ctx_r2.showSidebar$$));
91
+ } }
92
+ export class ResourceYamlEditorComponent {
93
+ set originalValue(value) {
94
+ this._originalValue = value || '';
95
+ }
96
+ get originalValue() {
97
+ return this._originalValue;
98
+ }
99
+ constructor(yamlUtil, schemaService, monacoLanguageService) {
100
+ this.yamlUtil = yamlUtil;
101
+ this.schemaService = schemaService;
102
+ this.monacoLanguageService = monacoLanguageService;
103
+ this.destroy$ = new Subject();
104
+ this._value = '';
105
+ this._originalValue = '';
106
+ this.onChange = (_value) => {
107
+ // Placeholder for form control change callback
108
+ };
109
+ this.onTouched = () => {
110
+ // Placeholder for form control touched callback
111
+ };
112
+ this.showSidebar$$ = new BehaviorSubject(false);
113
+ this.showDebugPanel$$ = new BehaviorSubject(false);
114
+ this.monacoEditor = null;
115
+ this.registeredSchemas = new Set();
116
+ this.hasWrapper = true;
117
+ this.showDebugInfo = false;
118
+ this.sidebarEnable = true;
119
+ this.schemaEnable = true;
120
+ this.exampleEnable = true;
121
+ this.autoFoldManagedFields = true;
122
+ this.options = yamlWriteMinimapOptions;
123
+ this.actionsConfig = updateActions;
124
+ this.tryYaml = new EventEmitter();
125
+ this.autoFillNamespace = true;
126
+ /**
127
+ * 自动获取的 schema,当没有手动提供 schema 时使用
128
+ */
129
+ this.autoSchema$ = this.resource$.pipe(switchMap(resource => {
130
+ if (!resource) {
131
+ return of(null);
132
+ }
133
+ const firstResource = (Array.isArray(resource) ? resource[0] : resource);
134
+ if (!firstResource?.apiVersion || !firstResource?.kind) {
135
+ return of(null);
136
+ }
137
+ return this.schemaService.getResourceSchema(firstResource.apiVersion, firstResource.kind);
138
+ }), publishRef());
139
+ /**
140
+ * 最终使用的 schema,优先使用手动提供的,否则使用自动获取的
141
+ */
142
+ this.finalSchema$ = combineLatest([this.schema$, this.autoSchema$]).pipe(map(([manualSchema, autoSchema]) => manualSchema || autoSchema), distinctUntilChanged(), shareReplay(1));
143
+ this.yamlSchemaService =
144
+ this.monacoLanguageService.getLanguageSchemaService(['yaml', 'yamlDefaults'], yamlDefaults);
145
+ // 自动设置 schema
146
+ combineLatest([this.resource$, this.finalSchema$])
147
+ .pipe(takeUntil(this.destroy$))
148
+ .subscribe(([resource, schema]) => {
149
+ if (resource && schema) {
150
+ const firstResource = Array.isArray(resource)
151
+ ? resource[0]
152
+ : resource;
153
+ if (firstResource && !Array.isArray(firstResource)) {
154
+ this.setYamlSchema(firstResource, schema);
155
+ }
156
+ }
157
+ });
158
+ this.autoSchema$.pipe(takeUntil(this.destroy$)).subscribe();
159
+ }
160
+ ngAfterViewInit() {
161
+ // 监听 YAML 内容变化,自动折叠 managedFields
162
+ if (this.autoFoldManagedFields) {
163
+ // 使用更短的延迟时间,减少视觉闪烁
164
+ setTimeout(() => {
165
+ const editor = this.getEditorInstance();
166
+ if (editor) {
167
+ foldManagedFields(editor);
168
+ }
169
+ }, 0);
170
+ }
171
+ }
172
+ get value() {
173
+ return this._value;
174
+ }
175
+ set value(val) {
176
+ this._value = val;
177
+ this.onChange(val);
178
+ this.onTouched();
179
+ }
180
+ // ControlValueAccessor implementation
181
+ writeValue(value) {
182
+ this._value = value || '';
183
+ }
184
+ registerOnChange(fn) {
185
+ this.onChange = fn;
186
+ }
187
+ registerOnTouched(fn) {
188
+ this.onTouched = fn;
189
+ }
190
+ toggleSidebar() {
191
+ this.showSidebar$$.next(!this.showSidebar$$.value);
192
+ }
193
+ toggleDebugInfo() {
194
+ this.showDebugPanel$$.next(!this.showDebugPanel$$.value);
195
+ }
196
+ getCurrentResource() {
197
+ const resource = this.resource;
198
+ if (Array.isArray(resource)) {
199
+ return resource.length > 0 ? resource[0] : null;
200
+ }
201
+ return resource || null;
202
+ }
203
+ getCurrentSchema() {
204
+ return this.schema || null;
205
+ }
206
+ getDebugInfo() {
207
+ const resource = this.getCurrentResource();
208
+ return {
209
+ hasResource: !!resource,
210
+ resourceApiVersion: resource?.apiVersion,
211
+ resourceKind: resource?.kind,
212
+ hasManualSchema: !!this.schema,
213
+ workspaceHelperAvailable: this.schemaService.isWorkspaceHelperAvailable(),
214
+ currentWorkspace: this.schemaService.workspaceHelper?.baseParamsSnapshot,
215
+ };
216
+ }
217
+ onTryYaml(yamlContent) {
218
+ let targetYaml = yamlContent;
219
+ const namespace = this.schemaService.workspaceHelper?.baseParamsSnapshot?.namespace;
220
+ if (this.autoFillNamespace && namespace) {
221
+ targetYaml = parseAll(yamlContent)
222
+ .filter(r => !!r)
223
+ .map((r) => {
224
+ if (!r?.metadata?.namespace) {
225
+ return {
226
+ ...r,
227
+ metadata: {
228
+ ...r.metadata,
229
+ namespace,
230
+ },
231
+ };
232
+ }
233
+ return r;
234
+ })
235
+ .map(r => stringify(r, { sortMapEntries: true }))
236
+ .join('---\r\n');
237
+ }
238
+ this.tryYaml.emit(targetYaml);
239
+ }
240
+ /**
241
+ * 设置 YAML schema 以提供 hover 提示和自动完成
242
+ */
243
+ setYamlSchema(resource, schema) {
244
+ if (!schema) {
245
+ return;
246
+ }
247
+ // 使用 apiVersion + kind 组合作为标识
248
+ const apiVersion = resource?.apiVersion || 'unknown';
249
+ const kind = resource?.kind || 'unknown';
250
+ const schemaKey = `${apiVersion}/${kind}`;
251
+ this.modelUri = `${schemaKey}.yaml`;
252
+ // 检查是否已经注册过相同的 schema,避免重复注册
253
+ if (this.registeredSchemas.has(schemaKey)) {
254
+ return;
255
+ }
256
+ // 获取完整的 definitions 以支持 $ref 引用
257
+ const definitions = this.schemaService.definitions || {};
258
+ // 创建包含完整 definitions 的 schema 对象
259
+ const fullSchema = {
260
+ ...schema,
261
+ definitions,
262
+ };
263
+ // 确保schema被正确注册,并启用自动完成功能
264
+ this.yamlSchemaService.addSchema({
265
+ uri: `k8s://${schemaKey}.schema.json`,
266
+ fileMatch: [this.modelUri],
267
+ schema: fullSchema,
268
+ });
269
+ this.registeredSchemas.add(schemaKey);
270
+ }
271
+ /**
272
+ * 获取 Monaco 编辑器实例
273
+ */
274
+ getEditorInstance() {
275
+ if (!this.monacoEditor && this.codeEditorRef?.editor) {
276
+ this.monacoEditor = this.codeEditorRef.editor;
277
+ }
278
+ return this.monacoEditor;
279
+ }
280
+ /**
281
+ * 手动折叠 managedFields
282
+ */
283
+ foldManagedFields() {
284
+ const editor = this.getEditorInstance();
285
+ if (editor) {
286
+ foldManagedFields(editor);
287
+ }
288
+ }
289
+ ngOnDestroy() {
290
+ this.destroy$.next();
291
+ this.destroy$.complete();
292
+ }
293
+ static { this.ɵfac = function ResourceYamlEditorComponent_Factory(t) { return new (t || ResourceYamlEditorComponent)(i0.ɵɵdirectiveInject(i1.YamlUtilService), i0.ɵɵdirectiveInject(i2.KubernetesSchemaService), i0.ɵɵdirectiveInject(i3.MonacoLanguageService)); }; }
294
+ static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: ResourceYamlEditorComponent, selectors: [["acl-resource-yaml-editor"]], viewQuery: function ResourceYamlEditorComponent_Query(rf, ctx) { if (rf & 1) {
295
+ i0.ɵɵviewQuery(_c0, 5);
296
+ } if (rf & 2) {
297
+ let _t;
298
+ i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.codeEditorRef = _t.first);
299
+ } }, inputs: { hasWrapper: "hasWrapper", showDebugInfo: "showDebugInfo", sidebarEnable: "sidebarEnable", schema: "schema", schemaEnable: "schemaEnable", exampleEnable: "exampleEnable", resource: "resource", autoFoldManagedFields: "autoFoldManagedFields", originalValue: "originalValue", options: "options", actionsConfig: "actionsConfig", autoFillNamespace: "autoFillNamespace", extraExamples: "extraExamples" }, outputs: { tryYaml: "tryYaml" }, standalone: true, features: [i0.ɵɵProvidersFeature([
300
+ {
301
+ provide: NG_VALUE_ACCESSOR,
302
+ useExisting: forwardRef(() => ResourceYamlEditorComponent),
303
+ multi: true,
304
+ },
305
+ ]), i0.ɵɵStandaloneFeature], decls: 3, vars: 2, consts: [["content", ""], ["codeEditor", ""], [4, "ngIf", "ngIfElse"], [4, "ngTemplateOutlet"], [1, "yaml-editor-container"], [1, "yaml-editor-section"], ["name", "yaml", 3, "ngModelChange", "originalValue", "ngModel", "options", "actionsConfig", "modelUri"], ["auiCodeEditorToolbarRightSide", ""], ["auiButton", "", "class", "aui-code-editor-toolbar__control-button", "size", "small", 3, "type", "disabled", "title", "click", 4, "ngIf"], ["class", "yaml-sidebar-section", 4, "ngIf"], ["auiButton", "", "size", "small", 1, "aui-code-editor-toolbar__control-button", 3, "click", "type", "disabled", "title"], [3, "icon"], [1, "yaml-sidebar-section"], [3, "close", "tryYaml", "resource", "schema", "schemaEnable", "exampleEnable", "extraExamples"]], template: function ResourceYamlEditorComponent_Template(rf, ctx) { if (rf & 1) {
306
+ i0.ɵɵtemplate(0, ResourceYamlEditorComponent_aui_card_0_Template, 2, 1, "aui-card", 2)(1, ResourceYamlEditorComponent_ng_template_1_Template, 9, 13, "ng-template", null, 0, i0.ɵɵtemplateRefExtractor);
307
+ } if (rf & 2) {
308
+ const content_r1 = i0.ɵɵreference(2);
309
+ i0.ɵɵproperty("ngIf", ctx.hasWrapper)("ngIfElse", content_r1);
310
+ } }, dependencies: [i4.CardComponent, NgIf,
311
+ FormsModule, i5.NgControlStatus, i5.NgModel, ButtonModule,
312
+ CodeEditorModule, i3.CodeEditorComponent, i6.TranslatePipe, AsyncPipe,
313
+ NgTemplateOutlet,
314
+ ResourceYamlSidebarComponent,
315
+ 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-editor-container[_ngcontent-%COMP%]{display:flex;height:100%}.yaml-editor-container.with-sidebar[_ngcontent-%COMP%] .yaml-editor-section[_ngcontent-%COMP%]{flex:1;min-width:0}.yaml-editor-container.with-sidebar[_ngcontent-%COMP%] .yaml-sidebar-section[_ngcontent-%COMP%]{width:400px;flex-shrink:0}.yaml-editor-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-editor-container.with-sidebar[_ngcontent-%COMP%] .yaml-sidebar-section[_ngcontent-%COMP%]{width:350px}}@media (max-width: 992px){.yaml-editor-container.with-sidebar[_ngcontent-%COMP%]{flex-direction:column}.yaml-editor-container.with-sidebar[_ngcontent-%COMP%] .yaml-editor-section[_ngcontent-%COMP%]{flex:1;min-height:50%}.yaml-editor-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 }); }
316
+ }
317
+ __decorate([
318
+ ObservableInput(),
319
+ __metadata("design:type", Observable)
320
+ ], ResourceYamlEditorComponent.prototype, "resource$", void 0);
321
+ __decorate([
322
+ ObservableInput(),
323
+ __metadata("design:type", Observable)
324
+ ], ResourceYamlEditorComponent.prototype, "schema$", void 0);
325
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ResourceYamlEditorComponent, [{
326
+ type: Component,
327
+ args: [{ selector: 'acl-resource-yaml-editor', preserveWhitespaces: false, standalone: true, imports: [
328
+ CARD_MODULE,
329
+ NgIf,
330
+ FormsModule,
331
+ CHECKBOX_MODULE,
332
+ ButtonModule,
333
+ CodeEditorModule,
334
+ TRANSLATE_MODULE,
335
+ AsyncPipe,
336
+ NgTemplateOutlet,
337
+ ResourceYamlSidebarComponent,
338
+ IconModule,
339
+ ], providers: [
340
+ {
341
+ provide: NG_VALUE_ACCESSOR,
342
+ useExisting: forwardRef(() => ResourceYamlEditorComponent),
343
+ multi: true,
344
+ },
345
+ ], 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-editor-container\"\n [class.with-sidebar]=\"showSidebar$$ | async\"\n >\n <div class=\"yaml-editor-section\">\n <aui-code-editor\n #codeEditor\n name=\"yaml\"\n [originalValue]=\"originalValue\"\n [(ngModel)]=\"value\"\n [options]=\"options\"\n [actionsConfig]=\"actionsConfig\"\n [modelUri]=\"modelUri\"\n >\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 <div\n class=\"yaml-sidebar-section\"\n *ngIf=\"showSidebar$$ | async\"\n >\n <acl-resource-yaml-sidebar\n [resource]=\"getCurrentResource()\"\n [schema]=\"finalSchema$ | async\"\n [schemaEnable]=\"schemaEnable\"\n [exampleEnable]=\"exampleEnable\"\n [extraExamples]=\"extraExamples\"\n (close)=\"toggleSidebar()\"\n (tryYaml)=\"onTryYaml($event)\"\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-editor-container{display:flex;height:100%}.yaml-editor-container.with-sidebar .yaml-editor-section{flex:1;min-width:0}.yaml-editor-container.with-sidebar .yaml-sidebar-section{width:400px;flex-shrink:0}.yaml-editor-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-editor-container.with-sidebar .yaml-sidebar-section{width:350px}}@media (max-width: 992px){.yaml-editor-container.with-sidebar{flex-direction:column}.yaml-editor-container.with-sidebar .yaml-editor-section{flex:1;min-height:50%}.yaml-editor-container.with-sidebar .yaml-sidebar-section{width:100%;height:50%;border-top:1px solid var(--aui-color-border, #e0e0e0);border-left:none}}\n"] }]
346
+ }], () => [{ type: i1.YamlUtilService }, { type: i2.KubernetesSchemaService }, { type: i3.MonacoLanguageService }], { codeEditorRef: [{
347
+ type: ViewChild,
348
+ args: ['codeEditor', { static: false }]
349
+ }], hasWrapper: [{
350
+ type: Input
351
+ }], showDebugInfo: [{
352
+ type: Input
353
+ }], sidebarEnable: [{
354
+ type: Input
355
+ }], schema: [{
356
+ type: Input
357
+ }], schemaEnable: [{
358
+ type: Input
359
+ }], exampleEnable: [{
360
+ type: Input
361
+ }], resource: [{
362
+ type: Input
363
+ }], autoFoldManagedFields: [{
364
+ type: Input
365
+ }], originalValue: [{
366
+ type: Input
367
+ }], options: [{
368
+ type: Input
369
+ }], actionsConfig: [{
370
+ type: Input
371
+ }], tryYaml: [{
372
+ type: Output
373
+ }], resource$: [], schema$: [], autoFillNamespace: [{
374
+ type: Input
375
+ }], extraExamples: [{
376
+ type: Input
377
+ }] }); })();
378
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(ResourceYamlEditorComponent, { className: "ResourceYamlEditorComponent", filePath: "code/resource-yaml-editor/component.ts", lineNumber: 88 }); })();
379
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"component.js","sourceRoot":"","sources":["../../../../../../libs/common/src/code/resource-yaml-editor/component.ts","../../../../../../libs/common/src/code/resource-yaml-editor/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  EventEmitter,\n  Input,\n  Output,\n  ViewChild,\n  forwardRef,\n  OnDestroy,\n  AfterViewInit,\n} from '@angular/core';\nimport {\n  ControlValueAccessor,\n  FormsModule,\n  NG_VALUE_ACCESSOR,\n} from '@angular/forms';\nimport { yamlDefaults } 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 { publishRef } from '../../core/utils/operators';\nimport { parseAll, stringify } from '../../core/utils/yaml';\nimport { TRANSLATE_MODULE } from '../../translate/translate.module';\nimport { updateActions, yamlWriteMinimapOptions } from '../code-editor-configs';\nimport {\n  foldManagedFields,\n  EditorInstanceProvider,\n} from '../managed-fields-folder.util';\nimport { ResourceYamlSidebarComponent } from '../yaml-sidebar/component';\nimport { YamlExample } from '../yaml-sidebar/types';\n\n@Component({\n  selector: 'acl-resource-yaml-editor',\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    TRANSLATE_MODULE,\n    AsyncPipe,\n    NgTemplateOutlet,\n    ResourceYamlSidebarComponent,\n    IconModule,\n  ],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => ResourceYamlEditorComponent),\n      multi: true,\n    },\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ResourceYamlEditorComponent<T extends KubernetesResource>\n  implements\n    ControlValueAccessor,\n    OnDestroy,\n    EditorInstanceProvider,\n    AfterViewInit\n{\n  private destroy$ = new Subject<void>();\n  private _value = '';\n  private _originalValue = '';\n  private onChange = (_value: string) => {\n    // Placeholder for form control change callback\n  };\n\n  private onTouched = () => {\n    // Placeholder for form control touched callback\n  };\n\n  showSidebar$$ = new BehaviorSubject(false);\n  showDebugPanel$$ = new BehaviorSubject(false);\n\n  modelUri: string;\n  private yamlSchemaService: LanguageSchemaService;\n  private monacoEditor: any = null;\n  private registeredSchemas = new Set<string>();\n\n  @ViewChild('codeEditor', { static: false })\n  private codeEditorRef: any;\n\n  @Input()\n  hasWrapper = true;\n\n  @Input()\n  showDebugInfo = false;\n\n  @Input()\n  sidebarEnable = true;\n\n  @Input()\n  schema: OpenAPIV3SchemaObject;\n\n  @Input()\n  schemaEnable = true;\n\n  @Input()\n  exampleEnable = true;\n\n  @Input()\n  resource: Arrayable<T>;\n\n  @Input()\n  autoFoldManagedFields = true;\n\n  @Input()\n  set originalValue(value: string) {\n    this._originalValue = value || '';\n  }\n\n  get originalValue(): string {\n    return this._originalValue;\n  }\n\n  @Input()\n  options = yamlWriteMinimapOptions;\n\n  @Input()\n  actionsConfig = updateActions;\n\n  @Output()\n  tryYaml = new EventEmitter<string>();\n\n  @ObservableInput()\n  readonly resource$!: Observable<Arrayable<T>>;\n\n  @ObservableInput()\n  readonly schema$!: Observable<OpenAPIV3SchemaObject>;\n\n  @Input()\n  autoFillNamespace = true;\n\n  @Input()\n  extraExamples: YamlExample[];\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    publishRef(),\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    // 自动设置 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.autoSchema$.pipe(takeUntil(this.destroy$)).subscribe();\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  get value(): string {\n    return this._value;\n  }\n\n  set value(val: string) {\n    this._value = val;\n    this.onChange(val);\n    this.onTouched();\n  }\n\n  // ControlValueAccessor implementation\n  writeValue(value: string): void {\n    this._value = value || '';\n  }\n\n  registerOnChange(fn: (value: string) => void): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: () => void): void {\n    this.onTouched = fn;\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  getDebugInfo() {\n    const resource = this.getCurrentResource();\n    return {\n      hasResource: !!resource,\n      resourceApiVersion: resource?.apiVersion,\n      resourceKind: resource?.kind,\n      hasManualSchema: !!this.schema,\n      workspaceHelperAvailable: this.schemaService.isWorkspaceHelperAvailable(),\n      currentWorkspace: this.schemaService.workspaceHelper?.baseParamsSnapshot,\n    };\n  }\n\n  onTryYaml(yamlContent: string) {\n    let targetYaml = yamlContent;\n\n    const namespace =\n      this.schemaService.workspaceHelper?.baseParamsSnapshot?.namespace;\n\n    if (this.autoFillNamespace && namespace) {\n      targetYaml = parseAll(yamlContent)\n        .filter(r => !!r)\n        .map((r: KubernetesResource) => {\n          if (!r?.metadata?.namespace) {\n            return {\n              ...r,\n              metadata: {\n                ...r.metadata,\n                namespace,\n              },\n            };\n          }\n          return r;\n        })\n        .map(r => stringify(r, { sortMapEntries: true }))\n        .join('---\\r\\n');\n    }\n\n    this.tryYaml.emit(targetYaml);\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  /**\n   * 获取 Monaco 编辑器实例\n   */\n  getEditorInstance():\n    | import('monaco-editor').editor.IStandaloneCodeEditor\n    | null {\n    if (!this.monacoEditor && this.codeEditorRef?.editor) {\n      this.monacoEditor = this.codeEditorRef.editor;\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  }\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-editor-container\"\n    [class.with-sidebar]=\"showSidebar$$ | async\"\n  >\n    <div class=\"yaml-editor-section\">\n      <aui-code-editor\n        #codeEditor\n        name=\"yaml\"\n        [originalValue]=\"originalValue\"\n        [(ngModel)]=\"value\"\n        [options]=\"options\"\n        [actionsConfig]=\"actionsConfig\"\n        [modelUri]=\"modelUri\"\n      >\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    <div\n      class=\"yaml-sidebar-section\"\n      *ngIf=\"showSidebar$$ | async\"\n    >\n      <acl-resource-yaml-sidebar\n        [resource]=\"getCurrentResource()\"\n        [schema]=\"finalSchema$ | async\"\n        [schemaEnable]=\"schemaEnable\"\n        [exampleEnable]=\"exampleEnable\"\n        [extraExamples]=\"extraExamples\"\n        (close)=\"toggleSidebar()\"\n        (tryYaml)=\"onTryYaml($event)\"\n      ></acl-resource-yaml-sidebar>\n    </div>\n  </div>\n</ng-template>\n"]}