@alauda-fe/common 1.4.28-beta.6 → 1.4.28
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/array-form-table/form/component.d.ts +1 -1
- 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-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/core/abstract/base-nested-form-control.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 +147 -0
- package/esm2022/code/public-api.mjs +5 -1
- package/esm2022/code/resource-yaml-display/component.mjs +257 -43
- package/esm2022/code/resource-yaml-editor/component.mjs +392 -0
- package/esm2022/code/yaml-examples.mjs +337 -0
- package/esm2022/code/yaml-sidebar/component.mjs +482 -0
- package/esm2022/code/yaml-sidebar/types.mjs +2 -0
- package/esm2022/core/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 +3 -3
- 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 +1 -1
- package/styles/global.scss +4 -0
|
@@ -0,0 +1,482 @@
|
|
|
1
|
+
import { IconModule, TabsModule, ButtonModule } from '@alauda/ui';
|
|
2
|
+
import { NgIf, NgForOf, KeyValuePipe } from '@angular/common';
|
|
3
|
+
import { HttpClient } from '@angular/common/http';
|
|
4
|
+
import { Component, Input, ChangeDetectionStrategy, Output, EventEmitter, ChangeDetectorRef, } from '@angular/core';
|
|
5
|
+
import { of, map, catchError } from 'rxjs';
|
|
6
|
+
import { ParseJsonTranslatePipe } from '../../core/pipes/parse-json-translate.pipe';
|
|
7
|
+
import { KubernetesSchemaService } from '../../core/services/kubernetes-schema.service';
|
|
8
|
+
import { TRANSLATE_MODULE } from '../../translate/translate.module';
|
|
9
|
+
import { BUILT_IN_YAML_EXAMPLES } from '../yaml-examples';
|
|
10
|
+
import * as i0 from "@angular/core";
|
|
11
|
+
import * as i1 from "../../core/services/kubernetes-schema.service";
|
|
12
|
+
import * as i2 from "@angular/common/http";
|
|
13
|
+
import * as i3 from "../../translate/translate.pipe";
|
|
14
|
+
import * as i4 from "@alauda/ui";
|
|
15
|
+
function ResourceYamlSidebarComponent_aui_tab_5_ng_container_1_Template(rf, ctx) { if (rf & 1) {
|
|
16
|
+
i0.ɵɵelementContainerStart(0);
|
|
17
|
+
i0.ɵɵtext(1, " Schema ");
|
|
18
|
+
i0.ɵɵelementContainerEnd();
|
|
19
|
+
} }
|
|
20
|
+
function ResourceYamlSidebarComponent_aui_tab_5_ng_container_2_div_1_div_1_Template(rf, ctx) { if (rf & 1) {
|
|
21
|
+
i0.ɵɵelement(0, "div", 13);
|
|
22
|
+
i0.ɵɵpipe(1, "aclParseJsonTranslate");
|
|
23
|
+
} if (rf & 2) {
|
|
24
|
+
const ctx_r0 = i0.ɵɵnextContext(4);
|
|
25
|
+
i0.ɵɵproperty("innerHTML", ctx_r0.processDescription(i0.ɵɵpipeBind1(1, 1, ctx_r0.schema.description)), i0.ɵɵsanitizeHtml);
|
|
26
|
+
} }
|
|
27
|
+
function ResourceYamlSidebarComponent_aui_tab_5_ng_container_2_div_1_ng_container_3_Template(rf, ctx) { if (rf & 1) {
|
|
28
|
+
const _r2 = i0.ɵɵgetCurrentView();
|
|
29
|
+
i0.ɵɵelementContainerStart(0);
|
|
30
|
+
i0.ɵɵelementStart(1, "a", 14);
|
|
31
|
+
i0.ɵɵlistener("click", function ResourceYamlSidebarComponent_aui_tab_5_ng_container_2_div_1_ng_container_3_Template_a_click_1_listener() { i0.ɵɵrestoreView(_r2); const ctx_r0 = i0.ɵɵnextContext(4); return i0.ɵɵresetView(ctx_r0.refresh()); });
|
|
32
|
+
i0.ɵɵtext(2);
|
|
33
|
+
i0.ɵɵelementEnd();
|
|
34
|
+
i0.ɵɵelementContainerEnd();
|
|
35
|
+
} if (rf & 2) {
|
|
36
|
+
const ctx_r0 = i0.ɵɵnextContext(4);
|
|
37
|
+
i0.ɵɵadvance(2);
|
|
38
|
+
i0.ɵɵtextInterpolate(ctx_r0.resourceKind);
|
|
39
|
+
} }
|
|
40
|
+
function ResourceYamlSidebarComponent_aui_tab_5_ng_container_2_div_1_ng_container_4_ng_container_1_Template(rf, ctx) { if (rf & 1) {
|
|
41
|
+
const _r3 = i0.ɵɵgetCurrentView();
|
|
42
|
+
i0.ɵɵelementContainerStart(0);
|
|
43
|
+
i0.ɵɵelementStart(1, "span", 15);
|
|
44
|
+
i0.ɵɵtext(2, ">");
|
|
45
|
+
i0.ɵɵelementEnd();
|
|
46
|
+
i0.ɵɵelementStart(3, "a", 14);
|
|
47
|
+
i0.ɵɵlistener("click", function ResourceYamlSidebarComponent_aui_tab_5_ng_container_2_div_1_ng_container_4_ng_container_1_Template_a_click_3_listener() { i0.ɵɵrestoreView(_r3); const i_r4 = i0.ɵɵnextContext().index; const ctx_r0 = i0.ɵɵnextContext(4); return i0.ɵɵresetView(ctx_r0.navigateToPath(i_r4)); });
|
|
48
|
+
i0.ɵɵtext(4);
|
|
49
|
+
i0.ɵɵelementEnd();
|
|
50
|
+
i0.ɵɵelementContainerEnd();
|
|
51
|
+
} if (rf & 2) {
|
|
52
|
+
const p_r5 = i0.ɵɵnextContext().$implicit;
|
|
53
|
+
i0.ɵɵadvance(4);
|
|
54
|
+
i0.ɵɵtextInterpolate(p_r5);
|
|
55
|
+
} }
|
|
56
|
+
function ResourceYamlSidebarComponent_aui_tab_5_ng_container_2_div_1_ng_container_4_ng_container_2_Template(rf, ctx) { if (rf & 1) {
|
|
57
|
+
i0.ɵɵelementContainerStart(0);
|
|
58
|
+
i0.ɵɵelementStart(1, "span", 15);
|
|
59
|
+
i0.ɵɵtext(2, ">");
|
|
60
|
+
i0.ɵɵelementEnd();
|
|
61
|
+
i0.ɵɵelementStart(3, "span");
|
|
62
|
+
i0.ɵɵtext(4);
|
|
63
|
+
i0.ɵɵelementEnd();
|
|
64
|
+
i0.ɵɵelementContainerEnd();
|
|
65
|
+
} if (rf & 2) {
|
|
66
|
+
const p_r5 = i0.ɵɵnextContext().$implicit;
|
|
67
|
+
i0.ɵɵadvance(4);
|
|
68
|
+
i0.ɵɵtextInterpolate(p_r5);
|
|
69
|
+
} }
|
|
70
|
+
function ResourceYamlSidebarComponent_aui_tab_5_ng_container_2_div_1_ng_container_4_Template(rf, ctx) { if (rf & 1) {
|
|
71
|
+
i0.ɵɵelementContainerStart(0);
|
|
72
|
+
i0.ɵɵtemplate(1, ResourceYamlSidebarComponent_aui_tab_5_ng_container_2_div_1_ng_container_4_ng_container_1_Template, 5, 1, "ng-container", 3)(2, ResourceYamlSidebarComponent_aui_tab_5_ng_container_2_div_1_ng_container_4_ng_container_2_Template, 5, 1, "ng-container", 3);
|
|
73
|
+
i0.ɵɵelementContainerEnd();
|
|
74
|
+
} if (rf & 2) {
|
|
75
|
+
const isLast_r6 = ctx.last;
|
|
76
|
+
i0.ɵɵadvance();
|
|
77
|
+
i0.ɵɵproperty("ngIf", !isLast_r6);
|
|
78
|
+
i0.ɵɵadvance();
|
|
79
|
+
i0.ɵɵproperty("ngIf", isLast_r6);
|
|
80
|
+
} }
|
|
81
|
+
function ResourceYamlSidebarComponent_aui_tab_5_ng_container_2_div_1_div_6_p_7_Template(rf, ctx) { if (rf & 1) {
|
|
82
|
+
const _r7 = i0.ɵɵgetCurrentView();
|
|
83
|
+
i0.ɵɵelementStart(0, "p")(1, "a", 14);
|
|
84
|
+
i0.ɵɵlistener("click", function ResourceYamlSidebarComponent_aui_tab_5_ng_container_2_div_1_div_6_p_7_Template_a_click_1_listener() { i0.ɵɵrestoreView(_r7); const item_r8 = i0.ɵɵnextContext().$implicit; const ctx_r0 = i0.ɵɵnextContext(4); return i0.ɵɵresetView(ctx_r0.drillDownToProperty(item_r8.key)); });
|
|
85
|
+
i0.ɵɵtext(2);
|
|
86
|
+
i0.ɵɵpipe(3, "translate");
|
|
87
|
+
i0.ɵɵelementEnd()();
|
|
88
|
+
} if (rf & 2) {
|
|
89
|
+
i0.ɵɵadvance(2);
|
|
90
|
+
i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(3, 1, "view_detail"), " ");
|
|
91
|
+
} }
|
|
92
|
+
function ResourceYamlSidebarComponent_aui_tab_5_ng_container_2_div_1_div_6_Template(rf, ctx) { if (rf & 1) {
|
|
93
|
+
i0.ɵɵelementStart(0, "div", 16)(1, "h3")(2, "span");
|
|
94
|
+
i0.ɵɵtext(3);
|
|
95
|
+
i0.ɵɵelementEnd();
|
|
96
|
+
i0.ɵɵelementStart(4, "span", 17);
|
|
97
|
+
i0.ɵɵtext(5);
|
|
98
|
+
i0.ɵɵelementEnd()();
|
|
99
|
+
i0.ɵɵelement(6, "p", 18);
|
|
100
|
+
i0.ɵɵtemplate(7, ResourceYamlSidebarComponent_aui_tab_5_ng_container_2_div_1_div_6_p_7_Template, 4, 3, "p", 3);
|
|
101
|
+
i0.ɵɵelementEnd();
|
|
102
|
+
} if (rf & 2) {
|
|
103
|
+
const item_r8 = ctx.$implicit;
|
|
104
|
+
const ctx_r0 = i0.ɵɵnextContext(4);
|
|
105
|
+
i0.ɵɵadvance(3);
|
|
106
|
+
i0.ɵɵtextInterpolate(item_r8.key);
|
|
107
|
+
i0.ɵɵadvance(2);
|
|
108
|
+
i0.ɵɵtextInterpolate(item_r8.value.type);
|
|
109
|
+
i0.ɵɵadvance();
|
|
110
|
+
i0.ɵɵproperty("innerHTML", ctx_r0.processDescription(item_r8.value.description), i0.ɵɵsanitizeHtml);
|
|
111
|
+
i0.ɵɵadvance();
|
|
112
|
+
i0.ɵɵproperty("ngIf", ctx_r0.hasViewableContent(item_r8.value));
|
|
113
|
+
} }
|
|
114
|
+
function ResourceYamlSidebarComponent_aui_tab_5_ng_container_2_div_1_Template(rf, ctx) { if (rf & 1) {
|
|
115
|
+
i0.ɵɵelementStart(0, "div", 7);
|
|
116
|
+
i0.ɵɵtemplate(1, ResourceYamlSidebarComponent_aui_tab_5_ng_container_2_div_1_div_1_Template, 2, 3, "div", 8);
|
|
117
|
+
i0.ɵɵelementStart(2, "div", 9);
|
|
118
|
+
i0.ɵɵtemplate(3, ResourceYamlSidebarComponent_aui_tab_5_ng_container_2_div_1_ng_container_3_Template, 3, 1, "ng-container", 3)(4, ResourceYamlSidebarComponent_aui_tab_5_ng_container_2_div_1_ng_container_4_Template, 3, 2, "ng-container", 10);
|
|
119
|
+
i0.ɵɵelementEnd();
|
|
120
|
+
i0.ɵɵelementStart(5, "div", 11);
|
|
121
|
+
i0.ɵɵtemplate(6, ResourceYamlSidebarComponent_aui_tab_5_ng_container_2_div_1_div_6_Template, 8, 4, "div", 12);
|
|
122
|
+
i0.ɵɵpipe(7, "keyvalue");
|
|
123
|
+
i0.ɵɵelementEnd()();
|
|
124
|
+
} if (rf & 2) {
|
|
125
|
+
const ctx_r0 = i0.ɵɵnextContext(3);
|
|
126
|
+
i0.ɵɵadvance();
|
|
127
|
+
i0.ɵɵproperty("ngIf", ctx_r0.schema.description);
|
|
128
|
+
i0.ɵɵadvance(2);
|
|
129
|
+
i0.ɵɵproperty("ngIf", ctx_r0.path.length);
|
|
130
|
+
i0.ɵɵadvance();
|
|
131
|
+
i0.ɵɵproperty("ngForOf", ctx_r0.path);
|
|
132
|
+
i0.ɵɵadvance(2);
|
|
133
|
+
i0.ɵɵproperty("ngForOf", i0.ɵɵpipeBind1(7, 4, ctx_r0.properties));
|
|
134
|
+
} }
|
|
135
|
+
function ResourceYamlSidebarComponent_aui_tab_5_ng_container_2_Template(rf, ctx) { if (rf & 1) {
|
|
136
|
+
i0.ɵɵelementContainerStart(0);
|
|
137
|
+
i0.ɵɵtemplate(1, ResourceYamlSidebarComponent_aui_tab_5_ng_container_2_div_1_Template, 8, 6, "div", 6);
|
|
138
|
+
i0.ɵɵelementContainerEnd();
|
|
139
|
+
} if (rf & 2) {
|
|
140
|
+
const ctx_r0 = i0.ɵɵnextContext(2);
|
|
141
|
+
i0.ɵɵadvance();
|
|
142
|
+
i0.ɵɵproperty("ngIf", ctx_r0.schema);
|
|
143
|
+
} }
|
|
144
|
+
function ResourceYamlSidebarComponent_aui_tab_5_Template(rf, ctx) { if (rf & 1) {
|
|
145
|
+
i0.ɵɵelementStart(0, "aui-tab");
|
|
146
|
+
i0.ɵɵtemplate(1, ResourceYamlSidebarComponent_aui_tab_5_ng_container_1_Template, 2, 0, "ng-container", 4)(2, ResourceYamlSidebarComponent_aui_tab_5_ng_container_2_Template, 2, 1, "ng-container", 5);
|
|
147
|
+
i0.ɵɵelementEnd();
|
|
148
|
+
} }
|
|
149
|
+
function ResourceYamlSidebarComponent_aui_tab_6_ng_container_1_Template(rf, ctx) { if (rf & 1) {
|
|
150
|
+
i0.ɵɵelementContainerStart(0);
|
|
151
|
+
i0.ɵɵtext(1, " Examples ");
|
|
152
|
+
i0.ɵɵelementContainerEnd();
|
|
153
|
+
} }
|
|
154
|
+
function ResourceYamlSidebarComponent_aui_tab_6_ng_container_2_div_2_Template(rf, ctx) { if (rf & 1) {
|
|
155
|
+
const _r9 = i0.ɵɵgetCurrentView();
|
|
156
|
+
i0.ɵɵelementStart(0, "div", 21)(1, "h3");
|
|
157
|
+
i0.ɵɵtext(2);
|
|
158
|
+
i0.ɵɵelementStart(3, "span");
|
|
159
|
+
i0.ɵɵtext(4);
|
|
160
|
+
i0.ɵɵelementEnd()();
|
|
161
|
+
i0.ɵɵelement(5, "p", 18);
|
|
162
|
+
i0.ɵɵelementStart(6, "p", 22)(7, "a", 14);
|
|
163
|
+
i0.ɵɵlistener("click", function ResourceYamlSidebarComponent_aui_tab_6_ng_container_2_div_2_Template_a_click_7_listener() { const example_r10 = i0.ɵɵrestoreView(_r9).$implicit; const ctx_r0 = i0.ɵɵnextContext(3); return i0.ɵɵresetView(ctx_r0.tryExample(example_r10)); });
|
|
164
|
+
i0.ɵɵelement(8, "aui-icon", 23);
|
|
165
|
+
i0.ɵɵelementStart(9, "span");
|
|
166
|
+
i0.ɵɵtext(10, "Try it");
|
|
167
|
+
i0.ɵɵelementEnd()();
|
|
168
|
+
i0.ɵɵelementStart(11, "a", 14);
|
|
169
|
+
i0.ɵɵlistener("click", function ResourceYamlSidebarComponent_aui_tab_6_ng_container_2_div_2_Template_a_click_11_listener() { const example_r10 = i0.ɵɵrestoreView(_r9).$implicit; const ctx_r0 = i0.ɵɵnextContext(3); return i0.ɵɵresetView(ctx_r0.downloadYaml(example_r10)); });
|
|
170
|
+
i0.ɵɵelement(12, "aui-icon", 24);
|
|
171
|
+
i0.ɵɵelementStart(13, "span");
|
|
172
|
+
i0.ɵɵtext(14, "Download YAML");
|
|
173
|
+
i0.ɵɵelementEnd()()()();
|
|
174
|
+
} if (rf & 2) {
|
|
175
|
+
const example_r10 = ctx.$implicit;
|
|
176
|
+
const i_r11 = ctx.index;
|
|
177
|
+
const ctx_r0 = i0.ɵɵnextContext(3);
|
|
178
|
+
i0.ɵɵadvance(2);
|
|
179
|
+
i0.ɵɵtextInterpolate1(" ", i_r11 + 1, ". ");
|
|
180
|
+
i0.ɵɵadvance(2);
|
|
181
|
+
i0.ɵɵtextInterpolate(example_r10.title);
|
|
182
|
+
i0.ɵɵadvance();
|
|
183
|
+
i0.ɵɵproperty("innerHTML", ctx_r0.processDescription(example_r10.description), i0.ɵɵsanitizeHtml);
|
|
184
|
+
} }
|
|
185
|
+
function ResourceYamlSidebarComponent_aui_tab_6_ng_container_2_Template(rf, ctx) { if (rf & 1) {
|
|
186
|
+
i0.ɵɵelementContainerStart(0);
|
|
187
|
+
i0.ɵɵelementStart(1, "div", 19);
|
|
188
|
+
i0.ɵɵtemplate(2, ResourceYamlSidebarComponent_aui_tab_6_ng_container_2_div_2_Template, 15, 3, "div", 20);
|
|
189
|
+
i0.ɵɵelementEnd();
|
|
190
|
+
i0.ɵɵelementContainerEnd();
|
|
191
|
+
} if (rf & 2) {
|
|
192
|
+
const ctx_r0 = i0.ɵɵnextContext(2);
|
|
193
|
+
i0.ɵɵadvance(2);
|
|
194
|
+
i0.ɵɵproperty("ngForOf", ctx_r0.examples);
|
|
195
|
+
} }
|
|
196
|
+
function ResourceYamlSidebarComponent_aui_tab_6_Template(rf, ctx) { if (rf & 1) {
|
|
197
|
+
i0.ɵɵelementStart(0, "aui-tab");
|
|
198
|
+
i0.ɵɵtemplate(1, ResourceYamlSidebarComponent_aui_tab_6_ng_container_1_Template, 2, 0, "ng-container", 4)(2, ResourceYamlSidebarComponent_aui_tab_6_ng_container_2_Template, 3, 1, "ng-container", 5);
|
|
199
|
+
i0.ɵɵelementEnd();
|
|
200
|
+
} }
|
|
201
|
+
export class ResourceYamlSidebarComponent {
|
|
202
|
+
constructor(schemaService, http, cdr) {
|
|
203
|
+
this.schemaService = schemaService;
|
|
204
|
+
this.http = http;
|
|
205
|
+
this.cdr = cdr;
|
|
206
|
+
this.close = new EventEmitter();
|
|
207
|
+
this.tryYaml = new EventEmitter();
|
|
208
|
+
this.schemaEnable = true;
|
|
209
|
+
this.exampleEnable = true;
|
|
210
|
+
this.DEFINITIONS_PREFIX = '#/definitions/';
|
|
211
|
+
this.path = [];
|
|
212
|
+
this.examples = [];
|
|
213
|
+
this.hasSchema = false;
|
|
214
|
+
this.hasExamples = false;
|
|
215
|
+
}
|
|
216
|
+
ngOnInit() {
|
|
217
|
+
this.refresh();
|
|
218
|
+
this.loadExamples();
|
|
219
|
+
}
|
|
220
|
+
ngOnChanges(changes) {
|
|
221
|
+
if (changes.schema || changes.resource) {
|
|
222
|
+
this.refresh();
|
|
223
|
+
this.loadExamples();
|
|
224
|
+
}
|
|
225
|
+
}
|
|
226
|
+
refresh() {
|
|
227
|
+
if (this.schema) {
|
|
228
|
+
this.currentSchema = this.schema;
|
|
229
|
+
this.properties = this.schema.properties || {};
|
|
230
|
+
this.path = [];
|
|
231
|
+
this.hasSchema = true;
|
|
232
|
+
}
|
|
233
|
+
else {
|
|
234
|
+
this.hasSchema = false;
|
|
235
|
+
}
|
|
236
|
+
if (this.resource) {
|
|
237
|
+
this.resourceKind = this.resource.kind || 'Resource';
|
|
238
|
+
}
|
|
239
|
+
}
|
|
240
|
+
loadExamples() {
|
|
241
|
+
if (!this.resource) {
|
|
242
|
+
this.examples = [];
|
|
243
|
+
this.hasExamples = false;
|
|
244
|
+
this.cdr.markForCheck();
|
|
245
|
+
return;
|
|
246
|
+
}
|
|
247
|
+
const resourceKey = `${this.resource.apiVersion}.${this.resource.kind}`;
|
|
248
|
+
const builtInExamples = BUILT_IN_YAML_EXAMPLES[resourceKey] || [];
|
|
249
|
+
// 加载 ConsoleYAMLSample CRD 中的示例
|
|
250
|
+
this.loadConsoleYAMLSamples().subscribe({
|
|
251
|
+
next: crdExamples => {
|
|
252
|
+
this.examples = [
|
|
253
|
+
...builtInExamples,
|
|
254
|
+
...(this.extraExamples || []),
|
|
255
|
+
...crdExamples,
|
|
256
|
+
];
|
|
257
|
+
this.hasExamples = this.examples.length > 0;
|
|
258
|
+
this.cdr.markForCheck();
|
|
259
|
+
},
|
|
260
|
+
error: () => {
|
|
261
|
+
// 如果加载 CRD 示例失败,只使用内置示例
|
|
262
|
+
this.examples = builtInExamples;
|
|
263
|
+
this.hasExamples = this.examples.length > 0;
|
|
264
|
+
this.cdr.markForCheck();
|
|
265
|
+
},
|
|
266
|
+
});
|
|
267
|
+
}
|
|
268
|
+
loadConsoleYAMLSamples() {
|
|
269
|
+
if (!this.resource) {
|
|
270
|
+
return of([]);
|
|
271
|
+
}
|
|
272
|
+
// 构建查询 ConsoleYAMLSample 的 API 路径
|
|
273
|
+
const apiPath = '/apis/console.alauda.io/v1/consoleyamlsamples';
|
|
274
|
+
return this.http.get(apiPath).pipe(map(response => {
|
|
275
|
+
return response.items
|
|
276
|
+
.filter(sample => {
|
|
277
|
+
const target = sample.spec.targetResource;
|
|
278
|
+
return (target.apiVersion === this.resource.apiVersion &&
|
|
279
|
+
target.kind === this.resource.kind);
|
|
280
|
+
})
|
|
281
|
+
.map(sample => ({
|
|
282
|
+
title: sample.spec.title,
|
|
283
|
+
description: sample.spec.description,
|
|
284
|
+
yaml: sample.spec.yaml,
|
|
285
|
+
snippet: sample.spec.snippet,
|
|
286
|
+
}));
|
|
287
|
+
}), catchError(() => of([])));
|
|
288
|
+
}
|
|
289
|
+
drillDownToProperty(name) {
|
|
290
|
+
const property = this.currentSchema.properties?.[name];
|
|
291
|
+
if (property) {
|
|
292
|
+
let targetSchema = null;
|
|
293
|
+
// 处理 $ref 引用
|
|
294
|
+
if (property.$ref) {
|
|
295
|
+
const ref = property.$ref;
|
|
296
|
+
if (ref.startsWith(this.DEFINITIONS_PREFIX)) {
|
|
297
|
+
const definitionName = ref.replace(this.DEFINITIONS_PREFIX, '');
|
|
298
|
+
// 从根 schema 的 definitions 中获取定义
|
|
299
|
+
const rootDefinitions = this.schemaService.definitions;
|
|
300
|
+
targetSchema = rootDefinitions?.[definitionName] || null;
|
|
301
|
+
}
|
|
302
|
+
}
|
|
303
|
+
// 处理普通的嵌套属性
|
|
304
|
+
else if (property.properties || property.items?.properties) {
|
|
305
|
+
targetSchema = property.items?.properties ? property.items : property;
|
|
306
|
+
}
|
|
307
|
+
if (targetSchema) {
|
|
308
|
+
this.currentSchema = targetSchema;
|
|
309
|
+
this.path.push(name);
|
|
310
|
+
this.properties = targetSchema.properties || {};
|
|
311
|
+
}
|
|
312
|
+
}
|
|
313
|
+
}
|
|
314
|
+
navigateToPath(index) {
|
|
315
|
+
const targetPath = this.path.slice(0, index + 1);
|
|
316
|
+
this.path = [...targetPath];
|
|
317
|
+
let currentObj = this.schema;
|
|
318
|
+
for (const pathSegment of targetPath) {
|
|
319
|
+
const property = currentObj.properties?.[pathSegment];
|
|
320
|
+
if (property) {
|
|
321
|
+
// 处理 $ref 引用
|
|
322
|
+
if (property.$ref) {
|
|
323
|
+
const ref = property.$ref;
|
|
324
|
+
if (ref.startsWith(this.DEFINITIONS_PREFIX)) {
|
|
325
|
+
const definitionName = ref.replace(this.DEFINITIONS_PREFIX, '');
|
|
326
|
+
const rootDefinitions = this.schema?.definitions;
|
|
327
|
+
const definition = rootDefinitions?.[definitionName];
|
|
328
|
+
if (definition) {
|
|
329
|
+
currentObj = definition;
|
|
330
|
+
}
|
|
331
|
+
}
|
|
332
|
+
}
|
|
333
|
+
// 处理普通的嵌套属性
|
|
334
|
+
else {
|
|
335
|
+
currentObj = property.items?.properties ? property.items : property;
|
|
336
|
+
}
|
|
337
|
+
}
|
|
338
|
+
}
|
|
339
|
+
this.currentSchema = currentObj;
|
|
340
|
+
this.properties = currentObj.properties || {};
|
|
341
|
+
}
|
|
342
|
+
hasNestedProperties(property) {
|
|
343
|
+
return ((property.type === 'object' &&
|
|
344
|
+
property.properties &&
|
|
345
|
+
Object.keys(property.properties).length > 0) ||
|
|
346
|
+
(property.type === 'array' &&
|
|
347
|
+
property.items &&
|
|
348
|
+
typeof property.items === 'object' &&
|
|
349
|
+
property.items.properties &&
|
|
350
|
+
Object.keys(property.items.properties || {})
|
|
351
|
+
.length > 0));
|
|
352
|
+
}
|
|
353
|
+
getPropertyType(property) {
|
|
354
|
+
if (property.type) {
|
|
355
|
+
if (Array.isArray(property.type)) {
|
|
356
|
+
return property.type.join(' | ');
|
|
357
|
+
}
|
|
358
|
+
return property.type;
|
|
359
|
+
}
|
|
360
|
+
return 'unknown';
|
|
361
|
+
}
|
|
362
|
+
isRequired(propertyName) {
|
|
363
|
+
return this.currentSchema?.required?.includes(propertyName) || false;
|
|
364
|
+
}
|
|
365
|
+
/**
|
|
366
|
+
* 检查属性是否有 $ref 引用或嵌套属性
|
|
367
|
+
*/
|
|
368
|
+
hasViewableContent(property) {
|
|
369
|
+
return (
|
|
370
|
+
// 有 properties 的对象
|
|
371
|
+
(property.type === 'object' &&
|
|
372
|
+
property.properties &&
|
|
373
|
+
Object.keys(property.properties).length > 0) ||
|
|
374
|
+
// 有 properties 的数组项
|
|
375
|
+
(property.type === 'array' &&
|
|
376
|
+
property.items &&
|
|
377
|
+
typeof property.items === 'object' &&
|
|
378
|
+
property.items.properties &&
|
|
379
|
+
Object.keys(property.items.properties || {})
|
|
380
|
+
.length > 0) ||
|
|
381
|
+
// 有 $ref 引用
|
|
382
|
+
!!property.$ref);
|
|
383
|
+
}
|
|
384
|
+
/**
|
|
385
|
+
* 检查属性是否有 $ref 引用
|
|
386
|
+
*/
|
|
387
|
+
hasRefProperty(property) {
|
|
388
|
+
return !!property.$ref;
|
|
389
|
+
}
|
|
390
|
+
/**
|
|
391
|
+
* 获取 $ref 引用的定义名称
|
|
392
|
+
*/
|
|
393
|
+
getRefDefinitionName(property) {
|
|
394
|
+
const ref = property.$ref;
|
|
395
|
+
if (ref && typeof ref === 'string') {
|
|
396
|
+
// 从 "#/definitions/io.k8s.api.apps.v1.DeploymentSpec" 中提取定义名称
|
|
397
|
+
if (ref.startsWith(this.DEFINITIONS_PREFIX)) {
|
|
398
|
+
return ref.replace(this.DEFINITIONS_PREFIX, '');
|
|
399
|
+
}
|
|
400
|
+
const parts = ref.split('/');
|
|
401
|
+
return parts[parts.length - 1] || ref;
|
|
402
|
+
}
|
|
403
|
+
return '';
|
|
404
|
+
}
|
|
405
|
+
// Examples 相关方法
|
|
406
|
+
tryExample(example) {
|
|
407
|
+
// 触发事件,让父组件处理 try it 功能,将 YAML 内容发送给父组件
|
|
408
|
+
this.tryYaml.emit(example.yaml);
|
|
409
|
+
}
|
|
410
|
+
downloadYaml(example) {
|
|
411
|
+
const blob = new Blob([example.yaml], { type: 'text/yaml' });
|
|
412
|
+
const url = window.URL.createObjectURL(blob);
|
|
413
|
+
const link = document.createElement('a');
|
|
414
|
+
link.href = url;
|
|
415
|
+
link.download = `${example.title.toLowerCase().replace(/\s+/g, '-')}.yaml`;
|
|
416
|
+
document.body.appendChild(link);
|
|
417
|
+
link.click();
|
|
418
|
+
document.body.removeChild(link);
|
|
419
|
+
window.URL.revokeObjectURL(url);
|
|
420
|
+
}
|
|
421
|
+
// 处理描述中的链接
|
|
422
|
+
processDescription(description) {
|
|
423
|
+
if (!description)
|
|
424
|
+
return '';
|
|
425
|
+
// 将 URL 转换为可点击的链接
|
|
426
|
+
const urlRegex = /(https?:\/\/[^\s]+)/g;
|
|
427
|
+
return description.replace(urlRegex, '<a href="$1" target="_blank" rel="noopener noreferrer">$1</a>');
|
|
428
|
+
}
|
|
429
|
+
static { this.ɵfac = function ResourceYamlSidebarComponent_Factory(t) { return new (t || ResourceYamlSidebarComponent)(i0.ɵɵdirectiveInject(i1.KubernetesSchemaService), i0.ɵɵdirectiveInject(i2.HttpClient), i0.ɵɵdirectiveInject(i0.ChangeDetectorRef)); }; }
|
|
430
|
+
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: ResourceYamlSidebarComponent, selectors: [["acl-resource-yaml-sidebar"]], inputs: { resource: "resource", schema: "schema", schemaEnable: "schemaEnable", exampleEnable: "exampleEnable", extraExamples: "extraExamples" }, outputs: { close: "close", tryYaml: "tryYaml" }, standalone: true, features: [i0.ɵɵNgOnChangesFeature, i0.ɵɵStandaloneFeature], decls: 7, vars: 3, consts: [[1, "schema-header"], ["icon", "xmark", 3, "click"], ["type", "card"], [4, "ngIf"], [4, "auiTabLabel"], [4, "auiTabContent"], ["class", "schema-content", 4, "ngIf"], [1, "schema-content"], ["class", "schema-desc", 3, "innerHTML", 4, "ngIf"], [1, "schema-path"], [4, "ngFor", "ngForOf"], [1, "schema-list"], ["class", "schema-item", 4, "ngFor", "ngForOf"], [1, "schema-desc", 3, "innerHTML"], ["href", "javascript:", 3, "click"], [1, "path-mark"], [1, "schema-item"], [1, "obj-type"], [3, "innerHTML"], [1, "example-list"], ["class", "example-item", 4, "ngFor", "ngForOf"], [1, "example-item"], [1, "tw-flex", "tw-justify-between"], ["icon", "arrow_turn_up", "size", "14", "margin", "right"], ["icon", "download", "size", "14", "margin", "right"]], template: function ResourceYamlSidebarComponent_Template(rf, ctx) { if (rf & 1) {
|
|
431
|
+
i0.ɵɵelementStart(0, "div", 0)(1, "span");
|
|
432
|
+
i0.ɵɵtext(2);
|
|
433
|
+
i0.ɵɵelementEnd();
|
|
434
|
+
i0.ɵɵelementStart(3, "aui-icon", 1);
|
|
435
|
+
i0.ɵɵlistener("click", function ResourceYamlSidebarComponent_Template_aui_icon_click_3_listener() { return ctx.close.next(); });
|
|
436
|
+
i0.ɵɵelementEnd()();
|
|
437
|
+
i0.ɵɵelementStart(4, "aui-tab-group", 2);
|
|
438
|
+
i0.ɵɵtemplate(5, ResourceYamlSidebarComponent_aui_tab_5_Template, 3, 0, "aui-tab", 3)(6, ResourceYamlSidebarComponent_aui_tab_6_Template, 3, 0, "aui-tab", 3);
|
|
439
|
+
i0.ɵɵelementEnd();
|
|
440
|
+
} if (rf & 2) {
|
|
441
|
+
i0.ɵɵadvance(2);
|
|
442
|
+
i0.ɵɵtextInterpolate(ctx.resourceKind);
|
|
443
|
+
i0.ɵɵadvance(3);
|
|
444
|
+
i0.ɵɵproperty("ngIf", ctx.schemaEnable && ctx.hasSchema);
|
|
445
|
+
i0.ɵɵadvance();
|
|
446
|
+
i0.ɵɵproperty("ngIf", ctx.exampleEnable && ctx.hasExamples);
|
|
447
|
+
} }, dependencies: [NgIf,
|
|
448
|
+
NgForOf,
|
|
449
|
+
KeyValuePipe, i3.TranslatePipe, ParseJsonTranslatePipe,
|
|
450
|
+
IconModule, i4.IconComponent, TabsModule, i4.TabGroupComponent, i4.TabComponent, i4.TabLabelDirective, i4.TabContentDirective, ButtonModule], styles: ["[_nghost-%COMP%]{display:block;box-sizing:border-box;min-width:360px;padding:16px;background-color:rgb(var(--aui-color-n-10));box-shadow:0 0 4px rgba(var(--aui-color-n-1),.16);margin-left:12px;overflow-y:scroll}[_nghost-%COMP%]::-webkit-scrollbar{width:8px;height:4px}[_nghost-%COMP%]::-webkit-scrollbar-thumb{border-radius:4px;background-color:rgb(var(--aui-color-n-7))}[_nghost-%COMP%]::-webkit-scrollbar-thumb:hover{background-color:rgb(var(--aui-color-n-5))}[_nghost-%COMP%]::-webkit-scrollbar-corner{background-color:transparent}aui-tab-group[_ngcontent-%COMP%]{display:block;margin-top:5px}.schema-header[_ngcontent-%COMP%]{height:40px;display:flex;justify-content:space-between;align-items:center;font-size:18px}.schema-header[_ngcontent-%COMP%] aui-icon[_ngcontent-%COMP%]{font-size:16px;color:rgb(var(--aui-color-n-6));cursor:pointer}.schema-header[_ngcontent-%COMP%] aui-icon[_ngcontent-%COMP%]:hover{color:rgb(var(--aui-color-primary))}.schema-content[_ngcontent-%COMP%]{line-height:20px;overflow-y:auto;height:calc(100% - 40px)}.schema-content[_ngcontent-%COMP%]::-webkit-scrollbar{width:8px;height:4px}.schema-content[_ngcontent-%COMP%]::-webkit-scrollbar-thumb{border-radius:4px;background-color:rgb(var(--aui-color-n-7))}.schema-content[_ngcontent-%COMP%]::-webkit-scrollbar-thumb:hover{background-color:rgb(var(--aui-color-n-5))}.schema-content[_ngcontent-%COMP%]::-webkit-scrollbar-corner{background-color:transparent}.schema-desc[_ngcontent-%COMP%]{margin-bottom:12px}.schema-desc[_ngcontent-%COMP%] a[_ngcontent-%COMP%]{color:#007bff;text-decoration:none}.schema-desc[_ngcontent-%COMP%] a[_ngcontent-%COMP%]:hover{text-decoration:underline}.schema-path[_ngcontent-%COMP%]{display:flex;flex-wrap:wrap;margin-bottom:12px}.schema-path[_ngcontent-%COMP%] *[_ngcontent-%COMP%]{margin-left:2px;word-break:break-all}.schema-path[_ngcontent-%COMP%] span[_ngcontent-%COMP%]:first-child{margin-right:2px}.schema-path[_ngcontent-%COMP%] .path-mark[_ngcontent-%COMP%]{margin:0 4px;color:rgb(var(--aui-color-n-6))}.schema-list[_ngcontent-%COMP%] .schema-item[_ngcontent-%COMP%], .schema-list[_ngcontent-%COMP%] .example-item[_ngcontent-%COMP%], .example-list[_ngcontent-%COMP%] .schema-item[_ngcontent-%COMP%], .example-list[_ngcontent-%COMP%] .example-item[_ngcontent-%COMP%]{padding-left:16px}.schema-list[_ngcontent-%COMP%] .schema-item[_ngcontent-%COMP%]:not(:last-of-type), .schema-list[_ngcontent-%COMP%] .example-item[_ngcontent-%COMP%]:not(:last-of-type), .example-list[_ngcontent-%COMP%] .schema-item[_ngcontent-%COMP%]:not(:last-of-type), .example-list[_ngcontent-%COMP%] .example-item[_ngcontent-%COMP%]:not(:last-of-type){border-bottom:1px solid rgb(var(--aui-color-border));margin-bottom:12px}.schema-list[_ngcontent-%COMP%] .schema-item[_ngcontent-%COMP%] h3[_ngcontent-%COMP%]:before, .example-list[_ngcontent-%COMP%] .schema-item[_ngcontent-%COMP%] h3[_ngcontent-%COMP%]:before{content:\"\";display:block;width:6px;height:6px;border-radius:50%;background-color:rgb(var(--aui-color-n-6));position:absolute;left:-12px;top:8px}.schema-list[_ngcontent-%COMP%] h3[_ngcontent-%COMP%], .example-list[_ngcontent-%COMP%] h3[_ngcontent-%COMP%]{position:relative;font-weight:500;margin-bottom:12px;word-break:break-word}.schema-list[_ngcontent-%COMP%] h3[_ngcontent-%COMP%] span[_ngcontent-%COMP%], .example-list[_ngcontent-%COMP%] h3[_ngcontent-%COMP%] span[_ngcontent-%COMP%]{margin-right:4px}.schema-list[_ngcontent-%COMP%] h3[_ngcontent-%COMP%] .obj-type[_ngcontent-%COMP%], .example-list[_ngcontent-%COMP%] h3[_ngcontent-%COMP%] .obj-type[_ngcontent-%COMP%]{color:rgb(var(--aui-color-n-4))}.schema-list[_ngcontent-%COMP%] p[_ngcontent-%COMP%], .example-list[_ngcontent-%COMP%] p[_ngcontent-%COMP%]{margin-bottom:12px;word-break:break-word}.schema-list[_ngcontent-%COMP%] p[_ngcontent-%COMP%] a[_ngcontent-%COMP%], .example-list[_ngcontent-%COMP%] p[_ngcontent-%COMP%] a[_ngcontent-%COMP%]{color:#007bff;text-decoration:none}.schema-list[_ngcontent-%COMP%] p[_ngcontent-%COMP%] a[_ngcontent-%COMP%]:hover, .example-list[_ngcontent-%COMP%] p[_ngcontent-%COMP%] a[_ngcontent-%COMP%]:hover{text-decoration:underline}.schema-examples[_ngcontent-%COMP%]{padding:16px}.examples-header[_ngcontent-%COMP%]{margin-bottom:16px}.examples-header[_ngcontent-%COMP%] h3[_ngcontent-%COMP%]{margin:0;font-size:18px;font-weight:600;color:#333}.examples-content[_ngcontent-%COMP%] .examples-list[_ngcontent-%COMP%] .example-item[_ngcontent-%COMP%]{margin-bottom:24px;border:1px solid #e1e5e9;border-radius:6px;overflow:hidden}.examples-content[_ngcontent-%COMP%] .examples-list[_ngcontent-%COMP%] .example-item[_ngcontent-%COMP%]:last-child{margin-bottom:0}.examples-content[_ngcontent-%COMP%] .examples-list[_ngcontent-%COMP%] .example-item[_ngcontent-%COMP%] .example-header[_ngcontent-%COMP%]{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background-color:#f8f9fa;border-bottom:1px solid #e1e5e9}.examples-content[_ngcontent-%COMP%] .examples-list[_ngcontent-%COMP%] .example-item[_ngcontent-%COMP%] .example-header[_ngcontent-%COMP%] .example-title[_ngcontent-%COMP%]{margin:0;font-size:16px;font-weight:600;color:#333}.examples-content[_ngcontent-%COMP%] .examples-list[_ngcontent-%COMP%] .example-item[_ngcontent-%COMP%] .example-header[_ngcontent-%COMP%] .example-actions[_ngcontent-%COMP%]{display:flex;gap:8px}.examples-content[_ngcontent-%COMP%] .examples-list[_ngcontent-%COMP%] .example-item[_ngcontent-%COMP%] .example-header[_ngcontent-%COMP%] .example-actions[_ngcontent-%COMP%] .btn[_ngcontent-%COMP%]{padding:4px 12px;font-size:12px;border-radius:4px;cursor:pointer;transition:all .2s ease}.examples-content[_ngcontent-%COMP%] .examples-list[_ngcontent-%COMP%] .example-item[_ngcontent-%COMP%] .example-header[_ngcontent-%COMP%] .example-actions[_ngcontent-%COMP%] .btn.btn-outline-primary[_ngcontent-%COMP%]{color:#007bff;border:1px solid #007bff;background-color:transparent}.examples-content[_ngcontent-%COMP%] .examples-list[_ngcontent-%COMP%] .example-item[_ngcontent-%COMP%] .example-header[_ngcontent-%COMP%] .example-actions[_ngcontent-%COMP%] .btn.btn-outline-primary[_ngcontent-%COMP%]:hover{color:#fff;background-color:#007bff}.examples-content[_ngcontent-%COMP%] .examples-list[_ngcontent-%COMP%] .example-item[_ngcontent-%COMP%] .example-header[_ngcontent-%COMP%] .example-actions[_ngcontent-%COMP%] .btn.btn-outline-secondary[_ngcontent-%COMP%]{color:#6c757d;border:1px solid #6c757d;background-color:transparent}.examples-content[_ngcontent-%COMP%] .examples-list[_ngcontent-%COMP%] .example-item[_ngcontent-%COMP%] .example-header[_ngcontent-%COMP%] .example-actions[_ngcontent-%COMP%] .btn.btn-outline-secondary[_ngcontent-%COMP%]:hover{color:#fff;background-color:#6c757d}.examples-content[_ngcontent-%COMP%] .examples-list[_ngcontent-%COMP%] .example-item[_ngcontent-%COMP%] .example-description[_ngcontent-%COMP%]{padding:12px 16px;color:#666;font-size:14px;line-height:1.5;border-bottom:1px solid #e1e5e9}.examples-content[_ngcontent-%COMP%] .examples-list[_ngcontent-%COMP%] .example-item[_ngcontent-%COMP%] .example-description[_ngcontent-%COMP%] a[_ngcontent-%COMP%]{color:#007bff;text-decoration:none}.examples-content[_ngcontent-%COMP%] .examples-list[_ngcontent-%COMP%] .example-item[_ngcontent-%COMP%] .example-description[_ngcontent-%COMP%] a[_ngcontent-%COMP%]:hover{text-decoration:underline}.examples-content[_ngcontent-%COMP%] .examples-list[_ngcontent-%COMP%] .example-item[_ngcontent-%COMP%] .example-yaml[_ngcontent-%COMP%]{background-color:#f8f9fa}.examples-content[_ngcontent-%COMP%] .examples-list[_ngcontent-%COMP%] .example-item[_ngcontent-%COMP%] .example-yaml[_ngcontent-%COMP%] pre[_ngcontent-%COMP%]{margin:0;padding:16px;background-color:transparent;border:none;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:13px;line-height:1.4;color:#333;overflow-x:auto}.examples-content[_ngcontent-%COMP%] .examples-list[_ngcontent-%COMP%] .example-item[_ngcontent-%COMP%] .example-yaml[_ngcontent-%COMP%] pre[_ngcontent-%COMP%] code[_ngcontent-%COMP%]{background-color:transparent;padding:0;color:inherit}"], changeDetection: 0 }); }
|
|
451
|
+
}
|
|
452
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ResourceYamlSidebarComponent, [{
|
|
453
|
+
type: Component,
|
|
454
|
+
args: [{ selector: 'acl-resource-yaml-sidebar', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [
|
|
455
|
+
NgIf,
|
|
456
|
+
NgForOf,
|
|
457
|
+
KeyValuePipe,
|
|
458
|
+
TRANSLATE_MODULE,
|
|
459
|
+
ParseJsonTranslatePipe,
|
|
460
|
+
IconModule,
|
|
461
|
+
TabsModule,
|
|
462
|
+
ButtonModule,
|
|
463
|
+
], template: "<div class=\"schema-header\">\n <span>{{ resourceKind }}</span>\n <aui-icon\n icon=\"xmark\"\n (click)=\"close.next()\"\n ></aui-icon>\n</div>\n<aui-tab-group type=\"card\">\n <aui-tab *ngIf=\"schemaEnable && hasSchema\">\n <ng-container *auiTabLabel> Schema </ng-container>\n <ng-container *auiTabContent>\n <div\n *ngIf=\"schema\"\n class=\"schema-content\"\n >\n <div\n *ngIf=\"schema.description\"\n class=\"schema-desc\"\n [innerHTML]=\"\n processDescription(schema.description | aclParseJsonTranslate)\n \"\n ></div>\n <div class=\"schema-path\">\n <ng-container *ngIf=\"path.length\">\n <a\n href=\"javascript:\"\n (click)=\"refresh()\"\n >{{ resourceKind }}</a\n >\n </ng-container>\n\n <ng-container *ngFor=\"let p of path; index as i; last as isLast\">\n <ng-container *ngIf=\"!isLast\">\n <span class=\"path-mark\">></span>\n <a\n href=\"javascript:\"\n (click)=\"navigateToPath(i)\"\n >{{ p }}</a\n >\n </ng-container>\n <ng-container *ngIf=\"isLast\">\n <span class=\"path-mark\">></span>\n <span>{{ p }}</span>\n </ng-container>\n </ng-container>\n </div>\n <div class=\"schema-list\">\n <div\n *ngFor=\"let item of properties | keyvalue\"\n class=\"schema-item\"\n >\n <h3>\n <span>{{ item.key }}</span>\n <span class=\"obj-type\">{{ item.value.type }}</span>\n </h3>\n <p [innerHTML]=\"processDescription(item.value.description)\"></p>\n <p *ngIf=\"hasViewableContent(item.value)\">\n <a\n href=\"javascript:\"\n (click)=\"drillDownToProperty(item.key)\"\n >\n {{ 'view_detail' | translate }}\n </a>\n </p>\n </div>\n </div>\n </div>\n </ng-container>\n </aui-tab>\n <aui-tab *ngIf=\"exampleEnable && hasExamples\">\n <ng-container *auiTabLabel> Examples </ng-container>\n <ng-container *auiTabContent>\n <div class=\"example-list\">\n <div\n *ngFor=\"let example of examples; let i = index\"\n class=\"example-item\"\n >\n <h3>\n {{ i + 1 }}. <span>{{ example.title }}</span>\n </h3>\n <p [innerHTML]=\"processDescription(example.description)\"></p>\n <p class=\"tw-flex tw-justify-between\">\n <a\n href=\"javascript:\"\n (click)=\"tryExample(example)\"\n >\n <aui-icon\n icon=\"arrow_turn_up\"\n size=\"14\"\n margin=\"right\"\n ></aui-icon>\n <span>Try it</span>\n </a>\n <a\n href=\"javascript:\"\n (click)=\"downloadYaml(example)\"\n >\n <aui-icon\n icon=\"download\"\n size=\"14\"\n margin=\"right\"\n ></aui-icon>\n <span>Download YAML</span>\n </a>\n </p>\n </div>\n </div>\n </ng-container>\n </aui-tab>\n</aui-tab-group>\n", styles: [":host{display:block;box-sizing:border-box;min-width:360px;padding:16px;background-color:rgb(var(--aui-color-n-10));box-shadow:0 0 4px rgba(var(--aui-color-n-1),.16);margin-left:12px;overflow-y:scroll}:host::-webkit-scrollbar{width:8px;height:4px}:host::-webkit-scrollbar-thumb{border-radius:4px;background-color:rgb(var(--aui-color-n-7))}:host::-webkit-scrollbar-thumb:hover{background-color:rgb(var(--aui-color-n-5))}:host::-webkit-scrollbar-corner{background-color:transparent}aui-tab-group{display:block;margin-top:5px}.schema-header{height:40px;display:flex;justify-content:space-between;align-items:center;font-size:18px}.schema-header aui-icon{font-size:16px;color:rgb(var(--aui-color-n-6));cursor:pointer}.schema-header aui-icon:hover{color:rgb(var(--aui-color-primary))}.schema-content{line-height:20px;overflow-y:auto;height:calc(100% - 40px)}.schema-content::-webkit-scrollbar{width:8px;height:4px}.schema-content::-webkit-scrollbar-thumb{border-radius:4px;background-color:rgb(var(--aui-color-n-7))}.schema-content::-webkit-scrollbar-thumb:hover{background-color:rgb(var(--aui-color-n-5))}.schema-content::-webkit-scrollbar-corner{background-color:transparent}.schema-desc{margin-bottom:12px}.schema-desc a{color:#007bff;text-decoration:none}.schema-desc a:hover{text-decoration:underline}.schema-path{display:flex;flex-wrap:wrap;margin-bottom:12px}.schema-path *{margin-left:2px;word-break:break-all}.schema-path span:first-child{margin-right:2px}.schema-path .path-mark{margin:0 4px;color:rgb(var(--aui-color-n-6))}.schema-list .schema-item,.schema-list .example-item,.example-list .schema-item,.example-list .example-item{padding-left:16px}.schema-list .schema-item:not(:last-of-type),.schema-list .example-item:not(:last-of-type),.example-list .schema-item:not(:last-of-type),.example-list .example-item:not(:last-of-type){border-bottom:1px solid rgb(var(--aui-color-border));margin-bottom:12px}.schema-list .schema-item h3:before,.example-list .schema-item h3:before{content:\"\";display:block;width:6px;height:6px;border-radius:50%;background-color:rgb(var(--aui-color-n-6));position:absolute;left:-12px;top:8px}.schema-list h3,.example-list h3{position:relative;font-weight:500;margin-bottom:12px;word-break:break-word}.schema-list h3 span,.example-list h3 span{margin-right:4px}.schema-list h3 .obj-type,.example-list h3 .obj-type{color:rgb(var(--aui-color-n-4))}.schema-list p,.example-list p{margin-bottom:12px;word-break:break-word}.schema-list p a,.example-list p a{color:#007bff;text-decoration:none}.schema-list p a:hover,.example-list p a:hover{text-decoration:underline}.schema-examples{padding:16px}.examples-header{margin-bottom:16px}.examples-header h3{margin:0;font-size:18px;font-weight:600;color:#333}.examples-content .examples-list .example-item{margin-bottom:24px;border:1px solid #e1e5e9;border-radius:6px;overflow:hidden}.examples-content .examples-list .example-item:last-child{margin-bottom:0}.examples-content .examples-list .example-item .example-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background-color:#f8f9fa;border-bottom:1px solid #e1e5e9}.examples-content .examples-list .example-item .example-header .example-title{margin:0;font-size:16px;font-weight:600;color:#333}.examples-content .examples-list .example-item .example-header .example-actions{display:flex;gap:8px}.examples-content .examples-list .example-item .example-header .example-actions .btn{padding:4px 12px;font-size:12px;border-radius:4px;cursor:pointer;transition:all .2s ease}.examples-content .examples-list .example-item .example-header .example-actions .btn.btn-outline-primary{color:#007bff;border:1px solid #007bff;background-color:transparent}.examples-content .examples-list .example-item .example-header .example-actions .btn.btn-outline-primary:hover{color:#fff;background-color:#007bff}.examples-content .examples-list .example-item .example-header .example-actions .btn.btn-outline-secondary{color:#6c757d;border:1px solid #6c757d;background-color:transparent}.examples-content .examples-list .example-item .example-header .example-actions .btn.btn-outline-secondary:hover{color:#fff;background-color:#6c757d}.examples-content .examples-list .example-item .example-description{padding:12px 16px;color:#666;font-size:14px;line-height:1.5;border-bottom:1px solid #e1e5e9}.examples-content .examples-list .example-item .example-description a{color:#007bff;text-decoration:none}.examples-content .examples-list .example-item .example-description a:hover{text-decoration:underline}.examples-content .examples-list .example-item .example-yaml{background-color:#f8f9fa}.examples-content .examples-list .example-item .example-yaml pre{margin:0;padding:16px;background-color:transparent;border:none;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:13px;line-height:1.4;color:#333;overflow-x:auto}.examples-content .examples-list .example-item .example-yaml pre code{background-color:transparent;padding:0;color:inherit}\n"] }]
|
|
464
|
+
}], () => [{ type: i1.KubernetesSchemaService }, { type: i2.HttpClient }, { type: i0.ChangeDetectorRef }], { resource: [{
|
|
465
|
+
type: Input
|
|
466
|
+
}], schema: [{
|
|
467
|
+
type: Input
|
|
468
|
+
}],
|
|
469
|
+
// eslint-disable-next-line @angular-eslint/no-output-native
|
|
470
|
+
close: [{
|
|
471
|
+
type: Output
|
|
472
|
+
}], tryYaml: [{
|
|
473
|
+
type: Output
|
|
474
|
+
}], schemaEnable: [{
|
|
475
|
+
type: Input
|
|
476
|
+
}], exampleEnable: [{
|
|
477
|
+
type: Input
|
|
478
|
+
}], extraExamples: [{
|
|
479
|
+
type: Input
|
|
480
|
+
}] }); })();
|
|
481
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(ResourceYamlSidebarComponent, { className: "ResourceYamlSidebarComponent", filePath: "code/yaml-sidebar/component.ts", lineNumber: 43 }); })();
|
|
482
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"component.js","sourceRoot":"","sources":["../../../../../../libs/common/src/code/yaml-sidebar/component.ts","../../../../../../libs/common/src/code/yaml-sidebar/template.html"],"names":[],"mappings":"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","sourcesContent":["import { IconModule, TabsModule, ButtonModule } from '@alauda/ui';\nimport { NgIf, NgForOf, KeyValuePipe } from '@angular/common';\nimport { HttpClient } from '@angular/common/http';\nimport {\n  Component,\n  Input,\n  OnInit,\n  OnChanges,\n  SimpleChanges,\n  ChangeDetectionStrategy,\n  Output,\n  EventEmitter,\n  ChangeDetectorRef,\n} from '@angular/core';\nimport { Observable, of, map, catchError } from 'rxjs';\n\nimport { ParseJsonTranslatePipe } from '../../core/pipes/parse-json-translate.pipe';\nimport { KubernetesSchemaService } from '../../core/services/kubernetes-schema.service';\nimport { KubernetesResource } from '../../core/types/k8s/core';\nimport { OpenAPIV3SchemaObject } from '../../core/types/schema';\nimport { TRANSLATE_MODULE } from '../../translate/translate.module';\nimport { BUILT_IN_YAML_EXAMPLES } from '../yaml-examples';\n\nimport { YamlExample, ConsoleYAMLSample } from './types';\n\n@Component({\n  selector: 'acl-resource-yaml-sidebar',\n  templateUrl: 'template.html',\n  styleUrls: ['styles.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    NgIf,\n    NgForOf,\n    KeyValuePipe,\n    TRANSLATE_MODULE,\n    ParseJsonTranslatePipe,\n    IconModule,\n    TabsModule,\n    ButtonModule,\n  ],\n})\nexport class ResourceYamlSidebarComponent implements OnInit, OnChanges {\n  @Input()\n  resource: KubernetesResource;\n\n  @Input()\n  schema: OpenAPIV3SchemaObject;\n\n  @Output()\n  // eslint-disable-next-line @angular-eslint/no-output-native\n  close = new EventEmitter<void>();\n\n  @Output()\n  tryYaml = new EventEmitter<string>();\n\n  @Input()\n  schemaEnable = true;\n\n  @Input()\n  exampleEnable = true;\n\n  @Input()\n  extraExamples: YamlExample[];\n\n  private readonly DEFINITIONS_PREFIX = '#/definitions/';\n\n  currentSchema: OpenAPIV3SchemaObject;\n  properties: { [key: string]: OpenAPIV3SchemaObject };\n  path: string[] = [];\n  resourceKind: string;\n  examples: YamlExample[] = [];\n  hasSchema = false;\n  hasExamples = false;\n\n  constructor(\n    private schemaService: KubernetesSchemaService,\n    private http: HttpClient,\n    private cdr: ChangeDetectorRef,\n  ) {}\n\n  ngOnInit() {\n    this.refresh();\n    this.loadExamples();\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes.schema || changes.resource) {\n      this.refresh();\n      this.loadExamples();\n    }\n  }\n\n  refresh() {\n    if (this.schema) {\n      this.currentSchema = this.schema;\n      this.properties = this.schema.properties || {};\n      this.path = [];\n      this.hasSchema = true;\n    } else {\n      this.hasSchema = false;\n    }\n\n    if (this.resource) {\n      this.resourceKind = this.resource.kind || 'Resource';\n    }\n  }\n\n  private loadExamples() {\n    if (!this.resource) {\n      this.examples = [];\n      this.hasExamples = false;\n      this.cdr.markForCheck();\n      return;\n    }\n\n    const resourceKey = `${this.resource.apiVersion}.${this.resource.kind}`;\n    const builtInExamples = BUILT_IN_YAML_EXAMPLES[resourceKey] || [];\n\n    // 加载 ConsoleYAMLSample CRD 中的示例\n    this.loadConsoleYAMLSamples().subscribe({\n      next: crdExamples => {\n        this.examples = [\n          ...builtInExamples,\n          ...(this.extraExamples || []),\n          ...crdExamples,\n        ];\n        this.hasExamples = this.examples.length > 0;\n        this.cdr.markForCheck();\n      },\n      error: () => {\n        // 如果加载 CRD 示例失败，只使用内置示例\n        this.examples = builtInExamples;\n        this.hasExamples = this.examples.length > 0;\n        this.cdr.markForCheck();\n      },\n    });\n  }\n\n  private loadConsoleYAMLSamples(): Observable<YamlExample[]> {\n    if (!this.resource) {\n      return of([]);\n    }\n\n    // 构建查询 ConsoleYAMLSample 的 API 路径\n    const apiPath = '/apis/console.alauda.io/v1/consoleyamlsamples';\n\n    return this.http.get<{ items: ConsoleYAMLSample[] }>(apiPath).pipe(\n      map(response => {\n        return response.items\n          .filter(sample => {\n            const target = sample.spec.targetResource;\n            return (\n              target.apiVersion === this.resource.apiVersion &&\n              target.kind === this.resource.kind\n            );\n          })\n          .map(sample => ({\n            title: sample.spec.title,\n            description: sample.spec.description,\n            yaml: sample.spec.yaml,\n            snippet: sample.spec.snippet,\n          }));\n      }),\n      catchError(() => of([])),\n    );\n  }\n\n  drillDownToProperty(name: string) {\n    const property = this.currentSchema.properties?.[name];\n    if (property) {\n      let targetSchema: OpenAPIV3SchemaObject | null = null;\n      // 处理 $ref 引用\n      if ((property as any).$ref) {\n        const ref = (property as any).$ref as string;\n\n        if (ref.startsWith(this.DEFINITIONS_PREFIX)) {\n          const definitionName = ref.replace(this.DEFINITIONS_PREFIX, '');\n          // 从根 schema 的 definitions 中获取定义\n          const rootDefinitions = this.schemaService.definitions;\n          targetSchema = rootDefinitions?.[definitionName] || null;\n        }\n      }\n      // 处理普通的嵌套属性\n      else if (property.properties || property.items?.properties) {\n        targetSchema = property.items?.properties ? property.items : property;\n      }\n\n      if (targetSchema) {\n        this.currentSchema = targetSchema;\n        this.path.push(name);\n        this.properties = targetSchema.properties || {};\n      }\n    }\n  }\n\n  navigateToPath(index: number) {\n    const targetPath = this.path.slice(0, index + 1);\n    this.path = [...targetPath];\n\n    let currentObj = this.schema;\n    for (const pathSegment of targetPath) {\n      const property = currentObj.properties?.[pathSegment];\n      if (property) {\n        // 处理 $ref 引用\n        if ((property as any).$ref) {\n          const ref = (property as any).$ref as string;\n          if (ref.startsWith(this.DEFINITIONS_PREFIX)) {\n            const definitionName = ref.replace(this.DEFINITIONS_PREFIX, '');\n            const rootDefinitions = (this.schema as any)?.definitions;\n            const definition = rootDefinitions?.[definitionName];\n            if (definition) {\n              currentObj = definition;\n            }\n          }\n        }\n        // 处理普通的嵌套属性\n        else {\n          currentObj = property.items?.properties ? property.items : property;\n        }\n      }\n    }\n\n    this.currentSchema = currentObj;\n    this.properties = currentObj.properties || {};\n  }\n\n  hasNestedProperties(property: OpenAPIV3SchemaObject): boolean {\n    return (\n      (property.type === 'object' &&\n        property.properties &&\n        Object.keys(property.properties).length > 0) ||\n      (property.type === 'array' &&\n        property.items &&\n        typeof property.items === 'object' &&\n        (property.items as OpenAPIV3SchemaObject).properties &&\n        Object.keys((property.items as OpenAPIV3SchemaObject).properties || {})\n          .length > 0)\n    );\n  }\n\n  getPropertyType(property: OpenAPIV3SchemaObject): string {\n    if (property.type) {\n      if (Array.isArray(property.type)) {\n        return property.type.join(' | ');\n      }\n      return property.type;\n    }\n    return 'unknown';\n  }\n\n  isRequired(propertyName: string): boolean {\n    return this.currentSchema?.required?.includes(propertyName) || false;\n  }\n\n  /**\n   * 检查属性是否有 $ref 引用或嵌套属性\n   */\n  hasViewableContent(property: OpenAPIV3SchemaObject): boolean {\n    return (\n      // 有 properties 的对象\n      (property.type === 'object' &&\n        property.properties &&\n        Object.keys(property.properties).length > 0) ||\n      // 有 properties 的数组项\n      (property.type === 'array' &&\n        property.items &&\n        typeof property.items === 'object' &&\n        (property.items as OpenAPIV3SchemaObject).properties &&\n        Object.keys((property.items as OpenAPIV3SchemaObject).properties || {})\n          .length > 0) ||\n      // 有 $ref 引用\n      !!(property as any).$ref\n    );\n  }\n\n  /**\n   * 检查属性是否有 $ref 引用\n   */\n  hasRefProperty(property: OpenAPIV3SchemaObject): boolean {\n    return !!(property as any).$ref;\n  }\n\n  /**\n   * 获取 $ref 引用的定义名称\n   */\n  getRefDefinitionName(property: OpenAPIV3SchemaObject): string {\n    const ref = (property as any).$ref;\n    if (ref && typeof ref === 'string') {\n      // 从 \"#/definitions/io.k8s.api.apps.v1.DeploymentSpec\" 中提取定义名称\n      if (ref.startsWith(this.DEFINITIONS_PREFIX)) {\n        return ref.replace(this.DEFINITIONS_PREFIX, '');\n      }\n      const parts = ref.split('/');\n      return parts[parts.length - 1] || ref;\n    }\n    return '';\n  }\n\n  // Examples 相关方法\n  tryExample(example: YamlExample) {\n    // 触发事件，让父组件处理 try it 功能，将 YAML 内容发送给父组件\n    this.tryYaml.emit(example.yaml);\n  }\n\n  downloadYaml(example: YamlExample) {\n    const blob = new Blob([example.yaml], { type: 'text/yaml' });\n    const url = window.URL.createObjectURL(blob);\n    const link = document.createElement('a');\n    link.href = url;\n    link.download = `${example.title.toLowerCase().replace(/\\s+/g, '-')}.yaml`;\n    document.body.appendChild(link);\n    link.click();\n    document.body.removeChild(link);\n    window.URL.revokeObjectURL(url);\n  }\n\n  // 处理描述中的链接\n  processDescription(description: string): string {\n    if (!description) return '';\n\n    // 将 URL 转换为可点击的链接\n    const urlRegex = /(https?:\\/\\/[^\\s]+)/g;\n    return description.replace(\n      urlRegex,\n      '<a href=\"$1\" target=\"_blank\" rel=\"noopener noreferrer\">$1</a>',\n    );\n  }\n}\n","<div class=\"schema-header\">\n  <span>{{ resourceKind }}</span>\n  <aui-icon\n    icon=\"xmark\"\n    (click)=\"close.next()\"\n  ></aui-icon>\n</div>\n<aui-tab-group type=\"card\">\n  <aui-tab *ngIf=\"schemaEnable && hasSchema\">\n    <ng-container *auiTabLabel> Schema </ng-container>\n    <ng-container *auiTabContent>\n      <div\n        *ngIf=\"schema\"\n        class=\"schema-content\"\n      >\n        <div\n          *ngIf=\"schema.description\"\n          class=\"schema-desc\"\n          [innerHTML]=\"\n            processDescription(schema.description | aclParseJsonTranslate)\n          \"\n        ></div>\n        <div class=\"schema-path\">\n          <ng-container *ngIf=\"path.length\">\n            <a\n              href=\"javascript:\"\n              (click)=\"refresh()\"\n              >{{ resourceKind }}</a\n            >\n          </ng-container>\n\n          <ng-container *ngFor=\"let p of path; index as i; last as isLast\">\n            <ng-container *ngIf=\"!isLast\">\n              <span class=\"path-mark\">></span>\n              <a\n                href=\"javascript:\"\n                (click)=\"navigateToPath(i)\"\n                >{{ p }}</a\n              >\n            </ng-container>\n            <ng-container *ngIf=\"isLast\">\n              <span class=\"path-mark\">></span>\n              <span>{{ p }}</span>\n            </ng-container>\n          </ng-container>\n        </div>\n        <div class=\"schema-list\">\n          <div\n            *ngFor=\"let item of properties | keyvalue\"\n            class=\"schema-item\"\n          >\n            <h3>\n              <span>{{ item.key }}</span>\n              <span class=\"obj-type\">{{ item.value.type }}</span>\n            </h3>\n            <p [innerHTML]=\"processDescription(item.value.description)\"></p>\n            <p *ngIf=\"hasViewableContent(item.value)\">\n              <a\n                href=\"javascript:\"\n                (click)=\"drillDownToProperty(item.key)\"\n              >\n                {{ 'view_detail' | translate }}\n              </a>\n            </p>\n          </div>\n        </div>\n      </div>\n    </ng-container>\n  </aui-tab>\n  <aui-tab *ngIf=\"exampleEnable && hasExamples\">\n    <ng-container *auiTabLabel> Examples </ng-container>\n    <ng-container *auiTabContent>\n      <div class=\"example-list\">\n        <div\n          *ngFor=\"let example of examples; let i = index\"\n          class=\"example-item\"\n        >\n          <h3>\n            {{ i + 1 }}. <span>{{ example.title }}</span>\n          </h3>\n          <p [innerHTML]=\"processDescription(example.description)\"></p>\n          <p class=\"tw-flex tw-justify-between\">\n            <a\n              href=\"javascript:\"\n              (click)=\"tryExample(example)\"\n            >\n              <aui-icon\n                icon=\"arrow_turn_up\"\n                size=\"14\"\n                margin=\"right\"\n              ></aui-icon>\n              <span>Try it</span>\n            </a>\n            <a\n              href=\"javascript:\"\n              (click)=\"downloadYaml(example)\"\n            >\n              <aui-icon\n                icon=\"download\"\n                size=\"14\"\n                margin=\"right\"\n              ></aui-icon>\n              <span>Download YAML</span>\n            </a>\n          </p>\n        </div>\n      </div>\n    </ng-container>\n  </aui-tab>\n</aui-tab-group>\n"]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbW1vbi9zcmMvY29kZS95YW1sLXNpZGViYXIvdHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgWWFtbEV4YW1wbGUge1xuICB0aXRsZTogc3RyaW5nO1xuICBkZXNjcmlwdGlvbjogc3RyaW5nO1xuICB5YW1sOiBzdHJpbmc7XG4gIHNuaXBwZXQ/OiBib29sZWFuO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIENvbnNvbGVZQU1MU2FtcGxlIHtcbiAgbWV0YWRhdGE6IHtcbiAgICBuYW1lOiBzdHJpbmc7XG4gIH07XG4gIHNwZWM6IHtcbiAgICB0aXRsZTogc3RyaW5nO1xuICAgIGRlc2NyaXB0aW9uOiBzdHJpbmc7XG4gICAgeWFtbDogc3RyaW5nO1xuICAgIHNuaXBwZXQ/OiBib29sZWFuO1xuICAgIHRhcmdldFJlc291cmNlOiB7XG4gICAgICBhcGlWZXJzaW9uOiBzdHJpbmc7XG4gICAgICBraW5kOiBzdHJpbmc7XG4gICAgfTtcbiAgfTtcbn1cbiJdfQ==
|
|
@@ -30,7 +30,7 @@ export class NestedTreeNodeComponent extends CdkNestedTreeNode {
|
|
|
30
30
|
},
|
|
31
31
|
], changeDetection: ChangeDetectionStrategy.OnPush, styles: [":host{display:block}\n"] }]
|
|
32
32
|
}], null, null); })();
|
|
33
|
-
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(NestedTreeNodeComponent, { className: "NestedTreeNodeComponent" }); })();
|
|
33
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(NestedTreeNodeComponent, { className: "NestedTreeNodeComponent", filePath: "core/components/tree/node/component.ts", lineNumber: 35 }); })();
|
|
34
34
|
export class TreeNodeDefDirective extends CdkTreeNodeDef {
|
|
35
35
|
static { this.ɵfac = /*@__PURE__*/ (() => { let ɵTreeNodeDefDirective_BaseFactory; return function TreeNodeDefDirective_Factory(t) { return (ɵTreeNodeDefDirective_BaseFactory || (ɵTreeNodeDefDirective_BaseFactory = i0.ɵɵgetInheritedFactory(TreeNodeDefDirective)))(t || TreeNodeDefDirective); }; })(); }
|
|
36
36
|
static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: TreeNodeDefDirective, selectors: [["", "aclTreeNodeDef", ""]], inputs: { when: [0, "aclTreeNodeDefWhen", "when"] }, features: [i0.ɵɵProvidersFeature([{ provide: CdkTreeNodeDef, useExisting: TreeNodeDefDirective }]), i0.ɵɵInheritDefinitionFeature] }); }
|
|
@@ -24,5 +24,5 @@ export class TreeComponent extends CdkTree {
|
|
|
24
24
|
type: ViewChild,
|
|
25
25
|
args: [TreeNodeOutletDirective, { static: true }]
|
|
26
26
|
}] }); })();
|
|
27
|
-
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(TreeComponent, { className: "TreeComponent" }); })();
|
|
27
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(TreeComponent, { className: "TreeComponent", filePath: "core/components/tree/tree/component.ts", lineNumber: 20 }); })();
|
|
28
28
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21tb24vc3JjL2NvcmUvY29tcG9uZW50cy90cmVlL3RyZWUvY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21tb24vc3JjL2NvcmUvY29tcG9uZW50cy90cmVlL3RyZWUvdGVtcGxhdGUuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSw4RUFBOEU7QUFDOUUsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQzVDLE9BQU8sRUFDTCx1QkFBdUIsRUFDdkIsU0FBUyxFQUNULFNBQVMsRUFDVCxpQkFBaUIsR0FDbEIsTUFBTSxlQUFlLENBQUM7QUFFdkIsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sV0FBVyxDQUFDOzs7QUFVcEQsTUFBTSxPQUFPLGFBQW9CLFNBQVEsT0FBYTt3TkFBekMsYUFBYSxTQUFiLGFBQWE7b0VBQWIsYUFBYTsyQkFDYix1QkFBdUI7Ozs7cUVBSHZCLENBQUMsRUFBRSxPQUFPLEVBQUUsT0FBTyxFQUFFLFdBQVcsRUFBRSxhQUFhLEVBQUUsQ0FBQztZQ2pCL0QsOEJBQXVCO1lBQ3JCLDJCQUErQztZQUNqRCxpQkFBTTs7O2lGRGlCTyxhQUFhO2NBUnpCLFNBQVM7MkJBQ0UsVUFBVSxZQUNWLFNBQVMsaUJBRUosaUJBQWlCLENBQUMsSUFBSSxtQkFDcEIsdUJBQXVCLENBQUMsT0FBTyxhQUNyQyxDQUFDLEVBQUUsT0FBTyxFQUFFLE9BQU8sRUFBRSxXQUFXLGVBQWUsRUFBRSxDQUFDO2dCQUlwRCxXQUFXO2tCQURuQixTQUFTO21CQUFDLHVCQUF1QixFQUFFLEVBQUUsTUFBTSxFQUFFLElBQUksRUFBRTs7a0ZBRHpDLGFBQWEiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBlc2xpbnQtZGlzYWJsZSBAYW5ndWxhci1lc2xpbnQvcHJlZmVyLW9uLXB1c2gtY29tcG9uZW50LWNoYW5nZS1kZXRlY3Rpb24gKi9cbmltcG9ydCB7IENka1RyZWUgfSBmcm9tICdAYW5ndWxhci9jZGsvdHJlZSc7XG5pbXBvcnQge1xuICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcbiAgQ29tcG9uZW50LFxuICBWaWV3Q2hpbGQsXG4gIFZpZXdFbmNhcHN1bGF0aW9uLFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgVHJlZU5vZGVPdXRsZXREaXJlY3RpdmUgfSBmcm9tICcuLi9vdXRsZXQnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdhY2wtdHJlZScsXG4gIGV4cG9ydEFzOiAnYWNsVHJlZScsXG4gIHRlbXBsYXRlVXJsOiAndGVtcGxhdGUuaHRtbCcsXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmUsXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuRGVmYXVsdCxcbiAgcHJvdmlkZXJzOiBbeyBwcm92aWRlOiBDZGtUcmVlLCB1c2VFeGlzdGluZzogVHJlZUNvbXBvbmVudCB9XSxcbn0pXG5leHBvcnQgY2xhc3MgVHJlZUNvbXBvbmVudDxULCBLPiBleHRlbmRzIENka1RyZWU8VCwgSz4ge1xuICBAVmlld0NoaWxkKFRyZWVOb2RlT3V0bGV0RGlyZWN0aXZlLCB7IHN0YXRpYzogdHJ1ZSB9KVxuICBvdmVycmlkZSBfbm9kZU91dGxldDogVHJlZU5vZGVPdXRsZXREaXJlY3RpdmU7XG59XG4iLCI8ZGl2IGNsYXNzPVwidHJlZS1saXN0XCI+XG4gIDxuZy1jb250YWluZXIgYWNsVHJlZU5vZGVPdXRsZXQ+PC9uZy1jb250YWluZXI+XG48L2Rpdj5cbiJdfQ==
|