@alauda-fe/storage 0.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/alauda-fe-storage.mjs +5 -0
- package/esm2022/index.mjs +23 -0
- package/esm2022/lib/components/pvc-delete-dialog/component.mjs +292 -0
- package/esm2022/lib/components/pvc-expand-capacity-dialog/component.mjs +193 -0
- package/esm2022/lib/components/pvc-form/component.mjs +674 -0
- package/esm2022/lib/components/rebuild-volume-dialog/component.mjs +251 -0
- package/esm2022/lib/components/source-link/component.mjs +81 -0
- package/esm2022/lib/components/spec-form/component.mjs +464 -0
- package/esm2022/lib/components/storage-feature-tags/component.mjs +146 -0
- package/esm2022/lib/components/storageclass-select/component.mjs +179 -0
- package/esm2022/lib/pipes/actual-capacity.pipe.mjs +17 -0
- package/esm2022/lib/services/common-util.service.mjs +163 -0
- package/esm2022/lib/services/pvc-util.service.mjs +416 -0
- package/esm2022/lib/types/commons.mjs +75 -0
- package/esm2022/lib/types/internal.mjs +7 -0
- package/esm2022/lib/types/k8s.mjs +2 -0
- package/esm2022/lib/types/resource-definition.mjs +13 -0
- package/esm2022/lib/types/resource-exports.mjs +8 -0
- package/esm2022/lib/types/resource-internals.mjs +2 -0
- package/esm2022/lib/utils/constants.mjs +202 -0
- package/esm2022/lib/utils/resource-exports.mjs +65 -0
- package/esm2022/lib/utils/util.mjs +132 -0
- package/index.d.ts +17 -0
- package/lib/components/pvc-delete-dialog/component.d.ts +33 -0
- package/lib/components/pvc-expand-capacity-dialog/component.d.ts +36 -0
- package/lib/components/pvc-form/component.d.ts +106 -0
- package/lib/components/rebuild-volume-dialog/component.d.ts +28 -0
- package/lib/components/source-link/component.d.ts +17 -0
- package/lib/components/spec-form/component.d.ts +71 -0
- package/lib/components/storage-feature-tags/component.d.ts +25 -0
- package/lib/components/storageclass-select/component.d.ts +26 -0
- package/lib/pipes/actual-capacity.pipe.d.ts +8 -0
- package/lib/services/common-util.service.d.ts +48 -0
- package/lib/services/pvc-util.service.d.ts +130 -0
- package/lib/types/commons.d.ts +85 -0
- package/lib/types/internal.d.ts +4 -0
- package/lib/types/k8s.d.ts +105 -0
- package/lib/types/resource-definition.d.ts +18 -0
- package/lib/types/resource-exports.d.ts +16 -0
- package/lib/types/resource-internals.d.ts +20 -0
- package/lib/utils/constants.d.ts +37 -0
- package/lib/utils/resource-exports.d.ts +12 -0
- package/lib/utils/util.d.ts +19 -0
- package/package.json +38 -0
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Generated bundle index. Do not edit.
|
|
3
|
+
*/
|
|
4
|
+
export * from './index';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWxhdWRhLWZlLXN0b3JhZ2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9tb2R1bGVzL3N0b3JhZ2Uvc3JjL2FsYXVkYS1mZS1zdG9yYWdlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyxTQUFTLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEdlbmVyYXRlZCBidW5kbGUgaW5kZXguIERvIG5vdCBlZGl0LlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vaW5kZXgnO1xuIl19
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
// components
|
|
2
|
+
export { DeletePvcDialogComponent } from './lib/components/pvc-delete-dialog/component';
|
|
3
|
+
export { PvcExpandCapacityDialogComponent } from './lib/components/pvc-expand-capacity-dialog/component';
|
|
4
|
+
export { PersistentVolumeClaimFormComponent } from './lib/components/pvc-form/component';
|
|
5
|
+
export { RebuildVolumeDialogComponent } from './lib/components/rebuild-volume-dialog/component';
|
|
6
|
+
export { ResourceSpecFormComponent } from './lib/components/spec-form/component';
|
|
7
|
+
export { StorageFeatureTagsComponent } from './lib/components/storage-feature-tags/component';
|
|
8
|
+
export { StorageClassSelectComponent } from './lib/components/storageclass-select/component';
|
|
9
|
+
// utils
|
|
10
|
+
export * from './lib/utils/constants';
|
|
11
|
+
export * from './lib/utils/resource-exports';
|
|
12
|
+
export * from './lib/utils/util';
|
|
13
|
+
// types
|
|
14
|
+
export * from './lib/types/commons';
|
|
15
|
+
export * from './lib/types/k8s';
|
|
16
|
+
export * from './lib/types/resource-definition';
|
|
17
|
+
export * from './lib/types/resource-exports';
|
|
18
|
+
// pipes
|
|
19
|
+
export * from './lib/pipes/actual-capacity.pipe';
|
|
20
|
+
// services
|
|
21
|
+
export { StorageCommonUtilService, } from './lib/services/common-util.service';
|
|
22
|
+
export * from './lib/services/pvc-util.service';
|
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9tb2R1bGVzL3N0b3JhZ2Uvc3JjL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGFBQWE7QUFDYixPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSw4Q0FBOEMsQ0FBQztBQUN4RixPQUFPLEVBQUUsZ0NBQWdDLEVBQUUsTUFBTSx1REFBdUQsQ0FBQztBQUN6RyxPQUFPLEVBQUUsa0NBQWtDLEVBQUUsTUFBTSxxQ0FBcUMsQ0FBQztBQUN6RixPQUFPLEVBQUUsNEJBQTRCLEVBQUUsTUFBTSxrREFBa0QsQ0FBQztBQUNoRyxPQUFPLEVBQUUseUJBQXlCLEVBQUUsTUFBTSxzQ0FBc0MsQ0FBQztBQUNqRixPQUFPLEVBQUUsMkJBQTJCLEVBQUUsTUFBTSxpREFBaUQsQ0FBQztBQUM5RixPQUFPLEVBQUUsMkJBQTJCLEVBQUUsTUFBTSxnREFBZ0QsQ0FBQztBQUM3RixRQUFRO0FBQ1IsY0FBYyx1QkFBdUIsQ0FBQztBQUN0QyxjQUFjLDhCQUE4QixDQUFDO0FBQzdDLGNBQWMsa0JBQWtCLENBQUM7QUFDakMsUUFBUTtBQUNSLGNBQWMscUJBQXFCLENBQUM7QUFDcEMsY0FBYyxpQkFBaUIsQ0FBQztBQUNoQyxjQUFjLGlDQUFpQyxDQUFDO0FBQ2hELGNBQWMsOEJBQThCLENBQUM7QUFFN0MsUUFBUTtBQUNSLGNBQWMsa0NBQWtDLENBQUM7QUFFakQsV0FBVztBQUNYLE9BQU8sRUFDTCx3QkFBd0IsR0FFekIsTUFBTSxvQ0FBb0MsQ0FBQztBQUM1QyxjQUFjLGlDQUFpQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLy8gY29tcG9uZW50c1xuZXhwb3J0IHsgRGVsZXRlUHZjRGlhbG9nQ29tcG9uZW50IH0gZnJvbSAnLi9saWIvY29tcG9uZW50cy9wdmMtZGVsZXRlLWRpYWxvZy9jb21wb25lbnQnO1xuZXhwb3J0IHsgUHZjRXhwYW5kQ2FwYWNpdHlEaWFsb2dDb21wb25lbnQgfSBmcm9tICcuL2xpYi9jb21wb25lbnRzL3B2Yy1leHBhbmQtY2FwYWNpdHktZGlhbG9nL2NvbXBvbmVudCc7XG5leHBvcnQgeyBQZXJzaXN0ZW50Vm9sdW1lQ2xhaW1Gb3JtQ29tcG9uZW50IH0gZnJvbSAnLi9saWIvY29tcG9uZW50cy9wdmMtZm9ybS9jb21wb25lbnQnO1xuZXhwb3J0IHsgUmVidWlsZFZvbHVtZURpYWxvZ0NvbXBvbmVudCB9IGZyb20gJy4vbGliL2NvbXBvbmVudHMvcmVidWlsZC12b2x1bWUtZGlhbG9nL2NvbXBvbmVudCc7XG5leHBvcnQgeyBSZXNvdXJjZVNwZWNGb3JtQ29tcG9uZW50IH0gZnJvbSAnLi9saWIvY29tcG9uZW50cy9zcGVjLWZvcm0vY29tcG9uZW50JztcbmV4cG9ydCB7IFN0b3JhZ2VGZWF0dXJlVGFnc0NvbXBvbmVudCB9IGZyb20gJy4vbGliL2NvbXBvbmVudHMvc3RvcmFnZS1mZWF0dXJlLXRhZ3MvY29tcG9uZW50JztcbmV4cG9ydCB7IFN0b3JhZ2VDbGFzc1NlbGVjdENvbXBvbmVudCB9IGZyb20gJy4vbGliL2NvbXBvbmVudHMvc3RvcmFnZWNsYXNzLXNlbGVjdC9jb21wb25lbnQnO1xuLy8gdXRpbHNcbmV4cG9ydCAqIGZyb20gJy4vbGliL3V0aWxzL2NvbnN0YW50cyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi91dGlscy9yZXNvdXJjZS1leHBvcnRzJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3V0aWxzL3V0aWwnO1xuLy8gdHlwZXNcbmV4cG9ydCAqIGZyb20gJy4vbGliL3R5cGVzL2NvbW1vbnMnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdHlwZXMvazhzJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3R5cGVzL3Jlc291cmNlLWRlZmluaXRpb24nO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdHlwZXMvcmVzb3VyY2UtZXhwb3J0cyc7XG5cbi8vIHBpcGVzXG5leHBvcnQgKiBmcm9tICcuL2xpYi9waXBlcy9hY3R1YWwtY2FwYWNpdHkucGlwZSc7XG5cbi8vIHNlcnZpY2VzXG5leHBvcnQge1xuICBTdG9yYWdlQ29tbW9uVXRpbFNlcnZpY2UsXG4gIFN0b3JhZ2VTZWxlY3RPcHRpb24sXG59IGZyb20gJy4vbGliL3NlcnZpY2VzL2NvbW1vbi11dGlsLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvc2VydmljZXMvcHZjLXV0aWwuc2VydmljZSc7XG4iXX0=
|
|
@@ -0,0 +1,292 @@
|
|
|
1
|
+
import { ButtonModule, DIALOG_DATA, DialogModule, DialogRef, IconModule, InputModule, MessageService, TableModule, TooltipModule, } from '@alauda/ui';
|
|
2
|
+
import { E2eAttributeBindingDirective, EffectDirectiveModule, FieldNotAvailablePipe, K8S_UTIL_PIPES_MODULE, K8sApiService, K8sUtilService, PurePipe, RESOURCE_TYPES, TRANSLATE_MODULE, TranslateService, matchLabelsToString, publishRef, skipError, } from '@alauda-fe/common';
|
|
3
|
+
import { AsyncPipe, NgIf } from '@angular/common';
|
|
4
|
+
import { ChangeDetectionStrategy, Component, Inject } from '@angular/core';
|
|
5
|
+
import { FormsModule } from '@angular/forms';
|
|
6
|
+
import { BehaviorSubject, finalize, forkJoin, map, of, switchMap } from 'rxjs';
|
|
7
|
+
import { PVCUtilService } from '../../services/pvc-util.service';
|
|
8
|
+
import { STORAGE_RESOURCE_TYPES } from '../../types/resource-definition';
|
|
9
|
+
import { SourceLinkComponent } from '../source-link/component';
|
|
10
|
+
import * as i0 from "@angular/core";
|
|
11
|
+
import * as i1 from "@alauda-fe/common";
|
|
12
|
+
import * as i2 from "../../services/pvc-util.service";
|
|
13
|
+
import * as i3 from "@alauda/ui";
|
|
14
|
+
import * as i4 from "@angular/forms";
|
|
15
|
+
const _c0 = a0 => ({ name: a0 });
|
|
16
|
+
const _c1 = (a0, a1) => ({ name: a0, length: a1 });
|
|
17
|
+
function DeletePvcDialogComponent_ng_container_6_ng_container_1_aui_table_header_cell_8_Template(rf, ctx) { if (rf & 1) {
|
|
18
|
+
i0.ɵɵelementStart(0, "aui-table-header-cell", 18);
|
|
19
|
+
i0.ɵɵtext(1);
|
|
20
|
+
i0.ɵɵpipe(2, "translate");
|
|
21
|
+
i0.ɵɵelementEnd();
|
|
22
|
+
} if (rf & 2) {
|
|
23
|
+
i0.ɵɵadvance();
|
|
24
|
+
i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(2, 1, "resource_name"), " ");
|
|
25
|
+
} }
|
|
26
|
+
function DeletePvcDialogComponent_ng_container_6_ng_container_1_aui_table_cell_9_Template(rf, ctx) { if (rf & 1) {
|
|
27
|
+
i0.ɵɵelementStart(0, "aui-table-cell")(1, "span", 19);
|
|
28
|
+
i0.ɵɵpipe(2, "aclName");
|
|
29
|
+
i0.ɵɵtext(3);
|
|
30
|
+
i0.ɵɵpipe(4, "aclName");
|
|
31
|
+
i0.ɵɵelementEnd()();
|
|
32
|
+
} if (rf & 2) {
|
|
33
|
+
const item_r1 = ctx.$implicit;
|
|
34
|
+
i0.ɵɵadvance();
|
|
35
|
+
i0.ɵɵproperty("auiTooltip", i0.ɵɵpipeBind1(2, 2, item_r1));
|
|
36
|
+
i0.ɵɵadvance(2);
|
|
37
|
+
i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(4, 4, item_r1), " ");
|
|
38
|
+
} }
|
|
39
|
+
function DeletePvcDialogComponent_ng_container_6_ng_container_1_aui_table_header_cell_11_Template(rf, ctx) { if (rf & 1) {
|
|
40
|
+
i0.ɵɵelementStart(0, "aui-table-header-cell");
|
|
41
|
+
i0.ɵɵtext(1);
|
|
42
|
+
i0.ɵɵpipe(2, "translate");
|
|
43
|
+
i0.ɵɵelementEnd();
|
|
44
|
+
} if (rf & 2) {
|
|
45
|
+
i0.ɵɵadvance();
|
|
46
|
+
i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(2, 1, "type"), " ");
|
|
47
|
+
} }
|
|
48
|
+
function DeletePvcDialogComponent_ng_container_6_ng_container_1_aui_table_cell_12_Template(rf, ctx) { if (rf & 1) {
|
|
49
|
+
i0.ɵɵelementStart(0, "aui-table-cell");
|
|
50
|
+
i0.ɵɵtext(1);
|
|
51
|
+
i0.ɵɵpipe(2, "translate");
|
|
52
|
+
i0.ɵɵelementEnd();
|
|
53
|
+
} if (rf & 2) {
|
|
54
|
+
const item_r2 = ctx.$implicit;
|
|
55
|
+
i0.ɵɵadvance();
|
|
56
|
+
i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(2, 1, item_r2.kind === "VolumeSnapshot" ? "storage.snapshot" : "pod"), " ");
|
|
57
|
+
} }
|
|
58
|
+
function DeletePvcDialogComponent_ng_container_6_ng_container_1_aui_table_header_cell_14_Template(rf, ctx) { if (rf & 1) {
|
|
59
|
+
i0.ɵɵelementStart(0, "aui-table-header-cell");
|
|
60
|
+
i0.ɵɵtext(1);
|
|
61
|
+
i0.ɵɵpipe(2, "translate");
|
|
62
|
+
i0.ɵɵelementEnd();
|
|
63
|
+
} if (rf & 2) {
|
|
64
|
+
i0.ɵɵadvance();
|
|
65
|
+
i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(2, 1, "source"), " ");
|
|
66
|
+
} }
|
|
67
|
+
function DeletePvcDialogComponent_ng_container_6_ng_container_1_aui_table_cell_15_acl_source_link_1_Template(rf, ctx) { if (rf & 1) {
|
|
68
|
+
i0.ɵɵelement(0, "acl-source-link", 21);
|
|
69
|
+
i0.ɵɵpipe(1, "pure");
|
|
70
|
+
i0.ɵɵpipe(2, "async");
|
|
71
|
+
} if (rf & 2) {
|
|
72
|
+
const item_r3 = i0.ɵɵnextContext().$implicit;
|
|
73
|
+
const ctx_r3 = i0.ɵɵnextContext(3);
|
|
74
|
+
i0.ɵɵproperty("sourceLink", i0.ɵɵpipeBind1(2, 6, i0.ɵɵpipeBind4(1, 1, item_r3, ctx_r3.pvcUtil.getSource$, ctx_r3.modalData.cluster, ctx_r3.modalData.namespace)));
|
|
75
|
+
} }
|
|
76
|
+
function DeletePvcDialogComponent_ng_container_6_ng_container_1_aui_table_cell_15_ng_template_2_Template(rf, ctx) { if (rf & 1) {
|
|
77
|
+
i0.ɵɵtext(0);
|
|
78
|
+
i0.ɵɵpipe(1, "aclFieldNotAvailable");
|
|
79
|
+
} if (rf & 2) {
|
|
80
|
+
i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(1, 1, null), " ");
|
|
81
|
+
} }
|
|
82
|
+
function DeletePvcDialogComponent_ng_container_6_ng_container_1_aui_table_cell_15_Template(rf, ctx) { if (rf & 1) {
|
|
83
|
+
i0.ɵɵelementStart(0, "aui-table-cell");
|
|
84
|
+
i0.ɵɵtemplate(1, DeletePvcDialogComponent_ng_container_6_ng_container_1_aui_table_cell_15_acl_source_link_1_Template, 3, 8, "acl-source-link", 20)(2, DeletePvcDialogComponent_ng_container_6_ng_container_1_aui_table_cell_15_ng_template_2_Template, 2, 3, "ng-template", null, 1, i0.ɵɵtemplateRefExtractor);
|
|
85
|
+
i0.ɵɵelementEnd();
|
|
86
|
+
} if (rf & 2) {
|
|
87
|
+
const item_r3 = ctx.$implicit;
|
|
88
|
+
const empty_r5 = i0.ɵɵreference(3);
|
|
89
|
+
i0.ɵɵadvance();
|
|
90
|
+
i0.ɵɵproperty("ngIf", item_r3.kind !== "VolumeSnapshot")("ngIfElse", empty_r5);
|
|
91
|
+
} }
|
|
92
|
+
function DeletePvcDialogComponent_ng_container_6_ng_container_1_aui_table_header_row_16_Template(rf, ctx) { if (rf & 1) {
|
|
93
|
+
i0.ɵɵelement(0, "aui-table-header-row");
|
|
94
|
+
} }
|
|
95
|
+
function DeletePvcDialogComponent_ng_container_6_ng_container_1_aui_table_row_17_Template(rf, ctx) { if (rf & 1) {
|
|
96
|
+
i0.ɵɵelement(0, "aui-table-row");
|
|
97
|
+
} }
|
|
98
|
+
function DeletePvcDialogComponent_ng_container_6_ng_container_1_Template(rf, ctx) { if (rf & 1) {
|
|
99
|
+
i0.ɵɵelementContainerStart(0);
|
|
100
|
+
i0.ɵɵelementStart(1, "p", 7);
|
|
101
|
+
i0.ɵɵtext(2);
|
|
102
|
+
i0.ɵɵpipe(3, "aclName");
|
|
103
|
+
i0.ɵɵpipe(4, "translate");
|
|
104
|
+
i0.ɵɵelementEnd();
|
|
105
|
+
i0.ɵɵelementStart(5, "div", 8)(6, "aui-table", 9);
|
|
106
|
+
i0.ɵɵelementContainerStart(7, 10);
|
|
107
|
+
i0.ɵɵtemplate(8, DeletePvcDialogComponent_ng_container_6_ng_container_1_aui_table_header_cell_8_Template, 3, 3, "aui-table-header-cell", 11)(9, DeletePvcDialogComponent_ng_container_6_ng_container_1_aui_table_cell_9_Template, 5, 6, "aui-table-cell", 12);
|
|
108
|
+
i0.ɵɵelementContainerEnd();
|
|
109
|
+
i0.ɵɵelementContainerStart(10, 13);
|
|
110
|
+
i0.ɵɵtemplate(11, DeletePvcDialogComponent_ng_container_6_ng_container_1_aui_table_header_cell_11_Template, 3, 3, "aui-table-header-cell", 14)(12, DeletePvcDialogComponent_ng_container_6_ng_container_1_aui_table_cell_12_Template, 3, 3, "aui-table-cell", 12);
|
|
111
|
+
i0.ɵɵelementContainerEnd();
|
|
112
|
+
i0.ɵɵelementContainerStart(13, 15);
|
|
113
|
+
i0.ɵɵtemplate(14, DeletePvcDialogComponent_ng_container_6_ng_container_1_aui_table_header_cell_14_Template, 3, 3, "aui-table-header-cell", 14)(15, DeletePvcDialogComponent_ng_container_6_ng_container_1_aui_table_cell_15_Template, 4, 2, "aui-table-cell", 12);
|
|
114
|
+
i0.ɵɵelementContainerEnd();
|
|
115
|
+
i0.ɵɵtemplate(16, DeletePvcDialogComponent_ng_container_6_ng_container_1_aui_table_header_row_16_Template, 1, 0, "aui-table-header-row", 16)(17, DeletePvcDialogComponent_ng_container_6_ng_container_1_aui_table_row_17_Template, 1, 0, "aui-table-row", 17);
|
|
116
|
+
i0.ɵɵelementEnd()();
|
|
117
|
+
i0.ɵɵelementContainerEnd();
|
|
118
|
+
} if (rf & 2) {
|
|
119
|
+
const list_r6 = i0.ɵɵnextContext().declare;
|
|
120
|
+
const ctx_r3 = i0.ɵɵnextContext();
|
|
121
|
+
i0.ɵɵadvance(2);
|
|
122
|
+
i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind2(4, 7, "storage.pvc_can_delete_content", i0.ɵɵpureFunction2(10, _c1, i0.ɵɵpipeBind1(3, 5, ctx_r3.modalData.pvc), list_r6.length)), " ");
|
|
123
|
+
i0.ɵɵadvance(4);
|
|
124
|
+
i0.ɵɵproperty("dataSource", list_r6);
|
|
125
|
+
i0.ɵɵadvance(10);
|
|
126
|
+
i0.ɵɵproperty("auiTableHeaderRowDef", ctx_r3.COLUMNS)("auiTableHeaderRowDefSticky", true);
|
|
127
|
+
i0.ɵɵadvance();
|
|
128
|
+
i0.ɵɵproperty("auiTableRowDefColumns", ctx_r3.COLUMNS);
|
|
129
|
+
} }
|
|
130
|
+
function DeletePvcDialogComponent_ng_container_6_Template(rf, ctx) { if (rf & 1) {
|
|
131
|
+
i0.ɵɵelementContainerStart(0);
|
|
132
|
+
i0.ɵɵtemplate(1, DeletePvcDialogComponent_ng_container_6_ng_container_1_Template, 18, 13, "ng-container", 6);
|
|
133
|
+
i0.ɵɵelementContainerEnd();
|
|
134
|
+
} if (rf & 2) {
|
|
135
|
+
const list_r6 = ctx.declare;
|
|
136
|
+
i0.ɵɵnextContext();
|
|
137
|
+
const deleteTemplate_r7 = i0.ɵɵreference(9);
|
|
138
|
+
i0.ɵɵadvance();
|
|
139
|
+
i0.ɵɵproperty("ngIf", list_r6 == null ? null : list_r6.length)("ngIfElse", deleteTemplate_r7);
|
|
140
|
+
} }
|
|
141
|
+
function DeletePvcDialogComponent_ng_template_8_Template(rf, ctx) { if (rf & 1) {
|
|
142
|
+
const _r8 = i0.ɵɵgetCurrentView();
|
|
143
|
+
i0.ɵɵelementStart(0, "p", 22);
|
|
144
|
+
i0.ɵɵtext(1);
|
|
145
|
+
i0.ɵɵpipe(2, "aclName");
|
|
146
|
+
i0.ɵɵpipe(3, "translate");
|
|
147
|
+
i0.ɵɵelementEnd();
|
|
148
|
+
i0.ɵɵelementStart(4, "div", 23);
|
|
149
|
+
i0.ɵɵtext(5);
|
|
150
|
+
i0.ɵɵpipe(6, "translate");
|
|
151
|
+
i0.ɵɵelementStart(7, "span", 24);
|
|
152
|
+
i0.ɵɵtext(8);
|
|
153
|
+
i0.ɵɵpipe(9, "aclName");
|
|
154
|
+
i0.ɵɵelementEnd();
|
|
155
|
+
i0.ɵɵtext(10);
|
|
156
|
+
i0.ɵɵpipe(11, "translate");
|
|
157
|
+
i0.ɵɵelementEnd();
|
|
158
|
+
i0.ɵɵelementStart(12, "input", 25);
|
|
159
|
+
i0.ɵɵtwoWayListener("ngModelChange", function DeletePvcDialogComponent_ng_template_8_Template_input_ngModelChange_12_listener($event) { i0.ɵɵrestoreView(_r8); const ctx_r3 = i0.ɵɵnextContext(); i0.ɵɵtwoWayBindingSet(ctx_r3.inputValue, $event) || (ctx_r3.inputValue = $event); return i0.ɵɵresetView($event); });
|
|
160
|
+
i0.ɵɵelementEnd();
|
|
161
|
+
} if (rf & 2) {
|
|
162
|
+
const ctx_r3 = i0.ɵɵnextContext();
|
|
163
|
+
i0.ɵɵadvance();
|
|
164
|
+
i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind2(3, 7, "storage.delete_pvc_content", i0.ɵɵpureFunction1(16, _c0, i0.ɵɵpipeBind1(2, 5, ctx_r3.modalData.pvc))), " ");
|
|
165
|
+
i0.ɵɵadvance(4);
|
|
166
|
+
i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(6, 10, "please_enter_extra"), " ");
|
|
167
|
+
i0.ɵɵadvance(3);
|
|
168
|
+
i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(9, 12, ctx_r3.modalData.pvc), " ");
|
|
169
|
+
i0.ɵɵadvance(2);
|
|
170
|
+
i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(11, 14, "extra_determine_delete"), " ");
|
|
171
|
+
i0.ɵɵadvance(2);
|
|
172
|
+
i0.ɵɵtwoWayProperty("ngModel", ctx_r3.inputValue);
|
|
173
|
+
} }
|
|
174
|
+
function DeletePvcDialogComponent_button_12_Template(rf, ctx) { if (rf & 1) {
|
|
175
|
+
const _r9 = i0.ɵɵgetCurrentView();
|
|
176
|
+
i0.ɵɵelementStart(0, "button", 26);
|
|
177
|
+
i0.ɵɵpipe(1, "async");
|
|
178
|
+
i0.ɵɵpipe(2, "aclName");
|
|
179
|
+
i0.ɵɵlistener("click", function DeletePvcDialogComponent_button_12_Template_button_click_0_listener() { i0.ɵɵrestoreView(_r9); const ctx_r3 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r3.confirm()); });
|
|
180
|
+
i0.ɵɵtext(3);
|
|
181
|
+
i0.ɵɵpipe(4, "translate");
|
|
182
|
+
i0.ɵɵelementEnd();
|
|
183
|
+
} if (rf & 2) {
|
|
184
|
+
const ctx_r3 = i0.ɵɵnextContext();
|
|
185
|
+
i0.ɵɵproperty("loading", i0.ɵɵpipeBind1(1, 3, ctx_r3.submitting$$))("disabled", ctx_r3.inputValue !== i0.ɵɵpipeBind1(2, 5, ctx_r3.modalData.pvc));
|
|
186
|
+
i0.ɵɵadvance(3);
|
|
187
|
+
i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(4, 7, "delete"), " ");
|
|
188
|
+
} }
|
|
189
|
+
const COLUMNS = ['name', 'type', 'source'];
|
|
190
|
+
export class DeletePvcDialogComponent {
|
|
191
|
+
constructor(modalData, k8sApi, k8sUtil, pvcUtil, dialogRef, message, translate) {
|
|
192
|
+
this.modalData = modalData;
|
|
193
|
+
this.k8sApi = k8sApi;
|
|
194
|
+
this.k8sUtil = k8sUtil;
|
|
195
|
+
this.pvcUtil = pvcUtil;
|
|
196
|
+
this.dialogRef = dialogRef;
|
|
197
|
+
this.message = message;
|
|
198
|
+
this.translate = translate;
|
|
199
|
+
this.COLUMNS = COLUMNS;
|
|
200
|
+
this.inputValue = '';
|
|
201
|
+
this.submitting$$ = new BehaviorSubject(false);
|
|
202
|
+
this.pods$ = of(this.modalData).pipe(switchMap(({ cluster, namespace, pvc }) => this.pvcUtil.getRelatedPods(cluster, namespace, pvc.metadata.name)), publishRef());
|
|
203
|
+
this.snapshots$ = of(this.modalData).pipe(switchMap(({ cluster, namespace, pvc }) => this.k8sApi.getResourceList({
|
|
204
|
+
type: STORAGE_RESOURCE_TYPES.VOLUME_SNAPSHOT,
|
|
205
|
+
cluster,
|
|
206
|
+
namespace,
|
|
207
|
+
queryParams: {
|
|
208
|
+
limit: '0',
|
|
209
|
+
labelSelector: matchLabelsToString({
|
|
210
|
+
[this.k8sUtil.normalizeType('sourcepvc', 'snapshot')]: this.k8sUtil.getName(pvc),
|
|
211
|
+
}),
|
|
212
|
+
},
|
|
213
|
+
})), map(res => res.items), skipError([]), publishRef());
|
|
214
|
+
this.list$ = forkJoin([this.pods$, this.snapshots$]).pipe(map(([pods, snapshots]) => [...(pods ?? []), ...snapshots]));
|
|
215
|
+
}
|
|
216
|
+
confirm() {
|
|
217
|
+
this.submitting$$.next(true);
|
|
218
|
+
this.k8sApi
|
|
219
|
+
.deleteResource({
|
|
220
|
+
type: RESOURCE_TYPES.PERSISTENT_VOLUME_CLAIM,
|
|
221
|
+
cluster: this.modalData.cluster,
|
|
222
|
+
resource: this.modalData.pvc,
|
|
223
|
+
})
|
|
224
|
+
.pipe(finalize(() => this.submitting$$.next(false)))
|
|
225
|
+
.subscribe(() => {
|
|
226
|
+
this.message.success(this.translate.get('pvc_delete_success'));
|
|
227
|
+
this.dialogRef.close(true);
|
|
228
|
+
});
|
|
229
|
+
}
|
|
230
|
+
static { this.ɵfac = function DeletePvcDialogComponent_Factory(t) { return new (t || DeletePvcDialogComponent)(i0.ɵɵdirectiveInject(DIALOG_DATA), i0.ɵɵdirectiveInject(i1.K8sApiService), i0.ɵɵdirectiveInject(i1.K8sUtilService), i0.ɵɵdirectiveInject(i2.PVCUtilService), i0.ɵɵdirectiveInject(i3.DialogRef), i0.ɵɵdirectiveInject(i3.MessageService), i0.ɵɵdirectiveInject(i1.TranslateService)); }; }
|
|
231
|
+
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: DeletePvcDialogComponent, selectors: [["ng-component"]], standalone: true, features: [i0.ɵɵStandaloneFeature], decls: 17, vars: 17, consts: [["deleteTemplate", ""], ["empty", ""], ["icon", "exclamation_triangle_s", "background", "triangle", "size", "22", 1, "header-icon"], [4, "declare"], ["aui-button", "danger", 3, "loading", "disabled", "click", 4, "ngIf"], ["aui-button", "", "auiDialogClose", ""], [4, "ngIf", "ngIfElse"], [1, "tw-mb-16"], ["auiTableScrollWrapper", "400px"], ["auiTableScrollable", "", 3, "dataSource"], ["auiTableColumnDef", "name"], ["sticky", "", 4, "auiTableHeaderCellDef"], [4, "auiTableCellDef"], ["auiTableColumnDef", "type"], [4, "auiTableHeaderCellDef"], ["auiTableColumnDef", "source"], [4, "auiTableHeaderRowDef", "auiTableHeaderRowDefSticky"], [4, "auiTableRowDef", "auiTableRowDefColumns"], ["sticky", ""], [3, "auiTooltip"], [3, "sourceLink", 4, "ngIf", "ngIfElse"], [3, "sourceLink"], [1, "tw-mt-0", "tw-mb-12", "tw-text-main-text"], [1, "tw-mb-4", "tw-text-main-text"], [1, "tw-text-red"], ["aui-input", "", "trim", "", 3, "ngModelChange", "ngModel"], ["aui-button", "danger", 3, "click", "loading", "disabled"]], template: function DeletePvcDialogComponent_Template(rf, ctx) { if (rf & 1) {
|
|
232
|
+
i0.ɵɵelementStart(0, "aui-dialog-header");
|
|
233
|
+
i0.ɵɵelement(1, "aui-icon", 2);
|
|
234
|
+
i0.ɵɵtext(2);
|
|
235
|
+
i0.ɵɵpipe(3, "aclName");
|
|
236
|
+
i0.ɵɵpipe(4, "translate");
|
|
237
|
+
i0.ɵɵelementEnd();
|
|
238
|
+
i0.ɵɵelementStart(5, "aui-dialog-content");
|
|
239
|
+
i0.ɵɵtemplate(6, DeletePvcDialogComponent_ng_container_6_Template, 2, 2, "ng-container", 3);
|
|
240
|
+
i0.ɵɵpipe(7, "async");
|
|
241
|
+
i0.ɵɵtemplate(8, DeletePvcDialogComponent_ng_template_8_Template, 13, 18, "ng-template", null, 0, i0.ɵɵtemplateRefExtractor);
|
|
242
|
+
i0.ɵɵelementEnd();
|
|
243
|
+
i0.ɵɵelementStart(10, "aui-dialog-footer")(11, "div");
|
|
244
|
+
i0.ɵɵtemplate(12, DeletePvcDialogComponent_button_12_Template, 5, 9, "button", 4);
|
|
245
|
+
i0.ɵɵpipe(13, "async");
|
|
246
|
+
i0.ɵɵelementStart(14, "button", 5);
|
|
247
|
+
i0.ɵɵtext(15);
|
|
248
|
+
i0.ɵɵpipe(16, "translate");
|
|
249
|
+
i0.ɵɵelementEnd()()();
|
|
250
|
+
} if (rf & 2) {
|
|
251
|
+
let tmp_3_0;
|
|
252
|
+
i0.ɵɵadvance(2);
|
|
253
|
+
i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind2(4, 6, "storage.delete_pvc_title", i0.ɵɵpureFunction1(15, _c0, i0.ɵɵpipeBind1(3, 4, ctx.modalData.pvc))), "\n");
|
|
254
|
+
i0.ɵɵadvance(4);
|
|
255
|
+
i0.ɵɵproperty("declare", i0.ɵɵpipeBind1(7, 9, ctx.list$));
|
|
256
|
+
i0.ɵɵadvance(6);
|
|
257
|
+
i0.ɵɵproperty("ngIf", !((tmp_3_0 = i0.ɵɵpipeBind1(13, 11, ctx.list$)) == null ? null : tmp_3_0.length));
|
|
258
|
+
i0.ɵɵadvance(3);
|
|
259
|
+
i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(16, 13, "cancel"), " ");
|
|
260
|
+
} }, dependencies: [AsyncPipe,
|
|
261
|
+
TableModule, i3.TableComponent, i3.TableRowComponent, i3.TableHeaderRowComponent, i3.TableCellDirective, i3.TableCellDefDirective, i3.TableHeaderCellDirective, i3.TableRowDefDirective, i3.TableHeaderRowDefDirective, i3.TableHeaderCellDefDirective, i3.TableColumnDefDirective, i3.TableScrollWrapperDirective, i3.TableScrollableDirective, NgIf,
|
|
262
|
+
PurePipe,
|
|
263
|
+
DialogModule, i3.DialogHeaderComponent, i3.DialogContentComponent, i3.DialogFooterComponent, i3.DialogCloseDirective, IconModule, i3.IconComponent, TooltipModule, i3.TooltipDirective, InputModule, i3.InputComponent, FieldNotAvailablePipe, i1.K8sNamePipe, i1.TranslatePipe, SourceLinkComponent,
|
|
264
|
+
FormsModule, i4.DefaultValueAccessor, i4.NgControlStatus, i4.NgModel, ButtonModule, i3.ButtonComponent, E2eAttributeBindingDirective,
|
|
265
|
+
EffectDirectiveModule, i1.TrimDirective], encapsulation: 2, changeDetection: 0 }); }
|
|
266
|
+
}
|
|
267
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(DeletePvcDialogComponent, [{
|
|
268
|
+
type: Component,
|
|
269
|
+
args: [{ standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, imports: [
|
|
270
|
+
AsyncPipe,
|
|
271
|
+
TableModule,
|
|
272
|
+
NgIf,
|
|
273
|
+
PurePipe,
|
|
274
|
+
DialogModule,
|
|
275
|
+
IconModule,
|
|
276
|
+
TooltipModule,
|
|
277
|
+
InputModule,
|
|
278
|
+
FieldNotAvailablePipe,
|
|
279
|
+
K8S_UTIL_PIPES_MODULE,
|
|
280
|
+
TRANSLATE_MODULE,
|
|
281
|
+
SourceLinkComponent,
|
|
282
|
+
FormsModule,
|
|
283
|
+
ButtonModule,
|
|
284
|
+
E2eAttributeBindingDirective,
|
|
285
|
+
EffectDirectiveModule,
|
|
286
|
+
], template: "<aui-dialog-header>\n <aui-icon\n class=\"header-icon\"\n icon=\"exclamation_triangle_s\"\n background=\"triangle\"\n size=\"22\"\n ></aui-icon>\n {{\n 'storage.delete_pvc_title' | translate: { name: modalData.pvc | aclName }\n }}\n</aui-dialog-header>\n\n<aui-dialog-content>\n <ng-container *declare=\"list$ | async as list\">\n <ng-container *ngIf=\"list?.length; else deleteTemplate\">\n <p class=\"tw-mb-16\">\n {{\n 'storage.pvc_can_delete_content'\n | translate: { name: modalData.pvc | aclName, length: list.length }\n }}\n </p>\n <div auiTableScrollWrapper=\"400px\">\n <aui-table\n auiTableScrollable\n [dataSource]=\"list\"\n >\n <ng-container auiTableColumnDef=\"name\">\n <aui-table-header-cell\n sticky\n *auiTableHeaderCellDef\n >\n {{ 'resource_name' | translate }}\n </aui-table-header-cell>\n <aui-table-cell *auiTableCellDef=\"let item\">\n <span [auiTooltip]=\"item | aclName\">\n {{ item | aclName }}\n </span>\n </aui-table-cell>\n </ng-container>\n <ng-container auiTableColumnDef=\"type\">\n <aui-table-header-cell *auiTableHeaderCellDef>\n {{ 'type' | translate }}\n </aui-table-header-cell>\n <aui-table-cell *auiTableCellDef=\"let item\">\n {{\n (item.kind === 'VolumeSnapshot' ? 'storage.snapshot' : 'pod')\n | translate\n }}\n </aui-table-cell>\n </ng-container>\n <ng-container auiTableColumnDef=\"source\">\n <aui-table-header-cell *auiTableHeaderCellDef>\n {{ 'source' | translate }}\n </aui-table-header-cell>\n <aui-table-cell *auiTableCellDef=\"let item\">\n <acl-source-link\n *ngIf=\"item.kind !== 'VolumeSnapshot'; else empty\"\n [sourceLink]=\"\n item\n | pure\n : pvcUtil.getSource$\n : modalData.cluster\n : modalData.namespace\n | async\n \"\n ></acl-source-link>\n <ng-template #empty>\n {{ null | aclFieldNotAvailable }}\n </ng-template>\n </aui-table-cell>\n </ng-container>\n <aui-table-header-row\n *auiTableHeaderRowDef=\"COLUMNS; sticky: true\"\n ></aui-table-header-row>\n <aui-table-row\n *auiTableRowDef=\"let row; columns: COLUMNS\"\n ></aui-table-row>\n </aui-table>\n </div>\n </ng-container>\n </ng-container>\n <ng-template #deleteTemplate>\n <p class=\"tw-mt-0 tw-mb-12 tw-text-main-text\">\n {{\n 'storage.delete_pvc_content'\n | translate: { name: modalData.pvc | aclName }\n }}\n </p>\n <div class=\"tw-mb-4 tw-text-main-text\">\n {{ 'please_enter_extra' | translate }}\n <span class=\"tw-text-red\">\n {{ modalData.pvc | aclName }}\n </span>\n {{ 'extra_determine_delete' | translate }}\n </div>\n <input\n aui-input\n [(ngModel)]=\"inputValue\"\n trim\n />\n </ng-template>\n</aui-dialog-content>\n\n<aui-dialog-footer>\n <div>\n <button\n *ngIf=\"!(list$ | async)?.length\"\n aui-button=\"danger\"\n [loading]=\"submitting$$ | async\"\n [disabled]=\"inputValue !== (modalData.pvc | aclName)\"\n (click)=\"confirm()\"\n >\n {{ 'delete' | translate }}\n </button>\n <button\n aui-button\n auiDialogClose\n >\n {{ 'cancel' | translate }}\n </button>\n </div>\n</aui-dialog-footer>\n" }]
|
|
287
|
+
}], () => [{ type: undefined, decorators: [{
|
|
288
|
+
type: Inject,
|
|
289
|
+
args: [DIALOG_DATA]
|
|
290
|
+
}] }, { type: i1.K8sApiService }, { type: i1.K8sUtilService }, { type: i2.PVCUtilService }, { type: i3.DialogRef }, { type: i3.MessageService }, { type: i1.TranslateService }], null); })();
|
|
291
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(DeletePvcDialogComponent, { className: "DeletePvcDialogComponent", filePath: "lib/components/pvc-delete-dialog/component.ts", lineNumber: 64 }); })();
|
|
292
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"component.js","sourceRoot":"","sources":["../../../../../../../modules/storage/src/lib/components/pvc-delete-dialog/component.ts","../../../../../../../modules/storage/src/lib/components/pvc-delete-dialog/template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ButtonModule,\n  DIALOG_DATA,\n  DialogModule,\n  DialogRef,\n  IconModule,\n  InputModule,\n  MessageService,\n  TableModule,\n  TooltipModule,\n} from '@alauda/ui';\nimport {\n  E2eAttributeBindingDirective,\n  EffectDirectiveModule,\n  FieldNotAvailablePipe,\n  K8S_UTIL_PIPES_MODULE,\n  K8sApiService,\n  K8sUtilService,\n  KubernetesResource,\n  PersistentVolumeClaim,\n  PurePipe,\n  RESOURCE_TYPES,\n  TRANSLATE_MODULE,\n  TranslateService,\n  matchLabelsToString,\n  publishRef,\n  skipError,\n} from '@alauda-fe/common';\nimport { AsyncPipe, NgIf } from '@angular/common';\nimport { ChangeDetectionStrategy, Component, Inject } from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { BehaviorSubject, finalize, forkJoin, map, of, switchMap } from 'rxjs';\n\nimport { PVCUtilService } from '../../services/pvc-util.service';\nimport { VolumeSnapshot } from '../../types/k8s';\nimport { STORAGE_RESOURCE_TYPES } from '../../types/resource-definition';\nimport { SourceLinkComponent } from '../source-link/component';\n\nconst COLUMNS = ['name', 'type', 'source'];\n\n@Component({\n  standalone: true,\n  templateUrl: 'template.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [\n    AsyncPipe,\n    TableModule,\n    NgIf,\n    PurePipe,\n    DialogModule,\n    IconModule,\n    TooltipModule,\n    InputModule,\n    FieldNotAvailablePipe,\n    K8S_UTIL_PIPES_MODULE,\n    TRANSLATE_MODULE,\n    SourceLinkComponent,\n    FormsModule,\n    ButtonModule,\n    E2eAttributeBindingDirective,\n    EffectDirectiveModule,\n  ],\n})\nexport class DeletePvcDialogComponent {\n  COLUMNS = COLUMNS;\n  inputValue = '';\n\n  submitting$$ = new BehaviorSubject<boolean>(false);\n\n  pods$ = of(this.modalData).pipe(\n    switchMap(({ cluster, namespace, pvc }) =>\n      this.pvcUtil.getRelatedPods(cluster, namespace, pvc.metadata.name),\n    ),\n    publishRef(),\n  );\n\n  snapshots$ = of(this.modalData).pipe(\n    switchMap(({ cluster, namespace, pvc }) =>\n      this.k8sApi.getResourceList<VolumeSnapshot>({\n        type: STORAGE_RESOURCE_TYPES.VOLUME_SNAPSHOT,\n        cluster,\n        namespace,\n        queryParams: {\n          limit: '0',\n          labelSelector: matchLabelsToString({\n            [this.k8sUtil.normalizeType('sourcepvc', 'snapshot')]:\n              this.k8sUtil.getName(pvc),\n          }),\n        },\n      }),\n    ),\n    map(res => res.items),\n    skipError([] as VolumeSnapshot[]),\n    publishRef(),\n  );\n\n  list$ = forkJoin([this.pods$, this.snapshots$]).pipe(\n    map(\n      ([pods, snapshots]) =>\n        [...(pods ?? []), ...snapshots] as KubernetesResource[],\n    ),\n  );\n\n  constructor(\n    @Inject(DIALOG_DATA)\n    public readonly modalData: {\n      cluster: string;\n      namespace: string;\n      pvc: PersistentVolumeClaim;\n    },\n    private readonly k8sApi: K8sApiService,\n    private readonly k8sUtil: K8sUtilService,\n    protected readonly pvcUtil: PVCUtilService,\n    private readonly dialogRef: DialogRef,\n    private readonly message: MessageService,\n    private readonly translate: TranslateService,\n  ) {}\n\n  confirm() {\n    this.submitting$$.next(true);\n\n    this.k8sApi\n      .deleteResource<PersistentVolumeClaim>({\n        type: RESOURCE_TYPES.PERSISTENT_VOLUME_CLAIM,\n        cluster: this.modalData.cluster,\n        resource: this.modalData.pvc,\n      })\n      .pipe(finalize(() => this.submitting$$.next(false)))\n      .subscribe(() => {\n        this.message.success(this.translate.get('pvc_delete_success'));\n        this.dialogRef.close(true);\n      });\n  }\n}\n","<aui-dialog-header>\n  <aui-icon\n    class=\"header-icon\"\n    icon=\"exclamation_triangle_s\"\n    background=\"triangle\"\n    size=\"22\"\n  ></aui-icon>\n  {{\n    'storage.delete_pvc_title' | translate: { name: modalData.pvc | aclName }\n  }}\n</aui-dialog-header>\n\n<aui-dialog-content>\n  <ng-container *declare=\"list$ | async as list\">\n    <ng-container *ngIf=\"list?.length; else deleteTemplate\">\n      <p class=\"tw-mb-16\">\n        {{\n          'storage.pvc_can_delete_content'\n            | translate: { name: modalData.pvc | aclName, length: list.length }\n        }}\n      </p>\n      <div auiTableScrollWrapper=\"400px\">\n        <aui-table\n          auiTableScrollable\n          [dataSource]=\"list\"\n        >\n          <ng-container auiTableColumnDef=\"name\">\n            <aui-table-header-cell\n              sticky\n              *auiTableHeaderCellDef\n            >\n              {{ 'resource_name' | translate }}\n            </aui-table-header-cell>\n            <aui-table-cell *auiTableCellDef=\"let item\">\n              <span [auiTooltip]=\"item | aclName\">\n                {{ item | aclName }}\n              </span>\n            </aui-table-cell>\n          </ng-container>\n          <ng-container auiTableColumnDef=\"type\">\n            <aui-table-header-cell *auiTableHeaderCellDef>\n              {{ 'type' | translate }}\n            </aui-table-header-cell>\n            <aui-table-cell *auiTableCellDef=\"let item\">\n              {{\n                (item.kind === 'VolumeSnapshot' ? 'storage.snapshot' : 'pod')\n                  | translate\n              }}\n            </aui-table-cell>\n          </ng-container>\n          <ng-container auiTableColumnDef=\"source\">\n            <aui-table-header-cell *auiTableHeaderCellDef>\n              {{ 'source' | translate }}\n            </aui-table-header-cell>\n            <aui-table-cell *auiTableCellDef=\"let item\">\n              <acl-source-link\n                *ngIf=\"item.kind !== 'VolumeSnapshot'; else empty\"\n                [sourceLink]=\"\n                  item\n                    | pure\n                      : pvcUtil.getSource$\n                      : modalData.cluster\n                      : modalData.namespace\n                    | async\n                \"\n              ></acl-source-link>\n              <ng-template #empty>\n                {{ null | aclFieldNotAvailable }}\n              </ng-template>\n            </aui-table-cell>\n          </ng-container>\n          <aui-table-header-row\n            *auiTableHeaderRowDef=\"COLUMNS; sticky: true\"\n          ></aui-table-header-row>\n          <aui-table-row\n            *auiTableRowDef=\"let row; columns: COLUMNS\"\n          ></aui-table-row>\n        </aui-table>\n      </div>\n    </ng-container>\n  </ng-container>\n  <ng-template #deleteTemplate>\n    <p class=\"tw-mt-0 tw-mb-12 tw-text-main-text\">\n      {{\n        'storage.delete_pvc_content'\n          | translate: { name: modalData.pvc | aclName }\n      }}\n    </p>\n    <div class=\"tw-mb-4 tw-text-main-text\">\n      {{ 'please_enter_extra' | translate }}\n      <span class=\"tw-text-red\">\n        {{ modalData.pvc | aclName }}\n      </span>\n      {{ 'extra_determine_delete' | translate }}\n    </div>\n    <input\n      aui-input\n      [(ngModel)]=\"inputValue\"\n      trim\n    />\n  </ng-template>\n</aui-dialog-content>\n\n<aui-dialog-footer>\n  <div>\n    <button\n      *ngIf=\"!(list$ | async)?.length\"\n      aui-button=\"danger\"\n      [loading]=\"submitting$$ | async\"\n      [disabled]=\"inputValue !== (modalData.pvc | aclName)\"\n      (click)=\"confirm()\"\n    >\n      {{ 'delete' | translate }}\n    </button>\n    <button\n      aui-button\n      auiDialogClose\n    >\n      {{ 'cancel' | translate }}\n    </button>\n  </div>\n</aui-dialog-footer>\n"]}
|
|
@@ -0,0 +1,193 @@
|
|
|
1
|
+
import { ButtonModule, DIALOG_DATA, DialogModule, DialogRef, FormModule, InlineAlertModule, InputModule, MessageService, } from '@alauda/ui';
|
|
2
|
+
import { K8sApiService, publishRef, TranslateService, toUnitGi, POSITIVE_INT_PATTERN, RESOURCE_TYPES, TRANSLATE_MODULE, PurePipe, K8S_UTIL_PIPES_MODULE, ERRORS_MAPPER_MODULE, } from '@alauda-fe/common';
|
|
3
|
+
import { AsyncPipe, NgIf } from '@angular/common';
|
|
4
|
+
import { ChangeDetectionStrategy, Component, Inject } from '@angular/core';
|
|
5
|
+
import { FormsModule } from '@angular/forms';
|
|
6
|
+
import { Subject, finalize, startWith } from 'rxjs';
|
|
7
|
+
import { ActualCapacityPipe } from '../../pipes/actual-capacity.pipe';
|
|
8
|
+
import * as i0 from "@angular/core";
|
|
9
|
+
import * as i1 from "@alauda-fe/common";
|
|
10
|
+
import * as i2 from "@alauda/ui";
|
|
11
|
+
import * as i3 from "@angular/forms";
|
|
12
|
+
const _c0 = a0 => ({ capacity: a0 });
|
|
13
|
+
const _c1 = (a0, a1) => ({ pattern: a0, min: a1 });
|
|
14
|
+
function PvcExpandCapacityDialogComponent_aui_inline_alert_4_Template(rf, ctx) { if (rf & 1) {
|
|
15
|
+
i0.ɵɵelementStart(0, "aui-inline-alert", 12);
|
|
16
|
+
i0.ɵɵtext(1);
|
|
17
|
+
i0.ɵɵpipe(2, "translate");
|
|
18
|
+
i0.ɵɵelementEnd();
|
|
19
|
+
} if (rf & 2) {
|
|
20
|
+
i0.ɵɵadvance();
|
|
21
|
+
i0.ɵɵtextInterpolate(i0.ɵɵpipeBind1(2, 1, "storage.pvc_expand_capacity_help"));
|
|
22
|
+
} }
|
|
23
|
+
export class PvcExpandCapacityDialogComponent {
|
|
24
|
+
constructor(dialogData = {
|
|
25
|
+
resource: null,
|
|
26
|
+
cluster: '',
|
|
27
|
+
namespace: '',
|
|
28
|
+
isVM: false,
|
|
29
|
+
}, k8sApi, dialogRef, message, translate) {
|
|
30
|
+
this.dialogData = dialogData;
|
|
31
|
+
this.k8sApi = k8sApi;
|
|
32
|
+
this.dialogRef = dialogRef;
|
|
33
|
+
this.message = message;
|
|
34
|
+
this.translate = translate;
|
|
35
|
+
this.POSITIVE_INT_PATTERN = POSITIVE_INT_PATTERN;
|
|
36
|
+
this.submitting$$ = new Subject();
|
|
37
|
+
this.submitting$ = this.submitting$$.pipe(startWith(false), publishRef());
|
|
38
|
+
this.toUnitGi = toUnitGi;
|
|
39
|
+
}
|
|
40
|
+
submit(ngForm) {
|
|
41
|
+
ngForm.onSubmit(null);
|
|
42
|
+
if (ngForm.invalid) {
|
|
43
|
+
return;
|
|
44
|
+
}
|
|
45
|
+
this.submitting$$.next(true);
|
|
46
|
+
this.k8sApi
|
|
47
|
+
.patchResource({
|
|
48
|
+
type: RESOURCE_TYPES.PERSISTENT_VOLUME_CLAIM,
|
|
49
|
+
resource: this.dialogData.resource,
|
|
50
|
+
cluster: this.dialogData.cluster,
|
|
51
|
+
namespace: this.dialogData.namespace,
|
|
52
|
+
part: {
|
|
53
|
+
spec: {
|
|
54
|
+
resources: {
|
|
55
|
+
requests: {
|
|
56
|
+
storage: this.newCapacity + 'Gi',
|
|
57
|
+
},
|
|
58
|
+
},
|
|
59
|
+
},
|
|
60
|
+
},
|
|
61
|
+
})
|
|
62
|
+
.pipe(finalize(() => {
|
|
63
|
+
this.submitting$$.next(false);
|
|
64
|
+
}))
|
|
65
|
+
.subscribe({
|
|
66
|
+
next: () => {
|
|
67
|
+
this.dialogRef.close(true);
|
|
68
|
+
this.message.success(this.translate.get('expand_capacity_succeeded'));
|
|
69
|
+
},
|
|
70
|
+
error: () => {
|
|
71
|
+
this.message.error(this.translate.get('expand_capacity_failed'));
|
|
72
|
+
},
|
|
73
|
+
});
|
|
74
|
+
}
|
|
75
|
+
getNumber(capacity) {
|
|
76
|
+
return +capacity.replace('Gi', '') + 1;
|
|
77
|
+
}
|
|
78
|
+
getVolumeTypeTranslateKey(isVM) {
|
|
79
|
+
return isVM ? 'storage.virtual_disk_name' : 'storage.pvc_short';
|
|
80
|
+
}
|
|
81
|
+
static { this.ɵfac = function PvcExpandCapacityDialogComponent_Factory(t) { return new (t || PvcExpandCapacityDialogComponent)(i0.ɵɵdirectiveInject(DIALOG_DATA), i0.ɵɵdirectiveInject(i1.K8sApiService), i0.ɵɵdirectiveInject(i2.DialogRef), i0.ɵɵdirectiveInject(i2.MessageService), i0.ɵɵdirectiveInject(i1.TranslateService)); }; }
|
|
82
|
+
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: PvcExpandCapacityDialogComponent, selectors: [["ng-component"]], standalone: true, features: [i0.ɵɵStandaloneFeature], decls: 46, vars: 66, consts: [["ngForm", "ngForm"], ["capacity", "ngModel"], ["type", "warning", 4, "ngIf"], ["auiForm", "", "ngForm", ""], ["auiFormItemLabel", ""], ["width", "small"], ["auiFormItemControl", "", "required", ""], ["auiInputAddonAfter", ""], ["aui-input", "", "type", "text", "required", "", "name", "capacity", 1, "tw-flex-1", 3, "ngModelChange", "min", "pattern", "ngModel"], ["auiFormItemError", "", 3, "errors", "errorsMapper"], ["aui-button", "primary", 3, "click", "disabled", "loading"], ["aui-button", "", 3, "auiDialogClose", "disabled"], ["type", "warning"]], template: function PvcExpandCapacityDialogComponent_Template(rf, ctx) { if (rf & 1) {
|
|
83
|
+
const _r1 = i0.ɵɵgetCurrentView();
|
|
84
|
+
i0.ɵɵelementStart(0, "aui-dialog-header");
|
|
85
|
+
i0.ɵɵtext(1);
|
|
86
|
+
i0.ɵɵpipe(2, "translate");
|
|
87
|
+
i0.ɵɵelementEnd();
|
|
88
|
+
i0.ɵɵelementStart(3, "aui-dialog-content");
|
|
89
|
+
i0.ɵɵtemplate(4, PvcExpandCapacityDialogComponent_aui_inline_alert_4_Template, 3, 3, "aui-inline-alert", 2);
|
|
90
|
+
i0.ɵɵelementStart(5, "form", 3, 0)(7, "aui-form-item")(8, "label", 4);
|
|
91
|
+
i0.ɵɵtext(9);
|
|
92
|
+
i0.ɵɵpipe(10, "pure");
|
|
93
|
+
i0.ɵɵpipe(11, "translate");
|
|
94
|
+
i0.ɵɵelementEnd();
|
|
95
|
+
i0.ɵɵtext(12);
|
|
96
|
+
i0.ɵɵpipe(13, "aclName");
|
|
97
|
+
i0.ɵɵelementEnd();
|
|
98
|
+
i0.ɵɵelementStart(14, "aui-form-item")(15, "label", 4);
|
|
99
|
+
i0.ɵɵtext(16);
|
|
100
|
+
i0.ɵɵpipe(17, "translate");
|
|
101
|
+
i0.ɵɵelementEnd();
|
|
102
|
+
i0.ɵɵtext(18);
|
|
103
|
+
i0.ɵɵpipe(19, "rcActualCapacity");
|
|
104
|
+
i0.ɵɵelementEnd();
|
|
105
|
+
i0.ɵɵelementStart(20, "aui-form-item", 5)(21, "label", 4);
|
|
106
|
+
i0.ɵɵtext(22);
|
|
107
|
+
i0.ɵɵpipe(23, "translate");
|
|
108
|
+
i0.ɵɵelementEnd();
|
|
109
|
+
i0.ɵɵelementStart(24, "aui-input-group", 6)(25, "span", 7);
|
|
110
|
+
i0.ɵɵtext(26);
|
|
111
|
+
i0.ɵɵelementEnd();
|
|
112
|
+
i0.ɵɵelementStart(27, "input", 8, 1);
|
|
113
|
+
i0.ɵɵpipe(29, "pure");
|
|
114
|
+
i0.ɵɵpipe(30, "pure");
|
|
115
|
+
i0.ɵɵtwoWayListener("ngModelChange", function PvcExpandCapacityDialogComponent_Template_input_ngModelChange_27_listener($event) { i0.ɵɵrestoreView(_r1); i0.ɵɵtwoWayBindingSet(ctx.newCapacity, $event) || (ctx.newCapacity = $event); return i0.ɵɵresetView($event); });
|
|
116
|
+
i0.ɵɵelementEnd()();
|
|
117
|
+
i0.ɵɵelement(31, "acl-errors-mapper", 9);
|
|
118
|
+
i0.ɵɵpipe(32, "translate");
|
|
119
|
+
i0.ɵɵpipe(33, "pure");
|
|
120
|
+
i0.ɵɵpipe(34, "pure");
|
|
121
|
+
i0.ɵɵpipe(35, "translate");
|
|
122
|
+
i0.ɵɵelementEnd()()();
|
|
123
|
+
i0.ɵɵelementStart(36, "aui-dialog-footer")(37, "button", 10);
|
|
124
|
+
i0.ɵɵpipe(38, "async");
|
|
125
|
+
i0.ɵɵpipe(39, "async");
|
|
126
|
+
i0.ɵɵlistener("click", function PvcExpandCapacityDialogComponent_Template_button_click_37_listener() { i0.ɵɵrestoreView(_r1); const ngForm_r2 = i0.ɵɵreference(6); return i0.ɵɵresetView(ctx.submit(ngForm_r2)); });
|
|
127
|
+
i0.ɵɵtext(40);
|
|
128
|
+
i0.ɵɵpipe(41, "translate");
|
|
129
|
+
i0.ɵɵelementEnd();
|
|
130
|
+
i0.ɵɵelementStart(42, "button", 11);
|
|
131
|
+
i0.ɵɵpipe(43, "async");
|
|
132
|
+
i0.ɵɵtext(44);
|
|
133
|
+
i0.ɵɵpipe(45, "translate");
|
|
134
|
+
i0.ɵɵelementEnd()();
|
|
135
|
+
} if (rf & 2) {
|
|
136
|
+
const capacity_r3 = i0.ɵɵreference(28);
|
|
137
|
+
i0.ɵɵadvance();
|
|
138
|
+
i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(2, 19, "expansion"), "\n");
|
|
139
|
+
i0.ɵɵadvance(3);
|
|
140
|
+
i0.ɵɵproperty("ngIf", !ctx.dialogData.isVM);
|
|
141
|
+
i0.ɵɵadvance(5);
|
|
142
|
+
i0.ɵɵtextInterpolate(i0.ɵɵpipeBind1(11, 24, i0.ɵɵpipeBind2(10, 21, ctx.dialogData.isVM, ctx.getVolumeTypeTranslateKey)));
|
|
143
|
+
i0.ɵɵadvance(3);
|
|
144
|
+
i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(13, 26, ctx.dialogData.resource), " ");
|
|
145
|
+
i0.ɵɵadvance(4);
|
|
146
|
+
i0.ɵɵtextInterpolate(i0.ɵɵpipeBind1(17, 28, "storage.current_capacity"));
|
|
147
|
+
i0.ɵɵadvance(2);
|
|
148
|
+
i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(19, 30, ctx.dialogData.resource), " ");
|
|
149
|
+
i0.ɵɵadvance(4);
|
|
150
|
+
i0.ɵɵtextInterpolate(i0.ɵɵpipeBind1(23, 32, "storage.new_capacity"));
|
|
151
|
+
i0.ɵɵadvance(4);
|
|
152
|
+
i0.ɵɵtextInterpolate("Gi");
|
|
153
|
+
i0.ɵɵadvance();
|
|
154
|
+
i0.ɵɵproperty("min", i0.ɵɵpipeBind2(30, 37, i0.ɵɵpipeBind2(29, 34, ctx.dialogData.resource.spec.resources.requests.storage, ctx.toUnitGi), ctx.getNumber))("pattern", ctx.POSITIVE_INT_PATTERN.pattern);
|
|
155
|
+
i0.ɵɵtwoWayProperty("ngModel", ctx.newCapacity);
|
|
156
|
+
i0.ɵɵadvance(4);
|
|
157
|
+
i0.ɵɵproperty("errors", capacity_r3.errors)("errorsMapper", i0.ɵɵpureFunction2(63, _c1, i0.ɵɵpipeBind1(32, 40, ctx.POSITIVE_INT_PATTERN.tip), i0.ɵɵpipeBind2(35, 48, "storage.pvc_new_capacity_small_than_current_error", i0.ɵɵpureFunction1(61, _c0, i0.ɵɵpipeBind2(34, 45, i0.ɵɵpipeBind2(33, 42, ctx.dialogData.resource.spec.resources.requests.storage, ctx.toUnitGi), ctx.getNumber))) + "Gi"));
|
|
158
|
+
i0.ɵɵadvance(6);
|
|
159
|
+
i0.ɵɵproperty("disabled", i0.ɵɵpipeBind1(38, 51, ctx.submitting$))("loading", i0.ɵɵpipeBind1(39, 53, ctx.submitting$));
|
|
160
|
+
i0.ɵɵadvance(3);
|
|
161
|
+
i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(41, 55, "storage.expansion"), " ");
|
|
162
|
+
i0.ɵɵadvance(2);
|
|
163
|
+
i0.ɵɵproperty("auiDialogClose", false)("disabled", i0.ɵɵpipeBind1(43, 57, ctx.submitting$));
|
|
164
|
+
i0.ɵɵadvance(2);
|
|
165
|
+
i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(45, 59, "cancel"), " ");
|
|
166
|
+
} }, dependencies: [NgIf,
|
|
167
|
+
AsyncPipe,
|
|
168
|
+
DialogModule, i2.DialogHeaderComponent, i2.DialogContentComponent, i2.DialogFooterComponent, i2.DialogCloseDirective, FormModule, i2.FormDirective, i2.FormItemComponent, i2.FormItemErrorDirective, i2.FormItemLabelDirective, i2.FormItemControlDirective, FormsModule, i3.ɵNgNoValidate, i3.DefaultValueAccessor, i3.NgControlStatus, i3.NgControlStatusGroup, i3.RequiredValidator, i3.PatternValidator, i3.NgModel, i3.NgForm, InputModule, i2.InputComponent, i2.InputGroupComponent, i2.InputAddonAfterDirective, ButtonModule, i2.ButtonComponent, InlineAlertModule, i2.InlineAlertComponent, ActualCapacityPipe,
|
|
169
|
+
PurePipe, i1.ErrorsMapperComponent, i1.K8sNamePipe, i1.TranslatePipe], encapsulation: 2, changeDetection: 0 }); }
|
|
170
|
+
}
|
|
171
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(PvcExpandCapacityDialogComponent, [{
|
|
172
|
+
type: Component,
|
|
173
|
+
args: [{ standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, imports: [
|
|
174
|
+
NgIf,
|
|
175
|
+
AsyncPipe,
|
|
176
|
+
DialogModule,
|
|
177
|
+
FormModule,
|
|
178
|
+
FormsModule,
|
|
179
|
+
InputModule,
|
|
180
|
+
ButtonModule,
|
|
181
|
+
InlineAlertModule,
|
|
182
|
+
ActualCapacityPipe,
|
|
183
|
+
PurePipe,
|
|
184
|
+
ERRORS_MAPPER_MODULE,
|
|
185
|
+
K8S_UTIL_PIPES_MODULE,
|
|
186
|
+
TRANSLATE_MODULE,
|
|
187
|
+
], template: "<aui-dialog-header>\n {{ 'expansion' | translate }}\n</aui-dialog-header>\n<aui-dialog-content>\n <aui-inline-alert\n type=\"warning\"\n *ngIf=\"!dialogData.isVM\"\n >{{ 'storage.pvc_expand_capacity_help' | translate }}</aui-inline-alert\n >\n <form\n auiForm\n ngForm\n #ngForm=\"ngForm\"\n >\n <aui-form-item>\n <label auiFormItemLabel>{{\n dialogData.isVM | pure: getVolumeTypeTranslateKey | translate\n }}</label>\n {{ dialogData.resource | aclName }}\n </aui-form-item>\n <aui-form-item>\n <label auiFormItemLabel>{{\n 'storage.current_capacity' | translate\n }}</label>\n {{ dialogData.resource | rcActualCapacity }}\n </aui-form-item>\n <aui-form-item width=\"small\">\n <label auiFormItemLabel>{{ 'storage.new_capacity' | translate }}</label>\n <aui-input-group\n auiFormItemControl\n required\n >\n <span auiInputAddonAfter>{{ 'Gi' }}</span>\n <input\n aui-input\n type=\"text\"\n required\n [min]=\"\n dialogData.resource.spec.resources.requests.storage\n | pure: toUnitGi\n | pure: getNumber\n \"\n [pattern]=\"POSITIVE_INT_PATTERN.pattern\"\n class=\"tw-flex-1\"\n name=\"capacity\"\n [(ngModel)]=\"newCapacity\"\n #capacity=\"ngModel\"\n />\n </aui-input-group>\n <acl-errors-mapper\n auiFormItemError\n [errors]=\"capacity.errors\"\n [errorsMapper]=\"{\n pattern: POSITIVE_INT_PATTERN.tip | translate,\n min:\n ('storage.pvc_new_capacity_small_than_current_error'\n | translate\n : {\n capacity:\n dialogData.resource.spec.resources.requests.storage\n | pure: toUnitGi\n | pure: getNumber,\n }) + 'Gi',\n }\"\n ></acl-errors-mapper>\n </aui-form-item>\n </form>\n</aui-dialog-content>\n<aui-dialog-footer>\n <button\n aui-button=\"primary\"\n (click)=\"submit(ngForm)\"\n [disabled]=\"submitting$ | async\"\n [loading]=\"submitting$ | async\"\n >\n {{ 'storage.expansion' | translate }}\n </button>\n <button\n aui-button\n [auiDialogClose]=\"false\"\n [disabled]=\"submitting$ | async\"\n >\n {{ 'cancel' | translate }}\n </button>\n</aui-dialog-footer>\n" }]
|
|
188
|
+
}], () => [{ type: undefined, decorators: [{
|
|
189
|
+
type: Inject,
|
|
190
|
+
args: [DIALOG_DATA]
|
|
191
|
+
}] }, { type: i1.K8sApiService }, { type: i2.DialogRef }, { type: i2.MessageService }, { type: i1.TranslateService }], null); })();
|
|
192
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(PvcExpandCapacityDialogComponent, { className: "PvcExpandCapacityDialogComponent", filePath: "lib/components/pvc-expand-capacity-dialog/component.ts", lineNumber: 51 }); })();
|
|
193
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"component.js","sourceRoot":"","sources":["../../../../../../../modules/storage/src/lib/components/pvc-expand-capacity-dialog/component.ts","../../../../../../../modules/storage/src/lib/components/pvc-expand-capacity-dialog/template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ButtonModule,\n  DIALOG_DATA,\n  DialogModule,\n  DialogRef,\n  FormModule,\n  InlineAlertModule,\n  InputModule,\n  MessageService,\n} from '@alauda/ui';\nimport {\n  K8sApiService,\n  publishRef,\n  PersistentVolumeClaim,\n  TranslateService,\n  toUnitGi,\n  POSITIVE_INT_PATTERN,\n  RESOURCE_TYPES,\n  TRANSLATE_MODULE,\n  PurePipe,\n  K8S_UTIL_PIPES_MODULE,\n  ERRORS_MAPPER_MODULE,\n} from '@alauda-fe/common';\nimport { AsyncPipe, NgIf } from '@angular/common';\nimport { ChangeDetectionStrategy, Component, Inject } from '@angular/core';\nimport { FormsModule, NgForm } from '@angular/forms';\nimport { Subject, finalize, startWith } from 'rxjs';\n\nimport { ActualCapacityPipe } from '../../pipes/actual-capacity.pipe';\n\n@Component({\n  standalone: true,\n  templateUrl: './template.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [\n    NgIf,\n    AsyncPipe,\n    DialogModule,\n    FormModule,\n    FormsModule,\n    InputModule,\n    ButtonModule,\n    InlineAlertModule,\n    ActualCapacityPipe,\n    PurePipe,\n    ERRORS_MAPPER_MODULE,\n    K8S_UTIL_PIPES_MODULE,\n    TRANSLATE_MODULE,\n  ],\n})\nexport class PvcExpandCapacityDialogComponent {\n  newCapacity: string;\n  POSITIVE_INT_PATTERN = POSITIVE_INT_PATTERN;\n  submitting$$ = new Subject<boolean>();\n  submitting$ = this.submitting$$.pipe(startWith(false), publishRef());\n  toUnitGi = toUnitGi;\n\n  constructor(\n    @Inject(DIALOG_DATA)\n    public dialogData: {\n      resource: PersistentVolumeClaim;\n      cluster: string;\n      namespace: string;\n      isVM?: boolean;\n    } = {\n      resource: null,\n      cluster: '',\n      namespace: '',\n      isVM: false,\n    },\n    private readonly k8sApi: K8sApiService,\n    private readonly dialogRef: DialogRef<PvcExpandCapacityDialogComponent>,\n    private readonly message: MessageService,\n    private readonly translate: TranslateService,\n  ) {}\n\n  submit(ngForm: NgForm) {\n    ngForm.onSubmit(null);\n    if (ngForm.invalid) {\n      return;\n    }\n    this.submitting$$.next(true);\n    this.k8sApi\n      .patchResource({\n        type: RESOURCE_TYPES.PERSISTENT_VOLUME_CLAIM,\n        resource: this.dialogData.resource,\n        cluster: this.dialogData.cluster,\n        namespace: this.dialogData.namespace,\n        part: {\n          spec: {\n            resources: {\n              requests: {\n                storage: this.newCapacity + 'Gi',\n              },\n            },\n          },\n        },\n      })\n      .pipe(\n        finalize(() => {\n          this.submitting$$.next(false);\n        }),\n      )\n      .subscribe({\n        next: () => {\n          this.dialogRef.close(true);\n          this.message.success(this.translate.get('expand_capacity_succeeded'));\n        },\n        error: () => {\n          this.message.error(this.translate.get('expand_capacity_failed'));\n        },\n      });\n  }\n\n  getNumber(capacity: string) {\n    return +capacity.replace('Gi', '') + 1;\n  }\n\n  getVolumeTypeTranslateKey(isVM: boolean) {\n    return isVM ? 'storage.virtual_disk_name' : 'storage.pvc_short';\n  }\n}\n","<aui-dialog-header>\n  {{ 'expansion' | translate }}\n</aui-dialog-header>\n<aui-dialog-content>\n  <aui-inline-alert\n    type=\"warning\"\n    *ngIf=\"!dialogData.isVM\"\n    >{{ 'storage.pvc_expand_capacity_help' | translate }}</aui-inline-alert\n  >\n  <form\n    auiForm\n    ngForm\n    #ngForm=\"ngForm\"\n  >\n    <aui-form-item>\n      <label auiFormItemLabel>{{\n        dialogData.isVM | pure: getVolumeTypeTranslateKey | translate\n      }}</label>\n      {{ dialogData.resource | aclName }}\n    </aui-form-item>\n    <aui-form-item>\n      <label auiFormItemLabel>{{\n        'storage.current_capacity' | translate\n      }}</label>\n      {{ dialogData.resource | rcActualCapacity }}\n    </aui-form-item>\n    <aui-form-item width=\"small\">\n      <label auiFormItemLabel>{{ 'storage.new_capacity' | translate }}</label>\n      <aui-input-group\n        auiFormItemControl\n        required\n      >\n        <span auiInputAddonAfter>{{ 'Gi' }}</span>\n        <input\n          aui-input\n          type=\"text\"\n          required\n          [min]=\"\n            dialogData.resource.spec.resources.requests.storage\n              | pure: toUnitGi\n              | pure: getNumber\n          \"\n          [pattern]=\"POSITIVE_INT_PATTERN.pattern\"\n          class=\"tw-flex-1\"\n          name=\"capacity\"\n          [(ngModel)]=\"newCapacity\"\n          #capacity=\"ngModel\"\n        />\n      </aui-input-group>\n      <acl-errors-mapper\n        auiFormItemError\n        [errors]=\"capacity.errors\"\n        [errorsMapper]=\"{\n          pattern: POSITIVE_INT_PATTERN.tip | translate,\n          min:\n            ('storage.pvc_new_capacity_small_than_current_error'\n              | translate\n                : {\n                    capacity:\n                      dialogData.resource.spec.resources.requests.storage\n                      | pure: toUnitGi\n                      | pure: getNumber,\n                  }) + 'Gi',\n        }\"\n      ></acl-errors-mapper>\n    </aui-form-item>\n  </form>\n</aui-dialog-content>\n<aui-dialog-footer>\n  <button\n    aui-button=\"primary\"\n    (click)=\"submit(ngForm)\"\n    [disabled]=\"submitting$ | async\"\n    [loading]=\"submitting$ | async\"\n  >\n    {{ 'storage.expansion' | translate }}\n  </button>\n  <button\n    aui-button\n    [auiDialogClose]=\"false\"\n    [disabled]=\"submitting$ | async\"\n  >\n    {{ 'cancel' | translate }}\n  </button>\n</aui-dialog-footer>\n"]}
|