@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,464 @@
1
+ import { FormModule, IconModule, InputModule, RadioModule, SelectModule, TooltipModule, isTemplateRef, } from '@alauda/ui';
2
+ import { TRANSLATE_MODULE, ERRORS_MAPPER_MODULE, CoreModule, CoerceNumberDirective, POSITIVE_INT_PATTERN, initGreaterValidator, isEqual, TranslateService, } from '@alauda-fe/common';
3
+ import { CommonModule } from '@angular/common';
4
+ import { ChangeDetectionStrategy, Component, Injector, Input, } from '@angular/core';
5
+ import { ReactiveFormsModule, Validators } from '@angular/forms';
6
+ import { BaseResourceFormGroupComponent } from 'ng-resource-form-util';
7
+ import { debounceTime, distinctUntilChanged, takeUntil } from 'rxjs';
8
+ import { ResourceSize, } from '../../types/resource-exports';
9
+ import { formatResource, getResourceSpecificationMapper, getResourceSpecification, } from '../../utils/resource-exports';
10
+ import * as i0 from "@angular/core";
11
+ import * as i1 from "@alauda-fe/common";
12
+ import * as i2 from "@angular/common";
13
+ import * as i3 from "@angular/forms";
14
+ import * as i4 from "@alauda/ui";
15
+ function ResourceSpecFormComponent_aui_radio_button_6_Template(rf, ctx) { if (rf & 1) {
16
+ i0.ɵɵelementStart(0, "aui-radio-button", 28)(1, "div", 29)(2, "div");
17
+ i0.ɵɵtext(3);
18
+ i0.ɵɵpipe(4, "translate");
19
+ i0.ɵɵelementStart(5, "div", 30);
20
+ i0.ɵɵtext(6);
21
+ i0.ɵɵpipe(7, "translate");
22
+ i0.ɵɵelementEnd()()()();
23
+ } if (rf & 2) {
24
+ const item_r2 = ctx.$implicit;
25
+ i0.ɵɵproperty("value", item_r2.size);
26
+ i0.ɵɵadvance(3);
27
+ i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(4, 3, "storage." + item_r2.size + "_scale"), " ");
28
+ i0.ɵɵadvance(3);
29
+ i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(7, 5, item_r2.tip), " ");
30
+ } }
31
+ function ResourceSpecFormComponent_aui_icon_7_Template(rf, ctx) { if (rf & 1) {
32
+ i0.ɵɵelement(0, "aui-icon", 31);
33
+ } if (rf & 2) {
34
+ i0.ɵɵnextContext();
35
+ const descriptionTemplate_r3 = i0.ɵɵreference(9);
36
+ i0.ɵɵproperty("auiTooltip", descriptionTemplate_r3);
37
+ } }
38
+ function ResourceSpecFormComponent_ng_template_8_ng_container_0_Template(rf, ctx) { if (rf & 1) {
39
+ i0.ɵɵelementContainer(0, 33);
40
+ } if (rf & 2) {
41
+ const ctx_r3 = i0.ɵɵnextContext(2);
42
+ i0.ɵɵproperty("ngTemplateOutlet", ctx_r3.resourceSpecificationDescription);
43
+ } }
44
+ function ResourceSpecFormComponent_ng_template_8_ng_template_1_Template(rf, ctx) { if (rf & 1) {
45
+ i0.ɵɵtext(0);
46
+ } if (rf & 2) {
47
+ const ctx_r3 = i0.ɵɵnextContext(2);
48
+ i0.ɵɵtextInterpolate1(" ", ctx_r3.resourceSpecificationDescription, " ");
49
+ } }
50
+ function ResourceSpecFormComponent_ng_template_8_Template(rf, ctx) { if (rf & 1) {
51
+ i0.ɵɵtemplate(0, ResourceSpecFormComponent_ng_template_8_ng_container_0_Template, 1, 1, "ng-container", 32)(1, ResourceSpecFormComponent_ng_template_8_ng_template_1_Template, 1, 1, "ng-template", null, 5, i0.ɵɵtemplateRefExtractor);
52
+ } if (rf & 2) {
53
+ const text_r5 = i0.ɵɵreference(2);
54
+ const ctx_r3 = i0.ɵɵnextContext();
55
+ i0.ɵɵproperty("ngIf", ctx_r3.isTemplateRef(ctx_r3.resourceSpecificationDescription))("ngIfElse", text_r5);
56
+ } }
57
+ function ResourceSpecFormComponent_aui_form_item_10_aui_select_10_Template(rf, ctx) { if (rf & 1) {
58
+ i0.ɵɵelementStart(0, "aui-select", 36)(1, "aui-option", 37);
59
+ i0.ɵɵtext(2, "m");
60
+ i0.ɵɵelementEnd();
61
+ i0.ɵɵelementStart(3, "aui-option", 38);
62
+ i0.ɵɵpipe(4, "translate");
63
+ i0.ɵɵtext(5);
64
+ i0.ɵɵpipe(6, "translate");
65
+ i0.ɵɵelementEnd()();
66
+ } if (rf & 2) {
67
+ i0.ɵɵadvance(3);
68
+ i0.ɵɵproperty("label", i0.ɵɵpipeBind1(4, 2, "core"));
69
+ i0.ɵɵadvance(2);
70
+ i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(6, 4, "core"), " ");
71
+ } }
72
+ function ResourceSpecFormComponent_aui_form_item_10_ng_template_11_span_0_Template(rf, ctx) { if (rf & 1) {
73
+ i0.ɵɵelementStart(0, "span", 40);
74
+ i0.ɵɵtext(1);
75
+ i0.ɵɵpipe(2, "translate");
76
+ i0.ɵɵelementEnd();
77
+ } if (rf & 2) {
78
+ const cpuUnit_r6 = ctx.ngIf;
79
+ i0.ɵɵadvance();
80
+ i0.ɵɵtextInterpolate1(" ", cpuUnit_r6 === "core" ? i0.ɵɵpipeBind1(2, 1, "core") : cpuUnit_r6, " ");
81
+ } }
82
+ function ResourceSpecFormComponent_aui_form_item_10_ng_template_11_Template(rf, ctx) { if (rf & 1) {
83
+ i0.ɵɵtemplate(0, ResourceSpecFormComponent_aui_form_item_10_ng_template_11_span_0_Template, 3, 3, "span", 39);
84
+ } if (rf & 2) {
85
+ const ctx_r3 = i0.ɵɵnextContext(2);
86
+ i0.ɵɵproperty("ngIf", ctx_r3.form.get("requests.cpu.unit").value);
87
+ } }
88
+ function ResourceSpecFormComponent_aui_form_item_10_aui_select_21_Template(rf, ctx) { if (rf & 1) {
89
+ i0.ɵɵelementStart(0, "aui-select", 41)(1, "aui-option", 42);
90
+ i0.ɵɵtext(2, "Mi");
91
+ i0.ɵɵelementEnd();
92
+ i0.ɵɵelementStart(3, "aui-option", 43);
93
+ i0.ɵɵtext(4, "Gi");
94
+ i0.ɵɵelementEnd()();
95
+ } }
96
+ function ResourceSpecFormComponent_aui_form_item_10_ng_template_22_Template(rf, ctx) { if (rf & 1) {
97
+ i0.ɵɵelementStart(0, "span", 40);
98
+ i0.ɵɵtext(1);
99
+ i0.ɵɵelementEnd();
100
+ } if (rf & 2) {
101
+ const ctx_r3 = i0.ɵɵnextContext(2);
102
+ i0.ɵɵadvance();
103
+ i0.ɵɵtextInterpolate1(" ", ctx_r3.form.get("requests.memory.unit").value, " ");
104
+ } }
105
+ function ResourceSpecFormComponent_aui_form_item_10_Template(rf, ctx) { if (rf & 1) {
106
+ i0.ɵɵelementStart(0, "aui-form-item", 17)(1, "label", 12);
107
+ i0.ɵɵtext(2);
108
+ i0.ɵɵpipe(3, "translate");
109
+ i0.ɵɵelementEnd();
110
+ i0.ɵɵelementStart(4, "div", 34)(5, "aui-form-item", 19)(6, "aui-input-group", 20)(7, "span", 21);
111
+ i0.ɵɵtext(8, "CPU");
112
+ i0.ɵɵelementEnd();
113
+ i0.ɵɵelement(9, "input", 22);
114
+ i0.ɵɵtemplate(10, ResourceSpecFormComponent_aui_form_item_10_aui_select_10_Template, 7, 6, "aui-select", 23)(11, ResourceSpecFormComponent_aui_form_item_10_ng_template_11_Template, 1, 1, "ng-template", null, 6, i0.ɵɵtemplateRefExtractor);
115
+ i0.ɵɵelementEnd();
116
+ i0.ɵɵelement(13, "div", 24, 7);
117
+ i0.ɵɵelementEnd();
118
+ i0.ɵɵelementStart(15, "aui-form-item", 25)(16, "aui-input-group", 26)(17, "span", 21);
119
+ i0.ɵɵtext(18);
120
+ i0.ɵɵpipe(19, "translate");
121
+ i0.ɵɵelementEnd();
122
+ i0.ɵɵelement(20, "input", 35);
123
+ i0.ɵɵtemplate(21, ResourceSpecFormComponent_aui_form_item_10_aui_select_21_Template, 5, 0, "aui-select", 27)(22, ResourceSpecFormComponent_aui_form_item_10_ng_template_22_Template, 2, 1, "ng-template", null, 8, i0.ɵɵtemplateRefExtractor);
124
+ i0.ɵɵelementEnd();
125
+ i0.ɵɵelement(24, "div", 24, 9);
126
+ i0.ɵɵelementEnd()()();
127
+ } if (rf & 2) {
128
+ const rcUnit_r7 = i0.ɵɵreference(12);
129
+ const cpuRequestError_r8 = i0.ɵɵreference(14);
130
+ const rmUnit_r9 = i0.ɵɵreference(23);
131
+ const memoryRequiredError_r10 = i0.ɵɵreference(25);
132
+ const ctx_r3 = i0.ɵɵnextContext();
133
+ i0.ɵɵadvance(2);
134
+ i0.ɵɵtextInterpolate(i0.ɵɵpipeBind1(3, 14, "storage.resource_request"));
135
+ i0.ɵɵadvance(7);
136
+ i0.ɵɵproperty("pattern", ctx_r3.POSITIVE_INT_PATTERN.pattern)("aclErrorsMapper", ctx_r3.errorMapper)("aclErrorsMapperOutlet", cpuRequestError_r8)("readonly", ctx_r3.form.get("size").value !== ctx_r3.ResourceSize.CUSTOMIZE);
137
+ i0.ɵɵadvance();
138
+ i0.ɵɵproperty("ngIf", ctx_r3.form.get("size").value === ctx_r3.ResourceSize.CUSTOMIZE)("ngIfElse", rcUnit_r7);
139
+ i0.ɵɵadvance(8);
140
+ i0.ɵɵtextInterpolate(i0.ɵɵpipeBind1(19, 16, "memory"));
141
+ i0.ɵɵadvance(2);
142
+ i0.ɵɵproperty("readonly", ctx_r3.form.get("size").value !== ctx_r3.ResourceSize.CUSTOMIZE)("pattern", ctx_r3.POSITIVE_INT_PATTERN.pattern)("aclErrorsMapper", ctx_r3.errorMapper)("aclErrorsMapperOutlet", memoryRequiredError_r10);
143
+ i0.ɵɵadvance();
144
+ i0.ɵɵproperty("ngIf", ctx_r3.form.get("size").value === ctx_r3.ResourceSize.CUSTOMIZE)("ngIfElse", rmUnit_r9);
145
+ } }
146
+ function ResourceSpecFormComponent_aui_select_21_Template(rf, ctx) { if (rf & 1) {
147
+ i0.ɵɵelementStart(0, "aui-select", 36)(1, "aui-option", 37);
148
+ i0.ɵɵtext(2, "m");
149
+ i0.ɵɵelementEnd();
150
+ i0.ɵɵelementStart(3, "aui-option", 38);
151
+ i0.ɵɵpipe(4, "translate");
152
+ i0.ɵɵtext(5);
153
+ i0.ɵɵpipe(6, "translate");
154
+ i0.ɵɵelementEnd()();
155
+ } if (rf & 2) {
156
+ i0.ɵɵadvance(3);
157
+ i0.ɵɵproperty("label", i0.ɵɵpipeBind1(4, 2, "core"));
158
+ i0.ɵɵadvance(2);
159
+ i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(6, 4, "core"), " ");
160
+ } }
161
+ function ResourceSpecFormComponent_ng_template_22_span_0_Template(rf, ctx) { if (rf & 1) {
162
+ i0.ɵɵelementStart(0, "span", 40);
163
+ i0.ɵɵtext(1);
164
+ i0.ɵɵpipe(2, "translate");
165
+ i0.ɵɵelementEnd();
166
+ } if (rf & 2) {
167
+ const cpuUnit_r11 = ctx.ngIf;
168
+ i0.ɵɵadvance();
169
+ i0.ɵɵtextInterpolate1(" ", cpuUnit_r11 === "core" ? i0.ɵɵpipeBind1(2, 1, "core") : cpuUnit_r11, " ");
170
+ } }
171
+ function ResourceSpecFormComponent_ng_template_22_Template(rf, ctx) { if (rf & 1) {
172
+ i0.ɵɵtemplate(0, ResourceSpecFormComponent_ng_template_22_span_0_Template, 3, 3, "span", 39);
173
+ } if (rf & 2) {
174
+ const ctx_r3 = i0.ɵɵnextContext();
175
+ i0.ɵɵproperty("ngIf", ctx_r3.form.get("limits.cpu.unit").value);
176
+ } }
177
+ function ResourceSpecFormComponent_aui_select_32_Template(rf, ctx) { if (rf & 1) {
178
+ i0.ɵɵelementStart(0, "aui-select", 41)(1, "aui-option", 42);
179
+ i0.ɵɵtext(2, "Mi");
180
+ i0.ɵɵelementEnd();
181
+ i0.ɵɵelementStart(3, "aui-option", 43);
182
+ i0.ɵɵtext(4, "Gi");
183
+ i0.ɵɵelementEnd()();
184
+ } }
185
+ function ResourceSpecFormComponent_ng_template_33_Template(rf, ctx) { if (rf & 1) {
186
+ i0.ɵɵelementStart(0, "span", 40);
187
+ i0.ɵɵtext(1);
188
+ i0.ɵɵelementEnd();
189
+ } if (rf & 2) {
190
+ const ctx_r3 = i0.ɵɵnextContext();
191
+ i0.ɵɵadvance();
192
+ i0.ɵɵtextInterpolate1(" ", ctx_r3.form.get("limits.memory.unit").value, " ");
193
+ } }
194
+ const DEFINED_RESOURCE_SPECIFICATION = [
195
+ {
196
+ size: ResourceSize.SMALL,
197
+ limits: {
198
+ cpu: {
199
+ value: 200,
200
+ unit: 'm',
201
+ },
202
+ memory: {
203
+ value: 256,
204
+ unit: 'Mi',
205
+ },
206
+ },
207
+ },
208
+ {
209
+ size: ResourceSize.MEDIUM,
210
+ limits: {
211
+ cpu: {
212
+ value: 2,
213
+ unit: 'core',
214
+ },
215
+ memory: {
216
+ value: 1,
217
+ unit: 'Gi',
218
+ },
219
+ },
220
+ },
221
+ {
222
+ size: ResourceSize.LARGE,
223
+ limits: {
224
+ cpu: {
225
+ value: 4,
226
+ unit: 'core',
227
+ },
228
+ memory: {
229
+ value: 2,
230
+ unit: 'Gi',
231
+ },
232
+ },
233
+ },
234
+ ];
235
+ export class ResourceSpecFormComponent extends BaseResourceFormGroupComponent {
236
+ set errorMapper(errorMapper) {
237
+ this._errorMapper = {
238
+ ...this._errorMapper,
239
+ ...errorMapper,
240
+ };
241
+ }
242
+ get errorMapper() {
243
+ return this._errorMapper;
244
+ }
245
+ get resourceSpecificationMapper() {
246
+ return getResourceSpecificationMapper(this.resourceSpecification);
247
+ }
248
+ constructor(injector, translate) {
249
+ super(injector);
250
+ this.translate = translate;
251
+ this.resourceSpecification = DEFINED_RESOURCE_SPECIFICATION;
252
+ this.showResourceRequests = false;
253
+ this._errorMapper = {
254
+ pattern: this.translate.get(POSITIVE_INT_PATTERN.tip),
255
+ memory_max: this.translate.get('request_greater_than_limits_error'),
256
+ cpu_max: this.translate.get('request_greater_than_limits_error'),
257
+ };
258
+ this.ResourceSize = ResourceSize;
259
+ this.POSITIVE_INT_PATTERN = POSITIVE_INT_PATTERN;
260
+ this.isTemplateRef = isTemplateRef;
261
+ }
262
+ ngOnInit() {
263
+ super.ngOnInit();
264
+ if (this.showResourceRequests) {
265
+ const greaterValidatorSubscriptions = [
266
+ initGreaterValidator('cpu', this.form),
267
+ initGreaterValidator('memory', this.form),
268
+ ];
269
+ this.destroy$.subscribe(() => {
270
+ greaterValidatorSubscriptions.forEach(sub => sub.unsubscribe());
271
+ });
272
+ }
273
+ this.form.statusChanges
274
+ .pipe(debounceTime(0), distinctUntilChanged(isEqual), takeUntil(this.destroy$))
275
+ .subscribe(() => {
276
+ [
277
+ 'limits.cpu.value',
278
+ 'limits.memory.value',
279
+ ...(this.showResourceRequests
280
+ ? ['requests.cpu.value', 'requests.memory.value']
281
+ : []),
282
+ ].forEach(key => {
283
+ this.form.get(key).markAsDirty();
284
+ });
285
+ });
286
+ }
287
+ createForm() {
288
+ const { limits, requests } = this.resourceSpecificationMapper[ResourceSize.SMALL];
289
+ const resourceLimitForm = this.fb.group({
290
+ cpu: this.fb.group({
291
+ value: this.fb.control(limits?.cpu?.value, [Validators.required]),
292
+ unit: this.fb.control(limits?.cpu?.unit),
293
+ }, {
294
+ validators: this.validatorFn?.limits?.cpu || [],
295
+ }),
296
+ memory: this.fb.group({
297
+ value: this.fb.control(limits?.memory?.value, [Validators.required]),
298
+ unit: this.fb.control(limits?.memory?.unit),
299
+ }, {
300
+ validators: this.validatorFn?.limits?.memory || [],
301
+ }),
302
+ });
303
+ const resourceRequestForm = this.fb.group({
304
+ cpu: this.fb.group({
305
+ value: this.fb.control(requests?.cpu?.value, [Validators.required]),
306
+ unit: this.fb.control(requests?.cpu?.unit),
307
+ }, {
308
+ validators: this.validatorFn?.requests?.cpu || [],
309
+ }),
310
+ memory: this.fb.group({
311
+ value: this.fb.control(requests?.memory?.value, [
312
+ Validators.required,
313
+ ]),
314
+ unit: this.fb.control(requests?.memory?.unit),
315
+ }, {
316
+ validators: this.validatorFn?.requests?.memory || [],
317
+ }),
318
+ });
319
+ return this.fb.group({
320
+ size: this.fb.control(ResourceSize.SMALL),
321
+ limits: resourceLimitForm,
322
+ ...(this.showResourceRequests ? { requests: resourceRequestForm } : null),
323
+ });
324
+ }
325
+ getDefaultFormModel() {
326
+ return {
327
+ size: ResourceSize.SMALL,
328
+ limits: this.resourceSpecificationMapper[ResourceSize.SMALL]?.limits,
329
+ ...(this.showResourceRequests
330
+ ? {
331
+ requests: this.resourceSpecificationMapper[ResourceSize.SMALL]?.requests,
332
+ }
333
+ : null),
334
+ };
335
+ }
336
+ adaptFormModel(formModel) {
337
+ const { limits, requests } = formModel;
338
+ return {
339
+ limits: {
340
+ cpu: formatResource(limits.cpu),
341
+ memory: formatResource(limits.memory),
342
+ },
343
+ ...(this.showResourceRequests && {
344
+ requests: {
345
+ cpu: formatResource(requests.cpu),
346
+ memory: formatResource(requests.memory),
347
+ },
348
+ }),
349
+ };
350
+ }
351
+ adaptResourceModel(resource) {
352
+ if (!resource) {
353
+ return;
354
+ }
355
+ return getResourceSpecification(resource, this.resourceSpecification);
356
+ }
357
+ onResourceSizeChange(size) {
358
+ const limits = this.resourceSpecificationMapper[size]?.limits;
359
+ const resourceLimitForm = this.form.get('limits');
360
+ const requests = this.resourceSpecificationMapper[size]?.requests;
361
+ const resourceRequestForm = this.form.get('requests');
362
+ if (!limits) {
363
+ return;
364
+ }
365
+ resourceLimitForm.patchValue(limits);
366
+ resourceRequestForm?.patchValue(requests);
367
+ }
368
+ static { this.ɵfac = function ResourceSpecFormComponent_Factory(t) { return new (t || ResourceSpecFormComponent)(i0.ɵɵdirectiveInject(i0.Injector), i0.ɵɵdirectiveInject(i1.TranslateService)); }; }
369
+ static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: ResourceSpecFormComponent, selectors: [["acl-resource-spec-form"]], inputs: { resourceSizeTips: "resourceSizeTips", resourceSpecificationDescription: "resourceSpecificationDescription", resourceSpecification: "resourceSpecification", showResourceRequests: "showResourceRequests", validatorFn: "validatorFn", errorMapper: "errorMapper" }, standalone: true, features: [i0.ɵɵInheritDefinitionFeature, i0.ɵɵStandaloneFeature], decls: 37, vars: 25, consts: [["descriptionTemplate", ""], ["cUnit", ""], ["cpuError", ""], ["mUnit", ""], ["memoryError", ""], ["text", ""], ["rcUnit", ""], ["cpuRequestError", ""], ["rmUnit", ""], ["memoryRequiredError", ""], [3, "formGroup"], [1, "spec-model"], ["auiFormItemLabel", ""], ["auiFormItemControl", "", "formControlName", "size", "required", "", 3, "ngModelChange"], [3, "value", 4, "ngFor", "ngForOf"], ["auiFormItemAddon", "", "icon", "question_circle", "auiTooltipPosition", "end bottom", "class", "icon--help", 3, "auiTooltip", 4, "ngIf"], ["width", "large", 4, "ngIf"], ["width", "large"], ["formGroupName", "limits", 1, "tw-flex", "tw-flex-1", "aui-form-item__control"], [1, "tw-flex-1"], ["auiFormItemControl", "", "formGroupName", "cpu"], ["auiInputAddonBefore", "", 1, "tw-required-mark"], ["aui-input", "", "formControlName", "value", "aclCoerceNumber", "", "required", "", "auiFormItemControl", "", 3, "pattern", "aclErrorsMapper", "aclErrorsMapperOutlet", "readonly"], ["class", "custom-spec-form__cpu-unit", "auiInputAddonAfter", "", "formControlName", "unit", 4, "ngIf", "ngIfElse"], ["auiFormItemError", ""], ["width", "large", 1, "tw-flex-1", "tw-ml-8"], ["auiFormItemControl", "", "formGroupName", "memory"], ["auiInputAddonAfter", "", "formControlName", "unit", 4, "ngIf", "ngIfElse"], [3, "value"], [1, "spec-model__label"], [1, "text-help"], ["auiFormItemAddon", "", "icon", "question_circle", "auiTooltipPosition", "end bottom", 1, "icon--help", 3, "auiTooltip"], [3, "ngTemplateOutlet", 4, "ngIf", "ngIfElse"], [3, "ngTemplateOutlet"], ["formGroupName", "requests", 1, "tw-flex", "tw-flex-1", "aui-form-item__control"], ["aui-input", "", "formControlName", "value", "aclCoerceNumber", "", "required", "", 3, "readonly", "pattern", "aclErrorsMapper", "aclErrorsMapperOutlet"], ["auiInputAddonAfter", "", "formControlName", "unit", 1, "custom-spec-form__cpu-unit"], ["value", "m"], ["value", "core", 3, "label"], ["auiInputAddonAfter", "", 4, "ngIf"], ["auiInputAddonAfter", ""], ["auiInputAddonAfter", "", "formControlName", "unit"], ["value", "Mi"], ["value", "Gi"]], template: function ResourceSpecFormComponent_Template(rf, ctx) { if (rf & 1) {
370
+ const _r1 = i0.ɵɵgetCurrentView();
371
+ i0.ɵɵelementContainerStart(0, 10);
372
+ i0.ɵɵelementStart(1, "aui-form-item", 11)(2, "label", 12);
373
+ i0.ɵɵtext(3);
374
+ i0.ɵɵpipe(4, "translate");
375
+ i0.ɵɵelementEnd();
376
+ i0.ɵɵelementStart(5, "aui-radio-group", 13);
377
+ i0.ɵɵlistener("ngModelChange", function ResourceSpecFormComponent_Template_aui_radio_group_ngModelChange_5_listener($event) { i0.ɵɵrestoreView(_r1); return i0.ɵɵresetView(ctx.onResourceSizeChange($event)); });
378
+ i0.ɵɵtemplate(6, ResourceSpecFormComponent_aui_radio_button_6_Template, 8, 7, "aui-radio-button", 14);
379
+ i0.ɵɵelementEnd();
380
+ i0.ɵɵtemplate(7, ResourceSpecFormComponent_aui_icon_7_Template, 1, 1, "aui-icon", 15)(8, ResourceSpecFormComponent_ng_template_8_Template, 3, 2, "ng-template", null, 0, i0.ɵɵtemplateRefExtractor);
381
+ i0.ɵɵelementEnd();
382
+ i0.ɵɵtemplate(10, ResourceSpecFormComponent_aui_form_item_10_Template, 26, 18, "aui-form-item", 16);
383
+ i0.ɵɵelementStart(11, "aui-form-item", 17)(12, "label", 12);
384
+ i0.ɵɵtext(13);
385
+ i0.ɵɵpipe(14, "translate");
386
+ i0.ɵɵelementEnd();
387
+ i0.ɵɵelementStart(15, "div", 18)(16, "aui-form-item", 19)(17, "aui-input-group", 20)(18, "span", 21);
388
+ i0.ɵɵtext(19, "CPU");
389
+ i0.ɵɵelementEnd();
390
+ i0.ɵɵelement(20, "input", 22);
391
+ i0.ɵɵtemplate(21, ResourceSpecFormComponent_aui_select_21_Template, 7, 6, "aui-select", 23)(22, ResourceSpecFormComponent_ng_template_22_Template, 1, 1, "ng-template", null, 1, i0.ɵɵtemplateRefExtractor);
392
+ i0.ɵɵelementEnd();
393
+ i0.ɵɵelement(24, "div", 24, 2);
394
+ i0.ɵɵelementEnd();
395
+ i0.ɵɵelementStart(26, "aui-form-item", 25)(27, "aui-input-group", 26)(28, "span", 21);
396
+ i0.ɵɵtext(29);
397
+ i0.ɵɵpipe(30, "translate");
398
+ i0.ɵɵelementEnd();
399
+ i0.ɵɵelement(31, "input", 22);
400
+ i0.ɵɵtemplate(32, ResourceSpecFormComponent_aui_select_32_Template, 5, 0, "aui-select", 27)(33, ResourceSpecFormComponent_ng_template_33_Template, 2, 1, "ng-template", null, 3, i0.ɵɵtemplateRefExtractor);
401
+ i0.ɵɵelementEnd();
402
+ i0.ɵɵelement(35, "div", 24, 4);
403
+ i0.ɵɵelementEnd()()();
404
+ i0.ɵɵelementContainerEnd();
405
+ } if (rf & 2) {
406
+ const cUnit_r12 = i0.ɵɵreference(23);
407
+ const cpuError_r13 = i0.ɵɵreference(25);
408
+ const mUnit_r14 = i0.ɵɵreference(34);
409
+ const memoryError_r15 = i0.ɵɵreference(36);
410
+ i0.ɵɵproperty("formGroup", ctx.form);
411
+ i0.ɵɵadvance(3);
412
+ i0.ɵɵtextInterpolate(i0.ɵɵpipeBind1(4, 19, "storage.specification"));
413
+ i0.ɵɵadvance(3);
414
+ i0.ɵɵproperty("ngForOf", ctx.resourceSizeTips);
415
+ i0.ɵɵadvance();
416
+ i0.ɵɵproperty("ngIf", ctx.resourceSpecificationDescription);
417
+ i0.ɵɵadvance(3);
418
+ i0.ɵɵproperty("ngIf", ctx.showResourceRequests);
419
+ i0.ɵɵadvance(3);
420
+ i0.ɵɵtextInterpolate(i0.ɵɵpipeBind1(14, 21, "storage.resource_limit"));
421
+ i0.ɵɵadvance(7);
422
+ i0.ɵɵproperty("pattern", ctx.POSITIVE_INT_PATTERN.pattern)("aclErrorsMapper", ctx.errorMapper)("aclErrorsMapperOutlet", cpuError_r13)("readonly", ctx.form.get("size").value !== ctx.ResourceSize.CUSTOMIZE);
423
+ i0.ɵɵadvance();
424
+ i0.ɵɵproperty("ngIf", ctx.form.get("size").value === ctx.ResourceSize.CUSTOMIZE)("ngIfElse", cUnit_r12);
425
+ i0.ɵɵadvance(8);
426
+ i0.ɵɵtextInterpolate(i0.ɵɵpipeBind1(30, 23, "memory"));
427
+ i0.ɵɵadvance(2);
428
+ i0.ɵɵproperty("pattern", ctx.POSITIVE_INT_PATTERN.pattern)("aclErrorsMapper", ctx.errorMapper)("aclErrorsMapperOutlet", memoryError_r15)("readonly", ctx.form.get("size").value !== ctx.ResourceSize.CUSTOMIZE);
429
+ i0.ɵɵadvance();
430
+ i0.ɵɵproperty("ngIf", ctx.form.get("size").value === ctx.ResourceSize.CUSTOMIZE)("ngIfElse", mUnit_r14);
431
+ } }, dependencies: [CommonModule, i2.NgForOf, i2.NgIf, i2.NgTemplateOutlet, ReactiveFormsModule, i3.DefaultValueAccessor, i3.NgControlStatus, i3.NgControlStatusGroup, i3.RequiredValidator, i3.PatternValidator, i3.FormGroupDirective, i3.FormControlName, i3.FormGroupName, FormModule, i4.FormItemComponent, i4.FormItemAddonDirective, i4.FormItemErrorDirective, i4.FormItemLabelDirective, i4.FormItemControlDirective, IconModule, i4.IconComponent, InputModule, i4.InputComponent, i4.InputGroupComponent, i4.InputAddonBeforeDirective, i4.InputAddonAfterDirective, RadioModule, i4.RadioGroupComponent, i4.RadioButtonComponent, SelectModule, i4.SelectComponent, i4.OptionComponent, TooltipModule, i4.TooltipDirective, i1.TranslatePipe, i1.ErrorsMapperDirective, CoreModule, i1.E2eAttributeBindingDirective, i1.ValidatorsDirective, CoerceNumberDirective], styles: ["aui-form-item[_ngcontent-%COMP%] aui-form-item[_ngcontent-%COMP%] .aui-form-item{margin-bottom:0}.spec-model[_ngcontent-%COMP%] .aui-form-item__label-wrapper{height:64px}.spec-model[_ngcontent-%COMP%] .aui-form-item__label-wrapper.hasLabel:after{align-self:center}.spec-model[_ngcontent-%COMP%] .aui-form-item__addon-wrapper{align-self:center}.spec-model[_ngcontent-%COMP%] .aui-radio-button__label{height:64px;min-width:132px;padding:0}.spec-model[_ngcontent-%COMP%] .aui-radio-button__label>span{flex:1;height:100%}.spec-model[_ngcontent-%COMP%] .aui-radio-button__label .text-help{margin-top:2px;font-size:12px}.spec-model__label[_ngcontent-%COMP%]{display:flex;text-align:center;justify-content:center;align-items:center;height:100%;padding:0 15px}[_nghost-%COMP%] .aui-form-item__label-wrapper:empty{display:none}[_nghost-%COMP%] .aui-input-group__input-wrapper:focus-within+.aui-input-group__addon .aui-select__input, [_nghost-%COMP%] .aui-input-group__input-wrapper:hover+.aui-input-group__addon .aui-select__input{border-left-color:rgb(var(--aui-color-primary))}[_nghost-%COMP%] aui-input-group.ng-invalid .aui-input-group__input-wrapper+.aui-input-group__addon .aui-select__input{border-left-color:rgb(var(--aui-color-red))}[_nghost-%COMP%] .aui-input-group__addon--after aui-select{margin-left:-8px;margin-right:-8px;width:56px} html:not([lang|=zh]) .custom-spec-form__cpu-unit{width:78px}"], changeDetection: 0 }); }
432
+ }
433
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ResourceSpecFormComponent, [{
434
+ type: Component,
435
+ args: [{ standalone: true, selector: 'acl-resource-spec-form', changeDetection: ChangeDetectionStrategy.OnPush, imports: [
436
+ CommonModule,
437
+ ReactiveFormsModule,
438
+ FormModule,
439
+ IconModule,
440
+ InputModule,
441
+ RadioModule,
442
+ SelectModule,
443
+ TooltipModule,
444
+ TRANSLATE_MODULE,
445
+ ERRORS_MAPPER_MODULE,
446
+ CoreModule,
447
+ CoerceNumberDirective,
448
+ ], template: "<ng-container [formGroup]=\"form\">\n <aui-form-item class=\"spec-model\">\n <label auiFormItemLabel>{{ 'storage.specification' | translate }}</label>\n <aui-radio-group\n auiFormItemControl\n formControlName=\"size\"\n (ngModelChange)=\"onResourceSizeChange($event)\"\n required\n >\n <aui-radio-button\n *ngFor=\"let item of resourceSizeTips\"\n [value]=\"item.size\"\n >\n <div class=\"spec-model__label\">\n <div>\n {{ 'storage.' + item.size + '_scale' | translate }}\n <div class=\"text-help\">\n {{ item.tip | translate }}\n </div>\n </div>\n </div>\n </aui-radio-button>\n </aui-radio-group>\n <aui-icon\n *ngIf=\"resourceSpecificationDescription\"\n auiFormItemAddon\n [auiTooltip]=\"descriptionTemplate\"\n icon=\"question_circle\"\n auiTooltipPosition=\"end bottom\"\n class=\"icon--help\"\n ></aui-icon>\n <ng-template #descriptionTemplate>\n <ng-container\n *ngIf=\"isTemplateRef(resourceSpecificationDescription); else text\"\n [ngTemplateOutlet]=\"resourceSpecificationDescription\"\n ></ng-container>\n <ng-template #text>\n {{ resourceSpecificationDescription }}\n </ng-template>\n </ng-template>\n </aui-form-item>\n\n <aui-form-item\n width=\"large\"\n *ngIf=\"showResourceRequests\"\n >\n <label auiFormItemLabel>{{ 'storage.resource_request' | translate }}</label>\n <div\n formGroupName=\"requests\"\n class=\"tw-flex tw-flex-1 aui-form-item__control\"\n >\n <aui-form-item class=\"tw-flex-1\">\n <aui-input-group\n auiFormItemControl\n formGroupName=\"cpu\"\n >\n <span\n auiInputAddonBefore\n class=\"tw-required-mark\"\n >CPU</span\n >\n <input\n aui-input\n formControlName=\"value\"\n aclCoerceNumber\n [pattern]=\"POSITIVE_INT_PATTERN.pattern\"\n [aclErrorsMapper]=\"errorMapper\"\n [aclErrorsMapperOutlet]=\"cpuRequestError\"\n required\n [readonly]=\"form.get('size').value !== ResourceSize.CUSTOMIZE\"\n auiFormItemControl\n />\n <aui-select\n *ngIf=\"\n form.get('size').value === ResourceSize.CUSTOMIZE;\n else rcUnit\n \"\n class=\"custom-spec-form__cpu-unit\"\n auiInputAddonAfter\n formControlName=\"unit\"\n >\n <aui-option value=\"m\">m</aui-option>\n <aui-option\n value=\"core\"\n [label]=\"'core' | translate\"\n >\n {{ 'core' | translate }}\n </aui-option>\n </aui-select>\n <ng-template #rcUnit>\n <span\n *ngIf=\"form.get('requests.cpu.unit').value as cpuUnit\"\n auiInputAddonAfter\n >\n {{ cpuUnit === 'core' ? ('core' | translate) : cpuUnit }}\n </span>\n </ng-template>\n </aui-input-group>\n <div\n auiFormItemError\n #cpuRequestError\n ></div>\n </aui-form-item>\n\n <aui-form-item\n class=\"tw-flex-1 tw-ml-8\"\n width=\"large\"\n >\n <aui-input-group\n auiFormItemControl\n formGroupName=\"memory\"\n >\n <span\n auiInputAddonBefore\n class=\"tw-required-mark\"\n >{{ 'memory' | translate }}</span\n >\n <input\n aui-input\n formControlName=\"value\"\n aclCoerceNumber\n [readonly]=\"form.get('size').value !== ResourceSize.CUSTOMIZE\"\n [pattern]=\"POSITIVE_INT_PATTERN.pattern\"\n [aclErrorsMapper]=\"errorMapper\"\n [aclErrorsMapperOutlet]=\"memoryRequiredError\"\n required\n />\n <aui-select\n *ngIf=\"\n form.get('size').value === ResourceSize.CUSTOMIZE;\n else rmUnit\n \"\n auiInputAddonAfter\n formControlName=\"unit\"\n >\n <aui-option value=\"Mi\">Mi</aui-option>\n <aui-option value=\"Gi\">Gi</aui-option>\n </aui-select>\n <ng-template #rmUnit>\n <span auiInputAddonAfter>\n {{ form.get('requests.memory.unit').value }}\n </span>\n </ng-template>\n </aui-input-group>\n <div\n auiFormItemError\n #memoryRequiredError\n ></div>\n </aui-form-item>\n </div>\n </aui-form-item>\n\n <aui-form-item width=\"large\">\n <label auiFormItemLabel>{{ 'storage.resource_limit' | translate }}</label>\n <div\n formGroupName=\"limits\"\n class=\"tw-flex tw-flex-1 aui-form-item__control\"\n >\n <aui-form-item class=\"tw-flex-1\">\n <aui-input-group\n auiFormItemControl\n formGroupName=\"cpu\"\n >\n <span\n auiInputAddonBefore\n class=\"tw-required-mark\"\n >CPU</span\n >\n <input\n aui-input\n formControlName=\"value\"\n aclCoerceNumber\n [pattern]=\"POSITIVE_INT_PATTERN.pattern\"\n [aclErrorsMapper]=\"errorMapper\"\n [aclErrorsMapperOutlet]=\"cpuError\"\n [readonly]=\"form.get('size').value !== ResourceSize.CUSTOMIZE\"\n required\n auiFormItemControl\n />\n <aui-select\n *ngIf=\"\n form.get('size').value === ResourceSize.CUSTOMIZE;\n else cUnit\n \"\n class=\"custom-spec-form__cpu-unit\"\n auiInputAddonAfter\n formControlName=\"unit\"\n >\n <aui-option value=\"m\">m</aui-option>\n <aui-option\n value=\"core\"\n [label]=\"'core' | translate\"\n >\n {{ 'core' | translate }}\n </aui-option>\n </aui-select>\n <ng-template #cUnit>\n <span\n *ngIf=\"form.get('limits.cpu.unit').value as cpuUnit\"\n auiInputAddonAfter\n >\n {{ cpuUnit === 'core' ? ('core' | translate) : cpuUnit }}\n </span>\n </ng-template>\n </aui-input-group>\n <div\n auiFormItemError\n #cpuError\n ></div>\n </aui-form-item>\n\n <aui-form-item\n class=\"tw-flex-1 tw-ml-8\"\n width=\"large\"\n >\n <aui-input-group\n auiFormItemControl\n formGroupName=\"memory\"\n >\n <span\n auiInputAddonBefore\n class=\"tw-required-mark\"\n >{{ 'memory' | translate }}</span\n >\n <input\n aui-input\n formControlName=\"value\"\n aclCoerceNumber\n [pattern]=\"POSITIVE_INT_PATTERN.pattern\"\n [aclErrorsMapper]=\"errorMapper\"\n [aclErrorsMapperOutlet]=\"memoryError\"\n [readonly]=\"form.get('size').value !== ResourceSize.CUSTOMIZE\"\n required\n auiFormItemControl\n />\n\n <aui-select\n *ngIf=\"\n form.get('size').value === ResourceSize.CUSTOMIZE;\n else mUnit\n \"\n auiInputAddonAfter\n formControlName=\"unit\"\n >\n <aui-option value=\"Mi\">Mi</aui-option>\n <aui-option value=\"Gi\">Gi</aui-option>\n </aui-select>\n <ng-template #mUnit>\n <span auiInputAddonAfter>\n {{ form.get('limits.memory.unit').value }}\n </span>\n </ng-template>\n </aui-input-group>\n <div\n auiFormItemError\n #memoryError\n ></div>\n </aui-form-item>\n </div>\n </aui-form-item>\n</ng-container>\n", styles: ["aui-form-item aui-form-item ::ng-deep .aui-form-item{margin-bottom:0}.spec-model ::ng-deep .aui-form-item__label-wrapper{height:64px}.spec-model ::ng-deep .aui-form-item__label-wrapper.hasLabel:after{align-self:center}.spec-model ::ng-deep .aui-form-item__addon-wrapper{align-self:center}.spec-model ::ng-deep .aui-radio-button__label{height:64px;min-width:132px;padding:0}.spec-model ::ng-deep .aui-radio-button__label>span{flex:1;height:100%}.spec-model ::ng-deep .aui-radio-button__label .text-help{margin-top:2px;font-size:12px}.spec-model__label{display:flex;text-align:center;justify-content:center;align-items:center;height:100%;padding:0 15px}:host ::ng-deep .aui-form-item__label-wrapper:empty{display:none}:host ::ng-deep .aui-input-group__input-wrapper:focus-within+.aui-input-group__addon .aui-select__input,:host ::ng-deep .aui-input-group__input-wrapper:hover+.aui-input-group__addon .aui-select__input{border-left-color:rgb(var(--aui-color-primary))}:host ::ng-deep aui-input-group.ng-invalid .aui-input-group__input-wrapper+.aui-input-group__addon .aui-select__input{border-left-color:rgb(var(--aui-color-red))}:host ::ng-deep .aui-input-group__addon--after aui-select{margin-left:-8px;margin-right:-8px;width:56px}::ng-deep html:not([lang|=zh]) .custom-spec-form__cpu-unit{width:78px}\n"] }]
449
+ }], () => [{ type: i0.Injector }, { type: i1.TranslateService }], { resourceSizeTips: [{
450
+ type: Input,
451
+ args: [{ required: true }]
452
+ }], resourceSpecificationDescription: [{
453
+ type: Input
454
+ }], resourceSpecification: [{
455
+ type: Input
456
+ }], showResourceRequests: [{
457
+ type: Input
458
+ }], validatorFn: [{
459
+ type: Input
460
+ }], errorMapper: [{
461
+ type: Input
462
+ }] }); })();
463
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(ResourceSpecFormComponent, { className: "ResourceSpecFormComponent", filePath: "lib/components/spec-form/component.ts", lineNumber: 120 }); })();
464
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"component.js","sourceRoot":"","sources":["../../../../../../../modules/storage/src/lib/components/spec-form/component.ts","../../../../../../../modules/storage/src/lib/components/spec-form/template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  FormModule,\n  IconModule,\n  InputModule,\n  RadioModule,\n  SelectModule,\n  TooltipModule,\n  isTemplateRef,\n} from '@alauda/ui';\nimport {\n  TRANSLATE_MODULE,\n  ERRORS_MAPPER_MODULE,\n  CoreModule,\n  CoerceNumberDirective,\n  POSITIVE_INT_PATTERN,\n  initGreaterValidator,\n  isEqual,\n  StringMap,\n  TranslateService,\n} from '@alauda-fe/common';\nimport { CommonModule } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  Injector,\n  Input,\n  OnInit,\n  TemplateRef,\n} from '@angular/core';\nimport { ReactiveFormsModule, ValidatorFn, Validators } from '@angular/forms';\nimport { BaseResourceFormGroupComponent } from 'ng-resource-form-util';\nimport { debounceTime, distinctUntilChanged, takeUntil } from 'rxjs';\n\nimport {\n  ResourceSize,\n  ResourceSizeTip,\n  ResourceSpecification,\n} from '../../types/resource-exports';\nimport { ResourceRequirements } from '../../types/resource-internals';\nimport {\n  formatResource,\n  getResourceSpecificationMapper,\n  getResourceSpecification,\n} from '../../utils/resource-exports';\n\nconst DEFINED_RESOURCE_SPECIFICATION: ResourceSpecification[] = [\n  {\n    size: ResourceSize.SMALL,\n    limits: {\n      cpu: {\n        value: 200,\n        unit: 'm',\n      },\n      memory: {\n        value: 256,\n        unit: 'Mi',\n      },\n    },\n  },\n  {\n    size: ResourceSize.MEDIUM,\n    limits: {\n      cpu: {\n        value: 2,\n        unit: 'core',\n      },\n      memory: {\n        value: 1,\n        unit: 'Gi',\n      },\n    },\n  },\n  {\n    size: ResourceSize.LARGE,\n    limits: {\n      cpu: {\n        value: 4,\n        unit: 'core',\n      },\n      memory: {\n        value: 2,\n        unit: 'Gi',\n      },\n    },\n  },\n];\n\ninterface ResourceValidatorFn {\n  limits?: {\n    cpu: ValidatorFn[];\n    memory: ValidatorFn[];\n  };\n  requests?: {\n    cpu: ValidatorFn[];\n    memory: ValidatorFn[];\n  };\n}\n\n@Component({\n  standalone: true,\n  selector: 'acl-resource-spec-form',\n  templateUrl: 'template.html',\n  styleUrls: ['./style.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [\n    CommonModule,\n    ReactiveFormsModule,\n    FormModule,\n    IconModule,\n    InputModule,\n    RadioModule,\n    SelectModule,\n    TooltipModule,\n    TRANSLATE_MODULE,\n    ERRORS_MAPPER_MODULE,\n    CoreModule,\n    CoerceNumberDirective,\n  ],\n})\nexport class ResourceSpecFormComponent\n  extends BaseResourceFormGroupComponent<\n    ResourceRequirements,\n    ResourceSpecification\n  >\n  implements OnInit\n{\n  // 规格说明\n  @Input({ required: true })\n  resourceSizeTips: ResourceSizeTip[];\n\n  // 规格描述\n  @Input()\n  resourceSpecificationDescription: string | TemplateRef<any>;\n\n  @Input()\n  resourceSpecification = DEFINED_RESOURCE_SPECIFICATION;\n\n  @Input()\n  showResourceRequests = false;\n\n  @Input()\n  validatorFn: ResourceValidatorFn;\n\n  @Input()\n  set errorMapper(errorMapper: StringMap) {\n    this._errorMapper = {\n      ...this._errorMapper,\n      ...errorMapper,\n    };\n  }\n\n  get errorMapper() {\n    return this._errorMapper;\n  }\n\n  get resourceSpecificationMapper() {\n    return getResourceSpecificationMapper(this.resourceSpecification);\n  }\n\n  private _errorMapper: StringMap = {\n    pattern: this.translate.get(POSITIVE_INT_PATTERN.tip),\n    memory_max: this.translate.get('request_greater_than_limits_error'),\n    cpu_max: this.translate.get('request_greater_than_limits_error'),\n  };\n\n  ResourceSize = ResourceSize;\n  POSITIVE_INT_PATTERN = POSITIVE_INT_PATTERN;\n  isTemplateRef = isTemplateRef;\n\n  constructor(\n    injector: Injector,\n    private readonly translate: TranslateService,\n  ) {\n    super(injector);\n  }\n\n  override ngOnInit() {\n    super.ngOnInit();\n\n    if (this.showResourceRequests) {\n      const greaterValidatorSubscriptions = [\n        initGreaterValidator('cpu', this.form),\n        initGreaterValidator('memory', this.form),\n      ];\n      this.destroy$.subscribe(() => {\n        greaterValidatorSubscriptions.forEach(sub => sub.unsubscribe());\n      });\n    }\n\n    this.form.statusChanges\n      .pipe(\n        debounceTime(0),\n        distinctUntilChanged(isEqual),\n        takeUntil(this.destroy$),\n      )\n      .subscribe(() => {\n        [\n          'limits.cpu.value',\n          'limits.memory.value',\n          ...(this.showResourceRequests\n            ? ['requests.cpu.value', 'requests.memory.value']\n            : []),\n        ].forEach(key => {\n          this.form.get(key).markAsDirty();\n        });\n      });\n  }\n\n  override createForm() {\n    const { limits, requests } =\n      this.resourceSpecificationMapper[ResourceSize.SMALL];\n\n    const resourceLimitForm = this.fb.group({\n      cpu: this.fb.group(\n        {\n          value: this.fb.control(limits?.cpu?.value, [Validators.required]),\n          unit: this.fb.control(limits?.cpu?.unit),\n        },\n        {\n          validators: this.validatorFn?.limits?.cpu || [],\n        },\n      ),\n      memory: this.fb.group(\n        {\n          value: this.fb.control(limits?.memory?.value, [Validators.required]),\n          unit: this.fb.control(limits?.memory?.unit),\n        },\n        {\n          validators: this.validatorFn?.limits?.memory || [],\n        },\n      ),\n    });\n\n    const resourceRequestForm = this.fb.group({\n      cpu: this.fb.group(\n        {\n          value: this.fb.control(requests?.cpu?.value, [Validators.required]),\n          unit: this.fb.control(requests?.cpu?.unit),\n        },\n        {\n          validators: this.validatorFn?.requests?.cpu || [],\n        },\n      ),\n      memory: this.fb.group(\n        {\n          value: this.fb.control(requests?.memory?.value, [\n            Validators.required,\n          ]),\n          unit: this.fb.control(requests?.memory?.unit),\n        },\n        {\n          validators: this.validatorFn?.requests?.memory || [],\n        },\n      ),\n    });\n\n    return this.fb.group({\n      size: this.fb.control(ResourceSize.SMALL),\n      limits: resourceLimitForm,\n      ...(this.showResourceRequests ? { requests: resourceRequestForm } : null),\n    });\n  }\n\n  override getDefaultFormModel() {\n    return {\n      size: ResourceSize.SMALL,\n      limits: this.resourceSpecificationMapper[ResourceSize.SMALL]?.limits,\n      ...(this.showResourceRequests\n        ? {\n            requests:\n              this.resourceSpecificationMapper[ResourceSize.SMALL]?.requests,\n          }\n        : null),\n    };\n  }\n\n  override adaptFormModel(\n    formModel: ResourceSpecification,\n  ): ResourceRequirements {\n    const { limits, requests } = formModel;\n\n    return {\n      limits: {\n        cpu: formatResource(limits.cpu),\n        memory: formatResource(limits.memory),\n      },\n      ...(this.showResourceRequests && {\n        requests: {\n          cpu: formatResource(requests.cpu),\n          memory: formatResource(requests.memory),\n        },\n      }),\n    };\n  }\n\n  override adaptResourceModel(\n    resource: ResourceRequirements,\n  ): ResourceSpecification {\n    if (!resource) {\n      return;\n    }\n\n    return getResourceSpecification(resource, this.resourceSpecification);\n  }\n\n  onResourceSizeChange(size: ResourceSize) {\n    const limits = this.resourceSpecificationMapper[size]?.limits;\n    const resourceLimitForm = this.form.get('limits');\n\n    const requests = this.resourceSpecificationMapper[size]?.requests;\n    const resourceRequestForm = this.form.get('requests');\n\n    if (!limits) {\n      return;\n    }\n\n    resourceLimitForm.patchValue(limits);\n    resourceRequestForm?.patchValue(requests);\n  }\n}\n","<ng-container [formGroup]=\"form\">\n  <aui-form-item class=\"spec-model\">\n    <label auiFormItemLabel>{{ 'storage.specification' | translate }}</label>\n    <aui-radio-group\n      auiFormItemControl\n      formControlName=\"size\"\n      (ngModelChange)=\"onResourceSizeChange($event)\"\n      required\n    >\n      <aui-radio-button\n        *ngFor=\"let item of resourceSizeTips\"\n        [value]=\"item.size\"\n      >\n        <div class=\"spec-model__label\">\n          <div>\n            {{ 'storage.' + item.size + '_scale' | translate }}\n            <div class=\"text-help\">\n              {{ item.tip | translate }}\n            </div>\n          </div>\n        </div>\n      </aui-radio-button>\n    </aui-radio-group>\n    <aui-icon\n      *ngIf=\"resourceSpecificationDescription\"\n      auiFormItemAddon\n      [auiTooltip]=\"descriptionTemplate\"\n      icon=\"question_circle\"\n      auiTooltipPosition=\"end bottom\"\n      class=\"icon--help\"\n    ></aui-icon>\n    <ng-template #descriptionTemplate>\n      <ng-container\n        *ngIf=\"isTemplateRef(resourceSpecificationDescription); else text\"\n        [ngTemplateOutlet]=\"resourceSpecificationDescription\"\n      ></ng-container>\n      <ng-template #text>\n        {{ resourceSpecificationDescription }}\n      </ng-template>\n    </ng-template>\n  </aui-form-item>\n\n  <aui-form-item\n    width=\"large\"\n    *ngIf=\"showResourceRequests\"\n  >\n    <label auiFormItemLabel>{{ 'storage.resource_request' | translate }}</label>\n    <div\n      formGroupName=\"requests\"\n      class=\"tw-flex tw-flex-1 aui-form-item__control\"\n    >\n      <aui-form-item class=\"tw-flex-1\">\n        <aui-input-group\n          auiFormItemControl\n          formGroupName=\"cpu\"\n        >\n          <span\n            auiInputAddonBefore\n            class=\"tw-required-mark\"\n            >CPU</span\n          >\n          <input\n            aui-input\n            formControlName=\"value\"\n            aclCoerceNumber\n            [pattern]=\"POSITIVE_INT_PATTERN.pattern\"\n            [aclErrorsMapper]=\"errorMapper\"\n            [aclErrorsMapperOutlet]=\"cpuRequestError\"\n            required\n            [readonly]=\"form.get('size').value !== ResourceSize.CUSTOMIZE\"\n            auiFormItemControl\n          />\n          <aui-select\n            *ngIf=\"\n              form.get('size').value === ResourceSize.CUSTOMIZE;\n              else rcUnit\n            \"\n            class=\"custom-spec-form__cpu-unit\"\n            auiInputAddonAfter\n            formControlName=\"unit\"\n          >\n            <aui-option value=\"m\">m</aui-option>\n            <aui-option\n              value=\"core\"\n              [label]=\"'core' | translate\"\n            >\n              {{ 'core' | translate }}\n            </aui-option>\n          </aui-select>\n          <ng-template #rcUnit>\n            <span\n              *ngIf=\"form.get('requests.cpu.unit').value as cpuUnit\"\n              auiInputAddonAfter\n            >\n              {{ cpuUnit === 'core' ? ('core' | translate) : cpuUnit }}\n            </span>\n          </ng-template>\n        </aui-input-group>\n        <div\n          auiFormItemError\n          #cpuRequestError\n        ></div>\n      </aui-form-item>\n\n      <aui-form-item\n        class=\"tw-flex-1 tw-ml-8\"\n        width=\"large\"\n      >\n        <aui-input-group\n          auiFormItemControl\n          formGroupName=\"memory\"\n        >\n          <span\n            auiInputAddonBefore\n            class=\"tw-required-mark\"\n            >{{ 'memory' | translate }}</span\n          >\n          <input\n            aui-input\n            formControlName=\"value\"\n            aclCoerceNumber\n            [readonly]=\"form.get('size').value !== ResourceSize.CUSTOMIZE\"\n            [pattern]=\"POSITIVE_INT_PATTERN.pattern\"\n            [aclErrorsMapper]=\"errorMapper\"\n            [aclErrorsMapperOutlet]=\"memoryRequiredError\"\n            required\n          />\n          <aui-select\n            *ngIf=\"\n              form.get('size').value === ResourceSize.CUSTOMIZE;\n              else rmUnit\n            \"\n            auiInputAddonAfter\n            formControlName=\"unit\"\n          >\n            <aui-option value=\"Mi\">Mi</aui-option>\n            <aui-option value=\"Gi\">Gi</aui-option>\n          </aui-select>\n          <ng-template #rmUnit>\n            <span auiInputAddonAfter>\n              {{ form.get('requests.memory.unit').value }}\n            </span>\n          </ng-template>\n        </aui-input-group>\n        <div\n          auiFormItemError\n          #memoryRequiredError\n        ></div>\n      </aui-form-item>\n    </div>\n  </aui-form-item>\n\n  <aui-form-item width=\"large\">\n    <label auiFormItemLabel>{{ 'storage.resource_limit' | translate }}</label>\n    <div\n      formGroupName=\"limits\"\n      class=\"tw-flex tw-flex-1 aui-form-item__control\"\n    >\n      <aui-form-item class=\"tw-flex-1\">\n        <aui-input-group\n          auiFormItemControl\n          formGroupName=\"cpu\"\n        >\n          <span\n            auiInputAddonBefore\n            class=\"tw-required-mark\"\n            >CPU</span\n          >\n          <input\n            aui-input\n            formControlName=\"value\"\n            aclCoerceNumber\n            [pattern]=\"POSITIVE_INT_PATTERN.pattern\"\n            [aclErrorsMapper]=\"errorMapper\"\n            [aclErrorsMapperOutlet]=\"cpuError\"\n            [readonly]=\"form.get('size').value !== ResourceSize.CUSTOMIZE\"\n            required\n            auiFormItemControl\n          />\n          <aui-select\n            *ngIf=\"\n              form.get('size').value === ResourceSize.CUSTOMIZE;\n              else cUnit\n            \"\n            class=\"custom-spec-form__cpu-unit\"\n            auiInputAddonAfter\n            formControlName=\"unit\"\n          >\n            <aui-option value=\"m\">m</aui-option>\n            <aui-option\n              value=\"core\"\n              [label]=\"'core' | translate\"\n            >\n              {{ 'core' | translate }}\n            </aui-option>\n          </aui-select>\n          <ng-template #cUnit>\n            <span\n              *ngIf=\"form.get('limits.cpu.unit').value as cpuUnit\"\n              auiInputAddonAfter\n            >\n              {{ cpuUnit === 'core' ? ('core' | translate) : cpuUnit }}\n            </span>\n          </ng-template>\n        </aui-input-group>\n        <div\n          auiFormItemError\n          #cpuError\n        ></div>\n      </aui-form-item>\n\n      <aui-form-item\n        class=\"tw-flex-1 tw-ml-8\"\n        width=\"large\"\n      >\n        <aui-input-group\n          auiFormItemControl\n          formGroupName=\"memory\"\n        >\n          <span\n            auiInputAddonBefore\n            class=\"tw-required-mark\"\n            >{{ 'memory' | translate }}</span\n          >\n          <input\n            aui-input\n            formControlName=\"value\"\n            aclCoerceNumber\n            [pattern]=\"POSITIVE_INT_PATTERN.pattern\"\n            [aclErrorsMapper]=\"errorMapper\"\n            [aclErrorsMapperOutlet]=\"memoryError\"\n            [readonly]=\"form.get('size').value !== ResourceSize.CUSTOMIZE\"\n            required\n            auiFormItemControl\n          />\n\n          <aui-select\n            *ngIf=\"\n              form.get('size').value === ResourceSize.CUSTOMIZE;\n              else mUnit\n            \"\n            auiInputAddonAfter\n            formControlName=\"unit\"\n          >\n            <aui-option value=\"Mi\">Mi</aui-option>\n            <aui-option value=\"Gi\">Gi</aui-option>\n          </aui-select>\n          <ng-template #mUnit>\n            <span auiInputAddonAfter>\n              {{ form.get('limits.memory.unit').value }}\n            </span>\n          </ng-template>\n        </aui-input-group>\n        <div\n          auiFormItemError\n          #memoryError\n        ></div>\n      </aui-form-item>\n    </div>\n  </aui-form-item>\n</ng-container>\n"]}