@alauda-fe/crd-form 0.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/alauda-fe-crd-form.mjs +5 -0
- package/esm2022/lib/abstract/base-array.mjs +117 -0
- package/esm2022/lib/crd-form/component.mjs +334 -0
- package/esm2022/lib/crd-form/helper.mjs +32 -0
- package/esm2022/lib/crd-form.module.mjs +117 -0
- package/esm2022/lib/field-controls/expressions/expression-core.mjs +2 -0
- package/esm2022/lib/field-controls/expressions/props-expression.mjs +58 -0
- package/esm2022/lib/field-controls/form-item.component.mjs +121 -0
- package/esm2022/lib/field-controls/index.mjs +8 -0
- package/esm2022/lib/field-controls/module.mjs +141 -0
- package/esm2022/lib/field-controls/operand-advanced-field-group.component.mjs +80 -0
- package/esm2022/lib/field-controls/operand-array-field-group.component.mjs +112 -0
- package/esm2022/lib/field-controls/operand-field-group.component.mjs +98 -0
- package/esm2022/lib/field-controls/operand-field.component.mjs +870 -0
- package/esm2022/lib/field-controls/widgets/array-table/component.mjs +109 -0
- package/esm2022/lib/field-controls/widgets/basic-auth-secret/component.mjs +116 -0
- package/esm2022/lib/field-controls/widgets/basic-auth-secret/create/component.mjs +211 -0
- package/esm2022/lib/field-controls/widgets/basic-auth-secret/type.mjs +2 -0
- package/esm2022/lib/field-controls/widgets/index.mjs +8 -0
- package/esm2022/lib/field-controls/widgets/k8s-resource-prefix/component.mjs +169 -0
- package/esm2022/lib/field-controls/widgets/k8s-resource-prefix/util.mjs +40 -0
- package/esm2022/lib/field-controls/widgets/link/component.mjs +68 -0
- package/esm2022/lib/field-controls/widgets/resource-requirements/resource-requirements.component.mjs +524 -0
- package/esm2022/lib/field-controls/widgets/utils.mjs +73 -0
- package/esm2022/lib/field-controls/widgets/yaml-editor/yaml-editor.component.mjs +94 -0
- package/esm2022/lib/field-widgets/htpasswd/component.mjs +35 -0
- package/esm2022/lib/field-widgets/htpasswd/form.mjs +171 -0
- package/esm2022/lib/field-widgets/htpasswd/index.mjs +4 -0
- package/esm2022/lib/field-widgets/htpasswd/module.mjs +54 -0
- package/esm2022/lib/field-widgets/index.mjs +2 -0
- package/esm2022/lib/remote-widgets/constants.mjs +4 -0
- package/esm2022/lib/remote-widgets/index.mjs +4 -0
- package/esm2022/lib/remote-widgets/remote-widget.service.mjs +42 -0
- package/esm2022/lib/remote-widgets/token.mjs +7 -0
- package/esm2022/lib/spec-descriptors/capability/capability.component.mjs +139 -0
- package/esm2022/lib/spec-descriptors/capability-list/capability-list.component.mjs +189 -0
- package/esm2022/lib/spec-descriptors/index.mjs +4 -0
- package/esm2022/lib/spec-descriptors/util.mjs +13 -0
- package/esm2022/lib/types/index.mjs +73 -0
- package/esm2022/lib/utils/capability.mjs +295 -0
- package/esm2022/lib/utils/constant.mjs +22 -0
- package/esm2022/lib/utils/directives.mjs +19 -0
- package/esm2022/lib/utils/helper.mjs +201 -0
- package/esm2022/lib/utils/index.mjs +7 -0
- package/esm2022/lib/utils/service-model.mjs +12 -0
- package/esm2022/lib/utils/util.mjs +310 -0
- package/esm2022/public-api.mjs +13 -0
- package/index.d.ts +5 -0
- package/lib/abstract/base-array.d.ts +31 -0
- package/lib/crd-form/component.d.ts +61 -0
- package/lib/crd-form/helper.d.ts +7 -0
- package/lib/crd-form.module.d.ts +16 -0
- package/lib/field-controls/expressions/expression-core.d.ts +6 -0
- package/lib/field-controls/expressions/props-expression.d.ts +36 -0
- package/lib/field-controls/form-item.component.d.ts +11 -0
- package/lib/field-controls/index.d.ts +7 -0
- package/lib/field-controls/module.d.ts +23 -0
- package/lib/field-controls/operand-advanced-field-group.component.d.ts +16 -0
- package/lib/field-controls/operand-array-field-group.component.d.ts +8 -0
- package/lib/field-controls/operand-field-group.component.d.ts +24 -0
- package/lib/field-controls/operand-field.component.d.ts +110 -0
- package/lib/field-controls/widgets/array-table/component.d.ts +8 -0
- package/lib/field-controls/widgets/basic-auth-secret/component.d.ts +26 -0
- package/lib/field-controls/widgets/basic-auth-secret/create/component.d.ts +45 -0
- package/lib/field-controls/widgets/basic-auth-secret/type.d.ts +11 -0
- package/lib/field-controls/widgets/index.d.ts +7 -0
- package/lib/field-controls/widgets/k8s-resource-prefix/component.d.ts +35 -0
- package/lib/field-controls/widgets/k8s-resource-prefix/util.d.ts +3 -0
- package/lib/field-controls/widgets/link/component.d.ts +20 -0
- package/lib/field-controls/widgets/resource-requirements/resource-requirements.component.d.ts +88 -0
- package/lib/field-controls/widgets/utils.d.ts +17 -0
- package/lib/field-controls/widgets/yaml-editor/yaml-editor.component.d.ts +36 -0
- package/lib/field-widgets/htpasswd/component.d.ts +9 -0
- package/lib/field-widgets/htpasswd/form.d.ts +32 -0
- package/lib/field-widgets/htpasswd/index.d.ts +3 -0
- package/lib/field-widgets/htpasswd/module.d.ts +13 -0
- package/lib/field-widgets/index.d.ts +1 -0
- package/lib/remote-widgets/constants.d.ts +3 -0
- package/lib/remote-widgets/index.d.ts +3 -0
- package/lib/remote-widgets/remote-widget.service.d.ts +28 -0
- package/lib/remote-widgets/token.d.ts +3 -0
- package/lib/spec-descriptors/capability/capability.component.d.ts +20 -0
- package/lib/spec-descriptors/capability-list/capability-list.component.d.ts +34 -0
- package/lib/spec-descriptors/index.d.ts +3 -0
- package/lib/spec-descriptors/util.d.ts +4 -0
- package/lib/types/index.d.ts +122 -0
- package/lib/utils/capability.d.ts +54 -0
- package/lib/utils/constant.d.ts +12 -0
- package/lib/utils/directives.d.ts +9 -0
- package/lib/utils/helper.d.ts +61 -0
- package/lib/utils/index.d.ts +6 -0
- package/lib/utils/service-model.d.ts +44 -0
- package/lib/utils/util.d.ts +48 -0
- package/package.json +30 -0
- package/public-api.d.ts +9 -0
package/esm2022/lib/field-controls/widgets/resource-requirements/resource-requirements.component.mjs
ADDED
|
@@ -0,0 +1,524 @@
|
|
|
1
|
+
import { __decorate, __metadata } from "tslib";
|
|
2
|
+
import { bind, formatCPU, formatMemory, getResourceValue, getResourceViewModel, initGreaterValidator, RESOURCE_MAC_TYPES, resourceUnits, transferResource, TranslateService, } from '@alauda-fe/common';
|
|
3
|
+
import { ChangeDetectionStrategy, Component, Injector, Input, Optional, } from '@angular/core';
|
|
4
|
+
import { ControlContainer, } from '@angular/forms';
|
|
5
|
+
import { merge, omit, isEmpty } from 'lodash-es';
|
|
6
|
+
import { BaseResourceFormGroupComponent } from 'ng-resource-form-util';
|
|
7
|
+
import { getFieldDescription, getFieldDisplayName } from '../../../utils';
|
|
8
|
+
import { OperandFieldComponent } from '../../operand-field.component';
|
|
9
|
+
import { resolveRequirementsRequiredOptions, resolveRequirementsMinOrMaxOptions, } from '../utils';
|
|
10
|
+
import * as i0 from "@angular/core";
|
|
11
|
+
import * as i1 from "../../operand-field.component";
|
|
12
|
+
import * as i2 from "@angular/forms";
|
|
13
|
+
import * as i3 from "@alauda-fe/common";
|
|
14
|
+
import * as i4 from "@angular/common";
|
|
15
|
+
import * as i5 from "@alauda/ui";
|
|
16
|
+
const _c0 = a0 => ({ "tw-required-mark": a0 });
|
|
17
|
+
const _c1 = (a0, a1, a2) => [a0, a1, "min", "cpu", a2];
|
|
18
|
+
const _c2 = (a0, a1, a2) => [a0, a1, "max", "cpu", a2];
|
|
19
|
+
const _c3 = (a0, a1) => ({ min: a0, max: a1 });
|
|
20
|
+
const _c4 = (a0, a1, a2) => [a0, a1, "min", "memory", a2];
|
|
21
|
+
const _c5 = (a0, a1, a2) => [a0, a1, "max", "memory", a2];
|
|
22
|
+
const _c6 = (a0, a1, a2) => ({ cpu_max: a0, min: a1, max: a2 });
|
|
23
|
+
const _c7 = (a0, a1, a2) => ({ memory_max: a0, min: a1, max: a2 });
|
|
24
|
+
function ResourceRequirementsComponent_form_0_aui_option_13_Template(rf, ctx) { if (rf & 1) {
|
|
25
|
+
i0.ɵɵelementStart(0, "aui-option", 17);
|
|
26
|
+
i0.ɵɵpipe(1, "translate");
|
|
27
|
+
i0.ɵɵtext(2);
|
|
28
|
+
i0.ɵɵpipe(3, "translate");
|
|
29
|
+
i0.ɵɵelementEnd();
|
|
30
|
+
} if (rf & 2) {
|
|
31
|
+
const unit_r1 = ctx.$implicit;
|
|
32
|
+
i0.ɵɵproperty("value", unit_r1.value)("label", i0.ɵɵpipeBind1(1, 3, unit_r1.label));
|
|
33
|
+
i0.ɵɵadvance(2);
|
|
34
|
+
i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(3, 5, unit_r1.label), " ");
|
|
35
|
+
} }
|
|
36
|
+
function ResourceRequirementsComponent_form_0_acl_errors_mapper_14_Template(rf, ctx) { if (rf & 1) {
|
|
37
|
+
i0.ɵɵelement(0, "acl-errors-mapper", 18);
|
|
38
|
+
i0.ɵɵpipe(1, "pure");
|
|
39
|
+
i0.ɵɵpipe(2, "pure");
|
|
40
|
+
} if (rf & 2) {
|
|
41
|
+
const ctx_r1 = i0.ɵɵnextContext(2);
|
|
42
|
+
i0.ɵɵproperty("errors", ctx_r1.form.get("requests.cpu.value").errors)("errorsMapper", i0.ɵɵpureFunction2(22, _c3, i0.ɵɵpipeBindV(1, 2, i0.ɵɵpureFunction3(14, _c1, ctx_r1.requestCpuMin, ctx_r1.getMinOrMaxErrorsMapper, ctx_r1.translate.locale)), i0.ɵɵpipeBindV(2, 8, i0.ɵɵpureFunction3(18, _c2, ctx_r1.requestCpuMax, ctx_r1.getMinOrMaxErrorsMapper, ctx_r1.translate.locale))));
|
|
43
|
+
} }
|
|
44
|
+
function ResourceRequirementsComponent_form_0_aui_option_23_Template(rf, ctx) { if (rf & 1) {
|
|
45
|
+
i0.ɵɵelementStart(0, "aui-option", 19);
|
|
46
|
+
i0.ɵɵtext(1);
|
|
47
|
+
i0.ɵɵelementEnd();
|
|
48
|
+
} if (rf & 2) {
|
|
49
|
+
const unit_r3 = ctx.$implicit;
|
|
50
|
+
i0.ɵɵproperty("value", unit_r3);
|
|
51
|
+
i0.ɵɵadvance();
|
|
52
|
+
i0.ɵɵtextInterpolate1(" ", unit_r3, " ");
|
|
53
|
+
} }
|
|
54
|
+
function ResourceRequirementsComponent_form_0_acl_errors_mapper_24_Template(rf, ctx) { if (rf & 1) {
|
|
55
|
+
i0.ɵɵelement(0, "acl-errors-mapper", 18);
|
|
56
|
+
i0.ɵɵpipe(1, "pure");
|
|
57
|
+
i0.ɵɵpipe(2, "pure");
|
|
58
|
+
} if (rf & 2) {
|
|
59
|
+
const ctx_r1 = i0.ɵɵnextContext(2);
|
|
60
|
+
i0.ɵɵproperty("errors", ctx_r1.form.get("requests.memory.value").errors)("errorsMapper", i0.ɵɵpureFunction2(22, _c3, i0.ɵɵpipeBindV(1, 2, i0.ɵɵpureFunction3(14, _c4, ctx_r1.requestMemoryMin, ctx_r1.getMinOrMaxErrorsMapper, ctx_r1.translate.locale)), i0.ɵɵpipeBindV(2, 8, i0.ɵɵpureFunction3(18, _c5, ctx_r1.requestMemoryMax, ctx_r1.getMinOrMaxErrorsMapper, ctx_r1.translate.locale))));
|
|
61
|
+
} }
|
|
62
|
+
function ResourceRequirementsComponent_form_0_aui_option_37_Template(rf, ctx) { if (rf & 1) {
|
|
63
|
+
i0.ɵɵelementStart(0, "aui-option", 17);
|
|
64
|
+
i0.ɵɵpipe(1, "translate");
|
|
65
|
+
i0.ɵɵtext(2);
|
|
66
|
+
i0.ɵɵpipe(3, "translate");
|
|
67
|
+
i0.ɵɵelementEnd();
|
|
68
|
+
} if (rf & 2) {
|
|
69
|
+
const unit_r4 = ctx.$implicit;
|
|
70
|
+
i0.ɵɵproperty("value", unit_r4.value)("label", i0.ɵɵpipeBind1(1, 3, unit_r4.label));
|
|
71
|
+
i0.ɵɵadvance(2);
|
|
72
|
+
i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(3, 5, unit_r4.label), " ");
|
|
73
|
+
} }
|
|
74
|
+
function ResourceRequirementsComponent_form_0_acl_errors_mapper_38_Template(rf, ctx) { if (rf & 1) {
|
|
75
|
+
i0.ɵɵelement(0, "acl-errors-mapper", 18);
|
|
76
|
+
i0.ɵɵpipe(1, "translate");
|
|
77
|
+
i0.ɵɵpipe(2, "pure");
|
|
78
|
+
i0.ɵɵpipe(3, "pure");
|
|
79
|
+
} if (rf & 2) {
|
|
80
|
+
const ctx_r1 = i0.ɵɵnextContext(2);
|
|
81
|
+
i0.ɵɵproperty("errors", ctx_r1.form.get("limits.cpu.value").errors)("errorsMapper", i0.ɵɵpureFunction3(24, _c6, i0.ɵɵpipeBind1(1, 2, "request_greater_than_limits_error"), i0.ɵɵpipeBindV(2, 4, i0.ɵɵpureFunction3(16, _c1, ctx_r1.limitCpuMin, ctx_r1.getMinOrMaxErrorsMapper, ctx_r1.translate.locale)), i0.ɵɵpipeBindV(3, 10, i0.ɵɵpureFunction3(20, _c2, ctx_r1.limitCpuMax, ctx_r1.getMinOrMaxErrorsMapper, ctx_r1.translate.locale))));
|
|
82
|
+
} }
|
|
83
|
+
function ResourceRequirementsComponent_form_0_aui_option_47_Template(rf, ctx) { if (rf & 1) {
|
|
84
|
+
i0.ɵɵelementStart(0, "aui-option", 19);
|
|
85
|
+
i0.ɵɵtext(1);
|
|
86
|
+
i0.ɵɵelementEnd();
|
|
87
|
+
} if (rf & 2) {
|
|
88
|
+
const unit_r5 = ctx.$implicit;
|
|
89
|
+
i0.ɵɵproperty("value", unit_r5);
|
|
90
|
+
i0.ɵɵadvance();
|
|
91
|
+
i0.ɵɵtextInterpolate1(" ", unit_r5, " ");
|
|
92
|
+
} }
|
|
93
|
+
function ResourceRequirementsComponent_form_0_acl_errors_mapper_48_Template(rf, ctx) { if (rf & 1) {
|
|
94
|
+
i0.ɵɵelement(0, "acl-errors-mapper", 18);
|
|
95
|
+
i0.ɵɵpipe(1, "translate");
|
|
96
|
+
i0.ɵɵpipe(2, "pure");
|
|
97
|
+
i0.ɵɵpipe(3, "pure");
|
|
98
|
+
} if (rf & 2) {
|
|
99
|
+
const ctx_r1 = i0.ɵɵnextContext(2);
|
|
100
|
+
i0.ɵɵproperty("errors", ctx_r1.form.get("limits.memory.value").errors)("errorsMapper", i0.ɵɵpureFunction3(24, _c7, i0.ɵɵpipeBind1(1, 2, "request_greater_than_limits_error"), i0.ɵɵpipeBindV(2, 4, i0.ɵɵpureFunction3(16, _c4, ctx_r1.limitMemoryMin, ctx_r1.getMinOrMaxErrorsMapper, ctx_r1.translate.locale)), i0.ɵɵpipeBindV(3, 10, i0.ɵɵpureFunction3(20, _c5, ctx_r1.limitMemoryMax, ctx_r1.getMinOrMaxErrorsMapper, ctx_r1.translate.locale))));
|
|
101
|
+
} }
|
|
102
|
+
function ResourceRequirementsComponent_form_0_Template(rf, ctx) { if (rf & 1) {
|
|
103
|
+
i0.ɵɵelementStart(0, "form", 2)(1, "div", 3)(2, "div", 4);
|
|
104
|
+
i0.ɵɵtext(3);
|
|
105
|
+
i0.ɵɵpipe(4, "translate");
|
|
106
|
+
i0.ɵɵelementEnd();
|
|
107
|
+
i0.ɵɵelementStart(5, "div", 5)(6, "div", 6)(7, "div", 7)(8, "aui-input-group")(9, "div", 8);
|
|
108
|
+
i0.ɵɵtext(10, " CPU ");
|
|
109
|
+
i0.ɵɵelementEnd();
|
|
110
|
+
i0.ɵɵelement(11, "input", 9);
|
|
111
|
+
i0.ɵɵelementStart(12, "aui-select", 10);
|
|
112
|
+
i0.ɵɵtemplate(13, ResourceRequirementsComponent_form_0_aui_option_13_Template, 4, 7, "aui-option", 11);
|
|
113
|
+
i0.ɵɵelementEnd()()();
|
|
114
|
+
i0.ɵɵtemplate(14, ResourceRequirementsComponent_form_0_acl_errors_mapper_14_Template, 3, 25, "acl-errors-mapper", 12);
|
|
115
|
+
i0.ɵɵelementEnd();
|
|
116
|
+
i0.ɵɵelementStart(15, "div", 6)(16, "div", 13)(17, "aui-input-group")(18, "div", 8);
|
|
117
|
+
i0.ɵɵtext(19);
|
|
118
|
+
i0.ɵɵpipe(20, "translate");
|
|
119
|
+
i0.ɵɵelementEnd();
|
|
120
|
+
i0.ɵɵelement(21, "input", 9);
|
|
121
|
+
i0.ɵɵelementStart(22, "aui-select", 10);
|
|
122
|
+
i0.ɵɵtemplate(23, ResourceRequirementsComponent_form_0_aui_option_23_Template, 2, 2, "aui-option", 14);
|
|
123
|
+
i0.ɵɵelementEnd()()();
|
|
124
|
+
i0.ɵɵtemplate(24, ResourceRequirementsComponent_form_0_acl_errors_mapper_24_Template, 3, 25, "acl-errors-mapper", 12);
|
|
125
|
+
i0.ɵɵelementEnd()()();
|
|
126
|
+
i0.ɵɵelementStart(25, "div", 3)(26, "div", 4);
|
|
127
|
+
i0.ɵɵtext(27);
|
|
128
|
+
i0.ɵɵpipe(28, "translate");
|
|
129
|
+
i0.ɵɵelementEnd();
|
|
130
|
+
i0.ɵɵelementStart(29, "div", 15)(30, "div", 6)(31, "div", 16)(32, "aui-input-group")(33, "div", 8);
|
|
131
|
+
i0.ɵɵtext(34, " CPU ");
|
|
132
|
+
i0.ɵɵelementEnd();
|
|
133
|
+
i0.ɵɵelement(35, "input", 9);
|
|
134
|
+
i0.ɵɵelementStart(36, "aui-select", 10);
|
|
135
|
+
i0.ɵɵtemplate(37, ResourceRequirementsComponent_form_0_aui_option_37_Template, 4, 7, "aui-option", 11);
|
|
136
|
+
i0.ɵɵelementEnd()()();
|
|
137
|
+
i0.ɵɵtemplate(38, ResourceRequirementsComponent_form_0_acl_errors_mapper_38_Template, 4, 28, "acl-errors-mapper", 12);
|
|
138
|
+
i0.ɵɵelementEnd();
|
|
139
|
+
i0.ɵɵelementStart(39, "div", 6)(40, "div", 13)(41, "aui-input-group")(42, "div", 8);
|
|
140
|
+
i0.ɵɵtext(43);
|
|
141
|
+
i0.ɵɵpipe(44, "translate");
|
|
142
|
+
i0.ɵɵelementEnd();
|
|
143
|
+
i0.ɵɵelement(45, "input", 9);
|
|
144
|
+
i0.ɵɵelementStart(46, "aui-select", 10);
|
|
145
|
+
i0.ɵɵtemplate(47, ResourceRequirementsComponent_form_0_aui_option_47_Template, 2, 2, "aui-option", 14);
|
|
146
|
+
i0.ɵɵelementEnd()()();
|
|
147
|
+
i0.ɵɵtemplate(48, ResourceRequirementsComponent_form_0_acl_errors_mapper_48_Template, 4, 28, "acl-errors-mapper", 12);
|
|
148
|
+
i0.ɵɵelementEnd()()()();
|
|
149
|
+
} if (rf & 2) {
|
|
150
|
+
let tmp_7_0;
|
|
151
|
+
let tmp_13_0;
|
|
152
|
+
let tmp_19_0;
|
|
153
|
+
let tmp_25_0;
|
|
154
|
+
const ctx_r1 = i0.ɵɵnextContext();
|
|
155
|
+
i0.ɵɵproperty("formGroup", ctx_r1.form);
|
|
156
|
+
i0.ɵɵadvance(3);
|
|
157
|
+
i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(4, 24, "resource_requirements_requests"), " ");
|
|
158
|
+
i0.ɵɵadvance(6);
|
|
159
|
+
i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(32, _c0, ctx_r1.requestCpuRequired));
|
|
160
|
+
i0.ɵɵadvance(2);
|
|
161
|
+
i0.ɵɵproperty("required", ctx_r1.requestCpuRequired);
|
|
162
|
+
i0.ɵɵadvance(2);
|
|
163
|
+
i0.ɵɵproperty("ngForOf", ctx_r1.resourceUnits["cpu"]);
|
|
164
|
+
i0.ɵɵadvance();
|
|
165
|
+
i0.ɵɵproperty("ngIf", ((tmp_7_0 = ctx_r1.form.get("requests.cpu.value")) == null ? null : tmp_7_0.dirty) || (ctx_r1.controlContainer == null ? null : ctx_r1.controlContainer.formDirective == null ? null : ctx_r1.controlContainer.formDirective.submitted));
|
|
166
|
+
i0.ɵɵadvance(2);
|
|
167
|
+
i0.ɵɵproperty("formGroupName", "memory");
|
|
168
|
+
i0.ɵɵadvance(2);
|
|
169
|
+
i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(34, _c0, ctx_r1.requestMemoryRequired));
|
|
170
|
+
i0.ɵɵadvance();
|
|
171
|
+
i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(20, 26, "memory"), " ");
|
|
172
|
+
i0.ɵɵadvance(2);
|
|
173
|
+
i0.ɵɵproperty("required", ctx_r1.requestMemoryRequired);
|
|
174
|
+
i0.ɵɵadvance(2);
|
|
175
|
+
i0.ɵɵproperty("ngForOf", ctx_r1.resourceUnits["memory"]);
|
|
176
|
+
i0.ɵɵadvance();
|
|
177
|
+
i0.ɵɵproperty("ngIf", ((tmp_13_0 = ctx_r1.form.get("requests.memory.value")) == null ? null : tmp_13_0.dirty) || (ctx_r1.controlContainer == null ? null : ctx_r1.controlContainer.formDirective == null ? null : ctx_r1.controlContainer.formDirective.submitted));
|
|
178
|
+
i0.ɵɵadvance(3);
|
|
179
|
+
i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(28, 28, "resource_requirements_limits"), " ");
|
|
180
|
+
i0.ɵɵadvance(4);
|
|
181
|
+
i0.ɵɵproperty("formGroupName", "cpu");
|
|
182
|
+
i0.ɵɵadvance(2);
|
|
183
|
+
i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(36, _c0, ctx_r1.limitCpuRequired));
|
|
184
|
+
i0.ɵɵadvance(2);
|
|
185
|
+
i0.ɵɵproperty("required", ctx_r1.limitCpuRequired);
|
|
186
|
+
i0.ɵɵadvance(2);
|
|
187
|
+
i0.ɵɵproperty("ngForOf", ctx_r1.resourceUnits["cpu"]);
|
|
188
|
+
i0.ɵɵadvance();
|
|
189
|
+
i0.ɵɵproperty("ngIf", ((tmp_19_0 = ctx_r1.form.get("limits.cpu.value")) == null ? null : tmp_19_0.dirty) || (ctx_r1.controlContainer == null ? null : ctx_r1.controlContainer.formDirective == null ? null : ctx_r1.controlContainer.formDirective.submitted));
|
|
190
|
+
i0.ɵɵadvance(2);
|
|
191
|
+
i0.ɵɵproperty("formGroupName", "memory");
|
|
192
|
+
i0.ɵɵadvance(2);
|
|
193
|
+
i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(38, _c0, ctx_r1.limitMemoryRequired));
|
|
194
|
+
i0.ɵɵadvance();
|
|
195
|
+
i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(44, 30, "memory"), " ");
|
|
196
|
+
i0.ɵɵadvance(2);
|
|
197
|
+
i0.ɵɵproperty("required", ctx_r1.limitMemoryRequired);
|
|
198
|
+
i0.ɵɵadvance(2);
|
|
199
|
+
i0.ɵɵproperty("ngForOf", ctx_r1.resourceUnits["memory"]);
|
|
200
|
+
i0.ɵɵadvance();
|
|
201
|
+
i0.ɵɵproperty("ngIf", ((tmp_25_0 = ctx_r1.form.get("limits.memory.value")) == null ? null : tmp_25_0.dirty) || (ctx_r1.controlContainer == null ? null : ctx_r1.controlContainer.formDirective == null ? null : ctx_r1.controlContainer.formDirective.submitted));
|
|
202
|
+
} }
|
|
203
|
+
function ResourceRequirementsComponent_ng_template_1_Template(rf, ctx) { if (rf & 1) {
|
|
204
|
+
i0.ɵɵelementStart(0, "div", 20)(1, "div", 21)(2, "label", 22);
|
|
205
|
+
i0.ɵɵtext(3);
|
|
206
|
+
i0.ɵɵpipe(4, "translate");
|
|
207
|
+
i0.ɵɵelementEnd();
|
|
208
|
+
i0.ɵɵelement(5, "aui-icon", 23);
|
|
209
|
+
i0.ɵɵpipe(6, "translate");
|
|
210
|
+
i0.ɵɵelementStart(7, "span", 24);
|
|
211
|
+
i0.ɵɵtext(8);
|
|
212
|
+
i0.ɵɵpipe(9, "pure");
|
|
213
|
+
i0.ɵɵpipe(10, "aclFieldNotAvailable");
|
|
214
|
+
i0.ɵɵpipe(11, "pure");
|
|
215
|
+
i0.ɵɵpipe(12, "translate");
|
|
216
|
+
i0.ɵɵelementEnd();
|
|
217
|
+
i0.ɵɵelement(13, "aui-icon", 25);
|
|
218
|
+
i0.ɵɵpipe(14, "translate");
|
|
219
|
+
i0.ɵɵtext(15);
|
|
220
|
+
i0.ɵɵpipe(16, "pure");
|
|
221
|
+
i0.ɵɵpipe(17, "aclFieldNotAvailable");
|
|
222
|
+
i0.ɵɵelementEnd();
|
|
223
|
+
i0.ɵɵelementStart(18, "div", 21)(19, "label", 22);
|
|
224
|
+
i0.ɵɵtext(20);
|
|
225
|
+
i0.ɵɵpipe(21, "translate");
|
|
226
|
+
i0.ɵɵelementEnd();
|
|
227
|
+
i0.ɵɵelement(22, "aui-icon", 23);
|
|
228
|
+
i0.ɵɵpipe(23, "translate");
|
|
229
|
+
i0.ɵɵelementStart(24, "span", 24);
|
|
230
|
+
i0.ɵɵtext(25);
|
|
231
|
+
i0.ɵɵpipe(26, "pure");
|
|
232
|
+
i0.ɵɵpipe(27, "aclFieldNotAvailable");
|
|
233
|
+
i0.ɵɵpipe(28, "pure");
|
|
234
|
+
i0.ɵɵpipe(29, "translate");
|
|
235
|
+
i0.ɵɵelementEnd();
|
|
236
|
+
i0.ɵɵelement(30, "aui-icon", 25);
|
|
237
|
+
i0.ɵɵpipe(31, "translate");
|
|
238
|
+
i0.ɵɵtext(32);
|
|
239
|
+
i0.ɵɵpipe(33, "pure");
|
|
240
|
+
i0.ɵɵpipe(34, "aclFieldNotAvailable");
|
|
241
|
+
i0.ɵɵelementEnd()();
|
|
242
|
+
} if (rf & 2) {
|
|
243
|
+
const ctx_r1 = i0.ɵɵnextContext();
|
|
244
|
+
i0.ɵɵadvance(3);
|
|
245
|
+
i0.ɵɵtextInterpolate(i0.ɵɵpipeBind1(4, 12, "resource_requirements_requests"));
|
|
246
|
+
i0.ɵɵadvance(2);
|
|
247
|
+
i0.ɵɵproperty("title", i0.ɵɵpipeBind1(6, 14, "cpu"));
|
|
248
|
+
i0.ɵɵadvance(3);
|
|
249
|
+
i0.ɵɵtextInterpolate2("", i0.ɵɵpipeBind1(10, 19, i0.ɵɵpipeBind2(9, 16, ctx_r1.form.get("requests").get("cpu").value, ctx_r1.getResourceValue)), "", i0.ɵɵpipeBind1(12, 24, i0.ɵɵpipeBind2(11, 21, ctx_r1.form.get("requests").get("cpu.unit").value, ctx_r1.getCpuUnitLabel)), " ");
|
|
250
|
+
i0.ɵɵadvance(5);
|
|
251
|
+
i0.ɵɵproperty("title", i0.ɵɵpipeBind1(14, 26, "memory"));
|
|
252
|
+
i0.ɵɵadvance(2);
|
|
253
|
+
i0.ɵɵtextInterpolate1("", i0.ɵɵpipeBind1(17, 31, i0.ɵɵpipeBind2(16, 28, ctx_r1.form.get("requests").get("memory").value, ctx_r1.getResourceValue)), " ");
|
|
254
|
+
i0.ɵɵadvance(5);
|
|
255
|
+
i0.ɵɵtextInterpolate(i0.ɵɵpipeBind1(21, 33, "resource_requirements_limits"));
|
|
256
|
+
i0.ɵɵadvance(2);
|
|
257
|
+
i0.ɵɵproperty("title", i0.ɵɵpipeBind1(23, 35, "cpu"));
|
|
258
|
+
i0.ɵɵadvance(3);
|
|
259
|
+
i0.ɵɵtextInterpolate2("", i0.ɵɵpipeBind1(27, 40, i0.ɵɵpipeBind2(26, 37, ctx_r1.form.get("limits").get("cpu").value, ctx_r1.getResourceValue)), "", i0.ɵɵpipeBind1(29, 45, i0.ɵɵpipeBind2(28, 42, ctx_r1.form.get("limits").get("cpu.unit").value, ctx_r1.getCpuUnitLabel)), " ");
|
|
260
|
+
i0.ɵɵadvance(5);
|
|
261
|
+
i0.ɵɵproperty("title", i0.ɵɵpipeBind1(31, 47, "memory"));
|
|
262
|
+
i0.ɵɵadvance(2);
|
|
263
|
+
i0.ɵɵtextInterpolate1("", i0.ɵɵpipeBind1(34, 52, i0.ɵɵpipeBind2(33, 49, ctx_r1.form.get("limits").get("memory").value, ctx_r1.getResourceValue)), " ");
|
|
264
|
+
} }
|
|
265
|
+
function handleValidationErrors(valueCtrl, errors) {
|
|
266
|
+
// 这里避免覆盖其它 errors
|
|
267
|
+
const combinedErrors = { ...valueCtrl.errors, ...errors };
|
|
268
|
+
valueCtrl.setErrors(combinedErrors);
|
|
269
|
+
return combinedErrors;
|
|
270
|
+
}
|
|
271
|
+
function valueFormat(type, value) {
|
|
272
|
+
return type === 'cpu' ? formatCPU(value) : formatMemory(value);
|
|
273
|
+
}
|
|
274
|
+
function getCurrentValue(group, type) {
|
|
275
|
+
const valueCtrl = group.get('value');
|
|
276
|
+
const value = valueCtrl.value;
|
|
277
|
+
const unit = group.get('unit').value;
|
|
278
|
+
return valueFormat(type, (value || 0) + unit);
|
|
279
|
+
}
|
|
280
|
+
export class ResourceRequirementsComponent extends BaseResourceFormGroupComponent {
|
|
281
|
+
get requiredOptions() {
|
|
282
|
+
return resolveRequirementsRequiredOptions(this.fieldComponent?.field);
|
|
283
|
+
}
|
|
284
|
+
get limitMemoryRequired() {
|
|
285
|
+
return this.requiredOptions.required?.limit?.includes('memory');
|
|
286
|
+
}
|
|
287
|
+
get limitCpuRequired() {
|
|
288
|
+
return this.requiredOptions.required?.limit?.includes('cpu');
|
|
289
|
+
}
|
|
290
|
+
get requestMemoryRequired() {
|
|
291
|
+
return this.requiredOptions.required?.request?.includes('memory');
|
|
292
|
+
}
|
|
293
|
+
get requestCpuRequired() {
|
|
294
|
+
return this.requiredOptions.required?.request?.includes('cpu');
|
|
295
|
+
}
|
|
296
|
+
get minMaxOptions() {
|
|
297
|
+
return resolveRequirementsMinOrMaxOptions(this.fieldComponent?.field);
|
|
298
|
+
}
|
|
299
|
+
get limitMemoryMin() {
|
|
300
|
+
return this.minMaxOptions.min.limits?.memory;
|
|
301
|
+
}
|
|
302
|
+
get limitCpuMin() {
|
|
303
|
+
return this.minMaxOptions.min.limits?.cpu;
|
|
304
|
+
}
|
|
305
|
+
get requestMemoryMin() {
|
|
306
|
+
return this.minMaxOptions.min.requests?.memory;
|
|
307
|
+
}
|
|
308
|
+
get requestCpuMin() {
|
|
309
|
+
return this.minMaxOptions.min.requests?.cpu;
|
|
310
|
+
}
|
|
311
|
+
get limitMemoryMax() {
|
|
312
|
+
return this.minMaxOptions.max.limits?.memory;
|
|
313
|
+
}
|
|
314
|
+
get limitCpuMax() {
|
|
315
|
+
return this.minMaxOptions.max.limits?.cpu;
|
|
316
|
+
}
|
|
317
|
+
get requestMemoryMax() {
|
|
318
|
+
return this.minMaxOptions.max.requests?.memory;
|
|
319
|
+
}
|
|
320
|
+
get requestCpuMax() {
|
|
321
|
+
return this.minMaxOptions.max.requests?.cpu;
|
|
322
|
+
}
|
|
323
|
+
constructor(injector, fieldComponent, controlContainer, translate) {
|
|
324
|
+
super(injector);
|
|
325
|
+
this.fieldComponent = fieldComponent;
|
|
326
|
+
this.controlContainer = controlContainer;
|
|
327
|
+
this.translate = translate;
|
|
328
|
+
this.resourceUnits = resourceUnits;
|
|
329
|
+
this.getFieldDisplayName = getFieldDisplayName;
|
|
330
|
+
this.getFieldDescription = getFieldDescription;
|
|
331
|
+
this.getResourceValue = getResourceValue;
|
|
332
|
+
this.getResourceViewModel = getResourceViewModel;
|
|
333
|
+
}
|
|
334
|
+
ngOnInit() {
|
|
335
|
+
super.ngOnInit();
|
|
336
|
+
const greaterValidatorSubscriptions = [
|
|
337
|
+
initGreaterValidator('cpu', this.form),
|
|
338
|
+
initGreaterValidator('memory', this.form),
|
|
339
|
+
];
|
|
340
|
+
this.destroy$.subscribe(() => {
|
|
341
|
+
greaterValidatorSubscriptions.forEach(sub => sub.unsubscribe());
|
|
342
|
+
});
|
|
343
|
+
}
|
|
344
|
+
createForm() {
|
|
345
|
+
return this.fb.group({
|
|
346
|
+
limits: this.fb.group({
|
|
347
|
+
cpu: this.fb.group({
|
|
348
|
+
value: '',
|
|
349
|
+
unit: 'c',
|
|
350
|
+
}, {
|
|
351
|
+
validators: [
|
|
352
|
+
this.minValidator(this.limitCpuMin, 'cpu'),
|
|
353
|
+
this.maxValidator(this.limitCpuMax, 'cpu'),
|
|
354
|
+
],
|
|
355
|
+
}),
|
|
356
|
+
memory: this.fb.group({
|
|
357
|
+
value: '',
|
|
358
|
+
unit: 'Mi',
|
|
359
|
+
}, {
|
|
360
|
+
validators: [
|
|
361
|
+
this.minValidator(this.limitMemoryMin, 'memory'),
|
|
362
|
+
this.maxValidator(this.limitMemoryMax, 'memory'),
|
|
363
|
+
],
|
|
364
|
+
}),
|
|
365
|
+
}),
|
|
366
|
+
requests: this.fb.group({
|
|
367
|
+
cpu: this.fb.group({
|
|
368
|
+
value: '',
|
|
369
|
+
unit: 'c',
|
|
370
|
+
}, {
|
|
371
|
+
validators: [
|
|
372
|
+
this.minValidator(this.requestCpuMin, 'cpu'),
|
|
373
|
+
this.maxValidator(this.requestCpuMax, 'cpu'),
|
|
374
|
+
],
|
|
375
|
+
}),
|
|
376
|
+
memory: this.fb.group({
|
|
377
|
+
value: '',
|
|
378
|
+
unit: 'Mi',
|
|
379
|
+
}, {
|
|
380
|
+
validators: [
|
|
381
|
+
this.minValidator(this.requestMemoryMin, 'memory'),
|
|
382
|
+
this.maxValidator(this.requestMemoryMax, 'memory'),
|
|
383
|
+
],
|
|
384
|
+
}),
|
|
385
|
+
}),
|
|
386
|
+
});
|
|
387
|
+
}
|
|
388
|
+
getDefaultFormModel() {
|
|
389
|
+
return {
|
|
390
|
+
limits: {
|
|
391
|
+
cpu: {
|
|
392
|
+
value: '',
|
|
393
|
+
unit: 'c',
|
|
394
|
+
},
|
|
395
|
+
memory: {
|
|
396
|
+
value: '',
|
|
397
|
+
unit: 'Mi',
|
|
398
|
+
},
|
|
399
|
+
},
|
|
400
|
+
requests: {
|
|
401
|
+
cpu: {
|
|
402
|
+
value: '',
|
|
403
|
+
unit: 'c',
|
|
404
|
+
},
|
|
405
|
+
memory: {
|
|
406
|
+
value: '',
|
|
407
|
+
unit: 'Mi',
|
|
408
|
+
},
|
|
409
|
+
},
|
|
410
|
+
};
|
|
411
|
+
}
|
|
412
|
+
adaptFormModel(formModel) {
|
|
413
|
+
this.formatFormModel(formModel);
|
|
414
|
+
return {
|
|
415
|
+
requests: transferResource(formModel.requests),
|
|
416
|
+
limits: transferResource(formModel.limits),
|
|
417
|
+
};
|
|
418
|
+
}
|
|
419
|
+
minValidator(min, type) {
|
|
420
|
+
return (group) => {
|
|
421
|
+
if (!min) {
|
|
422
|
+
return null;
|
|
423
|
+
}
|
|
424
|
+
const valueCtrl = group.get('value');
|
|
425
|
+
const currentValue = getCurrentValue(group, type);
|
|
426
|
+
const minThreshold = valueFormat(type, min);
|
|
427
|
+
if (currentValue < minThreshold) {
|
|
428
|
+
return handleValidationErrors(valueCtrl, { min: true });
|
|
429
|
+
}
|
|
430
|
+
const errors = omit(valueCtrl.errors, 'min');
|
|
431
|
+
valueCtrl.setErrors(isEmpty(errors) ? null : errors);
|
|
432
|
+
return null;
|
|
433
|
+
};
|
|
434
|
+
}
|
|
435
|
+
maxValidator(max, type) {
|
|
436
|
+
return (group) => {
|
|
437
|
+
if (!max) {
|
|
438
|
+
return null;
|
|
439
|
+
}
|
|
440
|
+
const valueCtrl = group.get('value');
|
|
441
|
+
const currentValue = getCurrentValue(group, type);
|
|
442
|
+
const maxThreshold = valueFormat(type, max);
|
|
443
|
+
if (currentValue > maxThreshold) {
|
|
444
|
+
return handleValidationErrors(valueCtrl, { max: true });
|
|
445
|
+
}
|
|
446
|
+
const errors = omit(valueCtrl.errors, 'max');
|
|
447
|
+
valueCtrl.setErrors(isEmpty(errors) ? null : errors);
|
|
448
|
+
return null;
|
|
449
|
+
};
|
|
450
|
+
}
|
|
451
|
+
formatFormModel(formModel) {
|
|
452
|
+
Object.values(formModel).forEach(modelValue => {
|
|
453
|
+
Object.values(modelValue).forEach(v => {
|
|
454
|
+
v.value = `${v.value}`;
|
|
455
|
+
});
|
|
456
|
+
});
|
|
457
|
+
}
|
|
458
|
+
getCpuUnitLabel(value) {
|
|
459
|
+
return value === 'm'
|
|
460
|
+
? ''
|
|
461
|
+
: resourceUnits.cpu.find(unit => unit.value === value).label;
|
|
462
|
+
}
|
|
463
|
+
adaptResourceModel(resources) {
|
|
464
|
+
const resourcesModel = {};
|
|
465
|
+
if (resources) {
|
|
466
|
+
Object.keys(resources).forEach(kind => {
|
|
467
|
+
const resourceKind = kind;
|
|
468
|
+
resourcesModel[resourceKind] = Object.keys(resources[resourceKind])
|
|
469
|
+
.filter(key => RESOURCE_MAC_TYPES.includes(key))
|
|
470
|
+
.reduce((item, type) => {
|
|
471
|
+
const resourceType = type;
|
|
472
|
+
item[resourceType] = getResourceViewModel(resources[resourceKind][resourceType], resourceType);
|
|
473
|
+
return item;
|
|
474
|
+
}, {});
|
|
475
|
+
});
|
|
476
|
+
}
|
|
477
|
+
return merge(this.getDefaultFormModel(), resourcesModel);
|
|
478
|
+
}
|
|
479
|
+
getMinOrMaxErrorsMapper(value, kind, type, _locale) {
|
|
480
|
+
const resourceCtrl = getResourceViewModel(value, type);
|
|
481
|
+
return this.translate.get(`warning_${kind}`, {
|
|
482
|
+
value: resourceCtrl.value + this.translate.get(resourceCtrl.unit),
|
|
483
|
+
});
|
|
484
|
+
}
|
|
485
|
+
static { this.ɵfac = function ResourceRequirementsComponent_Factory(t) { return new (t || ResourceRequirementsComponent)(i0.ɵɵdirectiveInject(i0.Injector), i0.ɵɵdirectiveInject(i1.OperandFieldComponent, 8), i0.ɵɵdirectiveInject(i2.ControlContainer, 8), i0.ɵɵdirectiveInject(i3.TranslateService)); }; }
|
|
486
|
+
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: ResourceRequirementsComponent, selectors: [["acl-crd-resource-requirements"]], inputs: { readOnly: "readOnly", field: "field" }, features: [i0.ɵɵInheritDefinitionFeature], decls: 3, vars: 2, consts: [["readOnlyTemplate", ""], [3, "formGroup", 4, "ngIf", "ngIfElse"], [3, "formGroup"], [1, "resource_requirements"], [1, "input-group-label"], ["formGroupName", "requests", 1, "input-group-wrapper", "tw-items-start"], [1, "tw-flex", "tw-flex-col", "tw-flex-1"], ["formGroupName", "cpu", 1, "input-groups-wrapper", "cpu"], ["auiInputAddonBefore", "", 1, "addon-label", 3, "ngClass"], ["aui-input", "", "type", "number", "auiFormItemControl", "", "formControlName", "value", 3, "required"], ["auiInputAddonAfter", "", "auiFormItemControl", "", "formControlName", "unit"], [3, "value", "label", 4, "ngFor", "ngForOf"], ["class", "tw-text-s tw-text-red", 3, "errors", "errorsMapper", 4, "ngIf"], [1, "input-groups-wrapper", "memory", 3, "formGroupName"], [3, "value", 4, "ngFor", "ngForOf"], ["formGroupName", "limits", 1, "input-group-wrapper", "tw-items-start"], [1, "input-groups-wrapper", "cpu", 3, "formGroupName"], [3, "value", "label"], [1, "tw-text-s", "tw-text-red", 3, "errors", "errorsMapper"], [3, "value"], [1, "resource_requirements-display"], [1, "resource_requirements-display-item"], [1, "resource_requirements-display-item__label"], ["icon", "prod:cpu", "size", "16px", "color", "#6359b4", "margin", "right", 3, "title"], [1, "tw-mr-16"], ["icon", "prod:memory", "size", "16px", "color", "#007cb5", "margin", "right", 3, "title"]], template: function ResourceRequirementsComponent_Template(rf, ctx) { if (rf & 1) {
|
|
487
|
+
i0.ɵɵtemplate(0, ResourceRequirementsComponent_form_0_Template, 49, 40, "form", 1)(1, ResourceRequirementsComponent_ng_template_1_Template, 35, 54, "ng-template", null, 0, i0.ɵɵtemplateRefExtractor);
|
|
488
|
+
} if (rf & 2) {
|
|
489
|
+
const readOnlyTemplate_r6 = i0.ɵɵreference(2);
|
|
490
|
+
i0.ɵɵproperty("ngIf", !ctx.readOnly)("ngIfElse", readOnlyTemplate_r6);
|
|
491
|
+
} }, dependencies: [i4.NgClass, i4.NgForOf, i4.NgIf, i2.ɵNgNoValidate, i2.DefaultValueAccessor, i2.NumberValueAccessor, i2.NgControlStatus, i2.NgControlStatusGroup, i2.RequiredValidator, i2.FormGroupDirective, i2.FormControlName, i2.FormGroupName, i5.FormItemControlDirective, i5.IconComponent, i5.InputComponent, i5.InputGroupComponent, i5.InputAddonBeforeDirective, i5.InputAddonAfterDirective, i5.SelectComponent, i5.OptionComponent, i3.ErrorsMapperComponent, i3.ValidatorsDirective, i3.TranslatePipe, i3.FieldNotAvailablePipe, i3.PurePipe], styles: ["[_nghost-%COMP%] .resource_requirements[_ngcontent-%COMP%]:not(:last-of-type){margin-bottom:8px}[_nghost-%COMP%] .input-group-wrapper[_ngcontent-%COMP%]{display:flex}[_nghost-%COMP%] .input-group-label[_ngcontent-%COMP%]{line-height:var(--aui-inline-height-m)}[_nghost-%COMP%] aui-input-group[_ngcontent-%COMP%]{flex:1}[_nghost-%COMP%] aui-input-group[_ngcontent-%COMP%] .aui-input-group__addon--after{padding:0}[_nghost-%COMP%] aui-input-group[_ngcontent-%COMP%] .aui-input-group__addon--after aui-select{width:60px}[_nghost-%COMP%] aui-input-group[_ngcontent-%COMP%] .aui-input-group__addon--after aui-select .aui-input-group{width:62px}html:not([lang|=zh]) [_nghost-%COMP%] aui-input-group[_ngcontent-%COMP%] .aui-input-group__addon--after aui-select{width:78px}html:not([lang|=zh]) [_nghost-%COMP%] aui-input-group[_ngcontent-%COMP%] .aui-input-group__addon--after aui-select .aui-input-group{width:80px}[_nghost-%COMP%] aui-input-group[_ngcontent-%COMP%] .aui-input-group__addon--after aui-select .aui-input{border:0;background-color:transparent!important;border-top-right-radius:var(--aui-border-radius-m);border-bottom-right-radius:var(--aui-border-radius-m)}[_nghost-%COMP%] .addon-label[_ngcontent-%COMP%]{white-space:nowrap}[_nghost-%COMP%] .input-groups-wrapper[_ngcontent-%COMP%]{display:flex;flex:1;align-items:center}[_nghost-%COMP%] .input-groups-wrapper[_ngcontent-%COMP%]:first-child{margin-right:8px}[_nghost-%COMP%] .resource_requirements-display-item[_ngcontent-%COMP%]{display:flex;font-size:14px;line-height:20px;color:rgb(var(--aui-color-main-text));align-items:center;margin-top:8px}[_nghost-%COMP%] .resource_requirements-display-item[_ngcontent-%COMP%]:first-child{margin-top:0}[_nghost-%COMP%] .resource_requirements-display-item__label[_ngcontent-%COMP%]{white-space:nowrap;margin-right:8px}[_nghost-%COMP%] .resource_requirements-display-item__value[_ngcontent-%COMP%]{min-width:0;flex:1;white-space:nowrap;display:flex}[_nghost-%COMP%] .resource_requirements-display-item__value__overflow[_ngcontent-%COMP%]{display:block;overflow:hidden;text-overflow:ellipsis}[_nghost-%COMP%] .resource_requirements-display-item__value__wrap[_ngcontent-%COMP%]{white-space:pre-wrap;flex-wrap:wrap}[_nghost-%COMP%] .resource_requirements-display-item__label[_ngcontent-%COMP%], [_nghost-%COMP%] .resource_requirements-display-item__value[_ngcontent-%COMP%]{height:100%;align-items:flex-start}[_nghost-%COMP%] .aui-input-group__addon--before{width:70px}html:not([lang|=zh]) [_nghost-%COMP%] .memory .aui-input-group__addon--before{width:82px}"], changeDetection: 0 }); }
|
|
492
|
+
}
|
|
493
|
+
__decorate([
|
|
494
|
+
bind,
|
|
495
|
+
__metadata("design:type", Function),
|
|
496
|
+
__metadata("design:paramtypes", [String, String]),
|
|
497
|
+
__metadata("design:returntype", void 0)
|
|
498
|
+
], ResourceRequirementsComponent.prototype, "minValidator", null);
|
|
499
|
+
__decorate([
|
|
500
|
+
bind,
|
|
501
|
+
__metadata("design:type", Function),
|
|
502
|
+
__metadata("design:paramtypes", [String, String]),
|
|
503
|
+
__metadata("design:returntype", void 0)
|
|
504
|
+
], ResourceRequirementsComponent.prototype, "maxValidator", null);
|
|
505
|
+
__decorate([
|
|
506
|
+
bind,
|
|
507
|
+
__metadata("design:type", Function),
|
|
508
|
+
__metadata("design:paramtypes", [String, String, String, String]),
|
|
509
|
+
__metadata("design:returntype", void 0)
|
|
510
|
+
], ResourceRequirementsComponent.prototype, "getMinOrMaxErrorsMapper", null);
|
|
511
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ResourceRequirementsComponent, [{
|
|
512
|
+
type: Component,
|
|
513
|
+
args: [{ selector: 'acl-crd-resource-requirements', changeDetection: ChangeDetectionStrategy.OnPush, template: "<form\n [formGroup]=\"form\"\n *ngIf=\"!readOnly; else readOnlyTemplate\"\n>\n <div class=\"resource_requirements\">\n <div class=\"input-group-label\">\n {{ 'resource_requirements_requests' | translate }}\n </div>\n <div\n class=\"input-group-wrapper tw-items-start\"\n formGroupName=\"requests\"\n >\n <div class=\"tw-flex tw-flex-col tw-flex-1\">\n <div\n class=\"input-groups-wrapper cpu\"\n formGroupName=\"cpu\"\n >\n <aui-input-group>\n <div\n auiInputAddonBefore\n class=\"addon-label\"\n [ngClass]=\"{\n 'tw-required-mark': requestCpuRequired\n }\"\n >\n CPU\n </div>\n <input\n aui-input\n type=\"number\"\n [required]=\"requestCpuRequired\"\n auiFormItemControl\n formControlName=\"value\"\n />\n <aui-select\n auiInputAddonAfter\n auiFormItemControl\n formControlName=\"unit\"\n >\n <aui-option\n *ngFor=\"let unit of resourceUnits['cpu']\"\n [value]=\"unit.value\"\n [label]=\"unit.label | translate\"\n >\n {{ unit.label | translate }}\n </aui-option>\n </aui-select>\n </aui-input-group>\n </div>\n <acl-errors-mapper\n *ngIf=\"\n form.get('requests.cpu.value')?.dirty ||\n $any(controlContainer?.formDirective)?.submitted\n \"\n [errors]=\"form.get('requests.cpu.value').errors\"\n [errorsMapper]=\"{\n min: requestCpuMin | pure: getMinOrMaxErrorsMapper: 'min': 'cpu': translate.locale,\n max: requestCpuMax | pure: getMinOrMaxErrorsMapper: 'max': 'cpu': translate.locale,\n }\"\n class=\"tw-text-s tw-text-red\"\n >\n </acl-errors-mapper>\n </div>\n\n <div class=\"tw-flex tw-flex-col tw-flex-1\">\n <div\n class=\"input-groups-wrapper memory\"\n [formGroupName]=\"'memory'\"\n >\n <aui-input-group>\n <div\n auiInputAddonBefore\n class=\"addon-label\"\n [ngClass]=\"{\n 'tw-required-mark': requestMemoryRequired\n }\"\n >\n {{ 'memory' | translate }}\n </div>\n <input\n aui-input\n type=\"number\"\n auiFormItemControl\n formControlName=\"value\"\n [required]=\"requestMemoryRequired\"\n />\n <aui-select\n auiInputAddonAfter\n auiFormItemControl\n formControlName=\"unit\"\n >\n <aui-option\n *ngFor=\"let unit of resourceUnits['memory']\"\n [value]=\"unit\"\n >\n {{ unit }}\n </aui-option>\n </aui-select>\n </aui-input-group>\n </div>\n <acl-errors-mapper\n *ngIf=\"\n form.get('requests.memory.value')?.dirty ||\n $any(controlContainer?.formDirective)?.submitted\n \"\n [errors]=\"form.get('requests.memory.value').errors\"\n [errorsMapper]=\"{\n min: requestMemoryMin | pure: getMinOrMaxErrorsMapper: 'min': 'memory': translate.locale,\n max: requestMemoryMax | pure: getMinOrMaxErrorsMapper: 'max': 'memory': translate.locale ,\n }\"\n class=\"tw-text-s tw-text-red\"\n >\n </acl-errors-mapper>\n </div>\n </div>\n </div>\n <div class=\"resource_requirements\">\n <div class=\"input-group-label\">\n {{ 'resource_requirements_limits' | translate }}\n </div>\n <div\n class=\"input-group-wrapper tw-items-start\"\n formGroupName=\"limits\"\n >\n <div class=\"tw-flex tw-flex-col tw-flex-1\">\n <div\n class=\"input-groups-wrapper cpu\"\n [formGroupName]=\"'cpu'\"\n >\n <aui-input-group>\n <div\n auiInputAddonBefore\n class=\"addon-label\"\n [ngClass]=\"{\n 'tw-required-mark': limitCpuRequired\n }\"\n >\n CPU\n </div>\n <input\n aui-input\n type=\"number\"\n auiFormItemControl\n formControlName=\"value\"\n [required]=\"limitCpuRequired\"\n />\n <aui-select\n auiInputAddonAfter\n auiFormItemControl\n formControlName=\"unit\"\n >\n <aui-option\n *ngFor=\"let unit of resourceUnits['cpu']\"\n [value]=\"unit.value\"\n [label]=\"unit.label | translate\"\n >\n {{ unit.label | translate }}\n </aui-option>\n </aui-select>\n </aui-input-group>\n </div>\n <acl-errors-mapper\n *ngIf=\"\n form.get('limits.cpu.value')?.dirty ||\n $any(controlContainer?.formDirective)?.submitted\n \"\n [errors]=\"form.get('limits.cpu.value').errors\"\n [errorsMapper]=\"{\n cpu_max: 'request_greater_than_limits_error' | translate,\n min: limitCpuMin | pure: getMinOrMaxErrorsMapper: 'min': 'cpu': translate.locale,\n max: limitCpuMax | pure: getMinOrMaxErrorsMapper: 'max': 'cpu': translate.locale \n }\"\n class=\"tw-text-s tw-text-red\"\n >\n </acl-errors-mapper>\n </div>\n\n <div class=\"tw-flex tw-flex-col tw-flex-1\">\n <div\n class=\"input-groups-wrapper memory\"\n [formGroupName]=\"'memory'\"\n >\n <aui-input-group>\n <div\n auiInputAddonBefore\n class=\"addon-label\"\n [ngClass]=\"{\n 'tw-required-mark': limitMemoryRequired\n }\"\n >\n {{ 'memory' | translate }}\n </div>\n <input\n aui-input\n type=\"number\"\n auiFormItemControl\n formControlName=\"value\"\n [required]=\"limitMemoryRequired\"\n />\n <aui-select\n auiInputAddonAfter\n auiFormItemControl\n formControlName=\"unit\"\n >\n <aui-option\n *ngFor=\"let unit of resourceUnits['memory']\"\n [value]=\"unit\"\n >\n {{ unit }}\n </aui-option>\n </aui-select>\n </aui-input-group>\n </div>\n <acl-errors-mapper\n *ngIf=\"\n form.get('limits.memory.value')?.dirty ||\n $any(controlContainer?.formDirective)?.submitted\n \"\n [errors]=\"form.get('limits.memory.value').errors\"\n [errorsMapper]=\"{\n memory_max: 'request_greater_than_limits_error' | translate,\n min: limitMemoryMin | pure: getMinOrMaxErrorsMapper: 'min': 'memory': translate.locale,\n max: limitMemoryMax | pure: getMinOrMaxErrorsMapper: 'max': 'memory': translate.locale ,\n }\"\n class=\"tw-text-s tw-text-red\"\n >\n </acl-errors-mapper>\n </div>\n </div>\n </div>\n</form>\n\n<ng-template #readOnlyTemplate>\n <div class=\"resource_requirements-display\">\n <div class=\"resource_requirements-display-item\">\n <label class=\"resource_requirements-display-item__label\">{{\n 'resource_requirements_requests' | translate\n }}</label>\n <aui-icon\n icon=\"prod:cpu\"\n size=\"16px\"\n color=\"#6359b4\"\n margin=\"right\"\n [title]=\"'cpu' | translate\"\n ></aui-icon\n ><span class=\"tw-mr-16\"\n >{{\n form.get('requests').get('cpu').value\n | pure: getResourceValue\n | aclFieldNotAvailable\n }}{{\n form.get('requests').get('cpu.unit').value\n | pure: getCpuUnitLabel\n | translate\n }}\n </span>\n <aui-icon\n icon=\"prod:memory\"\n size=\"16px\"\n color=\"#007cb5\"\n margin=\"right\"\n [title]=\"'memory' | translate\"\n ></aui-icon\n >{{\n form.get('requests').get('memory').value\n | pure: getResourceValue\n | aclFieldNotAvailable\n }}\n </div>\n <div class=\"resource_requirements-display-item\">\n <label class=\"resource_requirements-display-item__label\">{{\n 'resource_requirements_limits' | translate\n }}</label>\n <aui-icon\n icon=\"prod:cpu\"\n size=\"16px\"\n color=\"#6359b4\"\n margin=\"right\"\n [title]=\"'cpu' | translate\"\n ></aui-icon\n ><span class=\"tw-mr-16\"\n >{{\n form.get('limits').get('cpu').value\n | pure: getResourceValue\n | aclFieldNotAvailable\n }}{{\n form.get('limits').get('cpu.unit').value\n | pure: getCpuUnitLabel\n | translate\n }}\n </span>\n <aui-icon\n icon=\"prod:memory\"\n size=\"16px\"\n color=\"#007cb5\"\n margin=\"right\"\n [title]=\"'memory' | translate\"\n ></aui-icon\n >{{\n form.get('limits').get('memory').value\n | pure: getResourceValue\n | aclFieldNotAvailable\n }}\n </div>\n </div>\n</ng-template>\n", styles: [":host .resource_requirements:not(:last-of-type){margin-bottom:8px}:host .input-group-wrapper{display:flex}:host .input-group-label{line-height:var(--aui-inline-height-m)}:host aui-input-group{flex:1}:host aui-input-group ::ng-deep .aui-input-group__addon--after{padding:0}:host aui-input-group ::ng-deep .aui-input-group__addon--after aui-select{width:60px}:host aui-input-group ::ng-deep .aui-input-group__addon--after aui-select .aui-input-group{width:62px}html:not([lang|=zh]) :host aui-input-group ::ng-deep .aui-input-group__addon--after aui-select{width:78px}html:not([lang|=zh]) :host aui-input-group ::ng-deep .aui-input-group__addon--after aui-select .aui-input-group{width:80px}:host aui-input-group ::ng-deep .aui-input-group__addon--after aui-select .aui-input{border:0;background-color:transparent!important;border-top-right-radius:var(--aui-border-radius-m);border-bottom-right-radius:var(--aui-border-radius-m)}:host .addon-label{white-space:nowrap}:host .input-groups-wrapper{display:flex;flex:1;align-items:center}:host .input-groups-wrapper:first-child{margin-right:8px}:host .resource_requirements-display-item{display:flex;font-size:14px;line-height:20px;color:rgb(var(--aui-color-main-text));align-items:center;margin-top:8px}:host .resource_requirements-display-item:first-child{margin-top:0}:host .resource_requirements-display-item__label{white-space:nowrap;margin-right:8px}:host .resource_requirements-display-item__value{min-width:0;flex:1;white-space:nowrap;display:flex}:host .resource_requirements-display-item__value__overflow{display:block;overflow:hidden;text-overflow:ellipsis}:host .resource_requirements-display-item__value__wrap{white-space:pre-wrap;flex-wrap:wrap}:host .resource_requirements-display-item__label,:host .resource_requirements-display-item__value{height:100%;align-items:flex-start}:host ::ng-deep .aui-input-group__addon--before{width:70px}html:not([lang|=zh]) :host ::ng-deep .memory .aui-input-group__addon--before{width:82px}\n"] }]
|
|
514
|
+
}], () => [{ type: i0.Injector }, { type: i1.OperandFieldComponent, decorators: [{
|
|
515
|
+
type: Optional
|
|
516
|
+
}] }, { type: i2.ControlContainer, decorators: [{
|
|
517
|
+
type: Optional
|
|
518
|
+
}] }, { type: i3.TranslateService }], { readOnly: [{
|
|
519
|
+
type: Input
|
|
520
|
+
}], field: [{
|
|
521
|
+
type: Input
|
|
522
|
+
}], minValidator: [], maxValidator: [], getMinOrMaxErrorsMapper: [] }); })();
|
|
523
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(ResourceRequirementsComponent, { className: "ResourceRequirementsComponent", filePath: "lib/field-controls/widgets/resource-requirements/resource-requirements.component.ts", lineNumber: 82 }); })();
|
|
524
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resource-requirements.component.js","sourceRoot":"","sources":["../../../../../../../../libs/crd-form/src/lib/field-controls/widgets/resource-requirements/resource-requirements.component.ts","../../../../../../../../libs/crd-form/src/lib/field-controls/widgets/resource-requirements/resource-requirements.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  bind,\n  formatCPU,\n  formatMemory,\n  getResourceValue,\n  getResourceViewModel,\n  initGreaterValidator,\n  RESOURCE_MAC_TYPES,\n  ResourceRequirementFormModal,\n  ResourceRequirementStrict,\n  resourceUnits,\n  transferResource,\n  TranslateService,\n} from '@alauda-fe/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  Injector,\n  Input,\n  OnInit,\n  Optional,\n} from '@angular/core';\nimport {\n  AbstractControl,\n  ControlContainer,\n  FormControl,\n  FormGroup,\n  ValidationErrors,\n} from '@angular/forms';\nimport { merge, omit, isEmpty } from 'lodash-es';\nimport { BaseResourceFormGroupComponent } from 'ng-resource-form-util';\n\nimport { OperandField } from '../../../types';\nimport { getFieldDescription, getFieldDisplayName } from '../../../utils';\nimport { OperandFieldComponent } from '../../operand-field.component';\nimport {\n  resolveRequirementsRequiredOptions,\n  resolveRequirementsMinOrMaxOptions,\n} from '../utils';\n\ntype AvailableResourceType = (typeof RESOURCE_MAC_TYPES)[number];\ntype ResourceKind = keyof ResourceRequirementFormModal;\n\ninterface ResourceControl {\n  value: string;\n  unit: string;\n}\n\nfunction handleValidationErrors(\n  valueCtrl: AbstractControl,\n  errors: ValidationErrors,\n): ValidationErrors | null {\n  // 这里避免覆盖其它 errors\n  const combinedErrors = { ...valueCtrl.errors, ...errors };\n  valueCtrl.setErrors(combinedErrors);\n  return combinedErrors;\n}\n\nfunction valueFormat(type: 'cpu' | 'memory', value: string) {\n  return type === 'cpu' ? formatCPU(value) : formatMemory(value);\n}\n\nfunction getCurrentValue(\n  group: FormGroup<{\n    value: FormControl<string>;\n    unit: FormControl<string>;\n  }>,\n  type: 'cpu' | 'memory',\n): number {\n  const valueCtrl = group.get('value');\n  const value = valueCtrl.value;\n  const unit = group.get('unit').value;\n  return valueFormat(type, (value || 0) + unit);\n}\n\n@Component({\n  selector: 'acl-crd-resource-requirements',\n  templateUrl: 'resource-requirements.component.html',\n  styleUrls: ['resource-requirements.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ResourceRequirementsComponent\n  extends BaseResourceFormGroupComponent<\n    ResourceRequirementStrict,\n    ResourceRequirementFormModal\n  >\n  implements OnInit\n{\n  @Input()\n  readOnly: boolean;\n\n  @Input()\n  field: OperandField;\n\n  get requiredOptions() {\n    return resolveRequirementsRequiredOptions(this.fieldComponent?.field);\n  }\n\n  get limitMemoryRequired() {\n    return this.requiredOptions.required?.limit?.includes('memory');\n  }\n\n  get limitCpuRequired() {\n    return this.requiredOptions.required?.limit?.includes('cpu');\n  }\n\n  get requestMemoryRequired() {\n    return this.requiredOptions.required?.request?.includes('memory');\n  }\n\n  get requestCpuRequired() {\n    return this.requiredOptions.required?.request?.includes('cpu');\n  }\n\n  get minMaxOptions() {\n    return resolveRequirementsMinOrMaxOptions(this.fieldComponent?.field);\n  }\n\n  get limitMemoryMin() {\n    return this.minMaxOptions.min.limits?.memory;\n  }\n\n  get limitCpuMin() {\n    return this.minMaxOptions.min.limits?.cpu;\n  }\n\n  get requestMemoryMin() {\n    return this.minMaxOptions.min.requests?.memory;\n  }\n\n  get requestCpuMin() {\n    return this.minMaxOptions.min.requests?.cpu;\n  }\n\n  get limitMemoryMax() {\n    return this.minMaxOptions.max.limits?.memory;\n  }\n\n  get limitCpuMax() {\n    return this.minMaxOptions.max.limits?.cpu;\n  }\n\n  get requestMemoryMax() {\n    return this.minMaxOptions.max.requests?.memory;\n  }\n\n  get requestCpuMax() {\n    return this.minMaxOptions.max.requests?.cpu;\n  }\n\n  resourceUnits = resourceUnits;\n  getFieldDisplayName = getFieldDisplayName;\n  getFieldDescription = getFieldDescription;\n  getResourceValue = getResourceValue;\n  getResourceViewModel = getResourceViewModel;\n\n  constructor(\n    injector: Injector,\n    @Optional()\n    private readonly fieldComponent: OperandFieldComponent,\n    @Optional()\n    public readonly controlContainer: ControlContainer,\n    public readonly translate: TranslateService,\n  ) {\n    super(injector);\n  }\n\n  override ngOnInit() {\n    super.ngOnInit();\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  createForm() {\n    return this.fb.group({\n      limits: this.fb.group({\n        cpu: this.fb.group(\n          {\n            value: '',\n            unit: 'c',\n          },\n          {\n            validators: [\n              this.minValidator(this.limitCpuMin, 'cpu'),\n              this.maxValidator(this.limitCpuMax, 'cpu'),\n            ],\n          },\n        ),\n        memory: this.fb.group(\n          {\n            value: '',\n            unit: 'Mi',\n          },\n          {\n            validators: [\n              this.minValidator(this.limitMemoryMin, 'memory'),\n              this.maxValidator(this.limitMemoryMax, 'memory'),\n            ],\n          },\n        ),\n      }),\n      requests: this.fb.group({\n        cpu: this.fb.group(\n          {\n            value: '',\n            unit: 'c',\n          },\n          {\n            validators: [\n              this.minValidator(this.requestCpuMin, 'cpu'),\n              this.maxValidator(this.requestCpuMax, 'cpu'),\n            ],\n          },\n        ),\n        memory: this.fb.group(\n          {\n            value: '',\n            unit: 'Mi',\n          },\n          {\n            validators: [\n              this.minValidator(this.requestMemoryMin, 'memory'),\n              this.maxValidator(this.requestMemoryMax, 'memory'),\n            ],\n          },\n        ),\n      }),\n    });\n  }\n\n  override getDefaultFormModel(): ResourceRequirementFormModal {\n    return {\n      limits: {\n        cpu: {\n          value: '',\n          unit: 'c',\n        },\n        memory: {\n          value: '',\n          unit: 'Mi',\n        },\n      },\n      requests: {\n        cpu: {\n          value: '',\n          unit: 'c',\n        },\n        memory: {\n          value: '',\n          unit: 'Mi',\n        },\n      },\n    };\n  }\n\n  override adaptFormModel(\n    formModel: ResourceRequirementFormModal,\n  ): ResourceRequirementStrict {\n    this.formatFormModel(formModel);\n    return {\n      requests: transferResource(formModel.requests),\n      limits: transferResource(formModel.limits),\n    };\n  }\n\n  @bind\n  private minValidator(min: string, type: 'cpu' | 'memory') {\n    return (\n      group: FormGroup<{\n        value: FormControl<string>;\n        unit: FormControl<string>;\n      }>,\n    ): ValidationErrors => {\n      if (!min) {\n        return null;\n      }\n\n      const valueCtrl = group.get('value');\n      const currentValue = getCurrentValue(group, type);\n      const minThreshold = valueFormat(type, min);\n\n      if (currentValue < minThreshold) {\n        return handleValidationErrors(valueCtrl, { min: true });\n      }\n      const errors = omit(valueCtrl.errors, 'min');\n      valueCtrl.setErrors(isEmpty(errors) ? null : errors);\n      return null;\n    };\n  }\n\n  @bind\n  private maxValidator(max: string, type: 'cpu' | 'memory') {\n    return (\n      group: FormGroup<{\n        value: FormControl<string>;\n        unit: FormControl<string>;\n      }>,\n    ): ValidationErrors => {\n      if (!max) {\n        return null;\n      }\n\n      const valueCtrl = group.get('value');\n      const currentValue = getCurrentValue(group, type);\n      const maxThreshold = valueFormat(type, max);\n\n      if (currentValue > maxThreshold) {\n        return handleValidationErrors(valueCtrl, { max: true });\n      }\n\n      const errors = omit(valueCtrl.errors, 'max');\n      valueCtrl.setErrors(isEmpty(errors) ? null : errors);\n      return null;\n    };\n  }\n\n  formatFormModel(formModel: ResourceRequirementFormModal) {\n    Object.values(formModel).forEach(modelValue => {\n      Object.values(modelValue).forEach(v => {\n        v.value = `${v.value}`;\n      });\n    });\n  }\n\n  getCpuUnitLabel(value: 'm' | 'c') {\n    return value === 'm'\n      ? ''\n      : resourceUnits.cpu.find(unit => unit.value === value).label;\n  }\n\n  override adaptResourceModel(\n    resources: ResourceRequirementStrict,\n  ): ResourceRequirementFormModal {\n    const resourcesModel = {} as ResourceRequirementFormModal;\n    if (resources) {\n      Object.keys(resources).forEach(kind => {\n        const resourceKind = kind as ResourceKind;\n        resourcesModel[resourceKind] = Object.keys(resources[resourceKind])\n          .filter(key =>\n            RESOURCE_MAC_TYPES.includes(key as AvailableResourceType),\n          )\n          .reduce((item, type) => {\n            const resourceType = type as AvailableResourceType;\n            item[resourceType] = getResourceViewModel(\n              resources[resourceKind][resourceType],\n              resourceType,\n            );\n            return item;\n          }, {} as Record<AvailableResourceType, ResourceControl>);\n      });\n    }\n    return merge(this.getDefaultFormModel(), resourcesModel);\n  }\n\n  @bind\n  getMinOrMaxErrorsMapper(\n    value: string,\n    kind: 'min' | 'max',\n    type: 'cpu' | 'memory',\n    _locale: string,\n  ) {\n    const resourceCtrl = getResourceViewModel(value, type);\n    return this.translate.get(`warning_${kind}`, {\n      value: resourceCtrl.value + this.translate.get(resourceCtrl.unit),\n    });\n  }\n}\n","<form\n  [formGroup]=\"form\"\n  *ngIf=\"!readOnly; else readOnlyTemplate\"\n>\n  <div class=\"resource_requirements\">\n    <div class=\"input-group-label\">\n      {{ 'resource_requirements_requests' | translate }}\n    </div>\n    <div\n      class=\"input-group-wrapper tw-items-start\"\n      formGroupName=\"requests\"\n    >\n      <div class=\"tw-flex tw-flex-col tw-flex-1\">\n        <div\n          class=\"input-groups-wrapper cpu\"\n          formGroupName=\"cpu\"\n        >\n          <aui-input-group>\n            <div\n              auiInputAddonBefore\n              class=\"addon-label\"\n              [ngClass]=\"{\n                'tw-required-mark': requestCpuRequired\n              }\"\n            >\n              CPU\n            </div>\n            <input\n              aui-input\n              type=\"number\"\n              [required]=\"requestCpuRequired\"\n              auiFormItemControl\n              formControlName=\"value\"\n            />\n            <aui-select\n              auiInputAddonAfter\n              auiFormItemControl\n              formControlName=\"unit\"\n            >\n              <aui-option\n                *ngFor=\"let unit of resourceUnits['cpu']\"\n                [value]=\"unit.value\"\n                [label]=\"unit.label | translate\"\n              >\n                {{ unit.label | translate }}\n              </aui-option>\n            </aui-select>\n          </aui-input-group>\n        </div>\n        <acl-errors-mapper\n          *ngIf=\"\n            form.get('requests.cpu.value')?.dirty ||\n            $any(controlContainer?.formDirective)?.submitted\n          \"\n          [errors]=\"form.get('requests.cpu.value').errors\"\n          [errorsMapper]=\"{\n            min: requestCpuMin | pure: getMinOrMaxErrorsMapper: 'min': 'cpu': translate.locale,\n            max: requestCpuMax | pure: getMinOrMaxErrorsMapper: 'max': 'cpu': translate.locale,\n          }\"\n          class=\"tw-text-s tw-text-red\"\n        >\n        </acl-errors-mapper>\n      </div>\n\n      <div class=\"tw-flex tw-flex-col tw-flex-1\">\n        <div\n          class=\"input-groups-wrapper memory\"\n          [formGroupName]=\"'memory'\"\n        >\n          <aui-input-group>\n            <div\n              auiInputAddonBefore\n              class=\"addon-label\"\n              [ngClass]=\"{\n                'tw-required-mark': requestMemoryRequired\n              }\"\n            >\n              {{ 'memory' | translate }}\n            </div>\n            <input\n              aui-input\n              type=\"number\"\n              auiFormItemControl\n              formControlName=\"value\"\n              [required]=\"requestMemoryRequired\"\n            />\n            <aui-select\n              auiInputAddonAfter\n              auiFormItemControl\n              formControlName=\"unit\"\n            >\n              <aui-option\n                *ngFor=\"let unit of resourceUnits['memory']\"\n                [value]=\"unit\"\n              >\n                {{ unit }}\n              </aui-option>\n            </aui-select>\n          </aui-input-group>\n        </div>\n        <acl-errors-mapper\n          *ngIf=\"\n            form.get('requests.memory.value')?.dirty ||\n            $any(controlContainer?.formDirective)?.submitted\n          \"\n          [errors]=\"form.get('requests.memory.value').errors\"\n          [errorsMapper]=\"{\n            min: requestMemoryMin | pure: getMinOrMaxErrorsMapper: 'min': 'memory': translate.locale,\n            max: requestMemoryMax | pure: getMinOrMaxErrorsMapper: 'max': 'memory': translate.locale ,\n          }\"\n          class=\"tw-text-s tw-text-red\"\n        >\n        </acl-errors-mapper>\n      </div>\n    </div>\n  </div>\n  <div class=\"resource_requirements\">\n    <div class=\"input-group-label\">\n      {{ 'resource_requirements_limits' | translate }}\n    </div>\n    <div\n      class=\"input-group-wrapper tw-items-start\"\n      formGroupName=\"limits\"\n    >\n      <div class=\"tw-flex tw-flex-col tw-flex-1\">\n        <div\n          class=\"input-groups-wrapper cpu\"\n          [formGroupName]=\"'cpu'\"\n        >\n          <aui-input-group>\n            <div\n              auiInputAddonBefore\n              class=\"addon-label\"\n              [ngClass]=\"{\n                'tw-required-mark': limitCpuRequired\n              }\"\n            >\n              CPU\n            </div>\n            <input\n              aui-input\n              type=\"number\"\n              auiFormItemControl\n              formControlName=\"value\"\n              [required]=\"limitCpuRequired\"\n            />\n            <aui-select\n              auiInputAddonAfter\n              auiFormItemControl\n              formControlName=\"unit\"\n            >\n              <aui-option\n                *ngFor=\"let unit of resourceUnits['cpu']\"\n                [value]=\"unit.value\"\n                [label]=\"unit.label | translate\"\n              >\n                {{ unit.label | translate }}\n              </aui-option>\n            </aui-select>\n          </aui-input-group>\n        </div>\n        <acl-errors-mapper\n          *ngIf=\"\n            form.get('limits.cpu.value')?.dirty ||\n            $any(controlContainer?.formDirective)?.submitted\n          \"\n          [errors]=\"form.get('limits.cpu.value').errors\"\n          [errorsMapper]=\"{\n            cpu_max: 'request_greater_than_limits_error' | translate,\n            min: limitCpuMin | pure: getMinOrMaxErrorsMapper: 'min': 'cpu': translate.locale,\n            max: limitCpuMax | pure: getMinOrMaxErrorsMapper: 'max': 'cpu': translate.locale \n          }\"\n          class=\"tw-text-s tw-text-red\"\n        >\n        </acl-errors-mapper>\n      </div>\n\n      <div class=\"tw-flex tw-flex-col tw-flex-1\">\n        <div\n          class=\"input-groups-wrapper memory\"\n          [formGroupName]=\"'memory'\"\n        >\n          <aui-input-group>\n            <div\n              auiInputAddonBefore\n              class=\"addon-label\"\n              [ngClass]=\"{\n                'tw-required-mark': limitMemoryRequired\n              }\"\n            >\n              {{ 'memory' | translate }}\n            </div>\n            <input\n              aui-input\n              type=\"number\"\n              auiFormItemControl\n              formControlName=\"value\"\n              [required]=\"limitMemoryRequired\"\n            />\n            <aui-select\n              auiInputAddonAfter\n              auiFormItemControl\n              formControlName=\"unit\"\n            >\n              <aui-option\n                *ngFor=\"let unit of resourceUnits['memory']\"\n                [value]=\"unit\"\n              >\n                {{ unit }}\n              </aui-option>\n            </aui-select>\n          </aui-input-group>\n        </div>\n        <acl-errors-mapper\n          *ngIf=\"\n            form.get('limits.memory.value')?.dirty ||\n            $any(controlContainer?.formDirective)?.submitted\n          \"\n          [errors]=\"form.get('limits.memory.value').errors\"\n          [errorsMapper]=\"{\n            memory_max: 'request_greater_than_limits_error' | translate,\n            min: limitMemoryMin | pure: getMinOrMaxErrorsMapper: 'min': 'memory': translate.locale,\n            max: limitMemoryMax | pure: getMinOrMaxErrorsMapper: 'max': 'memory': translate.locale ,\n          }\"\n          class=\"tw-text-s tw-text-red\"\n        >\n        </acl-errors-mapper>\n      </div>\n    </div>\n  </div>\n</form>\n\n<ng-template #readOnlyTemplate>\n  <div class=\"resource_requirements-display\">\n    <div class=\"resource_requirements-display-item\">\n      <label class=\"resource_requirements-display-item__label\">{{\n        'resource_requirements_requests' | translate\n      }}</label>\n      <aui-icon\n        icon=\"prod:cpu\"\n        size=\"16px\"\n        color=\"#6359b4\"\n        margin=\"right\"\n        [title]=\"'cpu' | translate\"\n      ></aui-icon\n      ><span class=\"tw-mr-16\"\n        >{{\n          form.get('requests').get('cpu').value\n            | pure: getResourceValue\n            | aclFieldNotAvailable\n        }}{{\n          form.get('requests').get('cpu.unit').value\n            | pure: getCpuUnitLabel\n            | translate\n        }}\n      </span>\n      <aui-icon\n        icon=\"prod:memory\"\n        size=\"16px\"\n        color=\"#007cb5\"\n        margin=\"right\"\n        [title]=\"'memory' | translate\"\n      ></aui-icon\n      >{{\n        form.get('requests').get('memory').value\n          | pure: getResourceValue\n          | aclFieldNotAvailable\n      }}\n    </div>\n    <div class=\"resource_requirements-display-item\">\n      <label class=\"resource_requirements-display-item__label\">{{\n        'resource_requirements_limits' | translate\n      }}</label>\n      <aui-icon\n        icon=\"prod:cpu\"\n        size=\"16px\"\n        color=\"#6359b4\"\n        margin=\"right\"\n        [title]=\"'cpu' | translate\"\n      ></aui-icon\n      ><span class=\"tw-mr-16\"\n        >{{\n          form.get('limits').get('cpu').value\n            | pure: getResourceValue\n            | aclFieldNotAvailable\n        }}{{\n          form.get('limits').get('cpu.unit').value\n            | pure: getCpuUnitLabel\n            | translate\n        }}\n      </span>\n      <aui-icon\n        icon=\"prod:memory\"\n        size=\"16px\"\n        color=\"#007cb5\"\n        margin=\"right\"\n        [title]=\"'memory' | translate\"\n      ></aui-icon\n      >{{\n        form.get('limits').get('memory').value\n          | pure: getResourceValue\n          | aclFieldNotAvailable\n      }}\n    </div>\n  </div>\n</ng-template>\n"]}
|