@alauda-fe/common 1.4.28-beta.0 → 1.4.28-beta.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/code/code-editor-configs.d.ts +2 -0
- package/code/managed-fields-folder.util.d.ts +35 -0
- package/code/public-api.d.ts +4 -0
- package/code/resource-yaml-display/component.d.ts +64 -6
- package/code/resource-yaml-display/schema/component.d.ts +61 -0
- package/code/resource-yaml-editor/component.d.ts +95 -0
- package/code/yaml-examples.d.ts +8 -0
- package/code/yaml-sidebar/component.d.ts +57 -0
- package/code/yaml-sidebar/types.d.ts +21 -0
- package/code/yaml-sidebar/yaml-examples.d.ts +8 -0
- package/core/directives/scroll-to-first-invalid.directive.d.ts +1 -1
- package/core/services/kubernetes-schema.service.d.ts +44 -0
- package/core/services/public-api.d.ts +1 -0
- package/core/types/openapi.d.ts +37 -0
- package/core/types/public-api.d.ts +1 -0
- package/esm2022/abnormal-page/abnormal-page.component.mjs +1 -1
- package/esm2022/array-form-table/form/component.mjs +1 -1
- package/esm2022/array-form-table/key-value-form/component.mjs +1 -1
- package/esm2022/array-form-table/key-value-table/component.mjs +1 -1
- package/esm2022/array-form-table/string-array-form/component.mjs +1 -1
- package/esm2022/async-data/error-page/component.mjs +1 -1
- package/esm2022/async-data/page-state/component.mjs +1 -1
- package/esm2022/business/notification-disabled-container/component.mjs +1 -1
- package/esm2022/business/resource-select/exports/cluster-list/component.mjs +1 -1
- package/esm2022/business/resource-select/exports/cluster-selector/component.mjs +1 -1
- package/esm2022/business/resource-select/exports/icon/component.mjs +1 -1
- package/esm2022/business/resource-select/exports/mesh-group-selector/component.mjs +1 -1
- package/esm2022/business/resource-select/exports/namespace-list/component.mjs +1 -1
- package/esm2022/business/resource-select/exports/namespace-page/component.mjs +1 -1
- package/esm2022/business/resource-select/exports/namespace-selector/component.mjs +1 -1
- package/esm2022/business/resource-select/exports/project-list/component.mjs +1 -1
- package/esm2022/business/resource-select/exports/project-page/component.mjs +1 -1
- package/esm2022/business/resource-select/exports/project-selector/component.mjs +1 -1
- package/esm2022/business/resource-select/internals/data-grid/component.mjs +1 -1
- package/esm2022/business/resource-select/internals/meshgroup-list/component.mjs +1 -1
- package/esm2022/business/resource-select/internals/no-data/component.mjs +1 -1
- package/esm2022/business/resource-select/internals/resource-dashboard/component.mjs +1 -1
- package/esm2022/business/resource-select/internals/selector-popup/component.mjs +1 -1
- package/esm2022/chart/common/axis/axis-label.component.mjs +1 -1
- package/esm2022/chart/common/axis/x-axis-ticks.component.mjs +1 -1
- package/esm2022/chart/common/axis/x-axis.component.mjs +1 -1
- package/esm2022/chart/common/axis/x-plot-lines.component.mjs +1 -1
- package/esm2022/chart/common/axis/y-axis-ticks.component.mjs +1 -1
- package/esm2022/chart/common/axis/y-axis.component.mjs +1 -1
- package/esm2022/chart/common/axis/y-plot-lines.component.mjs +1 -1
- package/esm2022/chart/common/chart/chart.component.mjs +1 -1
- package/esm2022/chart/common/legend/legend.component.mjs +1 -1
- package/esm2022/chart/common/range-area/range-area.component.mjs +1 -1
- package/esm2022/chart/common/reference-area/reference-area.component.mjs +1 -1
- package/esm2022/chart/common/series/area-series.component.mjs +1 -1
- package/esm2022/chart/common/series/bar-path.component.mjs +1 -1
- package/esm2022/chart/common/series/bar-series.component.mjs +1 -1
- package/esm2022/chart/common/series/line-series.component.mjs +1 -1
- package/esm2022/chart/common/tooltip/tooltip.component.mjs +1 -1
- package/esm2022/chart/custom-template/dropdown-legend.mjs +1 -1
- package/esm2022/code/code-display-dialog/component.mjs +1 -1
- package/esm2022/code/code-editor-configs.mjs +12 -2
- package/esm2022/code/k8s-yaml-display-dialog/component.mjs +1 -1
- package/esm2022/code/managed-fields-folder.util.mjs +136 -0
- package/esm2022/code/public-api.mjs +5 -1
- package/esm2022/code/resource-yaml-display/component.mjs +254 -43
- package/esm2022/code/resource-yaml-display/schema/component.mjs +531 -0
- package/esm2022/code/resource-yaml-editor/component.mjs +387 -0
- package/esm2022/code/yaml-examples.mjs +337 -0
- package/esm2022/code/yaml-sidebar/component.mjs +482 -0
- package/esm2022/code/yaml-sidebar/types.mjs +2 -0
- package/esm2022/code/yaml-sidebar/yaml-examples.mjs +340 -0
- package/esm2022/core/components/tree/node/component.mjs +1 -1
- package/esm2022/core/components/tree/tree/component.mjs +1 -1
- package/esm2022/core/directives/readonly-field.directive.mjs +1 -1
- package/esm2022/core/services/kubernetes-schema.service.mjs +129 -0
- package/esm2022/core/services/public-api.mjs +2 -1
- package/esm2022/core/services/workspace-helper.service.mjs +4 -3
- package/esm2022/core/types/openapi.mjs +2 -0
- package/esm2022/core/types/public-api.mjs +2 -1
- package/esm2022/custom-columns-setting/component.mjs +1 -1
- package/esm2022/disabled-container/disabled-container.component.mjs +1 -1
- package/esm2022/editable/editable.component.mjs +1 -1
- package/esm2022/editable-text/component.mjs +1 -1
- package/esm2022/exec/placeholder/component.mjs +1 -1
- package/esm2022/exec/terminal/component.mjs +1 -1
- package/esm2022/exec/terminal-group/component.mjs +1 -1
- package/esm2022/feature-gate-forbidden/component/component.mjs +1 -1
- package/esm2022/form/errors-mapper/errors-mapper-component/component.mjs +1 -1
- package/esm2022/form/errors-mapper/errors-mapper.directive.mjs +1 -1
- package/esm2022/form/labels-editor/component.mjs +1 -1
- package/esm2022/form/taints-editor/component.mjs +1 -1
- package/esm2022/form/upload-file/component.mjs +1 -1
- package/esm2022/form/validators/strong-password/strong-password-tooltip/component.mjs +1 -1
- package/esm2022/graph-canvas/components/graph-actions.component.mjs +1 -1
- package/esm2022/graph-canvas/components/graph-canvas.component.mjs +1 -1
- package/esm2022/graph-canvas/components/graph-link.component.mjs +1 -1
- package/esm2022/graph-canvas/components/graph-links.component.mjs +1 -1
- package/esm2022/grid-layout/components/grid/component.mjs +1 -1
- package/esm2022/grid-layout/components/grid-items/component.mjs +1 -1
- package/esm2022/help-document/component.mjs +1 -1
- package/esm2022/k8s-resource-list/footer/component.mjs +1 -1
- package/esm2022/k8s-shared/resource-mark/k8s-resource-mark.component.mjs +1 -1
- package/esm2022/k8s-shared/update-description-dialog/component.mjs +1 -1
- package/esm2022/k8s-shared/update-display-name-dialog/component.mjs +1 -1
- package/esm2022/k8s-shared/update-key-value-dialog/component.mjs +1 -1
- package/esm2022/lazy-component/lazy-load-component.mjs +1 -1
- package/esm2022/license/license-error/component.mjs +1 -1
- package/esm2022/list-display/component.mjs +1 -1
- package/esm2022/metric-chart/metric-chart.component.mjs +1 -1
- package/esm2022/metric-chart/metric-time-pick.mjs +1 -1
- package/esm2022/multi-search/action-input/component.mjs +1 -1
- package/esm2022/multi-search/form/component.mjs +1 -1
- package/esm2022/multi-search/multi-search-tags/component.mjs +1 -1
- package/esm2022/mutable/mosaic/mosaic.component.mjs +1 -1
- package/esm2022/notification/feedback-notification/component.mjs +1 -1
- package/esm2022/overview-banner/overview-banner.component.mjs +1 -1
- package/esm2022/page-guard/component/component.mjs +1 -1
- package/esm2022/page-scaffold/navigation/breadcrumb/breadcrumb.component.mjs +1 -1
- package/esm2022/page-scaffold/navigation/nav-menu/nav-item-li/nav-item-li.component.mjs +1 -1
- package/esm2022/page-scaffold/navigation/nav-menu/nav-item-ul/nav-item-ul.component.mjs +1 -1
- package/esm2022/page-scaffold/navigation/nav-menu/nav-menu.component.mjs +1 -1
- package/esm2022/page-scaffold/page/notices/maintenance.component.mjs +1 -1
- package/esm2022/page-scaffold/page/notices/notice.component.mjs +1 -1
- package/esm2022/page-scaffold/page/page.component.mjs +1 -1
- package/esm2022/page-scaffold/page-header/account-menu/component/component.mjs +1 -1
- package/esm2022/page-scaffold/page-header/common-layout/namespace-select/component.mjs +1 -1
- package/esm2022/page-scaffold/page-header/common-layout/product-select/component.mjs +1 -1
- package/esm2022/page-scaffold/page-header/component.mjs +1 -1
- package/esm2022/page-scaffold/page-header/enterprise-support-status/component.mjs +1 -1
- package/esm2022/page-scaffold/page-header/header-notify/component/header-notify.component.mjs +1 -1
- package/esm2022/page-scaffold/page-header/header-notify/component/notification-list/notification-list.component.mjs +1 -1
- package/esm2022/page-scaffold/page-header/help-menu/component/component.mjs +1 -1
- package/esm2022/pie-derivative-chart/donut-status/component.mjs +1 -1
- package/esm2022/pie-derivative-chart/radial-bar/radial-bar-chart.component.mjs +1 -1
- package/esm2022/pod-status/component.mjs +1 -1
- package/esm2022/searchable-selector/component.mjs +1 -1
- package/esm2022/skeleton/item/component.mjs +1 -1
- package/esm2022/skeleton/nav-skeleton/component.mjs +1 -1
- package/esm2022/table/component.mjs +1 -1
- package/esm2022/view-chart/custom-template/dropdown-legend.mjs +1 -1
- package/esm2022/view-chart/legend/legend.component.mjs +1 -1
- package/esm2022/view-chart/view-chart.component.mjs +1 -1
- package/esm2022/view-zchart/custom-template/dropdown-legend.mjs +1 -1
- package/esm2022/view-zchart/legend/legend.component.mjs +1 -1
- package/esm2022/view-zchart/view-zchart.component.mjs +1 -1
- package/esm2022/widget/card-section/card-section.component.mjs +1 -1
- package/esm2022/widget/confirm-delete/confirm-delete.component.mjs +1 -1
- package/esm2022/widget/current-time/component.mjs +1 -1
- package/esm2022/widget/date-range-picker/component.mjs +1 -1
- package/esm2022/widget/field-set/column/component.mjs +2 -2
- package/esm2022/widget/field-set/group/component.mjs +1 -1
- package/esm2022/widget/field-set/item/component.mjs +1 -1
- package/esm2022/widget/foldable-block/component.mjs +1 -1
- package/esm2022/widget/foldable-item-in-table/component.mjs +1 -1
- package/esm2022/widget/loading-mask/loading-mask.component.mjs +1 -1
- package/esm2022/widget/password-input/component.mjs +1 -1
- package/esm2022/widget/relative-time/component.mjs +1 -1
- package/esm2022/widget/resource-label/component.mjs +1 -1
- package/esm2022/widget/resource-multi-select/component.mjs +1 -1
- package/esm2022/widget/search-panel/component.mjs +1 -1
- package/esm2022/widget/search-panel/search-item/component.mjs +1 -1
- package/esm2022/widget/status-icon/status-icon.component.mjs +1 -1
- package/esm2022/widget/tags-label/component.mjs +1 -1
- package/esm2022/widget/terminating-tag/component.mjs +1 -1
- package/esm2022/widget/text-ellipsis/component.mjs +1 -1
- package/esm2022/widget/text-with-url/component.mjs +1 -1
- package/esm2022/widget/zero-state/zero-state.component.mjs +1 -1
- package/esm2022/workload-status-icon/component.mjs +1 -1
- package/esm2022/xterm/xterm-terminal/xterm-terminal.component.mjs +1 -1
- package/esm2022/xterm/xterm.component.mjs +1 -1
- package/package.json +2 -2
- package/styles/global.scss +4 -0
- package/table/component.d.ts +1 -1
|
@@ -0,0 +1,387 @@
|
|
|
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
|
+
this.hasFolded = false;
|
|
127
|
+
/**
|
|
128
|
+
* 自动获取的 schema,当没有手动提供 schema 时使用
|
|
129
|
+
*/
|
|
130
|
+
this.autoSchema$ = this.resource$.pipe(switchMap(resource => {
|
|
131
|
+
if (!resource) {
|
|
132
|
+
return of(null);
|
|
133
|
+
}
|
|
134
|
+
const firstResource = (Array.isArray(resource) ? resource[0] : resource);
|
|
135
|
+
if (!firstResource?.apiVersion || !firstResource?.kind) {
|
|
136
|
+
return of(null);
|
|
137
|
+
}
|
|
138
|
+
return this.schemaService.getResourceSchema(firstResource.apiVersion, firstResource.kind);
|
|
139
|
+
}), publishRef());
|
|
140
|
+
/**
|
|
141
|
+
* 最终使用的 schema,优先使用手动提供的,否则使用自动获取的
|
|
142
|
+
*/
|
|
143
|
+
this.finalSchema$ = combineLatest([this.schema$, this.autoSchema$]).pipe(map(([manualSchema, autoSchema]) => manualSchema || autoSchema), distinctUntilChanged(), shareReplay(1));
|
|
144
|
+
this.yamlSchemaService =
|
|
145
|
+
this.monacoLanguageService.getLanguageSchemaService(['yaml', 'yamlDefaults'], yamlDefaults);
|
|
146
|
+
// 自动设置 schema
|
|
147
|
+
combineLatest([this.resource$, this.finalSchema$])
|
|
148
|
+
.pipe(takeUntil(this.destroy$))
|
|
149
|
+
.subscribe(([resource, schema]) => {
|
|
150
|
+
if (resource && schema) {
|
|
151
|
+
const firstResource = Array.isArray(resource)
|
|
152
|
+
? resource[0]
|
|
153
|
+
: resource;
|
|
154
|
+
if (firstResource && !Array.isArray(firstResource)) {
|
|
155
|
+
this.setYamlSchema(firstResource, schema);
|
|
156
|
+
}
|
|
157
|
+
}
|
|
158
|
+
});
|
|
159
|
+
this.autoSchema$.pipe(takeUntil(this.destroy$)).subscribe();
|
|
160
|
+
}
|
|
161
|
+
ngAfterViewInit() {
|
|
162
|
+
// 监听 YAML 内容变化,自动折叠 managedFields
|
|
163
|
+
if (this.autoFoldManagedFields && this.schemaService.definitions) {
|
|
164
|
+
this.selfFoldManagedFields();
|
|
165
|
+
}
|
|
166
|
+
}
|
|
167
|
+
selfFoldManagedFields() {
|
|
168
|
+
if (this.hasFolded) {
|
|
169
|
+
return;
|
|
170
|
+
}
|
|
171
|
+
this.hasFolded = true;
|
|
172
|
+
setTimeout(() => {
|
|
173
|
+
const editor = this.getEditorInstance();
|
|
174
|
+
if (editor) {
|
|
175
|
+
foldManagedFields(editor);
|
|
176
|
+
}
|
|
177
|
+
}, 0);
|
|
178
|
+
}
|
|
179
|
+
get value() {
|
|
180
|
+
return this._value;
|
|
181
|
+
}
|
|
182
|
+
set value(val) {
|
|
183
|
+
this._value = val;
|
|
184
|
+
this.onChange(val);
|
|
185
|
+
this.onTouched();
|
|
186
|
+
}
|
|
187
|
+
// ControlValueAccessor implementation
|
|
188
|
+
writeValue(value) {
|
|
189
|
+
this._value = value || '';
|
|
190
|
+
}
|
|
191
|
+
registerOnChange(fn) {
|
|
192
|
+
this.onChange = fn;
|
|
193
|
+
}
|
|
194
|
+
registerOnTouched(fn) {
|
|
195
|
+
this.onTouched = fn;
|
|
196
|
+
}
|
|
197
|
+
toggleSidebar() {
|
|
198
|
+
this.showSidebar$$.next(!this.showSidebar$$.value);
|
|
199
|
+
}
|
|
200
|
+
toggleDebugInfo() {
|
|
201
|
+
this.showDebugPanel$$.next(!this.showDebugPanel$$.value);
|
|
202
|
+
}
|
|
203
|
+
getCurrentResource() {
|
|
204
|
+
const resource = this.resource;
|
|
205
|
+
if (Array.isArray(resource)) {
|
|
206
|
+
return resource.length > 0 ? resource[0] : null;
|
|
207
|
+
}
|
|
208
|
+
return resource || null;
|
|
209
|
+
}
|
|
210
|
+
getCurrentSchema() {
|
|
211
|
+
return this.schema || null;
|
|
212
|
+
}
|
|
213
|
+
getDebugInfo() {
|
|
214
|
+
const resource = this.getCurrentResource();
|
|
215
|
+
return {
|
|
216
|
+
hasResource: !!resource,
|
|
217
|
+
resourceApiVersion: resource?.apiVersion,
|
|
218
|
+
resourceKind: resource?.kind,
|
|
219
|
+
hasManualSchema: !!this.schema,
|
|
220
|
+
workspaceHelperAvailable: this.schemaService.isWorkspaceHelperAvailable(),
|
|
221
|
+
currentWorkspace: this.schemaService.workspaceHelper?.baseParamsSnapshot,
|
|
222
|
+
};
|
|
223
|
+
}
|
|
224
|
+
onTryYaml(yamlContent) {
|
|
225
|
+
let targetYaml = yamlContent;
|
|
226
|
+
const namespace = this.schemaService.workspaceHelper?.baseParamsSnapshot?.namespace;
|
|
227
|
+
if (this.autoFillNamespace && namespace) {
|
|
228
|
+
targetYaml = parseAll(yamlContent)
|
|
229
|
+
.filter(r => !!r)
|
|
230
|
+
.map((r) => {
|
|
231
|
+
if (!r?.metadata?.namespace) {
|
|
232
|
+
return {
|
|
233
|
+
...r,
|
|
234
|
+
metadata: {
|
|
235
|
+
...r.metadata,
|
|
236
|
+
namespace,
|
|
237
|
+
},
|
|
238
|
+
};
|
|
239
|
+
}
|
|
240
|
+
return r;
|
|
241
|
+
})
|
|
242
|
+
.map(r => stringify(r, { sortMapEntries: true }))
|
|
243
|
+
.join('---\r\n');
|
|
244
|
+
}
|
|
245
|
+
this.tryYaml.emit(targetYaml);
|
|
246
|
+
}
|
|
247
|
+
/**
|
|
248
|
+
* 设置 YAML schema 以提供 hover 提示和自动完成
|
|
249
|
+
*/
|
|
250
|
+
setYamlSchema(resource, schema) {
|
|
251
|
+
if (!schema) {
|
|
252
|
+
return;
|
|
253
|
+
}
|
|
254
|
+
// 使用 apiVersion + kind 组合作为标识
|
|
255
|
+
const apiVersion = resource?.apiVersion || 'unknown';
|
|
256
|
+
const kind = resource?.kind || 'unknown';
|
|
257
|
+
const schemaKey = `${apiVersion}/${kind}`;
|
|
258
|
+
this.modelUri = `${schemaKey}.yaml`;
|
|
259
|
+
this.selfFoldManagedFields();
|
|
260
|
+
// 检查是否已经注册过相同的 schema,避免重复注册
|
|
261
|
+
if (this.registeredSchemas.has(schemaKey)) {
|
|
262
|
+
return;
|
|
263
|
+
}
|
|
264
|
+
// 获取完整的 definitions 以支持 $ref 引用
|
|
265
|
+
const definitions = this.schemaService.definitions || {};
|
|
266
|
+
// 创建包含完整 definitions 的 schema 对象
|
|
267
|
+
const fullSchema = {
|
|
268
|
+
...schema,
|
|
269
|
+
definitions,
|
|
270
|
+
};
|
|
271
|
+
// 确保schema被正确注册,并启用自动完成功能
|
|
272
|
+
this.yamlSchemaService.addSchema({
|
|
273
|
+
uri: `k8s://${schemaKey}.schema.json`,
|
|
274
|
+
fileMatch: [this.modelUri],
|
|
275
|
+
schema: fullSchema,
|
|
276
|
+
});
|
|
277
|
+
this.registeredSchemas.add(schemaKey);
|
|
278
|
+
}
|
|
279
|
+
/**
|
|
280
|
+
* 获取 Monaco 编辑器实例
|
|
281
|
+
*/
|
|
282
|
+
getEditorInstance() {
|
|
283
|
+
if (!this.monacoEditor && this.codeEditorRef?.editor) {
|
|
284
|
+
this.monacoEditor = this.codeEditorRef.editor;
|
|
285
|
+
}
|
|
286
|
+
return this.monacoEditor;
|
|
287
|
+
}
|
|
288
|
+
/**
|
|
289
|
+
* 手动折叠 managedFields
|
|
290
|
+
*/
|
|
291
|
+
foldManagedFields() {
|
|
292
|
+
const editor = this.getEditorInstance();
|
|
293
|
+
if (editor) {
|
|
294
|
+
foldManagedFields(editor);
|
|
295
|
+
}
|
|
296
|
+
}
|
|
297
|
+
ngOnDestroy() {
|
|
298
|
+
this.destroy$.next();
|
|
299
|
+
this.destroy$.complete();
|
|
300
|
+
}
|
|
301
|
+
static { this.ɵfac = function ResourceYamlEditorComponent_Factory(t) { return new (t || ResourceYamlEditorComponent)(i0.ɵɵdirectiveInject(i1.YamlUtilService), i0.ɵɵdirectiveInject(i2.KubernetesSchemaService), i0.ɵɵdirectiveInject(i3.MonacoLanguageService)); }; }
|
|
302
|
+
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: ResourceYamlEditorComponent, selectors: [["acl-resource-yaml-editor"]], viewQuery: function ResourceYamlEditorComponent_Query(rf, ctx) { if (rf & 1) {
|
|
303
|
+
i0.ɵɵviewQuery(_c0, 5);
|
|
304
|
+
} if (rf & 2) {
|
|
305
|
+
let _t;
|
|
306
|
+
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.codeEditorRef = _t.first);
|
|
307
|
+
} }, 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([
|
|
308
|
+
{
|
|
309
|
+
provide: NG_VALUE_ACCESSOR,
|
|
310
|
+
useExisting: forwardRef(() => ResourceYamlEditorComponent),
|
|
311
|
+
multi: true,
|
|
312
|
+
},
|
|
313
|
+
]), 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) {
|
|
314
|
+
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);
|
|
315
|
+
} if (rf & 2) {
|
|
316
|
+
const content_r1 = i0.ɵɵreference(2);
|
|
317
|
+
i0.ɵɵproperty("ngIf", ctx.hasWrapper)("ngIfElse", content_r1);
|
|
318
|
+
} }, dependencies: [i4.CardComponent, NgIf,
|
|
319
|
+
FormsModule, i5.NgControlStatus, i5.NgModel, ButtonModule,
|
|
320
|
+
CodeEditorModule, i3.CodeEditorComponent, i6.TranslatePipe, AsyncPipe,
|
|
321
|
+
NgTemplateOutlet,
|
|
322
|
+
ResourceYamlSidebarComponent,
|
|
323
|
+
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 }); }
|
|
324
|
+
}
|
|
325
|
+
__decorate([
|
|
326
|
+
ObservableInput(),
|
|
327
|
+
__metadata("design:type", Observable)
|
|
328
|
+
], ResourceYamlEditorComponent.prototype, "resource$", void 0);
|
|
329
|
+
__decorate([
|
|
330
|
+
ObservableInput(),
|
|
331
|
+
__metadata("design:type", Observable)
|
|
332
|
+
], ResourceYamlEditorComponent.prototype, "schema$", void 0);
|
|
333
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ResourceYamlEditorComponent, [{
|
|
334
|
+
type: Component,
|
|
335
|
+
args: [{ selector: 'acl-resource-yaml-editor', preserveWhitespaces: false, standalone: true, imports: [
|
|
336
|
+
CARD_MODULE,
|
|
337
|
+
NgIf,
|
|
338
|
+
FormsModule,
|
|
339
|
+
CHECKBOX_MODULE,
|
|
340
|
+
ButtonModule,
|
|
341
|
+
CodeEditorModule,
|
|
342
|
+
TRANSLATE_MODULE,
|
|
343
|
+
AsyncPipe,
|
|
344
|
+
NgTemplateOutlet,
|
|
345
|
+
ResourceYamlSidebarComponent,
|
|
346
|
+
IconModule,
|
|
347
|
+
], providers: [
|
|
348
|
+
{
|
|
349
|
+
provide: NG_VALUE_ACCESSOR,
|
|
350
|
+
useExisting: forwardRef(() => ResourceYamlEditorComponent),
|
|
351
|
+
multi: true,
|
|
352
|
+
},
|
|
353
|
+
], 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"] }]
|
|
354
|
+
}], () => [{ type: i1.YamlUtilService }, { type: i2.KubernetesSchemaService }, { type: i3.MonacoLanguageService }], { codeEditorRef: [{
|
|
355
|
+
type: ViewChild,
|
|
356
|
+
args: ['codeEditor', { static: false }]
|
|
357
|
+
}], hasWrapper: [{
|
|
358
|
+
type: Input
|
|
359
|
+
}], showDebugInfo: [{
|
|
360
|
+
type: Input
|
|
361
|
+
}], sidebarEnable: [{
|
|
362
|
+
type: Input
|
|
363
|
+
}], schema: [{
|
|
364
|
+
type: Input
|
|
365
|
+
}], schemaEnable: [{
|
|
366
|
+
type: Input
|
|
367
|
+
}], exampleEnable: [{
|
|
368
|
+
type: Input
|
|
369
|
+
}], resource: [{
|
|
370
|
+
type: Input
|
|
371
|
+
}], autoFoldManagedFields: [{
|
|
372
|
+
type: Input
|
|
373
|
+
}], originalValue: [{
|
|
374
|
+
type: Input
|
|
375
|
+
}], options: [{
|
|
376
|
+
type: Input
|
|
377
|
+
}], actionsConfig: [{
|
|
378
|
+
type: Input
|
|
379
|
+
}], tryYaml: [{
|
|
380
|
+
type: Output
|
|
381
|
+
}], resource$: [], schema$: [], autoFillNamespace: [{
|
|
382
|
+
type: Input
|
|
383
|
+
}], extraExamples: [{
|
|
384
|
+
type: Input
|
|
385
|
+
}] }); })();
|
|
386
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(ResourceYamlEditorComponent, { className: "ResourceYamlEditorComponent" }); })();
|
|
387
|
+
//# 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  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    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 && this.schemaService.definitions) {\n      this.selfFoldManagedFields();\n    }\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    }, 0);\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    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  /**\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"]}
|