@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.
Files changed (44) hide show
  1. package/esm2022/alauda-fe-storage.mjs +5 -0
  2. package/esm2022/index.mjs +23 -0
  3. package/esm2022/lib/components/pvc-delete-dialog/component.mjs +292 -0
  4. package/esm2022/lib/components/pvc-expand-capacity-dialog/component.mjs +193 -0
  5. package/esm2022/lib/components/pvc-form/component.mjs +674 -0
  6. package/esm2022/lib/components/rebuild-volume-dialog/component.mjs +251 -0
  7. package/esm2022/lib/components/source-link/component.mjs +81 -0
  8. package/esm2022/lib/components/spec-form/component.mjs +464 -0
  9. package/esm2022/lib/components/storage-feature-tags/component.mjs +146 -0
  10. package/esm2022/lib/components/storageclass-select/component.mjs +179 -0
  11. package/esm2022/lib/pipes/actual-capacity.pipe.mjs +17 -0
  12. package/esm2022/lib/services/common-util.service.mjs +163 -0
  13. package/esm2022/lib/services/pvc-util.service.mjs +416 -0
  14. package/esm2022/lib/types/commons.mjs +75 -0
  15. package/esm2022/lib/types/internal.mjs +7 -0
  16. package/esm2022/lib/types/k8s.mjs +2 -0
  17. package/esm2022/lib/types/resource-definition.mjs +13 -0
  18. package/esm2022/lib/types/resource-exports.mjs +8 -0
  19. package/esm2022/lib/types/resource-internals.mjs +2 -0
  20. package/esm2022/lib/utils/constants.mjs +202 -0
  21. package/esm2022/lib/utils/resource-exports.mjs +65 -0
  22. package/esm2022/lib/utils/util.mjs +132 -0
  23. package/index.d.ts +17 -0
  24. package/lib/components/pvc-delete-dialog/component.d.ts +33 -0
  25. package/lib/components/pvc-expand-capacity-dialog/component.d.ts +36 -0
  26. package/lib/components/pvc-form/component.d.ts +106 -0
  27. package/lib/components/rebuild-volume-dialog/component.d.ts +28 -0
  28. package/lib/components/source-link/component.d.ts +17 -0
  29. package/lib/components/spec-form/component.d.ts +71 -0
  30. package/lib/components/storage-feature-tags/component.d.ts +25 -0
  31. package/lib/components/storageclass-select/component.d.ts +26 -0
  32. package/lib/pipes/actual-capacity.pipe.d.ts +8 -0
  33. package/lib/services/common-util.service.d.ts +48 -0
  34. package/lib/services/pvc-util.service.d.ts +130 -0
  35. package/lib/types/commons.d.ts +85 -0
  36. package/lib/types/internal.d.ts +4 -0
  37. package/lib/types/k8s.d.ts +105 -0
  38. package/lib/types/resource-definition.d.ts +18 -0
  39. package/lib/types/resource-exports.d.ts +16 -0
  40. package/lib/types/resource-internals.d.ts +20 -0
  41. package/lib/utils/constants.d.ts +37 -0
  42. package/lib/utils/resource-exports.d.ts +12 -0
  43. package/lib/utils/util.d.ts +19 -0
  44. package/package.json +38 -0
@@ -0,0 +1,674 @@
1
+ import { __decorate, __metadata } from "tslib";
2
+ import { FormModule, IconModule, InputModule, RadioModule, SelectModule, TooltipModule, } from '@alauda/ui';
3
+ import { AccessModes, getK8sResourceAnnotationErrorMapper$, k8sResourceAnnotationValidator, getK8sResourceLabelErrorMapper$, k8sResourceLabelValidator, VolumeMode, FoldableBlockComponent, KeyValueFormTableComponent, createNestedFormControl, dataTransfer, ReadonlyFieldDirective, K8S_RESOURCE_NAME_BASE, CoerceNumberDirective, TranslateService, DisabledDirective, ObservableInput, K8sApiService, RESOURCE_TYPES, skipError, VolumeModes, publishRef, bind, TRANSLATE_MODULE, ERRORS_MAPPER_MODULE, PurePipe, POSITIVE_INT_PATTERN, } from '@alauda-fe/common';
4
+ import { AsyncPipe, LowerCasePipe, NgFor, NgIf } from '@angular/common';
5
+ import { ChangeDetectionStrategy, Component, Input, forwardRef, } from '@angular/core';
6
+ import { FormsModule, NG_VALIDATORS, NG_VALUE_ACCESSOR } from '@angular/forms';
7
+ import { compose } from 'ramda';
8
+ import { Observable, combineLatest, map, of, switchMap } from 'rxjs';
9
+ import { StorageCommonUtilService, } from '../../services/common-util.service';
10
+ import { AccessModeTranslateKey, VolumeModeTranslateKey, } from '../../utils/constants';
11
+ import { buildPvcResource } from '../../utils/util';
12
+ import { StorageFeatureTagsComponent } from '../storage-feature-tags/component';
13
+ import { StorageClassSelectComponent } from '../storageclass-select/component';
14
+ import * as i0 from "@angular/core";
15
+ import * as i1 from "../../services/common-util.service";
16
+ import * as i2 from "@alauda-fe/common";
17
+ import * as i3 from "@angular/forms";
18
+ import * as i4 from "@alauda/ui";
19
+ const _c0 = a0 => ({ pattern: a0 });
20
+ function PersistentVolumeClaimFormComponent_aui_form_item_0_Template(rf, ctx) { if (rf & 1) {
21
+ const _r1 = i0.ɵɵgetCurrentView();
22
+ i0.ɵɵelementStart(0, "aui-form-item", 12)(1, "label", 13);
23
+ i0.ɵɵtext(2);
24
+ i0.ɵɵpipe(3, "translate");
25
+ i0.ɵɵelementEnd();
26
+ i0.ɵɵelementStart(4, "input", 14, 0);
27
+ i0.ɵɵpipe(6, "translate");
28
+ i0.ɵɵtwoWayListener("ngModelChange", function PersistentVolumeClaimFormComponent_aui_form_item_0_Template_input_ngModelChange_4_listener($event) { i0.ɵɵrestoreView(_r1); const ctx_r1 = i0.ɵɵnextContext(); i0.ɵɵtwoWayBindingSet(ctx_r1.model.name, $event) || (ctx_r1.model.name = $event); return i0.ɵɵresetView($event); });
29
+ i0.ɵɵelementEnd();
30
+ i0.ɵɵelement(7, "acl-errors-mapper", 15);
31
+ i0.ɵɵpipe(8, "translate");
32
+ i0.ɵɵelementEnd();
33
+ } if (rf & 2) {
34
+ const name_r3 = i0.ɵɵreference(5);
35
+ const ctx_r1 = i0.ɵɵnextContext();
36
+ i0.ɵɵadvance(2);
37
+ i0.ɵɵtextInterpolate(i0.ɵɵpipeBind1(3, 6, "name"));
38
+ i0.ɵɵadvance(2);
39
+ i0.ɵɵtwoWayProperty("ngModel", ctx_r1.model.name);
40
+ i0.ɵɵproperty("placeholder", i0.ɵɵpipeBind1(6, 8, ctx_r1.resourceNameReg.tip))("pattern", ctx_r1.resourceNameReg.pattern);
41
+ i0.ɵɵadvance(3);
42
+ i0.ɵɵproperty("errors", name_r3.errors)("errorsMapper", i0.ɵɵpureFunction1(12, _c0, i0.ɵɵpipeBind1(8, 10, ctx_r1.resourceNameReg.tip)));
43
+ } }
44
+ function PersistentVolumeClaimFormComponent_ng_container_2_aui_form_item_1_Template(rf, ctx) { if (rf & 1) {
45
+ i0.ɵɵelementStart(0, "aui-form-item")(1, "label", 13);
46
+ i0.ɵɵtext(2);
47
+ i0.ɵɵpipe(3, "translate");
48
+ i0.ɵɵelementEnd();
49
+ i0.ɵɵtext(4);
50
+ i0.ɵɵelementEnd();
51
+ } if (rf & 2) {
52
+ const dataSource_r4 = ctx.ngIf;
53
+ i0.ɵɵadvance(2);
54
+ i0.ɵɵtextInterpolate(i0.ɵɵpipeBind1(3, 2, "storage.data_source"));
55
+ i0.ɵɵadvance(2);
56
+ i0.ɵɵtextInterpolate1(" ", dataSource_r4.name, " ");
57
+ } }
58
+ function PersistentVolumeClaimFormComponent_ng_container_2_Template(rf, ctx) { if (rf & 1) {
59
+ i0.ɵɵelementContainerStart(0);
60
+ i0.ɵɵtemplate(1, PersistentVolumeClaimFormComponent_ng_container_2_aui_form_item_1_Template, 5, 4, "aui-form-item", 10);
61
+ i0.ɵɵelementContainerEnd();
62
+ } if (rf & 2) {
63
+ const ctx_r1 = i0.ɵɵnextContext();
64
+ i0.ɵɵadvance();
65
+ i0.ɵɵproperty("ngIf", ctx_r1.model.dataSource);
66
+ } }
67
+ function PersistentVolumeClaimFormComponent_aui_form_item_4_ng_template_11_Template(rf, ctx) { if (rf & 1) {
68
+ i0.ɵɵtext(0);
69
+ i0.ɵɵpipe(1, "translate");
70
+ } if (rf & 2) {
71
+ const ctx_r1 = i0.ɵɵnextContext(2);
72
+ i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(1, 1, ctx_r1.createMethod === ctx_r1.PvcStorageClassCreateType.DYNAMIC ? "storage.dynamic_create" : "storage.static_match"), " ");
73
+ } }
74
+ function PersistentVolumeClaimFormComponent_aui_form_item_4_Template(rf, ctx) { if (rf & 1) {
75
+ const _r5 = i0.ɵɵgetCurrentView();
76
+ i0.ɵɵelementStart(0, "aui-form-item")(1, "label", 13);
77
+ i0.ɵɵtext(2);
78
+ i0.ɵɵpipe(3, "translate");
79
+ i0.ɵɵelementEnd();
80
+ i0.ɵɵelementStart(4, "aui-radio-group", 16);
81
+ i0.ɵɵtwoWayListener("ngModelChange", function PersistentVolumeClaimFormComponent_aui_form_item_4_Template_aui_radio_group_ngModelChange_4_listener($event) { i0.ɵɵrestoreView(_r5); const ctx_r1 = i0.ɵɵnextContext(); i0.ɵɵtwoWayBindingSet(ctx_r1.createMethod, $event) || (ctx_r1.createMethod = $event); return i0.ɵɵresetView($event); });
82
+ i0.ɵɵlistener("ngModelChange", function PersistentVolumeClaimFormComponent_aui_form_item_4_Template_aui_radio_group_ngModelChange_4_listener($event) { i0.ɵɵrestoreView(_r5); const ctx_r1 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r1.createMethodChange($event)); });
83
+ i0.ɵɵelementStart(5, "aui-radio-button", 17);
84
+ i0.ɵɵtext(6);
85
+ i0.ɵɵpipe(7, "translate");
86
+ i0.ɵɵelementEnd();
87
+ i0.ɵɵelementStart(8, "aui-radio-button", 17);
88
+ i0.ɵɵtext(9);
89
+ i0.ɵɵpipe(10, "translate");
90
+ i0.ɵɵelementEnd()();
91
+ i0.ɵɵtemplate(11, PersistentVolumeClaimFormComponent_aui_form_item_4_ng_template_11_Template, 2, 3, "ng-template", null, 1, i0.ɵɵtemplateRefExtractor);
92
+ i0.ɵɵelementEnd();
93
+ } if (rf & 2) {
94
+ const createTypeTmpl_r6 = i0.ɵɵreference(12);
95
+ const ctx_r1 = i0.ɵɵnextContext();
96
+ i0.ɵɵadvance(2);
97
+ i0.ɵɵtextInterpolate(i0.ɵɵpipeBind1(3, 8, "storage.create_method"));
98
+ i0.ɵɵadvance(2);
99
+ i0.ɵɵtwoWayProperty("ngModel", ctx_r1.createMethod);
100
+ i0.ɵɵproperty("aclReadonlyField", ctx_r1.isFromSnapshot || !!ctx_r1.createType)("aclReadonlyFieldTemplate", createTypeTmpl_r6);
101
+ i0.ɵɵadvance();
102
+ i0.ɵɵproperty("value", ctx_r1.PvcStorageClassCreateType.DYNAMIC);
103
+ i0.ɵɵadvance();
104
+ i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(7, 10, "storage.dynamic_create"), " ");
105
+ i0.ɵɵadvance(2);
106
+ i0.ɵɵproperty("value", ctx_r1.PvcStorageClassCreateType.STATIC);
107
+ i0.ɵɵadvance();
108
+ i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(10, 12, "storage.static_match"), " ");
109
+ } }
110
+ function PersistentVolumeClaimFormComponent_ng_container_6_aui_form_item_1_Template(rf, ctx) { if (rf & 1) {
111
+ const _r7 = i0.ɵɵgetCurrentView();
112
+ i0.ɵɵelementStart(0, "aui-form-item", 18)(1, "label", 13);
113
+ i0.ɵɵtext(2);
114
+ i0.ɵɵpipe(3, "translate");
115
+ i0.ɵɵelementEnd();
116
+ i0.ɵɵelementStart(4, "acl-storageclass-select", 19, 2);
117
+ i0.ɵɵpipe(6, "async");
118
+ i0.ɵɵpipe(7, "async");
119
+ i0.ɵɵtwoWayListener("ngModelChange", function PersistentVolumeClaimFormComponent_ng_container_6_aui_form_item_1_Template_acl_storageclass_select_ngModelChange_4_listener($event) { i0.ɵɵrestoreView(_r7); const ctx_r1 = i0.ɵɵnextContext(2); i0.ɵɵtwoWayBindingSet(ctx_r1.model.storageClassName, $event) || (ctx_r1.model.storageClassName = $event); return i0.ɵɵresetView($event); });
120
+ i0.ɵɵlistener("storageClassChange", function PersistentVolumeClaimFormComponent_ng_container_6_aui_form_item_1_Template_acl_storageclass_select_storageClassChange_4_listener($event) { i0.ɵɵrestoreView(_r7); const ctx_r1 = i0.ɵɵnextContext(2); return i0.ɵɵresetView(ctx_r1.storageclassChange($event)); });
121
+ i0.ɵɵelementEnd();
122
+ i0.ɵɵelement(8, "acl-errors-mapper", 20);
123
+ i0.ɵɵelementEnd();
124
+ } if (rf & 2) {
125
+ const storageClassName_r8 = i0.ɵɵreference(5);
126
+ const ctx_r1 = i0.ɵɵnextContext(2);
127
+ i0.ɵɵadvance(2);
128
+ i0.ɵɵtextInterpolate(i0.ɵɵpipeBind1(3, 6, "storageclass"));
129
+ i0.ɵɵadvance(2);
130
+ i0.ɵɵproperty("storageClasses", i0.ɵɵpipeBind1(6, 8, ctx_r1.storageClassList$))("volumeSnapshotClasses", i0.ɵɵpipeBind1(7, 10, ctx_r1.volumeSnapshotClassList$))("isFromSnapshot", ctx_r1.isFromSnapshot);
131
+ i0.ɵɵtwoWayProperty("ngModel", ctx_r1.model.storageClassName);
132
+ i0.ɵɵadvance(4);
133
+ i0.ɵɵproperty("errors", storageClassName_r8.errors);
134
+ } }
135
+ function PersistentVolumeClaimFormComponent_ng_container_6_Template(rf, ctx) { if (rf & 1) {
136
+ i0.ɵɵelementContainerStart(0);
137
+ i0.ɵɵtemplate(1, PersistentVolumeClaimFormComponent_ng_container_6_aui_form_item_1_Template, 9, 12, "aui-form-item", 11);
138
+ i0.ɵɵelementContainerEnd();
139
+ } if (rf & 2) {
140
+ const ctx_r1 = i0.ɵɵnextContext();
141
+ i0.ɵɵadvance();
142
+ i0.ɵɵproperty("ngIf", ctx_r1.createMethod !== ctx_r1.PvcStorageClassCreateType.STATIC);
143
+ } }
144
+ function PersistentVolumeClaimFormComponent_aui_form_item_8_aui_radio_button_6_Template(rf, ctx) { if (rf & 1) {
145
+ i0.ɵɵelementStart(0, "aui-radio-button", 25);
146
+ i0.ɵɵpipe(1, "translate");
147
+ i0.ɵɵpipe(2, "pure");
148
+ i0.ɵɵpipe(3, "pure");
149
+ i0.ɵɵtext(4);
150
+ i0.ɵɵpipe(5, "translate");
151
+ i0.ɵɵelementEnd();
152
+ } if (rf & 2) {
153
+ const mode_r10 = ctx.$implicit;
154
+ const ctx_r1 = i0.ɵɵnextContext(2);
155
+ i0.ɵɵproperty("auiTooltip", i0.ɵɵpipeBind1(1, 5, "storage.storage_forbid_select_access_mode"))("auiTooltipDisabled", !i0.ɵɵpipeBind3(2, 7, mode_r10, ctx_r1.storageCommonUtil.isAccessModeDisabled, ctx_r1.selectedStorageSelectOption))("value", mode_r10)("disabled", i0.ɵɵpipeBind3(3, 11, mode_r10, ctx_r1.storageCommonUtil.isAccessModeDisabled, ctx_r1.selectedStorageSelectOption));
156
+ i0.ɵɵadvance(4);
157
+ i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(5, 15, "storage." + ctx_r1.AccessModeTranslateKey[mode_r10]), " ");
158
+ } }
159
+ function PersistentVolumeClaimFormComponent_aui_form_item_8_ng_template_10_Template(rf, ctx) { if (rf & 1) {
160
+ i0.ɵɵelementStart(0, "ul", 26)(1, "li");
161
+ i0.ɵɵtext(2);
162
+ i0.ɵɵpipe(3, "translate");
163
+ i0.ɵɵelementEnd();
164
+ i0.ɵɵelementStart(4, "li");
165
+ i0.ɵɵtext(5);
166
+ i0.ɵɵpipe(6, "translate");
167
+ i0.ɵɵelementEnd();
168
+ i0.ɵɵelementStart(7, "li");
169
+ i0.ɵɵtext(8);
170
+ i0.ɵɵpipe(9, "translate");
171
+ i0.ɵɵelementEnd()();
172
+ } if (rf & 2) {
173
+ i0.ɵɵadvance(2);
174
+ i0.ɵɵtextInterpolate(i0.ɵɵpipeBind1(3, 3, "storage.access_mode_rwo"));
175
+ i0.ɵɵadvance(3);
176
+ i0.ɵɵtextInterpolate(i0.ɵɵpipeBind1(6, 5, "storage.access_mode_rox"));
177
+ i0.ɵɵadvance(3);
178
+ i0.ɵɵtextInterpolate(i0.ɵɵpipeBind1(9, 7, "storage.access_mode_rwx"));
179
+ } }
180
+ function PersistentVolumeClaimFormComponent_aui_form_item_8_Template(rf, ctx) { if (rf & 1) {
181
+ const _r9 = i0.ɵɵgetCurrentView();
182
+ i0.ɵɵelementStart(0, "aui-form-item")(1, "label", 13);
183
+ i0.ɵɵtext(2);
184
+ i0.ɵɵpipe(3, "translate");
185
+ i0.ɵɵelementEnd();
186
+ i0.ɵɵelementStart(4, "aui-radio-group", 21, 3);
187
+ i0.ɵɵtwoWayListener("ngModelChange", function PersistentVolumeClaimFormComponent_aui_form_item_8_Template_aui_radio_group_ngModelChange_4_listener($event) { i0.ɵɵrestoreView(_r9); const ctx_r1 = i0.ɵɵnextContext(); i0.ɵɵtwoWayBindingSet(ctx_r1.model.accessModes, $event) || (ctx_r1.model.accessModes = $event); return i0.ɵɵresetView($event); });
188
+ i0.ɵɵtemplate(6, PersistentVolumeClaimFormComponent_aui_form_item_8_aui_radio_button_6_Template, 6, 17, "aui-radio-button", 22);
189
+ i0.ɵɵelementEnd();
190
+ i0.ɵɵelementStart(7, "div", 23);
191
+ i0.ɵɵelement(8, "aui-icon", 24);
192
+ i0.ɵɵelementEnd();
193
+ i0.ɵɵelement(9, "acl-errors-mapper", 20);
194
+ i0.ɵɵtemplate(10, PersistentVolumeClaimFormComponent_aui_form_item_8_ng_template_10_Template, 10, 9, "ng-template", null, 4, i0.ɵɵtemplateRefExtractor);
195
+ i0.ɵɵelementEnd();
196
+ } if (rf & 2) {
197
+ const accessMode_r11 = i0.ɵɵreference(5);
198
+ const accessModeTip_r12 = i0.ɵɵreference(11);
199
+ const ctx_r1 = i0.ɵɵnextContext();
200
+ i0.ɵɵadvance(2);
201
+ i0.ɵɵtextInterpolate(i0.ɵɵpipeBind1(3, 6, "storage.access_mode"));
202
+ i0.ɵɵadvance(2);
203
+ i0.ɵɵtwoWayProperty("ngModel", ctx_r1.model.accessModes);
204
+ i0.ɵɵadvance(2);
205
+ i0.ɵɵproperty("ngForOf", ctx_r1.accessModes);
206
+ i0.ɵɵadvance(2);
207
+ i0.ɵɵproperty("auiTooltip", accessModeTip_r12)("auiTooltipPosition", "top center");
208
+ i0.ɵɵadvance();
209
+ i0.ɵɵproperty("errors", accessMode_r11.errors);
210
+ } }
211
+ function PersistentVolumeClaimFormComponent_aui_form_item_10_aui_select_6_aui_option_1_Template(rf, ctx) { if (rf & 1) {
212
+ i0.ɵɵelementStart(0, "aui-option", 31);
213
+ i0.ɵɵtext(1);
214
+ i0.ɵɵelementEnd();
215
+ } if (rf & 2) {
216
+ const item_r15 = ctx.$implicit;
217
+ i0.ɵɵproperty("label", item_r15)("value", item_r15);
218
+ i0.ɵɵadvance();
219
+ i0.ɵɵtextInterpolate1(" ", item_r15, " ");
220
+ } }
221
+ function PersistentVolumeClaimFormComponent_aui_form_item_10_aui_select_6_Template(rf, ctx) { if (rf & 1) {
222
+ const _r14 = i0.ɵɵgetCurrentView();
223
+ i0.ɵɵelementStart(0, "aui-select", 29);
224
+ i0.ɵɵtwoWayListener("ngModelChange", function PersistentVolumeClaimFormComponent_aui_form_item_10_aui_select_6_Template_aui_select_ngModelChange_0_listener($event) { i0.ɵɵrestoreView(_r14); const ctx_r1 = i0.ɵɵnextContext(2); i0.ɵɵtwoWayBindingSet(ctx_r1.unit, $event) || (ctx_r1.unit = $event); return i0.ɵɵresetView($event); });
225
+ i0.ɵɵtemplate(1, PersistentVolumeClaimFormComponent_aui_form_item_10_aui_select_6_aui_option_1_Template, 2, 3, "aui-option", 30);
226
+ i0.ɵɵelementEnd();
227
+ } if (rf & 2) {
228
+ const ctx_r1 = i0.ɵɵnextContext(2);
229
+ i0.ɵɵtwoWayProperty("ngModel", ctx_r1.unit);
230
+ i0.ɵɵadvance();
231
+ i0.ɵɵproperty("ngForOf", ctx_r1.UNITS);
232
+ } }
233
+ function PersistentVolumeClaimFormComponent_aui_form_item_10_ng_template_7_Template(rf, ctx) { if (rf & 1) {
234
+ i0.ɵɵtext(0);
235
+ } if (rf & 2) {
236
+ const ctx_r1 = i0.ɵɵnextContext(2);
237
+ i0.ɵɵtextInterpolate1(" ", ctx_r1.model.storage, "Gi ");
238
+ } }
239
+ function PersistentVolumeClaimFormComponent_aui_form_item_10_Template(rf, ctx) { if (rf & 1) {
240
+ const _r13 = i0.ɵɵgetCurrentView();
241
+ i0.ɵɵelementStart(0, "aui-form-item", 18)(1, "label", 13);
242
+ i0.ɵɵtext(2);
243
+ i0.ɵɵpipe(3, "translate");
244
+ i0.ɵɵelementEnd();
245
+ i0.ɵɵelementStart(4, "input", 27, 5);
246
+ i0.ɵɵtwoWayListener("ngModelChange", function PersistentVolumeClaimFormComponent_aui_form_item_10_Template_input_ngModelChange_4_listener($event) { i0.ɵɵrestoreView(_r13); const ctx_r1 = i0.ɵɵnextContext(); i0.ɵɵtwoWayBindingSet(ctx_r1.model.storage, $event) || (ctx_r1.model.storage = $event); return i0.ɵɵresetView($event); });
247
+ i0.ɵɵelementEnd();
248
+ i0.ɵɵtemplate(6, PersistentVolumeClaimFormComponent_aui_form_item_10_aui_select_6_Template, 2, 2, "aui-select", 28)(7, PersistentVolumeClaimFormComponent_aui_form_item_10_ng_template_7_Template, 1, 1, "ng-template", null, 6, i0.ɵɵtemplateRefExtractor);
249
+ i0.ɵɵelement(9, "acl-errors-mapper", 15);
250
+ i0.ɵɵpipe(10, "translate");
251
+ i0.ɵɵelementEnd();
252
+ } if (rf & 2) {
253
+ const storage_r16 = i0.ɵɵreference(5);
254
+ const capacityTpl_r17 = i0.ɵɵreference(8);
255
+ const ctx_r1 = i0.ɵɵnextContext();
256
+ i0.ɵɵadvance(2);
257
+ i0.ɵɵtextInterpolate(i0.ɵɵpipeBind1(3, 8, "storage.capacity"));
258
+ i0.ɵɵadvance(2);
259
+ i0.ɵɵproperty("pattern", ctx_r1.POSITIVE_INT_PATTERN.pattern);
260
+ i0.ɵɵtwoWayProperty("ngModel", ctx_r1.model.storage);
261
+ i0.ɵɵproperty("aclReadonlyField", ctx_r1.isFromSnapshot)("aclReadonlyFieldTemplate", capacityTpl_r17);
262
+ i0.ɵɵadvance(2);
263
+ i0.ɵɵproperty("ngIf", !ctx_r1.isFromSnapshot);
264
+ i0.ɵɵadvance(3);
265
+ i0.ɵɵproperty("errors", storage_r16.errors)("errorsMapper", i0.ɵɵpureFunction1(12, _c0, i0.ɵɵpipeBind1(10, 10, ctx_r1.POSITIVE_INT_PATTERN.tip)));
266
+ } }
267
+ function PersistentVolumeClaimFormComponent_aui_form_item_12_aui_radio_button_5_Template(rf, ctx) { if (rf & 1) {
268
+ i0.ɵɵelementStart(0, "aui-radio-button", 35);
269
+ i0.ɵɵpipe(1, "translate");
270
+ i0.ɵɵpipe(2, "pure");
271
+ i0.ɵɵpipe(3, "pure");
272
+ i0.ɵɵtext(4);
273
+ i0.ɵɵpipe(5, "translate");
274
+ i0.ɵɵelementEnd();
275
+ } if (rf & 2) {
276
+ const mode_r19 = ctx.$implicit;
277
+ const ctx_r1 = i0.ɵɵnextContext(2);
278
+ i0.ɵɵproperty("auiTooltip", i0.ɵɵpipeBind1(1, 5, "storage.storage_forbid_select_volume_mode"))("auiTooltipDisabled", !i0.ɵɵpipeBind3(2, 7, mode_r19, ctx_r1.storageCommonUtil.isVolumeModeDisabled, ctx_r1.selectedStorageSelectOption))("disabled", i0.ɵɵpipeBind3(3, 11, mode_r19, ctx_r1.storageCommonUtil.isVolumeModeDisabled, ctx_r1.selectedStorageSelectOption))("value", mode_r19);
279
+ i0.ɵɵadvance(4);
280
+ i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(5, 15, "storage." + ctx_r1.VolumeModeTranslateKey[mode_r19]), " ");
281
+ } }
282
+ function PersistentVolumeClaimFormComponent_aui_form_item_12_div_6_Template(rf, ctx) { if (rf & 1) {
283
+ i0.ɵɵelementStart(0, "div", 23);
284
+ i0.ɵɵelement(1, "aui-icon", 24);
285
+ i0.ɵɵelementEnd();
286
+ } if (rf & 2) {
287
+ i0.ɵɵnextContext();
288
+ const volumeModeTip_r20 = i0.ɵɵreference(8);
289
+ i0.ɵɵadvance();
290
+ i0.ɵɵproperty("auiTooltip", volumeModeTip_r20)("auiTooltipPosition", "top center");
291
+ } }
292
+ function PersistentVolumeClaimFormComponent_aui_form_item_12_ng_template_7_Template(rf, ctx) { if (rf & 1) {
293
+ i0.ɵɵelementStart(0, "ul", 26)(1, "li");
294
+ i0.ɵɵtext(2);
295
+ i0.ɵɵpipe(3, "translate");
296
+ i0.ɵɵelementEnd();
297
+ i0.ɵɵelementStart(4, "li");
298
+ i0.ɵɵtext(5);
299
+ i0.ɵɵpipe(6, "translate");
300
+ i0.ɵɵelementEnd()();
301
+ } if (rf & 2) {
302
+ i0.ɵɵadvance(2);
303
+ i0.ɵɵtextInterpolate(i0.ɵɵpipeBind1(3, 2, "storage.volume_mode_file_system_hint"));
304
+ i0.ɵɵadvance(3);
305
+ i0.ɵɵtextInterpolate(i0.ɵɵpipeBind1(6, 4, "storage.volume_mode_block_device_hint"));
306
+ } }
307
+ function PersistentVolumeClaimFormComponent_aui_form_item_12_ng_template_9_Template(rf, ctx) { if (rf & 1) {
308
+ i0.ɵɵtext(0);
309
+ i0.ɵɵpipe(1, "translate");
310
+ } if (rf & 2) {
311
+ const ctx_r1 = i0.ɵɵnextContext(2);
312
+ i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(1, 1, ctx_r1.model.volumeMode === "Filesystem" ? "storage.file_system" : "storage.block_device"), " ");
313
+ } }
314
+ function PersistentVolumeClaimFormComponent_aui_form_item_12_Template(rf, ctx) { if (rf & 1) {
315
+ const _r18 = i0.ɵɵgetCurrentView();
316
+ i0.ɵɵelementStart(0, "aui-form-item")(1, "label", 13);
317
+ i0.ɵɵtext(2);
318
+ i0.ɵɵpipe(3, "translate");
319
+ i0.ɵɵelementEnd();
320
+ i0.ɵɵelementStart(4, "aui-radio-group", 32);
321
+ i0.ɵɵtwoWayListener("ngModelChange", function PersistentVolumeClaimFormComponent_aui_form_item_12_Template_aui_radio_group_ngModelChange_4_listener($event) { i0.ɵɵrestoreView(_r18); const ctx_r1 = i0.ɵɵnextContext(); i0.ɵɵtwoWayBindingSet(ctx_r1.model.volumeMode, $event) || (ctx_r1.model.volumeMode = $event); return i0.ɵɵresetView($event); });
322
+ i0.ɵɵtemplate(5, PersistentVolumeClaimFormComponent_aui_form_item_12_aui_radio_button_5_Template, 6, 17, "aui-radio-button", 33);
323
+ i0.ɵɵelementEnd();
324
+ i0.ɵɵtemplate(6, PersistentVolumeClaimFormComponent_aui_form_item_12_div_6_Template, 2, 2, "div", 34)(7, PersistentVolumeClaimFormComponent_aui_form_item_12_ng_template_7_Template, 7, 6, "ng-template", null, 7, i0.ɵɵtemplateRefExtractor)(9, PersistentVolumeClaimFormComponent_aui_form_item_12_ng_template_9_Template, 2, 3, "ng-template", null, 8, i0.ɵɵtemplateRefExtractor);
325
+ i0.ɵɵelementEnd();
326
+ } if (rf & 2) {
327
+ const volumeModeTmpl_r21 = i0.ɵɵreference(10);
328
+ const ctx_r1 = i0.ɵɵnextContext();
329
+ i0.ɵɵadvance(2);
330
+ i0.ɵɵtextInterpolate(i0.ɵɵpipeBind1(3, 6, "storage.volume_mode"));
331
+ i0.ɵɵadvance(2);
332
+ i0.ɵɵtwoWayProperty("ngModel", ctx_r1.model.volumeMode);
333
+ i0.ɵɵproperty("aclReadonlyField", ctx_r1.isFromSnapshot || !!ctx_r1.volumeMode)("aclReadonlyFieldTemplate", volumeModeTmpl_r21);
334
+ i0.ɵɵadvance();
335
+ i0.ɵɵproperty("ngForOf", ctx_r1.volumeModes);
336
+ i0.ɵɵadvance();
337
+ i0.ɵɵproperty("ngIf", !ctx_r1.volumeMode);
338
+ } }
339
+ function PersistentVolumeClaimFormComponent_ng_container_14_aui_form_item_3_Template(rf, ctx) { if (rf & 1) {
340
+ const _r22 = i0.ɵɵgetCurrentView();
341
+ i0.ɵɵelementStart(0, "aui-form-item", 38)(1, "label", 13);
342
+ i0.ɵɵtext(2);
343
+ i0.ɵɵpipe(3, "translate");
344
+ i0.ɵɵelementEnd();
345
+ i0.ɵɵelementStart(4, "acl-key-value-form-table", 39);
346
+ i0.ɵɵpipe(5, "translate");
347
+ i0.ɵɵpipe(6, "lowercase");
348
+ i0.ɵɵpipe(7, "async");
349
+ i0.ɵɵtwoWayListener("ngModelChange", function PersistentVolumeClaimFormComponent_ng_container_14_aui_form_item_3_Template_acl_key_value_form_table_ngModelChange_4_listener($event) { i0.ɵɵrestoreView(_r22); const ctx_r1 = i0.ɵɵnextContext(2); i0.ɵɵtwoWayBindingSet(ctx_r1.model.labels, $event) || (ctx_r1.model.labels = $event); return i0.ɵɵresetView($event); });
350
+ i0.ɵɵelementEnd()();
351
+ } if (rf & 2) {
352
+ const ctx_r1 = i0.ɵɵnextContext(2);
353
+ i0.ɵɵadvance(2);
354
+ i0.ɵɵtextInterpolate(i0.ɵɵpipeBind1(3, 5, "label"));
355
+ i0.ɵɵadvance(2);
356
+ i0.ɵɵtwoWayProperty("ngModel", ctx_r1.model.labels);
357
+ i0.ɵɵproperty("resourceNameTranslated", i0.ɵɵpipeBind1(6, 9, i0.ɵɵpipeBind1(5, 7, "storage.labels")))("validator", ctx_r1.labelValidator)("errorMapper", i0.ɵɵpipeBind1(7, 11, ctx_r1.labelErrorMapper$));
358
+ } }
359
+ function PersistentVolumeClaimFormComponent_ng_container_14_aui_form_item_5_Template(rf, ctx) { if (rf & 1) {
360
+ const _r23 = i0.ɵɵgetCurrentView();
361
+ i0.ɵɵelementStart(0, "aui-form-item", 38)(1, "label", 13);
362
+ i0.ɵɵtext(2);
363
+ i0.ɵɵpipe(3, "translate");
364
+ i0.ɵɵelementEnd();
365
+ i0.ɵɵelementStart(4, "acl-key-value-form-table", 40);
366
+ i0.ɵɵpipe(5, "translate");
367
+ i0.ɵɵpipe(6, "lowercase");
368
+ i0.ɵɵpipe(7, "async");
369
+ i0.ɵɵtwoWayListener("ngModelChange", function PersistentVolumeClaimFormComponent_ng_container_14_aui_form_item_5_Template_acl_key_value_form_table_ngModelChange_4_listener($event) { i0.ɵɵrestoreView(_r23); const ctx_r1 = i0.ɵɵnextContext(2); i0.ɵɵtwoWayBindingSet(ctx_r1.model.annotations, $event) || (ctx_r1.model.annotations = $event); return i0.ɵɵresetView($event); });
370
+ i0.ɵɵelementEnd()();
371
+ } if (rf & 2) {
372
+ const ctx_r1 = i0.ɵɵnextContext(2);
373
+ i0.ɵɵadvance(2);
374
+ i0.ɵɵtextInterpolate(i0.ɵɵpipeBind1(3, 5, "storage.k8s_annotation"));
375
+ i0.ɵɵadvance(2);
376
+ i0.ɵɵproperty("resourceNameTranslated", i0.ɵɵpipeBind1(6, 9, i0.ɵɵpipeBind1(5, 7, "storage.k8s_annotation")));
377
+ i0.ɵɵtwoWayProperty("ngModel", ctx_r1.model.annotations);
378
+ i0.ɵɵproperty("validator", ctx_r1.annotationValidator)("errorMapper", i0.ɵɵpipeBind1(7, 11, ctx_r1.annotationErrorMapper$));
379
+ } }
380
+ function PersistentVolumeClaimFormComponent_ng_container_14_ng_container_7_Template(rf, ctx) { if (rf & 1) {
381
+ const _r24 = i0.ɵɵgetCurrentView();
382
+ i0.ɵɵelementContainerStart(0);
383
+ i0.ɵɵelementStart(1, "aui-form-item", 41)(2, "label", 13);
384
+ i0.ɵɵtext(3);
385
+ i0.ɵɵpipe(4, "translate");
386
+ i0.ɵɵelementEnd();
387
+ i0.ɵɵelementStart(5, "acl-key-value-form-table", 42);
388
+ i0.ɵɵtwoWayListener("ngModelChange", function PersistentVolumeClaimFormComponent_ng_container_14_ng_container_7_Template_acl_key_value_form_table_ngModelChange_5_listener($event) { i0.ɵɵrestoreView(_r24); const ctx_r1 = i0.ɵɵnextContext(2); i0.ɵɵtwoWayBindingSet(ctx_r1.model.selector, $event) || (ctx_r1.model.selector = $event); return i0.ɵɵresetView($event); });
389
+ i0.ɵɵelementEnd()();
390
+ i0.ɵɵelementContainerEnd();
391
+ } if (rf & 2) {
392
+ const ctx_r1 = i0.ɵɵnextContext(2);
393
+ i0.ɵɵadvance();
394
+ i0.ɵɵproperty("hidden", ctx_r1.createMethod === ctx_r1.PvcStorageClassCreateType.DYNAMIC);
395
+ i0.ɵɵadvance(2);
396
+ i0.ɵɵtextInterpolate(i0.ɵɵpipeBind1(4, 3, "storage.selector"));
397
+ i0.ɵɵadvance(2);
398
+ i0.ɵɵtwoWayProperty("ngModel", ctx_r1.model.selector);
399
+ } }
400
+ function PersistentVolumeClaimFormComponent_ng_container_14_Template(rf, ctx) { if (rf & 1) {
401
+ i0.ɵɵelementContainerStart(0);
402
+ i0.ɵɵelementStart(1, "acl-foldable-block", 36);
403
+ i0.ɵɵpipe(2, "translate");
404
+ i0.ɵɵtemplate(3, PersistentVolumeClaimFormComponent_ng_container_14_aui_form_item_3_Template, 8, 13, "aui-form-item", 37);
405
+ i0.ɵɵpipe(4, "pure");
406
+ i0.ɵɵtemplate(5, PersistentVolumeClaimFormComponent_ng_container_14_aui_form_item_5_Template, 8, 13, "aui-form-item", 37);
407
+ i0.ɵɵpipe(6, "pure");
408
+ i0.ɵɵtemplate(7, PersistentVolumeClaimFormComponent_ng_container_14_ng_container_7_Template, 6, 5, "ng-container", 10);
409
+ i0.ɵɵpipe(8, "pure");
410
+ i0.ɵɵelementEnd();
411
+ i0.ɵɵelementContainerEnd();
412
+ } if (rf & 2) {
413
+ const ctx_r1 = i0.ɵɵnextContext();
414
+ i0.ɵɵadvance();
415
+ i0.ɵɵpropertyInterpolate("hint", i0.ɵɵpipeBind1(2, 4, "storage.advanced"));
416
+ i0.ɵɵadvance(2);
417
+ i0.ɵɵproperty("ngIf", i0.ɵɵpipeBind2(4, 6, "labels", ctx_r1.displayFieldSupported));
418
+ i0.ɵɵadvance(2);
419
+ i0.ɵɵproperty("ngIf", i0.ɵɵpipeBind2(6, 9, "annotations", ctx_r1.displayFieldSupported));
420
+ i0.ɵɵadvance(2);
421
+ i0.ɵɵproperty("ngIf", i0.ɵɵpipeBind2(8, 12, "selector", ctx_r1.displayFieldSupported));
422
+ } }
423
+ const PvcStorageClassCreateType = {
424
+ DYNAMIC: 'dynamic',
425
+ STATIC: 'static',
426
+ };
427
+ const UNITS = ['Gi', 'Ti'];
428
+ export class PersistentVolumeClaimFormComponent extends createNestedFormControl({
429
+ autoEmitChange: true,
430
+ }) {
431
+ get showAdvancedField() {
432
+ if (!this.displayFields?.length) {
433
+ return true;
434
+ }
435
+ return this.displayFields?.some(field => ['labels', 'annotations', 'selector'].includes(field));
436
+ }
437
+ writeValue(value) {
438
+ this.model = this.valueIn(value ??
439
+ buildPvcResource({
440
+ namespace: this.baseParams.namespace,
441
+ volumeMode: this.volumeMode,
442
+ }));
443
+ if (this.createType) {
444
+ this.createMethod = this.createType;
445
+ }
446
+ }
447
+ constructor(storageCommonUtil, translate, k8sApi) {
448
+ super();
449
+ this.storageCommonUtil = storageCommonUtil;
450
+ this.translate = translate;
451
+ this.k8sApi = k8sApi;
452
+ this.accessModes = AccessModes;
453
+ this.volumeModes = VolumeModes;
454
+ this.POSITIVE_INT_PATTERN = POSITIVE_INT_PATTERN;
455
+ this.model = {};
456
+ this.resourceNameReg = K8S_RESOURCE_NAME_BASE;
457
+ this.labelValidator = k8sResourceLabelValidator;
458
+ this.AccessModeTranslateKey = AccessModeTranslateKey;
459
+ this.VolumeModeTranslateKey = VolumeModeTranslateKey;
460
+ this.labelErrorMapper$ = getK8sResourceLabelErrorMapper$(this.translate);
461
+ this.annotationValidator = k8sResourceAnnotationValidator;
462
+ this.annotationErrorMapper$ = getK8sResourceAnnotationErrorMapper$(this.translate);
463
+ this.PvcStorageClassCreateType = PvcStorageClassCreateType;
464
+ this.UNITS = UNITS;
465
+ this.unit = 'Gi';
466
+ this.storageClassList$ = combineLatest([
467
+ this.baseParams$,
468
+ this.storageClasses$,
469
+ ]).pipe(switchMap(([{ cluster }, storageClasses]) => {
470
+ if (storageClasses) {
471
+ return of(storageClasses);
472
+ }
473
+ return this.k8sApi
474
+ .getResourceList({
475
+ type: RESOURCE_TYPES.STORAGE_CLASS,
476
+ cluster,
477
+ queryParams: {
478
+ limit: '0',
479
+ },
480
+ })
481
+ .pipe(map(res => res?.items));
482
+ }), publishRef());
483
+ this.volumeSnapshotClassList$ = this.baseParams$.pipe(switchMap(baseParams => this.k8sApi
484
+ .getResourceList({
485
+ type: RESOURCE_TYPES.VOLUME_SNAPSHOT_CLASS,
486
+ cluster: baseParams.cluster,
487
+ })
488
+ .pipe(map(r => r.items), skipError([]))), publishRef());
489
+ this.adaptResourceModel = (pvc) => {
490
+ const storage = pvc?.spec?.resources?.requests?.storage;
491
+ if (storage) {
492
+ const res = String(storage).match(/[A-Za-z]+|\d+(?:\.\d+)?/g);
493
+ pvc.spec.resources.requests.storage = res[0] || '';
494
+ this.unit = res[1] || 'Gi';
495
+ }
496
+ // "" 表示静态创建
497
+ this.createMethod =
498
+ pvc?.spec?.storageClassName === '' ? 'static' : 'dynamic';
499
+ return pvc;
500
+ };
501
+ this.overrideResource = (pvc) => {
502
+ if (this.createMethod === 'dynamic' ||
503
+ Object.keys(pvc?.spec?.selector?.matchLabels ?? {}).length === 0) {
504
+ delete pvc?.spec?.selector;
505
+ }
506
+ if (this.createMethod === 'static') {
507
+ pvc.spec.storageClassName = '';
508
+ }
509
+ if (pvc?.spec?.resources?.requests?.storage) {
510
+ pvc.spec.resources.requests.storage = `${pvc.spec.resources.requests.storage}${this.unit}`;
511
+ }
512
+ return pvc;
513
+ };
514
+ const [toModel, toResource] = dataTransfer({
515
+ name: 'metadata.name',
516
+ labels: 'metadata.labels',
517
+ annotations: 'metadata.annotations',
518
+ storageClassName: 'spec.storageClassName',
519
+ accessModes: ['spec', 'accessModes', 0],
520
+ volumeMode: 'spec.volumeMode',
521
+ storage: 'spec.resources.requests.storage',
522
+ dataSource: 'spec.dataSource',
523
+ selector: 'spec.selector.matchLabels',
524
+ });
525
+ this.valueIn = compose(toModel, this.adaptResourceModel);
526
+ this.modelOut = compose(this.overrideResource, toResource);
527
+ }
528
+ createMethodChange(createType) {
529
+ // 静态匹配不需要限制访问模式
530
+ if (createType === 'static') {
531
+ this.selectedStorageSelectOption = null;
532
+ }
533
+ }
534
+ storageclassChange(selectedOption) {
535
+ this.selectedStorageSelectOption = selectedOption;
536
+ this.setAccessModeToSupportValueIfNeed();
537
+ this.setVolumeModeToSupportValueIfNeed();
538
+ }
539
+ displayFieldSupported(fieldName) {
540
+ if (!this.displayFields?.length) {
541
+ return true;
542
+ }
543
+ return this.displayFields.includes(fieldName);
544
+ }
545
+ setAccessModeToSupportValueIfNeed() {
546
+ if (this.storageCommonUtil.isAccessModeDisabled(this.model.accessModes, this.selectedStorageSelectOption)) {
547
+ this.model.accessModes = this.accessModes.find(accessMode => !this.storageCommonUtil.isAccessModeDisabled(accessMode, this.selectedStorageSelectOption));
548
+ }
549
+ }
550
+ setVolumeModeToSupportValueIfNeed() {
551
+ if (this.storageCommonUtil.isVolumeModeDisabled(this.model.volumeMode, this.selectedStorageSelectOption)) {
552
+ this.model.volumeMode = this.volumeModes.find(volumeMode => !this.storageCommonUtil.isVolumeModeDisabled(volumeMode, this.selectedStorageSelectOption));
553
+ }
554
+ }
555
+ static { this.ɵfac = function PersistentVolumeClaimFormComponent_Factory(t) { return new (t || PersistentVolumeClaimFormComponent)(i0.ɵɵdirectiveInject(i1.StorageCommonUtilService), i0.ɵɵdirectiveInject(i2.TranslateService), i0.ɵɵdirectiveInject(i2.K8sApiService)); }; }
556
+ static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: PersistentVolumeClaimFormComponent, selectors: [["acl-pvc-form"]], inputs: { baseParams: "baseParams", storageClasses: "storageClasses", isFromSnapshot: "isFromSnapshot", createType: "createType", volumeMode: "volumeMode", displayFields: "displayFields" }, standalone: true, features: [i0.ɵɵProvidersFeature([
557
+ {
558
+ provide: NG_VALUE_ACCESSOR,
559
+ useExisting: forwardRef(() => PersistentVolumeClaimFormComponent),
560
+ multi: true,
561
+ },
562
+ {
563
+ provide: NG_VALIDATORS,
564
+ useExisting: forwardRef(() => PersistentVolumeClaimFormComponent),
565
+ multi: true,
566
+ },
567
+ ]), i0.ɵɵInheritDefinitionFeature, i0.ɵɵStandaloneFeature], decls: 15, vars: 29, consts: [["name", "ngModel"], ["createTypeTmpl", ""], ["storageClassName", "ngModel"], ["accessMode", "ngModel"], ["accessModeTip", ""], ["storage", "ngModel"], ["capacityTpl", ""], ["volumeModeTip", ""], ["volumeModeTmpl", ""], ["width", "large", 4, "ngIf"], [4, "ngIf"], ["width", "medium", 4, "ngIf"], ["width", "large"], ["auiFormItemLabel", ""], ["aui-input", "", "auiFormItemControl", "", "name", "name", "maxlength", "63", "required", "", 3, "ngModelChange", "ngModel", "placeholder", "pattern"], ["auiFormItemError", "", 3, "errors", "errorsMapper"], ["size", "medium", "name", "createMethod", 3, "ngModelChange", "ngModel", "aclReadonlyField", "aclReadonlyFieldTemplate"], [3, "value"], ["width", "medium"], ["auiFormItemControl", "", "required", "", "name", "storageClassName", 3, "ngModelChange", "storageClassChange", "storageClasses", "volumeSnapshotClasses", "isFromSnapshot", "ngModel"], ["auiFormItemError", "", 3, "errors"], ["auiFormItemControl", "", "required", "", "name", "accessModes", 3, "ngModelChange", "ngModel"], [3, "auiTooltip", "auiTooltipDisabled", "value", "disabled", 4, "ngFor", "ngForOf"], ["auiFormItemAddon", ""], ["icon", "question_circle", 1, "icon--help", 3, "auiTooltip", "auiTooltipPosition"], [3, "auiTooltip", "auiTooltipDisabled", "value", "disabled"], [1, "d-list"], ["aui-input", "", "type", "text", "name", "storage", "required", "", "auiFormItemControl", "", "required", "", 3, "ngModelChange", "pattern", "ngModel", "aclReadonlyField", "aclReadonlyFieldTemplate"], ["class", "tw-max-w-[60px] tw-ml-[-60px]", 3, "ngModel", "ngModelChange", 4, "ngIf"], [1, "tw-max-w-[60px]", "tw-ml-[-60px]", 3, "ngModelChange", "ngModel"], [3, "label", "value", 4, "ngFor", "ngForOf"], [3, "label", "value"], ["size", "medium", "name", "volumeMode", 3, "ngModelChange", "ngModel", "aclReadonlyField", "aclReadonlyFieldTemplate"], [3, "auiTooltip", "auiTooltipDisabled", "disabled", "value", 4, "ngFor", "ngForOf"], ["auiFormItemAddon", "", 4, "ngIf"], [3, "auiTooltip", "auiTooltipDisabled", "disabled", "value"], [3, "hint"], ["formGroupName", "metadata", 4, "ngIf"], ["formGroupName", "metadata"], ["auiFormItemControl", "", "name", "labels", 3, "ngModelChange", "ngModel", "resourceNameTranslated", "validator", "errorMapper"], ["auiFormItemControl", "", "name", "annotations", 3, "ngModelChange", "resourceNameTranslated", "ngModel", "validator", "errorMapper"], [3, "hidden"], ["auiFormItemControl", "", "name", "selector", 3, "ngModelChange", "ngModel"]], template: function PersistentVolumeClaimFormComponent_Template(rf, ctx) { if (rf & 1) {
568
+ i0.ɵɵtemplate(0, PersistentVolumeClaimFormComponent_aui_form_item_0_Template, 9, 14, "aui-form-item", 9);
569
+ i0.ɵɵpipe(1, "pure");
570
+ i0.ɵɵtemplate(2, PersistentVolumeClaimFormComponent_ng_container_2_Template, 2, 1, "ng-container", 10);
571
+ i0.ɵɵpipe(3, "pure");
572
+ i0.ɵɵtemplate(4, PersistentVolumeClaimFormComponent_aui_form_item_4_Template, 13, 14, "aui-form-item", 10);
573
+ i0.ɵɵpipe(5, "pure");
574
+ i0.ɵɵtemplate(6, PersistentVolumeClaimFormComponent_ng_container_6_Template, 2, 1, "ng-container", 10);
575
+ i0.ɵɵpipe(7, "pure");
576
+ i0.ɵɵtemplate(8, PersistentVolumeClaimFormComponent_aui_form_item_8_Template, 12, 8, "aui-form-item", 10);
577
+ i0.ɵɵpipe(9, "pure");
578
+ i0.ɵɵtemplate(10, PersistentVolumeClaimFormComponent_aui_form_item_10_Template, 11, 14, "aui-form-item", 11);
579
+ i0.ɵɵpipe(11, "pure");
580
+ i0.ɵɵtemplate(12, PersistentVolumeClaimFormComponent_aui_form_item_12_Template, 11, 8, "aui-form-item", 10);
581
+ i0.ɵɵpipe(13, "pure");
582
+ i0.ɵɵtemplate(14, PersistentVolumeClaimFormComponent_ng_container_14_Template, 9, 15, "ng-container", 10);
583
+ } if (rf & 2) {
584
+ i0.ɵɵproperty("ngIf", i0.ɵɵpipeBind2(1, 8, "name", ctx.displayFieldSupported));
585
+ i0.ɵɵadvance(2);
586
+ i0.ɵɵproperty("ngIf", i0.ɵɵpipeBind2(3, 11, "dataSource", ctx.displayFieldSupported));
587
+ i0.ɵɵadvance(2);
588
+ i0.ɵɵproperty("ngIf", i0.ɵɵpipeBind2(5, 14, "createType", ctx.displayFieldSupported));
589
+ i0.ɵɵadvance(2);
590
+ i0.ɵɵproperty("ngIf", i0.ɵɵpipeBind2(7, 17, "storageClassName", ctx.displayFieldSupported));
591
+ i0.ɵɵadvance(2);
592
+ i0.ɵɵproperty("ngIf", i0.ɵɵpipeBind2(9, 20, "accessModes", ctx.displayFieldSupported));
593
+ i0.ɵɵadvance(2);
594
+ i0.ɵɵproperty("ngIf", i0.ɵɵpipeBind2(11, 23, "storage", ctx.displayFieldSupported));
595
+ i0.ɵɵadvance(2);
596
+ i0.ɵɵproperty("ngIf", i0.ɵɵpipeBind2(13, 26, "volumeMode", ctx.displayFieldSupported));
597
+ i0.ɵɵadvance(2);
598
+ i0.ɵɵproperty("ngIf", ctx.showAdvancedField);
599
+ } }, dependencies: [NgIf,
600
+ NgFor,
601
+ FormsModule, i3.DefaultValueAccessor, i3.NgControlStatus, i3.NgControlStatusGroup, i3.RequiredValidator, i3.MaxLengthValidator, i3.PatternValidator, i3.NgModel, FormModule, i4.FormItemComponent, i4.FormItemAddonDirective, i4.FormItemErrorDirective, i4.FormItemLabelDirective, i4.FormItemControlDirective, RadioModule, i4.RadioGroupComponent, i4.RadioButtonComponent, InputModule, i4.InputComponent, SelectModule, i4.SelectComponent, i4.OptionComponent, TooltipModule, i4.TooltipDirective, IconModule, i4.IconComponent, PurePipe,
602
+ AsyncPipe,
603
+ LowerCasePipe,
604
+ ReadonlyFieldDirective,
605
+ FoldableBlockComponent,
606
+ StorageClassSelectComponent,
607
+ KeyValueFormTableComponent, i2.TranslatePipe, i2.ErrorsMapperComponent], encapsulation: 2, changeDetection: 0 }); }
608
+ }
609
+ __decorate([
610
+ ObservableInput(),
611
+ __metadata("design:type", Observable)
612
+ ], PersistentVolumeClaimFormComponent.prototype, "baseParams$", void 0);
613
+ __decorate([
614
+ ObservableInput(),
615
+ __metadata("design:type", Observable)
616
+ ], PersistentVolumeClaimFormComponent.prototype, "storageClasses$", void 0);
617
+ __decorate([
618
+ bind,
619
+ __metadata("design:type", Function),
620
+ __metadata("design:paramtypes", [String]),
621
+ __metadata("design:returntype", void 0)
622
+ ], PersistentVolumeClaimFormComponent.prototype, "displayFieldSupported", null);
623
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(PersistentVolumeClaimFormComponent, [{
624
+ type: Component,
625
+ args: [{ standalone: true, selector: 'acl-pvc-form', changeDetection: ChangeDetectionStrategy.OnPush, imports: [
626
+ NgIf,
627
+ NgFor,
628
+ FormsModule,
629
+ FormModule,
630
+ RadioModule,
631
+ InputModule,
632
+ SelectModule,
633
+ TooltipModule,
634
+ IconModule,
635
+ PurePipe,
636
+ AsyncPipe,
637
+ LowerCasePipe,
638
+ CoerceNumberDirective,
639
+ ReadonlyFieldDirective,
640
+ DisabledDirective,
641
+ FoldableBlockComponent,
642
+ StorageClassSelectComponent,
643
+ StorageFeatureTagsComponent,
644
+ KeyValueFormTableComponent,
645
+ TRANSLATE_MODULE,
646
+ ERRORS_MAPPER_MODULE,
647
+ ], providers: [
648
+ {
649
+ provide: NG_VALUE_ACCESSOR,
650
+ useExisting: forwardRef(() => PersistentVolumeClaimFormComponent),
651
+ multi: true,
652
+ },
653
+ {
654
+ provide: NG_VALIDATORS,
655
+ useExisting: forwardRef(() => PersistentVolumeClaimFormComponent),
656
+ multi: true,
657
+ },
658
+ ], template: "<aui-form-item\n width=\"large\"\n *ngIf=\"'name' | pure: displayFieldSupported\"\n>\n <label auiFormItemLabel>{{ 'name' | translate }}</label>\n <input\n aui-input\n auiFormItemControl\n [(ngModel)]=\"model.name\"\n name=\"name\"\n #name=\"ngModel\"\n maxlength=\"63\"\n [placeholder]=\"resourceNameReg.tip | translate\"\n [pattern]=\"resourceNameReg.pattern\"\n required\n />\n <acl-errors-mapper\n auiFormItemError\n [errors]=\"name.errors\"\n [errorsMapper]=\"{\n pattern: resourceNameReg.tip | translate,\n }\"\n ></acl-errors-mapper>\n</aui-form-item>\n\n<ng-container *ngIf=\"'dataSource' | pure: displayFieldSupported\">\n <aui-form-item *ngIf=\"model.dataSource as dataSource\">\n <label auiFormItemLabel>{{ 'storage.data_source' | translate }}</label>\n {{ dataSource.name }}\n </aui-form-item>\n</ng-container>\n\n<aui-form-item *ngIf=\"'createType' | pure: displayFieldSupported\">\n <label auiFormItemLabel>{{ 'storage.create_method' | translate }}</label>\n <aui-radio-group\n size=\"medium\"\n [(ngModel)]=\"createMethod\"\n name=\"createMethod\"\n [aclReadonlyField]=\"isFromSnapshot || !!createType\"\n [aclReadonlyFieldTemplate]=\"createTypeTmpl\"\n (ngModelChange)=\"createMethodChange($event)\"\n >\n <aui-radio-button [value]=\"PvcStorageClassCreateType.DYNAMIC\">\n {{ 'storage.dynamic_create' | translate }}\n </aui-radio-button>\n <aui-radio-button [value]=\"PvcStorageClassCreateType.STATIC\">\n {{ 'storage.static_match' | translate }}\n </aui-radio-button>\n </aui-radio-group>\n <ng-template #createTypeTmpl>\n {{\n (createMethod === PvcStorageClassCreateType.DYNAMIC\n ? 'storage.dynamic_create'\n : 'storage.static_match'\n ) | translate\n }}\n </ng-template>\n</aui-form-item>\n\n<ng-container *ngIf=\"'storageClassName' | pure: displayFieldSupported\">\n <aui-form-item\n *ngIf=\"createMethod !== PvcStorageClassCreateType.STATIC\"\n width=\"medium\"\n >\n <label auiFormItemLabel>{{ 'storageclass' | translate }}</label>\n <acl-storageclass-select\n [storageClasses]=\"storageClassList$ | async\"\n [volumeSnapshotClasses]=\"volumeSnapshotClassList$ | async\"\n [isFromSnapshot]=\"isFromSnapshot\"\n auiFormItemControl\n required\n [(ngModel)]=\"model.storageClassName\"\n name=\"storageClassName\"\n #storageClassName=\"ngModel\"\n (storageClassChange)=\"storageclassChange($event)\"\n ></acl-storageclass-select>\n <acl-errors-mapper\n auiFormItemError\n [errors]=\"storageClassName.errors\"\n ></acl-errors-mapper>\n </aui-form-item>\n</ng-container>\n\n<aui-form-item *ngIf=\"'accessModes' | pure: displayFieldSupported\">\n <label auiFormItemLabel>{{ 'storage.access_mode' | translate }}</label>\n <aui-radio-group\n auiFormItemControl\n [(ngModel)]=\"model.accessModes\"\n required\n name=\"accessModes\"\n #accessMode=\"ngModel\"\n >\n <aui-radio-button\n *ngFor=\"let mode of accessModes\"\n [auiTooltip]=\"'storage.storage_forbid_select_access_mode' | translate\"\n [auiTooltipDisabled]=\"\n !(\n mode\n | pure\n : storageCommonUtil.isAccessModeDisabled\n : selectedStorageSelectOption\n )\n \"\n [value]=\"mode\"\n [disabled]=\"\n mode\n | pure\n : storageCommonUtil.isAccessModeDisabled\n : selectedStorageSelectOption\n \"\n >\n {{ 'storage.' + AccessModeTranslateKey[mode] | translate }}\n </aui-radio-button>\n </aui-radio-group>\n <div auiFormItemAddon>\n <aui-icon\n [auiTooltip]=\"accessModeTip\"\n [auiTooltipPosition]=\"'top center'\"\n icon=\"question_circle\"\n class=\"icon--help\"\n ></aui-icon>\n </div>\n <acl-errors-mapper\n auiFormItemError\n [errors]=\"accessMode.errors\"\n ></acl-errors-mapper>\n <ng-template #accessModeTip>\n <ul class=\"d-list\">\n <li>{{ 'storage.access_mode_rwo' | translate }}</li>\n <li>{{ 'storage.access_mode_rox' | translate }}</li>\n <li>{{ 'storage.access_mode_rwx' | translate }}</li>\n </ul>\n </ng-template>\n</aui-form-item>\n\n<aui-form-item\n width=\"medium\"\n *ngIf=\"'storage' | pure: displayFieldSupported\"\n>\n <label auiFormItemLabel>{{ 'storage.capacity' | translate }}</label>\n <input\n aui-input\n type=\"text\"\n [pattern]=\"POSITIVE_INT_PATTERN.pattern\"\n [(ngModel)]=\"model.storage\"\n name=\"storage\"\n #storage=\"ngModel\"\n required\n auiFormItemControl\n required\n [aclReadonlyField]=\"isFromSnapshot\"\n [aclReadonlyFieldTemplate]=\"capacityTpl\"\n />\n <aui-select\n *ngIf=\"!isFromSnapshot\"\n [(ngModel)]=\"unit\"\n class=\"tw-max-w-[60px] tw-ml-[-60px]\"\n >\n <aui-option\n *ngFor=\"let item of UNITS\"\n [label]=\"item\"\n [value]=\"item\"\n >\n {{ item }}\n </aui-option>\n </aui-select>\n <ng-template #capacityTpl> {{ model.storage }}Gi </ng-template>\n <acl-errors-mapper\n auiFormItemError\n [errors]=\"storage.errors\"\n [errorsMapper]=\"{\n pattern: POSITIVE_INT_PATTERN.tip | translate,\n }\"\n ></acl-errors-mapper>\n</aui-form-item>\n\n<aui-form-item *ngIf=\"'volumeMode' | pure: displayFieldSupported\">\n <label auiFormItemLabel>{{ 'storage.volume_mode' | translate }}</label>\n <aui-radio-group\n size=\"medium\"\n [(ngModel)]=\"model.volumeMode\"\n name=\"volumeMode\"\n [aclReadonlyField]=\"isFromSnapshot || !!volumeMode\"\n [aclReadonlyFieldTemplate]=\"volumeModeTmpl\"\n >\n <aui-radio-button\n *ngFor=\"let mode of volumeModes\"\n [auiTooltip]=\"'storage.storage_forbid_select_volume_mode' | translate\"\n [auiTooltipDisabled]=\"\n !(\n mode\n | pure\n : storageCommonUtil.isVolumeModeDisabled\n : selectedStorageSelectOption\n )\n \"\n [disabled]=\"\n mode\n | pure\n : storageCommonUtil.isVolumeModeDisabled\n : selectedStorageSelectOption\n \"\n [value]=\"mode\"\n >\n {{ 'storage.' + VolumeModeTranslateKey[mode] | translate }}\n </aui-radio-button>\n </aui-radio-group>\n <div\n auiFormItemAddon\n *ngIf=\"!volumeMode\"\n >\n <aui-icon\n [auiTooltip]=\"volumeModeTip\"\n [auiTooltipPosition]=\"'top center'\"\n icon=\"question_circle\"\n class=\"icon--help\"\n ></aui-icon>\n </div>\n <ng-template #volumeModeTip>\n <ul class=\"d-list\">\n <li>{{ 'storage.volume_mode_file_system_hint' | translate }}</li>\n <li>{{ 'storage.volume_mode_block_device_hint' | translate }}</li>\n </ul>\n </ng-template>\n <ng-template #volumeModeTmpl>\n {{\n (model.volumeMode === 'Filesystem'\n ? 'storage.file_system'\n : 'storage.block_device'\n ) | translate\n }}\n </ng-template>\n</aui-form-item>\n\n<ng-container *ngIf=\"showAdvancedField\">\n <acl-foldable-block hint=\"{{ 'storage.advanced' | translate }}\">\n <aui-form-item\n formGroupName=\"metadata\"\n *ngIf=\"'labels' | pure: displayFieldSupported\"\n >\n <label auiFormItemLabel>{{ 'label' | translate }}</label>\n <acl-key-value-form-table\n auiFormItemControl\n [(ngModel)]=\"model.labels\"\n name=\"labels\"\n [resourceNameTranslated]=\"'storage.labels' | translate | lowercase\"\n [validator]=\"labelValidator\"\n [errorMapper]=\"labelErrorMapper$ | async\"\n ></acl-key-value-form-table>\n </aui-form-item>\n <aui-form-item\n formGroupName=\"metadata\"\n *ngIf=\"'annotations' | pure: displayFieldSupported\"\n >\n <label auiFormItemLabel>{{ 'storage.k8s_annotation' | translate }}</label>\n <acl-key-value-form-table\n auiFormItemControl\n [resourceNameTranslated]=\"\n 'storage.k8s_annotation' | translate | lowercase\n \"\n [(ngModel)]=\"model.annotations\"\n name=\"annotations\"\n [validator]=\"annotationValidator\"\n [errorMapper]=\"annotationErrorMapper$ | async\"\n ></acl-key-value-form-table>\n </aui-form-item>\n <ng-container *ngIf=\"'selector' | pure: displayFieldSupported\">\n <aui-form-item\n [hidden]=\"createMethod === PvcStorageClassCreateType.DYNAMIC\"\n >\n <label auiFormItemLabel>{{ 'storage.selector' | translate }}</label>\n <acl-key-value-form-table\n auiFormItemControl\n [(ngModel)]=\"model.selector\"\n name=\"selector\"\n ></acl-key-value-form-table>\n </aui-form-item>\n </ng-container>\n </acl-foldable-block>\n</ng-container>\n" }]
659
+ }], () => [{ type: i1.StorageCommonUtilService }, { type: i2.TranslateService }, { type: i2.K8sApiService }], { baseParams: [{
660
+ type: Input,
661
+ args: [{ required: true }]
662
+ }], baseParams$: [], storageClasses: [{
663
+ type: Input
664
+ }], storageClasses$: [], isFromSnapshot: [{
665
+ type: Input
666
+ }], createType: [{
667
+ type: Input
668
+ }], volumeMode: [{
669
+ type: Input
670
+ }], displayFields: [{
671
+ type: Input
672
+ }], displayFieldSupported: [] }); })();
673
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(PersistentVolumeClaimFormComponent, { className: "PersistentVolumeClaimFormComponent", filePath: "lib/components/pvc-form/component.ts", lineNumber: 134 }); })();
674
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"component.js","sourceRoot":"","sources":["../../../../../../../modules/storage/src/lib/components/pvc-form/component.ts","../../../../../../../modules/storage/src/lib/components/pvc-form/template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  FormModule,\n  IconModule,\n  InputModule,\n  RadioModule,\n  SelectModule,\n  TooltipModule,\n} from '@alauda/ui';\nimport {\n  AccessMode,\n  AccessModes,\n  getK8sResourceAnnotationErrorMapper$,\n  k8sResourceAnnotationValidator,\n  getK8sResourceLabelErrorMapper$,\n  k8sResourceLabelValidator,\n  VolumeMode,\n  LabelSelector,\n  FoldableBlockComponent,\n  KeyValueFormTableComponent,\n  PersistentVolumeClaim,\n  PersistentVolumeClaimDataSource,\n  createNestedFormControl,\n  dataTransfer,\n  ReadonlyFieldDirective,\n  K8S_RESOURCE_NAME_BASE,\n  CoerceNumberDirective,\n  TranslateService,\n  DisabledDirective,\n  ObservableInput,\n  K8sApiService,\n  RESOURCE_TYPES,\n  skipError,\n  VolumeModes,\n  ValueOf,\n  publishRef,\n  StringMap,\n  bind,\n  WorkspaceParams,\n  TRANSLATE_MODULE,\n  ERRORS_MAPPER_MODULE,\n  PurePipe,\n  POSITIVE_INT_PATTERN,\n} from '@alauda-fe/common';\nimport { AsyncPipe, LowerCasePipe, NgFor, NgIf } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  Input,\n  forwardRef,\n} from '@angular/core';\nimport { FormsModule, NG_VALIDATORS, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { compose } from 'ramda';\nimport { Observable, combineLatest, map, of, switchMap } from 'rxjs';\n\nimport {\n  StorageSelectOption,\n  StorageCommonUtilService,\n} from '../../services/common-util.service';\nimport { StorageClass, VolumeSnapshotClass } from '../../types/k8s';\nimport {\n  AccessModeTranslateKey,\n  VolumeModeTranslateKey,\n} from '../../utils/constants';\nimport { buildPvcResource } from '../../utils/util';\nimport { StorageFeatureTagsComponent } from '../storage-feature-tags/component';\nimport { StorageClassSelectComponent } from '../storageclass-select/component';\n\nconst PvcStorageClassCreateType = {\n  DYNAMIC: 'dynamic',\n  STATIC: 'static',\n} as const;\n\ntype PvcStorageClassCreateType = ValueOf<typeof PvcStorageClassCreateType>;\n\ninterface PersistentVolumeFormModel {\n  name: string;\n  labels: StringMap;\n  annotations: StringMap;\n  // null 表示使用默认 sc\n  // \"\" 或不写该字段表示不设置存储类\n  storageClassName: string;\n  accessModes: AccessMode;\n  volumeMode: VolumeMode;\n  storage: string;\n  dataSource?: PersistentVolumeClaimDataSource;\n  selector: LabelSelector;\n}\n\ntype DisplayField = keyof PersistentVolumeFormModel | 'createType';\n\nconst UNITS = ['Gi', 'Ti'] as const;\n\n@Component({\n  standalone: true,\n  selector: 'acl-pvc-form',\n  templateUrl: 'template.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [\n    NgIf,\n    NgFor,\n    FormsModule,\n    FormModule,\n    RadioModule,\n    InputModule,\n    SelectModule,\n    TooltipModule,\n    IconModule,\n    PurePipe,\n    AsyncPipe,\n    LowerCasePipe,\n    CoerceNumberDirective,\n    ReadonlyFieldDirective,\n    DisabledDirective,\n    FoldableBlockComponent,\n    StorageClassSelectComponent,\n    StorageFeatureTagsComponent,\n    KeyValueFormTableComponent,\n    TRANSLATE_MODULE,\n    ERRORS_MAPPER_MODULE,\n  ],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => PersistentVolumeClaimFormComponent),\n      multi: true,\n    },\n    {\n      provide: NG_VALIDATORS,\n      useExisting: forwardRef(() => PersistentVolumeClaimFormComponent),\n      multi: true,\n    },\n  ],\n})\nexport class PersistentVolumeClaimFormComponent extends createNestedFormControl<\n  PersistentVolumeClaim,\n  PersistentVolumeFormModel\n>({\n  autoEmitChange: true,\n}) {\n  @Input({ required: true })\n  baseParams: WorkspaceParams;\n\n  @ObservableInput()\n  baseParams$!: Observable<WorkspaceParams>;\n\n  @Input()\n  storageClasses: StorageClass[];\n\n  @ObservableInput()\n  storageClasses$!: Observable<StorageClass[]>;\n\n  // 快照类 pvc 创建\n  @Input()\n  isFromSnapshot: boolean;\n\n  // 如果传入相应的 createType 表示固定其值\n  @Input()\n  createType: PvcStorageClassCreateType;\n\n  // 如果传入相应的 volumeMode 表示固定其值\n  @Input()\n  volumeMode: VolumeMode;\n\n  // 如果传入相应的 displayField 表示只会展示对应的 control\n  @Input()\n  displayFields: DisplayField[];\n\n  get showAdvancedField() {\n    if (!this.displayFields?.length) {\n      return true;\n    }\n\n    return this.displayFields?.some(field =>\n      ['labels', 'annotations', 'selector'].includes(field),\n    );\n  }\n\n  accessModes = AccessModes;\n  volumeModes = VolumeModes;\n  POSITIVE_INT_PATTERN = POSITIVE_INT_PATTERN;\n\n  override model = {} as PersistentVolumeFormModel;\n\n  resourceNameReg = K8S_RESOURCE_NAME_BASE;\n  labelValidator = k8sResourceLabelValidator;\n  AccessModeTranslateKey = AccessModeTranslateKey;\n  VolumeModeTranslateKey = VolumeModeTranslateKey;\n\n  labelErrorMapper$ = getK8sResourceLabelErrorMapper$(this.translate);\n  annotationValidator = k8sResourceAnnotationValidator;\n  annotationErrorMapper$ = getK8sResourceAnnotationErrorMapper$(this.translate);\n\n  createMethod: PvcStorageClassCreateType;\n  PvcStorageClassCreateType = PvcStorageClassCreateType;\n  selectedStorageSelectOption: StorageSelectOption;\n  UNITS = UNITS;\n  unit = 'Gi';\n\n  storageClassList$ = combineLatest([\n    this.baseParams$,\n    this.storageClasses$,\n  ]).pipe(\n    switchMap(([{ cluster }, storageClasses]) => {\n      if (storageClasses) {\n        return of(storageClasses);\n      }\n      return this.k8sApi\n        .getResourceList<StorageClass>({\n          type: RESOURCE_TYPES.STORAGE_CLASS,\n          cluster,\n          queryParams: {\n            limit: '0',\n          },\n        })\n        .pipe(map(res => res?.items));\n    }),\n    publishRef(),\n  );\n\n  volumeSnapshotClassList$ = this.baseParams$.pipe(\n    switchMap(baseParams =>\n      this.k8sApi\n        .getResourceList<VolumeSnapshotClass>({\n          type: RESOURCE_TYPES.VOLUME_SNAPSHOT_CLASS,\n          cluster: baseParams.cluster,\n        })\n        .pipe(\n          map(r => r.items),\n          skipError([] as VolumeSnapshotClass[]),\n        ),\n    ),\n    publishRef(),\n  );\n\n  override writeValue(value: PersistentVolumeClaim): void {\n    this.model = this.valueIn(\n      value ??\n        buildPvcResource({\n          namespace: this.baseParams.namespace,\n          volumeMode: this.volumeMode,\n        }),\n    );\n    if (this.createType) {\n      this.createMethod = this.createType;\n    }\n  }\n\n  constructor(\n    protected storageCommonUtil: StorageCommonUtilService,\n    private readonly translate: TranslateService,\n    private readonly k8sApi: K8sApiService,\n  ) {\n    super();\n\n    const [toModel, toResource] = dataTransfer<\n      PersistentVolumeClaim,\n      PersistentVolumeFormModel\n    >({\n      name: 'metadata.name',\n      labels: 'metadata.labels',\n      annotations: 'metadata.annotations',\n      storageClassName: 'spec.storageClassName',\n      accessModes: ['spec', 'accessModes', 0],\n      volumeMode: 'spec.volumeMode',\n      storage: 'spec.resources.requests.storage',\n      dataSource: 'spec.dataSource',\n      selector: 'spec.selector.matchLabels',\n    });\n\n    this.valueIn = compose(toModel, this.adaptResourceModel);\n    this.modelOut = compose(this.overrideResource, toResource);\n  }\n\n  createMethodChange(createType: PvcStorageClassCreateType) {\n    // 静态匹配不需要限制访问模式\n    if (createType === 'static') {\n      this.selectedStorageSelectOption = null;\n    }\n  }\n\n  storageclassChange(selectedOption: StorageSelectOption) {\n    this.selectedStorageSelectOption = selectedOption;\n    this.setAccessModeToSupportValueIfNeed();\n    this.setVolumeModeToSupportValueIfNeed();\n  }\n\n  @bind\n  displayFieldSupported(fieldName: DisplayField) {\n    if (!this.displayFields?.length) {\n      return true;\n    }\n\n    return this.displayFields.includes(fieldName);\n  }\n\n  private setAccessModeToSupportValueIfNeed() {\n    if (\n      this.storageCommonUtil.isAccessModeDisabled(\n        this.model.accessModes,\n        this.selectedStorageSelectOption,\n      )\n    ) {\n      this.model.accessModes = this.accessModes.find(\n        accessMode =>\n          !this.storageCommonUtil.isAccessModeDisabled(\n            accessMode,\n            this.selectedStorageSelectOption,\n          ),\n      );\n    }\n  }\n\n  private setVolumeModeToSupportValueIfNeed() {\n    if (\n      this.storageCommonUtil.isVolumeModeDisabled(\n        this.model.volumeMode,\n        this.selectedStorageSelectOption,\n      )\n    ) {\n      this.model.volumeMode = this.volumeModes.find(\n        volumeMode =>\n          !this.storageCommonUtil.isVolumeModeDisabled(\n            volumeMode,\n            this.selectedStorageSelectOption,\n          ),\n      );\n    }\n  }\n\n  private readonly adaptResourceModel = (pvc: PersistentVolumeClaim) => {\n    const storage = pvc?.spec?.resources?.requests?.storage;\n    if (storage) {\n      const res = String(storage).match(/[A-Za-z]+|\\d+(?:\\.\\d+)?/g);\n      pvc.spec.resources.requests.storage = res[0] || '';\n      this.unit = res[1] || 'Gi';\n    }\n\n    // \"\" 表示静态创建\n    this.createMethod =\n      pvc?.spec?.storageClassName === '' ? 'static' : 'dynamic';\n\n    return pvc;\n  };\n\n  private readonly overrideResource = (pvc: PersistentVolumeClaim) => {\n    if (\n      this.createMethod === 'dynamic' ||\n      Object.keys(pvc?.spec?.selector?.matchLabels ?? {}).length === 0\n    ) {\n      delete pvc?.spec?.selector;\n    }\n\n    if (this.createMethod === 'static') {\n      pvc.spec.storageClassName = '';\n    }\n\n    if (pvc?.spec?.resources?.requests?.storage) {\n      pvc.spec.resources.requests.storage = `${pvc.spec.resources.requests.storage}${this.unit}`;\n    }\n    return pvc;\n  };\n}\n","<aui-form-item\n  width=\"large\"\n  *ngIf=\"'name' | pure: displayFieldSupported\"\n>\n  <label auiFormItemLabel>{{ 'name' | translate }}</label>\n  <input\n    aui-input\n    auiFormItemControl\n    [(ngModel)]=\"model.name\"\n    name=\"name\"\n    #name=\"ngModel\"\n    maxlength=\"63\"\n    [placeholder]=\"resourceNameReg.tip | translate\"\n    [pattern]=\"resourceNameReg.pattern\"\n    required\n  />\n  <acl-errors-mapper\n    auiFormItemError\n    [errors]=\"name.errors\"\n    [errorsMapper]=\"{\n      pattern: resourceNameReg.tip | translate,\n    }\"\n  ></acl-errors-mapper>\n</aui-form-item>\n\n<ng-container *ngIf=\"'dataSource' | pure: displayFieldSupported\">\n  <aui-form-item *ngIf=\"model.dataSource as dataSource\">\n    <label auiFormItemLabel>{{ 'storage.data_source' | translate }}</label>\n    {{ dataSource.name }}\n  </aui-form-item>\n</ng-container>\n\n<aui-form-item *ngIf=\"'createType' | pure: displayFieldSupported\">\n  <label auiFormItemLabel>{{ 'storage.create_method' | translate }}</label>\n  <aui-radio-group\n    size=\"medium\"\n    [(ngModel)]=\"createMethod\"\n    name=\"createMethod\"\n    [aclReadonlyField]=\"isFromSnapshot || !!createType\"\n    [aclReadonlyFieldTemplate]=\"createTypeTmpl\"\n    (ngModelChange)=\"createMethodChange($event)\"\n  >\n    <aui-radio-button [value]=\"PvcStorageClassCreateType.DYNAMIC\">\n      {{ 'storage.dynamic_create' | translate }}\n    </aui-radio-button>\n    <aui-radio-button [value]=\"PvcStorageClassCreateType.STATIC\">\n      {{ 'storage.static_match' | translate }}\n    </aui-radio-button>\n  </aui-radio-group>\n  <ng-template #createTypeTmpl>\n    {{\n      (createMethod === PvcStorageClassCreateType.DYNAMIC\n        ? 'storage.dynamic_create'\n        : 'storage.static_match'\n      ) | translate\n    }}\n  </ng-template>\n</aui-form-item>\n\n<ng-container *ngIf=\"'storageClassName' | pure: displayFieldSupported\">\n  <aui-form-item\n    *ngIf=\"createMethod !== PvcStorageClassCreateType.STATIC\"\n    width=\"medium\"\n  >\n    <label auiFormItemLabel>{{ 'storageclass' | translate }}</label>\n    <acl-storageclass-select\n      [storageClasses]=\"storageClassList$ | async\"\n      [volumeSnapshotClasses]=\"volumeSnapshotClassList$ | async\"\n      [isFromSnapshot]=\"isFromSnapshot\"\n      auiFormItemControl\n      required\n      [(ngModel)]=\"model.storageClassName\"\n      name=\"storageClassName\"\n      #storageClassName=\"ngModel\"\n      (storageClassChange)=\"storageclassChange($event)\"\n    ></acl-storageclass-select>\n    <acl-errors-mapper\n      auiFormItemError\n      [errors]=\"storageClassName.errors\"\n    ></acl-errors-mapper>\n  </aui-form-item>\n</ng-container>\n\n<aui-form-item *ngIf=\"'accessModes' | pure: displayFieldSupported\">\n  <label auiFormItemLabel>{{ 'storage.access_mode' | translate }}</label>\n  <aui-radio-group\n    auiFormItemControl\n    [(ngModel)]=\"model.accessModes\"\n    required\n    name=\"accessModes\"\n    #accessMode=\"ngModel\"\n  >\n    <aui-radio-button\n      *ngFor=\"let mode of accessModes\"\n      [auiTooltip]=\"'storage.storage_forbid_select_access_mode' | translate\"\n      [auiTooltipDisabled]=\"\n        !(\n          mode\n          | pure\n            : storageCommonUtil.isAccessModeDisabled\n            : selectedStorageSelectOption\n        )\n      \"\n      [value]=\"mode\"\n      [disabled]=\"\n        mode\n          | pure\n            : storageCommonUtil.isAccessModeDisabled\n            : selectedStorageSelectOption\n      \"\n    >\n      {{ 'storage.' + AccessModeTranslateKey[mode] | translate }}\n    </aui-radio-button>\n  </aui-radio-group>\n  <div auiFormItemAddon>\n    <aui-icon\n      [auiTooltip]=\"accessModeTip\"\n      [auiTooltipPosition]=\"'top center'\"\n      icon=\"question_circle\"\n      class=\"icon--help\"\n    ></aui-icon>\n  </div>\n  <acl-errors-mapper\n    auiFormItemError\n    [errors]=\"accessMode.errors\"\n  ></acl-errors-mapper>\n  <ng-template #accessModeTip>\n    <ul class=\"d-list\">\n      <li>{{ 'storage.access_mode_rwo' | translate }}</li>\n      <li>{{ 'storage.access_mode_rox' | translate }}</li>\n      <li>{{ 'storage.access_mode_rwx' | translate }}</li>\n    </ul>\n  </ng-template>\n</aui-form-item>\n\n<aui-form-item\n  width=\"medium\"\n  *ngIf=\"'storage' | pure: displayFieldSupported\"\n>\n  <label auiFormItemLabel>{{ 'storage.capacity' | translate }}</label>\n  <input\n    aui-input\n    type=\"text\"\n    [pattern]=\"POSITIVE_INT_PATTERN.pattern\"\n    [(ngModel)]=\"model.storage\"\n    name=\"storage\"\n    #storage=\"ngModel\"\n    required\n    auiFormItemControl\n    required\n    [aclReadonlyField]=\"isFromSnapshot\"\n    [aclReadonlyFieldTemplate]=\"capacityTpl\"\n  />\n  <aui-select\n    *ngIf=\"!isFromSnapshot\"\n    [(ngModel)]=\"unit\"\n    class=\"tw-max-w-[60px] tw-ml-[-60px]\"\n  >\n    <aui-option\n      *ngFor=\"let item of UNITS\"\n      [label]=\"item\"\n      [value]=\"item\"\n    >\n      {{ item }}\n    </aui-option>\n  </aui-select>\n  <ng-template #capacityTpl> {{ model.storage }}Gi </ng-template>\n  <acl-errors-mapper\n    auiFormItemError\n    [errors]=\"storage.errors\"\n    [errorsMapper]=\"{\n      pattern: POSITIVE_INT_PATTERN.tip | translate,\n    }\"\n  ></acl-errors-mapper>\n</aui-form-item>\n\n<aui-form-item *ngIf=\"'volumeMode' | pure: displayFieldSupported\">\n  <label auiFormItemLabel>{{ 'storage.volume_mode' | translate }}</label>\n  <aui-radio-group\n    size=\"medium\"\n    [(ngModel)]=\"model.volumeMode\"\n    name=\"volumeMode\"\n    [aclReadonlyField]=\"isFromSnapshot || !!volumeMode\"\n    [aclReadonlyFieldTemplate]=\"volumeModeTmpl\"\n  >\n    <aui-radio-button\n      *ngFor=\"let mode of volumeModes\"\n      [auiTooltip]=\"'storage.storage_forbid_select_volume_mode' | translate\"\n      [auiTooltipDisabled]=\"\n        !(\n          mode\n          | pure\n            : storageCommonUtil.isVolumeModeDisabled\n            : selectedStorageSelectOption\n        )\n      \"\n      [disabled]=\"\n        mode\n          | pure\n            : storageCommonUtil.isVolumeModeDisabled\n            : selectedStorageSelectOption\n      \"\n      [value]=\"mode\"\n    >\n      {{ 'storage.' + VolumeModeTranslateKey[mode] | translate }}\n    </aui-radio-button>\n  </aui-radio-group>\n  <div\n    auiFormItemAddon\n    *ngIf=\"!volumeMode\"\n  >\n    <aui-icon\n      [auiTooltip]=\"volumeModeTip\"\n      [auiTooltipPosition]=\"'top center'\"\n      icon=\"question_circle\"\n      class=\"icon--help\"\n    ></aui-icon>\n  </div>\n  <ng-template #volumeModeTip>\n    <ul class=\"d-list\">\n      <li>{{ 'storage.volume_mode_file_system_hint' | translate }}</li>\n      <li>{{ 'storage.volume_mode_block_device_hint' | translate }}</li>\n    </ul>\n  </ng-template>\n  <ng-template #volumeModeTmpl>\n    {{\n      (model.volumeMode === 'Filesystem'\n        ? 'storage.file_system'\n        : 'storage.block_device'\n      ) | translate\n    }}\n  </ng-template>\n</aui-form-item>\n\n<ng-container *ngIf=\"showAdvancedField\">\n  <acl-foldable-block hint=\"{{ 'storage.advanced' | translate }}\">\n    <aui-form-item\n      formGroupName=\"metadata\"\n      *ngIf=\"'labels' | pure: displayFieldSupported\"\n    >\n      <label auiFormItemLabel>{{ 'label' | translate }}</label>\n      <acl-key-value-form-table\n        auiFormItemControl\n        [(ngModel)]=\"model.labels\"\n        name=\"labels\"\n        [resourceNameTranslated]=\"'storage.labels' | translate | lowercase\"\n        [validator]=\"labelValidator\"\n        [errorMapper]=\"labelErrorMapper$ | async\"\n      ></acl-key-value-form-table>\n    </aui-form-item>\n    <aui-form-item\n      formGroupName=\"metadata\"\n      *ngIf=\"'annotations' | pure: displayFieldSupported\"\n    >\n      <label auiFormItemLabel>{{ 'storage.k8s_annotation' | translate }}</label>\n      <acl-key-value-form-table\n        auiFormItemControl\n        [resourceNameTranslated]=\"\n          'storage.k8s_annotation' | translate | lowercase\n        \"\n        [(ngModel)]=\"model.annotations\"\n        name=\"annotations\"\n        [validator]=\"annotationValidator\"\n        [errorMapper]=\"annotationErrorMapper$ | async\"\n      ></acl-key-value-form-table>\n    </aui-form-item>\n    <ng-container *ngIf=\"'selector' | pure: displayFieldSupported\">\n      <aui-form-item\n        [hidden]=\"createMethod === PvcStorageClassCreateType.DYNAMIC\"\n      >\n        <label auiFormItemLabel>{{ 'storage.selector' | translate }}</label>\n        <acl-key-value-form-table\n          auiFormItemControl\n          [(ngModel)]=\"model.selector\"\n          name=\"selector\"\n        ></acl-key-value-form-table>\n      </aui-form-item>\n    </ng-container>\n  </acl-foldable-block>\n</ng-container>\n"]}