@alauda-fe/common 1.4.29-beta.2 → 1.4.30-beta.0

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 (31) hide show
  1. package/array-form-table/form/component.d.ts +1 -1
  2. package/code/managed-fields-folder.util.d.ts +2 -3
  3. package/code/resource-yaml-display/component.d.ts +3 -8
  4. package/code/resource-yaml-editor/component.d.ts +2 -3
  5. package/code/yaml-sidebar/component.d.ts +6 -15
  6. package/core/abstract/base-nested-form-control.d.ts +1 -1
  7. package/core/services/kubernetes-schema.service.d.ts +1 -0
  8. package/core/services/plugin-util.service.d.ts +1 -1
  9. package/core/services/workspace-helper.service.d.ts +1 -1
  10. package/core/services/yaml-util.service.d.ts +1 -1
  11. package/core/types/schema.d.ts +9 -0
  12. package/core/utils/version.d.ts +1 -1
  13. package/esm2022/code/managed-fields-folder.util.mjs +1 -1
  14. package/esm2022/code/resource-yaml-display/component.mjs +24 -28
  15. package/esm2022/code/resource-yaml-editor/component.mjs +12 -15
  16. package/esm2022/code/yaml-examples.mjs +14 -6
  17. package/esm2022/code/yaml-sidebar/component.mjs +92 -118
  18. package/esm2022/core/services/kubernetes-schema.service.mjs +27 -21
  19. package/esm2022/core/services/plugin-util.service.mjs +3 -3
  20. package/esm2022/core/services/workspace-helper.service.mjs +1 -1
  21. package/esm2022/core/services/yaml-util.service.mjs +3 -2
  22. package/esm2022/core/types/schema.mjs +1 -1
  23. package/esm2022/permission/k8s-permission.service.mjs +5 -2
  24. package/esm2022/permission/types.mjs +1 -1
  25. package/esm2022/translate/i18n-assets-loader.mjs +7 -2
  26. package/esm2022/translate/translate.service.mjs +93 -171
  27. package/package.json +1 -1
  28. package/permission/types.d.ts +17 -8
  29. package/table/component.d.ts +1 -1
  30. package/table/helper.d.ts +1 -1
  31. package/translate/translate.service.d.ts +10 -50
@@ -83,7 +83,7 @@ export declare class ArrayFormTableComponent implements OnDestroy {
83
83
  addDisabled: boolean | '';
84
84
  actionColumnDivider: boolean | '';
85
85
  showZeroState: boolean;
86
- get formDirective(): FormGroupDirective | NgForm;
86
+ get formDirective(): NgForm | FormGroupDirective;
87
87
  /**
88
88
  * 自定义是否展示错误内容
89
89
  * 例如 control 是 FormGroup,只有在内部子 control 错误时才需要展示错误内容
@@ -1,14 +1,13 @@
1
- import { editor } from 'monaco-editor/esm/vs/editor/editor.api';
2
1
  /**
3
2
  * 自动折叠 managedFields 字段
4
3
  * @param monacoEditor Monaco 编辑器实例
5
4
  */
6
- export declare function foldManagedFields(monacoEditor: editor.IStandaloneCodeEditor): void;
5
+ export declare function foldManagedFields(monacoEditor: import('monaco-editor/esm/vs/editor/editor.api').editor.IStandaloneCodeEditor): void;
7
6
  /**
8
7
  * 编辑器实例获取器接口
9
8
  */
10
9
  export interface EditorInstanceProvider {
11
- getEditorInstance(): editor.IStandaloneCodeEditor | null;
10
+ getEditorInstance(): import('monaco-editor/esm/vs/editor/editor.api').editor.IStandaloneCodeEditor | null;
12
11
  }
13
12
  /**
14
13
  * ManagedFields 自动折叠器
@@ -1,12 +1,7 @@
1
1
  import { MonacoLanguageService } from '@alauda/code-editor';
2
2
  import { OnDestroy, AfterViewInit } from '@angular/core';
3
- import { editor } from 'monaco-editor/esm/vs/editor/editor.api';
4
3
  import { BehaviorSubject, Observable } from 'rxjs';
5
- import { KubernetesSchemaService } from '../../core/services/kubernetes-schema.service';
6
- import { YamlUtilService } from '../../core/services/yaml-util.service';
7
- import { Arrayable } from '../../core/types/helpers';
8
- import { KubernetesResource } from '../../core/types/k8s/core';
9
- import { OpenAPIV3SchemaObject } from '../../core/types/schema';
4
+ import { KubernetesSchemaService, YamlUtilService, Arrayable, KubernetesResource, OpenAPIV3SchemaObject } from '../../core/public-api';
10
5
  import { EditorInstanceProvider } from '../managed-fields-folder.util';
11
6
  import * as i0 from "@angular/core";
12
7
  export declare class ResourceYamlDisplayComponent<T extends KubernetesResource> implements OnDestroy, AfterViewInit, EditorInstanceProvider {
@@ -23,7 +18,7 @@ export declare class ResourceYamlDisplayComponent<T extends KubernetesResource>
23
18
  private monacoEditor;
24
19
  private registeredSchemas;
25
20
  codeEditorRef: {
26
- editor: editor.IStandaloneCodeEditor;
21
+ editor: import('monaco-editor/esm/vs/editor/editor.api').editor.IStandaloneCodeEditor;
27
22
  };
28
23
  hasWrapper: boolean;
29
24
  showDebugInfo: boolean;
@@ -67,7 +62,7 @@ export declare class ResourceYamlDisplayComponent<T extends KubernetesResource>
67
62
  /**
68
63
  * 获取 Monaco Editor 实例
69
64
  */
70
- getEditorInstance(): editor.IStandaloneCodeEditor | null;
65
+ getEditorInstance(): import('monaco-editor/esm/vs/editor/editor.api').editor.IStandaloneCodeEditor | null;
71
66
  /**
72
67
  * 自动折叠 managedFields 字段
73
68
  */
@@ -5,8 +5,7 @@ import { BehaviorSubject, Observable } from 'rxjs';
5
5
  import { KubernetesSchemaService } from '../../core/services/kubernetes-schema.service';
6
6
  import { YamlUtilService } from '../../core/services/yaml-util.service';
7
7
  import { Arrayable } from '../../core/types/helpers';
8
- import { KubernetesResource } from '../../core/types/k8s/core';
9
- import { OpenAPIV3SchemaObject } from '../../core/types/schema';
8
+ import { KubernetesResource, OpenAPIV3SchemaObject } from '../../core/types/public-api';
10
9
  import { EditorInstanceProvider } from '../managed-fields-folder.util';
11
10
  import { YamlExample } from '../yaml-sidebar/types';
12
11
  import * as i0 from "@angular/core";
@@ -84,7 +83,7 @@ export declare class ResourceYamlEditorComponent<T extends KubernetesResource> i
84
83
  /**
85
84
  * 获取 Monaco 编辑器实例
86
85
  */
87
- getEditorInstance(): import('monaco-editor').editor.IStandaloneCodeEditor | null;
86
+ getEditorInstance(): import('monaco-editor/esm/vs/editor/editor.api').editor.IStandaloneCodeEditor | null;
88
87
  /**
89
88
  * 手动折叠 managedFields
90
89
  */
@@ -1,14 +1,14 @@
1
1
  import { HttpClient } from '@angular/common/http';
2
- import { OnInit, OnChanges, SimpleChanges, EventEmitter, ChangeDetectorRef } from '@angular/core';
2
+ import { OnInit, OnChanges, SimpleChanges, EventEmitter, ChangeDetectorRef, ElementRef } from '@angular/core';
3
3
  import { KubernetesSchemaService } from '../../core/services/kubernetes-schema.service';
4
- import { KubernetesResource } from '../../core/types/k8s/core';
5
- import { OpenAPIV3SchemaObject } from '../../core/types/schema';
4
+ import { KubernetesResource, OpenAPIV3SchemaObject } from '../../core/types/public-api';
6
5
  import { YamlExample } from './types';
7
6
  import * as i0 from "@angular/core";
8
7
  export declare class ResourceYamlSidebarComponent implements OnInit, OnChanges {
9
8
  private schemaService;
10
9
  private http;
11
10
  private cdr;
11
+ private host;
12
12
  resource: KubernetesResource;
13
13
  schema: OpenAPIV3SchemaObject;
14
14
  close: EventEmitter<void>;
@@ -18,6 +18,7 @@ export declare class ResourceYamlSidebarComponent implements OnInit, OnChanges {
18
18
  extraExamples: YamlExample[];
19
19
  private readonly DEFINITIONS_PREFIX;
20
20
  currentSchema: OpenAPIV3SchemaObject;
21
+ currentSchemaDescription: string;
21
22
  properties: {
22
23
  [key: string]: OpenAPIV3SchemaObject;
23
24
  };
@@ -26,7 +27,7 @@ export declare class ResourceYamlSidebarComponent implements OnInit, OnChanges {
26
27
  examples: YamlExample[];
27
28
  hasSchema: boolean;
28
29
  hasExamples: boolean;
29
- constructor(schemaService: KubernetesSchemaService, http: HttpClient, cdr: ChangeDetectorRef);
30
+ constructor(schemaService: KubernetesSchemaService, http: HttpClient, cdr: ChangeDetectorRef, host: ElementRef<HTMLElement>);
30
31
  ngOnInit(): void;
31
32
  ngOnChanges(changes: SimpleChanges): void;
32
33
  refresh(): void;
@@ -34,24 +35,14 @@ export declare class ResourceYamlSidebarComponent implements OnInit, OnChanges {
34
35
  private loadConsoleYAMLSamples;
35
36
  drillDownToProperty(name: string): void;
36
37
  navigateToPath(index: number): void;
37
- hasNestedProperties(property: OpenAPIV3SchemaObject): boolean;
38
- getPropertyType(property: OpenAPIV3SchemaObject): string;
39
- isRequired(propertyName: string): boolean;
40
38
  /**
41
39
  * 检查属性是否有 $ref 引用或嵌套属性
42
40
  */
43
41
  hasViewableContent(property: OpenAPIV3SchemaObject): boolean;
44
- /**
45
- * 检查属性是否有 $ref 引用
46
- */
47
- hasRefProperty(property: OpenAPIV3SchemaObject): boolean;
48
- /**
49
- * 获取 $ref 引用的定义名称
50
- */
51
- getRefDefinitionName(property: OpenAPIV3SchemaObject): string;
52
42
  tryExample(example: YamlExample): void;
53
43
  downloadYaml(example: YamlExample): void;
54
44
  processDescription(description: string): string;
45
+ private scrollTop;
55
46
  static ɵfac: i0.ɵɵFactoryDeclaration<ResourceYamlSidebarComponent, never>;
56
47
  static ɵcmp: i0.ɵɵComponentDeclaration<ResourceYamlSidebarComponent, "acl-resource-yaml-sidebar", never, { "resource": { "alias": "resource"; "required": false; }; "schema": { "alias": "schema"; "required": false; }; "schemaEnable": { "alias": "schemaEnable"; "required": false; }; "exampleEnable": { "alias": "exampleEnable"; "required": false; }; "extraExamples": { "alias": "extraExamples"; "required": false; }; }, { "close": "close"; "tryYaml": "tryYaml"; }, never, never, true, never>;
57
48
  }
@@ -21,7 +21,7 @@ export declare class BaseNestedFormControl<V, M = V> implements AfterViewInit, O
21
21
  protected asyncValidator: boolean;
22
22
  protected cdr: ChangeDetectorRef;
23
23
  protected destroy$$: Subject<void>;
24
- protected hostForm: FormGroupDirective | NgForm;
24
+ protected hostForm: NgForm | FormGroupDirective;
25
25
  constructor();
26
26
  ngAfterViewInit(): void;
27
27
  ngOnDestroy(): void;
@@ -39,6 +39,7 @@ export declare class KubernetesSchemaService {
39
39
  * 从 Kubernetes API 获取 OpenAPI schema
40
40
  */
41
41
  private fetchOpenAPISchema;
42
+ private getDefinitionKey;
42
43
  static ɵfac: i0.ɵɵFactoryDeclaration<KubernetesSchemaService, never>;
43
44
  static ɵprov: i0.ɵɵInjectableDeclaration<KubernetesSchemaService>;
44
45
  }
@@ -4,7 +4,7 @@
4
4
  */
5
5
  import { HttpClient } from '@angular/common/http';
6
6
  import { Observable } from 'rxjs';
7
- import { KubernetesResource } from '../types/k8s/core';
7
+ import { KubernetesResource } from '../types/public-api';
8
8
  import * as i0 from "@angular/core";
9
9
  export type ModulePluginPhase = 'Running' | 'Processing' | 'Deleting' | 'Failed' | 'Upgrading' | 'Unknown';
10
10
  export interface ModulePluginInstallStatus {
@@ -1,5 +1,5 @@
1
1
  import { ActivatedRoute } from '@angular/router';
2
- import { Workspace } from '../utils/workspace';
2
+ import { Workspace } from '../utils/public-api';
3
3
  import * as i0 from "@angular/core";
4
4
  export declare class WorkspaceHelperService {
5
5
  private readonly baseParams$$;
@@ -1,4 +1,4 @@
1
- import { Arrayable, KubernetesResource } from '../public-api';
1
+ import { Arrayable, KubernetesResource } from '../types/public-api';
2
2
  import * as i0 from "@angular/core";
3
3
  export declare class YamlUtilService {
4
4
  private readonly baseDomain;
@@ -2,6 +2,7 @@ export interface OpenAPIV3SchemaObject {
2
2
  type: JSONSchema6TypeName;
3
3
  description?: string;
4
4
  enum?: string[];
5
+ $ref?: string;
5
6
  properties?: {
6
7
  [key: string]: OpenAPIV3SchemaObject;
7
8
  };
@@ -10,5 +11,13 @@ export interface OpenAPIV3SchemaObject {
10
11
  title?: string;
11
12
  default?: any;
12
13
  additionalProperties?: OpenAPIV3SchemaObject;
14
+ ['x-kubernetes-group-version-kind']?: Array<{
15
+ group: string;
16
+ version: string;
17
+ kind: string;
18
+ }>;
19
+ }
20
+ export interface OpenAPIV3SchemaObjects {
21
+ [name: string]: OpenAPIV3SchemaObject;
13
22
  }
14
23
  export type JSONSchema6TypeName = 'string' | 'number' | 'integer' | 'boolean' | 'object' | 'array' | 'null' | 'any';
@@ -36,4 +36,4 @@ export declare const compareVersion: {
36
36
  gte: (v1: string, v2: string) => boolean;
37
37
  cmp: (v1: string, v2: string, operator: CompareOperator) => boolean;
38
38
  };
39
- export declare const compareMinorVersion: (v1: string, v2: string) => 1 | 0 | -1;
39
+ export declare const compareMinorVersion: (v1: string, v2: string) => 0 | 1 | -1;
@@ -144,4 +144,4 @@ export class ManagedFieldsAutoFolder {
144
144
  }
145
145
  }
146
146
  }
147
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"managed-fields-folder.util.js","sourceRoot":"","sources":["../../../../../libs/common/src/code/managed-fields-folder.util.ts"],"names":[],"mappings":"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","sourcesContent":["import { editor } from 'monaco-editor/esm/vs/editor/editor.api';\nimport { Subscription } from 'rxjs';\n\n/**\n * 自动折叠 managedFields 字段\n * @param monacoEditor Monaco 编辑器实例\n */\nexport function foldManagedFields(\n  monacoEditor: editor.IStandaloneCodeEditor,\n): void {\n  if (!monacoEditor) {\n    return;\n  }\n\n  const model = monacoEditor.getModel();\n  if (!model) {\n    return;\n  }\n\n  try {\n    // 查找所有 managedFields 字段（只在 metadata 下的）\n    const managedFieldsMatches = model.findMatches(\n      '^(\\\\s+)managedFields:',\n      false,\n      true,\n      false,\n      null,\n      true,\n    );\n\n    if (managedFieldsMatches && managedFieldsMatches.length > 0) {\n      const foldingRanges: any[] = [];\n\n      for (const match of managedFieldsMatches) {\n        const startLine = match.range.startLineNumber;\n\n        const endLine = findManagedFieldsEndLine(model, startLine);\n\n        if (endLine > startLine) {\n          foldingRanges.push({\n            startLineNumber: startLine,\n            startColumn: 1,\n            endLineNumber: endLine,\n            endColumn: model.getLineMaxColumn(endLine),\n          });\n        }\n      }\n      if (foldingRanges.length > 0) {\n        // 递归折叠每个 managedFields 区域，确保每次折叠完成后再进行下一次\n        foldRangesSequentially(monacoEditor, foldingRanges?.reverse(), 0);\n      }\n    }\n  } catch (error) {\n    console.warn('Failed to fold managedFields:', error);\n  }\n}\n\n/**\n * 递归折叠多个区域，确保每次折叠完成后再进行下一次\n * @param monacoEditor Monaco 编辑器实例\n * @param foldingRanges 折叠区域数组\n * @param index 当前折叠的索引\n */\nasync function foldRangesSequentially(\n  monacoEditor: editor.IStandaloneCodeEditor,\n  foldingRanges: any[],\n  index: number,\n): Promise<void> {\n  if (index >= foldingRanges.length) {\n    return;\n  }\n\n  const range = foldingRanges[index];\n  monacoEditor.setSelection(range);\n  await Promise.resolve(monacoEditor.getAction('editor.fold')?.run());\n\n  return foldRangesSequentially(monacoEditor, foldingRanges, index + 1);\n}\n\n/**\n * 查找 managedFields 字段的结束行\n * @param model Monaco 编辑器模型\n * @param startLine 起始行号\n * @returns 结束行号\n */\nfunction findManagedFieldsEndLine(\n  model: editor.ITextModel,\n  startLine: number,\n): number {\n  const totalLines = model.getLineCount();\n  const startIndent = getLineIndentation(model, startLine);\n\n  // 从下一行开始查找\n  for (let line = startLine + 1; line <= totalLines; line++) {\n    const lineContent = model.getLineContent(line).trim();\n\n    // 跳过空行\n    if (!lineContent) {\n      continue;\n    }\n\n    const currentIndent = getLineIndentation(model, line);\n\n    // 如果缩进小于等于起始行，说明 managedFields 字段结束\n    if (currentIndent <= startIndent) {\n      return line - 1;\n    }\n  }\n\n  return totalLines;\n}\n\n/**\n * 获取行的缩进级别\n * @param model Monaco 编辑器模型\n * @param lineNumber 行号\n * @returns 缩进级别（空格数）\n */\nfunction getLineIndentation(\n  model: editor.ITextModel,\n  lineNumber: number,\n): number {\n  const lineContent = model.getLineContent(lineNumber);\n  const match = lineContent.match(/^(\\s*)/);\n  return match ? match[1].length : 0;\n}\n\n/**\n * 编辑器实例获取器接口\n */\nexport interface EditorInstanceProvider {\n  getEditorInstance(): editor.IStandaloneCodeEditor | null;\n}\n\n/**\n * ManagedFields 自动折叠器\n * 用于在内容变化时自动折叠 managedFields 字段\n */\nexport class ManagedFieldsAutoFolder {\n  private subscription?: Subscription;\n  private lastFoldedContent = '';\n\n  /**\n   * 开始监听内容变化并自动折叠\n   * @param editorProvider 编辑器实例提供者\n   * @param contentObservable 内容变化的 Observable\n   */\n  startAutoFold(\n    editorProvider: EditorInstanceProvider,\n    contentObservable: any,\n  ): void {\n    this.stopAutoFold();\n\n    this.subscription = contentObservable.subscribe(() => {\n      setTimeout(() => {\n        const editor = editorProvider.getEditorInstance();\n        if (editor) {\n          const model = editor.getModel();\n          if (model) {\n            const currentContent = model.getValue();\n            // 只有当内容真正发生变化时才执行折叠\n            if (\n              currentContent.includes('managedFields:') &&\n              currentContent !== this.lastFoldedContent\n            ) {\n              foldManagedFields(editor);\n              this.lastFoldedContent = currentContent;\n            }\n          }\n        }\n      }, 100);\n    });\n  }\n\n  /**\n   * 停止自动折叠\n   */\n  stopAutoFold(): void {\n    if (this.subscription) {\n      this.subscription.unsubscribe();\n      this.subscription = undefined;\n    }\n  }\n\n  /**\n   * 手动执行一次折叠\n   * @param editorProvider 编辑器实例提供者\n   */\n  foldOnce(editorProvider: EditorInstanceProvider): void {\n    const editor = editorProvider.getEditorInstance();\n    if (editor) {\n      foldManagedFields(editor);\n      const model = editor.getModel();\n      if (model) {\n        this.lastFoldedContent = model.getValue();\n      }\n    }\n  }\n}\n"]}
147
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"managed-fields-folder.util.js","sourceRoot":"","sources":["../../../../../libs/common/src/code/managed-fields-folder.util.ts"],"names":[],"mappings":"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","sourcesContent":["import { Subscription } from 'rxjs';\n\n/**\n * 自动折叠 managedFields 字段\n * @param monacoEditor Monaco 编辑器实例\n */\nexport function foldManagedFields(\n  monacoEditor: import('monaco-editor/esm/vs/editor/editor.api').editor.IStandaloneCodeEditor,\n): void {\n  if (!monacoEditor) {\n    return;\n  }\n\n  const model = monacoEditor.getModel();\n  if (!model) {\n    return;\n  }\n\n  try {\n    // 查找所有 managedFields 字段（只在 metadata 下的）\n    const managedFieldsMatches = model.findMatches(\n      '^(\\\\s+)managedFields:',\n      false,\n      true,\n      false,\n      null,\n      true,\n    );\n\n    if (managedFieldsMatches && managedFieldsMatches.length > 0) {\n      const foldingRanges: any[] = [];\n\n      for (const match of managedFieldsMatches) {\n        const startLine = match.range.startLineNumber;\n\n        const endLine = findManagedFieldsEndLine(model, startLine);\n\n        if (endLine > startLine) {\n          foldingRanges.push({\n            startLineNumber: startLine,\n            startColumn: 1,\n            endLineNumber: endLine,\n            endColumn: model.getLineMaxColumn(endLine),\n          });\n        }\n      }\n      if (foldingRanges.length > 0) {\n        // 递归折叠每个 managedFields 区域，确保每次折叠完成后再进行下一次\n        foldRangesSequentially(monacoEditor, foldingRanges?.reverse(), 0);\n      }\n    }\n  } catch (error) {\n    console.warn('Failed to fold managedFields:', error);\n  }\n}\n\n/**\n * 递归折叠多个区域，确保每次折叠完成后再进行下一次\n * @param monacoEditor Monaco 编辑器实例\n * @param foldingRanges 折叠区域数组\n * @param index 当前折叠的索引\n */\nasync function foldRangesSequentially(\n  monacoEditor: import('monaco-editor/esm/vs/editor/editor.api').editor.IStandaloneCodeEditor,\n  foldingRanges: any[],\n  index: number,\n): Promise<void> {\n  if (index >= foldingRanges.length) {\n    return;\n  }\n\n  const range = foldingRanges[index];\n  monacoEditor.setSelection(range);\n  await Promise.resolve(monacoEditor.getAction('editor.fold')?.run());\n\n  return foldRangesSequentially(monacoEditor, foldingRanges, index + 1);\n}\n\n/**\n * 查找 managedFields 字段的结束行\n * @param model Monaco 编辑器模型\n * @param startLine 起始行号\n * @returns 结束行号\n */\nfunction findManagedFieldsEndLine(\n  model: import('monaco-editor/esm/vs/editor/editor.api').editor.ITextModel,\n  startLine: number,\n): number {\n  const totalLines = model.getLineCount();\n  const startIndent = getLineIndentation(model, startLine);\n\n  // 从下一行开始查找\n  for (let line = startLine + 1; line <= totalLines; line++) {\n    const lineContent = model.getLineContent(line).trim();\n\n    // 跳过空行\n    if (!lineContent) {\n      continue;\n    }\n\n    const currentIndent = getLineIndentation(model, line);\n\n    // 如果缩进小于等于起始行，说明 managedFields 字段结束\n    if (currentIndent <= startIndent) {\n      return line - 1;\n    }\n  }\n\n  return totalLines;\n}\n\n/**\n * 获取行的缩进级别\n * @param model Monaco 编辑器模型\n * @param lineNumber 行号\n * @returns 缩进级别（空格数）\n */\nfunction getLineIndentation(\n  model: import('monaco-editor/esm/vs/editor/editor.api').editor.ITextModel,\n  lineNumber: number,\n): number {\n  const lineContent = model.getLineContent(lineNumber);\n  const match = lineContent.match(/^(\\s*)/);\n  return match ? match[1].length : 0;\n}\n\n/**\n * 编辑器实例获取器接口\n */\nexport interface EditorInstanceProvider {\n  getEditorInstance():\n    | import('monaco-editor/esm/vs/editor/editor.api').editor.IStandaloneCodeEditor\n    | null;\n}\n\n/**\n * ManagedFields 自动折叠器\n * 用于在内容变化时自动折叠 managedFields 字段\n */\nexport class ManagedFieldsAutoFolder {\n  private subscription?: Subscription;\n  private lastFoldedContent = '';\n\n  /**\n   * 开始监听内容变化并自动折叠\n   * @param editorProvider 编辑器实例提供者\n   * @param contentObservable 内容变化的 Observable\n   */\n  startAutoFold(\n    editorProvider: EditorInstanceProvider,\n    contentObservable: any,\n  ): void {\n    this.stopAutoFold();\n\n    this.subscription = contentObservable.subscribe(() => {\n      setTimeout(() => {\n        const editor = editorProvider.getEditorInstance();\n        if (editor) {\n          const model = editor.getModel();\n          if (model) {\n            const currentContent = model.getValue();\n            // 只有当内容真正发生变化时才执行折叠\n            if (\n              currentContent.includes('managedFields:') &&\n              currentContent !== this.lastFoldedContent\n            ) {\n              foldManagedFields(editor);\n              this.lastFoldedContent = currentContent;\n            }\n          }\n        }\n      }, 100);\n    });\n  }\n\n  /**\n   * 停止自动折叠\n   */\n  stopAutoFold(): void {\n    if (this.subscription) {\n      this.subscription.unsubscribe();\n      this.subscription = undefined;\n    }\n  }\n\n  /**\n   * 手动执行一次折叠\n   * @param editorProvider 编辑器实例提供者\n   */\n  foldOnce(editorProvider: EditorInstanceProvider): void {\n    const editor = editorProvider.getEditorInstance();\n    if (editor) {\n      foldManagedFields(editor);\n      const model = editor.getModel();\n      if (model) {\n        this.lastFoldedContent = model.getValue();\n      }\n    }\n  }\n}\n"]}
@@ -6,20 +6,17 @@ import { ChangeDetectionStrategy, Component, Input, ViewChild, } from '@angular/
6
6
  import { FormsModule } from '@angular/forms';
7
7
  import { yamlDefaults, setDiagnosticsOptions } from 'monaco-yaml';
8
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 { TranslateModule } from '../../translate/translate.module';
9
+ import { KubernetesSchemaService, YamlUtilService, ObservableInput, } from '../../core/public-api';
10
+ import { TRANSLATE_MODULE } from '../../translate/public-api';
13
11
  import { viewActions, yamlReadMinimapOptions, yamlReadOptions, } from '../code-editor-configs';
14
12
  import { foldManagedFields, } from '../managed-fields-folder.util';
15
13
  import { ResourceYamlSidebarComponent } from '../yaml-sidebar/component';
16
14
  import * as i0 from "@angular/core";
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";
15
+ import * as i1 from "../../core/public-api";
16
+ import * as i2 from "@alauda/code-editor";
17
+ import * as i3 from "@alauda/ui";
18
+ import * as i4 from "@angular/forms";
19
+ import * as i5 from "../../translate/translate.pipe";
23
20
  const _c0 = ["codeEditorRef"];
24
21
  function ResourceYamlDisplayComponent_aui_card_0_ng_container_1_Template(rf, ctx) { if (rf & 1) {
25
22
  i0.ɵɵelementContainer(0);
@@ -53,19 +50,18 @@ function ResourceYamlDisplayComponent_ng_template_1_button_9_Template(rf, ctx) {
53
50
  i0.ɵɵelementStart(0, "button", 13);
54
51
  i0.ɵɵpipe(1, "async");
55
52
  i0.ɵɵpipe(2, "async");
56
- i0.ɵɵpipe(3, "async");
57
- i0.ɵɵpipe(4, "translate");
53
+ i0.ɵɵpipe(3, "translate");
58
54
  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");
55
+ i0.ɵɵelement(4, "aui-icon", 14);
56
+ i0.ɵɵpipe(5, "async");
61
57
  i0.ɵɵelementEnd();
62
58
  } if (rf & 2) {
63
59
  i0.ɵɵnextContext();
64
60
  const codeEditorRef_r5 = i0.ɵɵreference(4);
65
61
  const ctx_r2 = i0.ɵɵnextContext();
66
- i0.ɵɵproperty("hidden", !!codeEditorRef_r5.fullscreenDialog)("type", i0.ɵɵpipeBind1(1, 5, ctx_r2.showSidebar$$) ? "primary" : "text")("disabled", !i0.ɵɵpipeBind1(2, 7, ctx_r2.finalSchema$))("auiTooltip", i0.ɵɵpipeBind1(4, 11, i0.ɵɵpipeBind1(3, 9, ctx_r2.showSidebar$$) ? "hide_sidebar" : "view_sidebar"));
67
- i0.ɵɵadvance(5);
68
- i0.ɵɵproperty("icon", i0.ɵɵpipeBind1(6, 13, ctx_r2.showSidebar$$) ? "prod:expand_sidebar" : "prod:collapse_sidebar");
62
+ i0.ɵɵproperty("hidden", !!codeEditorRef_r5.fullscreenDialog)("disabled", !i0.ɵɵpipeBind1(1, 4, ctx_r2.finalSchema$))("auiTooltip", i0.ɵɵpipeBind1(3, 8, i0.ɵɵpipeBind1(2, 6, ctx_r2.showSidebar$$) ? "hide_sidebar" : "view_sidebar"));
63
+ i0.ɵɵadvance(4);
64
+ i0.ɵɵproperty("icon", i0.ɵɵpipeBind1(5, 10, ctx_r2.showSidebar$$) ? "prod:expand_sidebar" : "prod:collapse_sidebar");
69
65
  } }
70
66
  function ResourceYamlDisplayComponent_ng_template_1_div_10_Template(rf, ctx) { if (rf & 1) {
71
67
  const _r6 = i0.ɵɵgetCurrentView();
@@ -87,7 +83,7 @@ function ResourceYamlDisplayComponent_ng_template_1_Template(rf, ctx) { if (rf &
87
83
  i0.ɵɵtemplate(7, ResourceYamlDisplayComponent_ng_template_1_aui_checkbox_7_Template, 4, 6, "aui-checkbox", 8);
88
84
  i0.ɵɵelementContainerEnd();
89
85
  i0.ɵɵelementContainerStart(8, 9);
90
- i0.ɵɵtemplate(9, ResourceYamlDisplayComponent_ng_template_1_button_9_Template, 7, 15, "button", 10);
86
+ i0.ɵɵtemplate(9, ResourceYamlDisplayComponent_ng_template_1_button_9_Template, 6, 12, "button", 10);
91
87
  i0.ɵɵelementContainerEnd();
92
88
  i0.ɵɵelementEnd()();
93
89
  i0.ɵɵtemplate(10, ResourceYamlDisplayComponent_ng_template_1_div_10_Template, 3, 6, "div", 11);
@@ -274,23 +270,23 @@ export class ResourceYamlDisplayComponent {
274
270
  this.destroy$.complete();
275
271
  this.monacoEditor = null;
276
272
  }
277
- static { this.ɵfac = function ResourceYamlDisplayComponent_Factory(t) { return new (t || ResourceYamlDisplayComponent)(i0.ɵɵdirectiveInject(i1.YamlUtilService), i0.ɵɵdirectiveInject(i2.KubernetesSchemaService), i0.ɵɵdirectiveInject(i3.MonacoLanguageService)); }; }
273
+ static { this.ɵfac = function ResourceYamlDisplayComponent_Factory(t) { return new (t || ResourceYamlDisplayComponent)(i0.ɵɵdirectiveInject(i1.YamlUtilService), i0.ɵɵdirectiveInject(i1.KubernetesSchemaService), i0.ɵɵdirectiveInject(i2.MonacoLanguageService)); }; }
278
274
  static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: ResourceYamlDisplayComponent, selectors: [["acl-resource-yaml-display"]], viewQuery: function ResourceYamlDisplayComponent_Query(rf, ctx) { if (rf & 1) {
279
275
  i0.ɵɵviewQuery(_c0, 5);
280
276
  } if (rf & 2) {
281
277
  let _t;
282
278
  i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.codeEditorRef = _t.first);
283
- } }, 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, "hidden", "type", "disabled", "auiTooltip", "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", "hidden", "type", "disabled", "auiTooltip"], [3, "icon"], [1, "yaml-sidebar-section"], [3, "close", "resource", "schema", "schemaEnable", "exampleEnable"]], template: function ResourceYamlDisplayComponent_Template(rf, ctx) { if (rf & 1) {
279
+ } }, 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", ""], ["type", "button", "class", "aui-code-editor-toolbar__control-button", "size", "small", 3, "hidden", "disabled", "auiTooltip", "click", 4, "ngIf"], ["class", "yaml-sidebar-section", 4, "ngIf"], [1, "aui-code-editor-toolbar__control-button", 3, "ngModelChange", "ngModel"], ["type", "button", "size", "small", 1, "aui-code-editor-toolbar__control-button", 3, "click", "hidden", "disabled", "auiTooltip"], [3, "icon"], [1, "yaml-sidebar-section"], [3, "close", "resource", "schema", "schemaEnable", "exampleEnable"]], template: function ResourceYamlDisplayComponent_Template(rf, ctx) { if (rf & 1) {
284
280
  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);
285
281
  } if (rf & 2) {
286
282
  const content_r1 = i0.ɵɵreference(2);
287
283
  i0.ɵɵproperty("ngIf", ctx.hasWrapper)("ngIfElse", content_r1);
288
- } }, dependencies: [i4.CardComponent, NgIf,
289
- FormsModule, i5.NgControlStatus, i5.NgModel, i4.CheckboxComponent, ButtonModule,
290
- CodeEditorModule, i3.CodeEditorComponent, TranslateModule, i6.TranslatePipe, AsyncPipe,
284
+ } }, dependencies: [i3.CardComponent, NgIf,
285
+ FormsModule, i4.NgControlStatus, i4.NgModel, i3.CheckboxComponent, ButtonModule,
286
+ CodeEditorModule, i2.CodeEditorComponent, i5.TranslatePipe, AsyncPipe,
291
287
  NgTemplateOutlet,
292
288
  ResourceYamlSidebarComponent,
293
- IconModule, i4.IconComponent, TooltipModule, i4.TooltipDirective], 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 }); }
289
+ IconModule, i3.IconComponent, TooltipModule, i3.TooltipDirective], 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:2;min-width:0}.yaml-display-container.with-sidebar[_ngcontent-%COMP%] .yaml-sidebar-section[_ngcontent-%COMP%]{flex:1 0 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 (width <= 1200px){.yaml-display-container.with-sidebar[_ngcontent-%COMP%] .yaml-sidebar-section[_ngcontent-%COMP%]{width:350px}}@media (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 }); }
294
290
  }
295
291
  __decorate([
296
292
  ObservableInput(),
@@ -309,14 +305,14 @@ __decorate([
309
305
  CHECKBOX_MODULE,
310
306
  ButtonModule,
311
307
  CodeEditorModule,
312
- TranslateModule,
308
+ TRANSLATE_MODULE,
313
309
  AsyncPipe,
314
310
  NgTemplateOutlet,
315
311
  ResourceYamlSidebarComponent,
316
312
  IconModule,
317
313
  TooltipModule,
318
- ], 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 [hidden]=\"!!codeEditorRef.fullscreenDialog\"\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 [auiTooltip]=\"\n ((showSidebar$$ | async) ? 'hide_sidebar' : 'view_sidebar')\n | 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"] }]
319
- }], () => [{ type: i1.YamlUtilService }, { type: i2.KubernetesSchemaService }, { type: i3.MonacoLanguageService }], { codeEditorRef: [{
314
+ ], 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 type=\"button\"\n *ngIf=\"sidebarEnable\"\n [hidden]=\"!!codeEditorRef.fullscreenDialog\"\n class=\"aui-code-editor-toolbar__control-button\"\n [disabled]=\"!(finalSchema$ | async)\"\n size=\"small\"\n (click)=\"toggleSidebar()\"\n [auiTooltip]=\"\n ((showSidebar$$ | async) ? 'hide_sidebar' : 'view_sidebar')\n | 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:2;min-width:0}.yaml-display-container.with-sidebar .yaml-sidebar-section{flex:1 0 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 (width <= 1200px){.yaml-display-container.with-sidebar .yaml-sidebar-section{width:350px}}@media (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"] }]
315
+ }], () => [{ type: i1.YamlUtilService }, { type: i1.KubernetesSchemaService }, { type: i2.MonacoLanguageService }], { codeEditorRef: [{
320
316
  type: ViewChild,
321
317
  args: ['codeEditorRef']
322
318
  }], hasWrapper: [{
@@ -343,4 +339,4 @@ __decorate([
343
339
  type: Input
344
340
  }] }); })();
345
341
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(ResourceYamlDisplayComponent, { className: "ResourceYamlDisplayComponent" }); })();
346
- //# 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  TooltipModule,\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    TooltipModule,\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  hasFolded = false;\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  selfFoldManagedFields() {\n    if (this.hasFolded) {\n      return;\n    }\n    this.hasFolded = true;\n    setTimeout(() => {\n      const editor = this.getEditorInstance();\n      if (editor) {\n        foldManagedFields(editor);\n      }\n    }, 50);\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    this.selfFoldManagedFields();\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    if (this.autoFoldManagedFields && this.schemaService.definitions) {\n      this.selfFoldManagedFields();\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            [hidden]=\"!!codeEditorRef.fullscreenDialog\"\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            [auiTooltip]=\"\n              ((showSidebar$$ | async) ? 'hide_sidebar' : 'view_sidebar')\n                | 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"]}
342
+ //# 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  TooltipModule,\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 { 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 {\n  KubernetesSchemaService,\n  YamlUtilService,\n  Arrayable,\n  KubernetesResource,\n  OpenAPIV3SchemaObject,\n  ObservableInput,\n} from '../../core/public-api';\nimport { TRANSLATE_MODULE } from '../../translate/public-api';\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    TRANSLATE_MODULE,\n    AsyncPipe,\n    NgTemplateOutlet,\n    ResourceYamlSidebarComponent,\n    IconModule,\n    TooltipModule,\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:\n    | import('monaco-editor/esm/vs/editor/editor.api').editor.IStandaloneCodeEditor\n    | null = null;\n\n  private registeredSchemas = new Set<string>();\n\n  @ViewChild('codeEditorRef')\n  codeEditorRef!: {\n    editor: import('monaco-editor/esm/vs/editor/editor.api').editor.IStandaloneCodeEditor;\n  };\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  hasFolded = false;\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  selfFoldManagedFields() {\n    if (this.hasFolded) {\n      return;\n    }\n    this.hasFolded = true;\n    setTimeout(() => {\n      const editor = this.getEditorInstance();\n      if (editor) {\n        foldManagedFields(editor);\n      }\n    }, 50);\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    this.selfFoldManagedFields();\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    if (this.autoFoldManagedFields && this.schemaService.definitions) {\n      this.selfFoldManagedFields();\n    }\n  }\n\n  /**\n   * 获取 Monaco Editor 实例\n   */\n  getEditorInstance():\n    | import('monaco-editor/esm/vs/editor/editor.api').editor.IStandaloneCodeEditor\n    | 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            type=\"button\"\n            *ngIf=\"sidebarEnable\"\n            [hidden]=\"!!codeEditorRef.fullscreenDialog\"\n            class=\"aui-code-editor-toolbar__control-button\"\n            [disabled]=\"!(finalSchema$ | async)\"\n            size=\"small\"\n            (click)=\"toggleSidebar()\"\n            [auiTooltip]=\"\n              ((showSidebar$$ | async) ? 'hide_sidebar' : 'view_sidebar')\n                | 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"]}