@alauda-fe/network 1.0.1 → 1.0.2

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 (62) hide show
  1. package/esm2022/index.mjs +10 -2
  2. package/esm2022/lib/components/certificate-status/component.mjs +7 -6
  3. package/esm2022/lib/components/fixed-ip/component.mjs +134 -91
  4. package/esm2022/lib/components/loadbalancer-spec-form/component.mjs +57 -57
  5. package/esm2022/lib/components/service-annotations-form/annotations.component.mjs +136 -142
  6. package/esm2022/lib/components/service-annotations-form-item/annotations.component.mjs +24 -25
  7. package/esm2022/lib/components/service-form/component.mjs +34 -33
  8. package/esm2022/lib/components/service-form/fieldset/component.mjs +92 -95
  9. package/esm2022/lib/directives/subnet-validator.directive.mjs +5 -5
  10. package/esm2022/lib/features/network-policy/components/add-peer-rule-handler/component.mjs +69 -0
  11. package/esm2022/lib/features/network-policy/components/ip-block-display/component.mjs +54 -0
  12. package/esm2022/lib/features/network-policy/components/label-selector-display/component.mjs +117 -0
  13. package/esm2022/lib/features/network-policy/components/peer-container/component.mjs +81 -0
  14. package/esm2022/lib/features/network-policy/components/pod-review/component.mjs +250 -0
  15. package/esm2022/lib/features/network-policy/components/rule-table/component.mjs +269 -0
  16. package/esm2022/lib/features/network-policy/form/network-policy/component.mjs +429 -0
  17. package/esm2022/lib/features/network-policy/form/network-policy-ip-block/component.mjs +102 -0
  18. package/esm2022/lib/features/network-policy/form/network-policy-peer/component.mjs +247 -0
  19. package/esm2022/lib/features/network-policy/form/network-policy-ports/component.mjs +161 -0
  20. package/esm2022/lib/features/network-policy/form/network-policy-remote-except-input/component.mjs +128 -0
  21. package/esm2022/lib/features/network-policy/form/network-policy-rule/component.mjs +142 -0
  22. package/esm2022/lib/services/alb-api.service.mjs +26 -6
  23. package/esm2022/lib/services/certificate-api.service.mjs +4 -4
  24. package/esm2022/lib/services/network-util.service.mjs +18 -4
  25. package/esm2022/lib/services/subnet-util.service.mjs +121 -0
  26. package/esm2022/lib/types/alb-exports.mjs +1 -1
  27. package/esm2022/lib/types/k8s-exports.mjs +2 -1
  28. package/esm2022/lib/types/metallb-exports.mjs +2 -0
  29. package/esm2022/lib/types/resource-definition.mjs +28 -2
  30. package/esm2022/lib/utils/alb-exports.mjs +1 -1
  31. package/esm2022/lib/utils/cidr-exports.mjs +3 -3
  32. package/esm2022/lib/utils/common-exports.mjs +22 -0
  33. package/esm2022/lib/utils/service-exports.mjs +1 -1
  34. package/esm2022/lib/utils/validators-exports.mjs +44 -0
  35. package/index.d.ts +9 -1
  36. package/lib/components/fixed-ip/component.d.ts +10 -3
  37. package/lib/components/service-annotations-form/annotations.component.d.ts +6 -6
  38. package/lib/components/service-annotations-form-item/annotations.component.d.ts +1 -1
  39. package/lib/components/service-form/component.d.ts +1 -1
  40. package/lib/features/network-policy/components/add-peer-rule-handler/component.d.ts +8 -0
  41. package/lib/features/network-policy/components/ip-block-display/component.d.ts +7 -0
  42. package/lib/features/network-policy/components/label-selector-display/component.d.ts +13 -0
  43. package/lib/features/network-policy/components/peer-container/component.d.ts +18 -0
  44. package/lib/features/network-policy/components/pod-review/component.d.ts +37 -0
  45. package/lib/features/network-policy/components/rule-table/component.d.ts +21 -0
  46. package/lib/features/network-policy/form/network-policy/component.d.ts +70 -0
  47. package/lib/features/network-policy/form/network-policy-ip-block/component.d.ts +23 -0
  48. package/lib/features/network-policy/form/network-policy-peer/component.d.ts +43 -0
  49. package/lib/features/network-policy/form/network-policy-ports/component.d.ts +17 -0
  50. package/lib/features/network-policy/form/network-policy-remote-except-input/component.d.ts +23 -0
  51. package/lib/features/network-policy/form/network-policy-rule/component.d.ts +28 -0
  52. package/lib/services/alb-api.service.d.ts +4 -2
  53. package/lib/services/network-util.service.d.ts +1 -0
  54. package/lib/services/subnet-util.service.d.ts +25 -0
  55. package/lib/types/alb-exports.d.ts +23 -0
  56. package/lib/types/k8s-exports.d.ts +51 -1
  57. package/lib/types/metallb-exports.d.ts +65 -0
  58. package/lib/types/resource-definition.d.ts +143 -0
  59. package/lib/utils/common-exports.d.ts +5 -0
  60. package/lib/utils/validators-exports.d.ts +16 -0
  61. package/package.json +9 -4
  62. package/styles.css +1 -0
@@ -0,0 +1,429 @@
1
+ import { ButtonModule, CheckboxModule, ConfirmType, DialogService, FormModule, IconModule, InputModule, TabsModule, } from '@alauda/ui';
2
+ import { DISPLAY_NAME, DeclareDirective, ERRORS_MAPPER_MODULE, EffectDirectiveModule, K8S_RESOURCE_NAME_START_WITH_CHARS_ONLY, K8sUtilService, KeyValueFormTableComponent, ReadonlyFieldDirective, SPEC, TRANSLATE_MODULE, TranslateService, getK8sResourceLabelErrorMapper$, k8sResourceLabelValidator, } from '@alauda-fe/common';
3
+ import { CommonModule } from '@angular/common';
4
+ import { ChangeDetectionStrategy, Component, Injector, Input, } from '@angular/core';
5
+ import { Validators, ReactiveFormsModule } from '@angular/forms';
6
+ import { has, uniq } from 'lodash-es';
7
+ import { BaseResourceFormGroupComponent } from 'ng-resource-form-util';
8
+ import { PodPreviewComponent } from '../../components/pod-review/component';
9
+ import { NetworkPolicyRuleFormComponent } from '../network-policy-rule/component';
10
+ import * as i0 from "@angular/core";
11
+ import * as i1 from "@alauda-fe/common";
12
+ import * as i2 from "@alauda/ui";
13
+ import * as i3 from "@angular/common";
14
+ import * as i4 from "@angular/forms";
15
+ const _c0 = a0 => ({ pattern: a0 });
16
+ const _c1 = () => ["spec", "podSelector", "matchLabels"];
17
+ const _c2 = a0 => ({ xxx: a0 });
18
+ const _c3 = a0 => ["spec", a0];
19
+ const _c4 = (a0, a1) => ({ policyType: a0, ruleDisabled: a1 });
20
+ function NetworkPolicyFormComponent_ng_template_29_Template(rf, ctx) { if (rf & 1) {
21
+ i0.ɵɵelementStart(0, "span", 17);
22
+ i0.ɵɵtext(1);
23
+ i0.ɵɵpipe(2, "translate");
24
+ i0.ɵɵelementEnd();
25
+ } if (rf & 2) {
26
+ i0.ɵɵadvance();
27
+ i0.ɵɵtextInterpolate(i0.ɵɵpipeBind1(2, 1, "network.target_pod_selector_no_data_tip"));
28
+ } }
29
+ function NetworkPolicyFormComponent_ng_container_31_ng_container_14_ng_container_1_aui_tab_2_ng_container_1_ng_container_1_aui_icon_1_Template(rf, ctx) { if (rf & 1) {
30
+ i0.ɵɵelement(0, "aui-icon", 31);
31
+ } }
32
+ function NetworkPolicyFormComponent_ng_container_31_ng_container_14_ng_container_1_aui_tab_2_ng_container_1_ng_container_1_Template(rf, ctx) { if (rf & 1) {
33
+ i0.ɵɵelementContainerStart(0);
34
+ i0.ɵɵtemplate(1, NetworkPolicyFormComponent_ng_container_31_ng_container_14_ng_container_1_aui_tab_2_ng_container_1_ng_container_1_aui_icon_1_Template, 1, 0, "aui-icon", 30);
35
+ i0.ɵɵelementStart(2, "span");
36
+ i0.ɵɵtext(3);
37
+ i0.ɵɵpipe(4, "translate");
38
+ i0.ɵɵelementEnd();
39
+ i0.ɵɵelementContainerEnd();
40
+ } if (rf & 2) {
41
+ const control_r6 = i0.ɵɵnextContext().ngIf;
42
+ const policyType_r2 = i0.ɵɵnextContext(4).$implicit;
43
+ i0.ɵɵadvance();
44
+ i0.ɵɵproperty("ngIf", control_r6.invalid && control_r6.dirty);
45
+ i0.ɵɵadvance(2);
46
+ i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(4, 2, policyType_r2), " ");
47
+ } }
48
+ function NetworkPolicyFormComponent_ng_container_31_ng_container_14_ng_container_1_aui_tab_2_ng_container_1_Template(rf, ctx) { if (rf & 1) {
49
+ i0.ɵɵelementContainerStart(0);
50
+ i0.ɵɵtemplate(1, NetworkPolicyFormComponent_ng_container_31_ng_container_14_ng_container_1_aui_tab_2_ng_container_1_ng_container_1_Template, 5, 4, "ng-container", 28);
51
+ i0.ɵɵelement(2, "acl-network-policy-rule-form", 29);
52
+ i0.ɵɵelementContainerEnd();
53
+ } if (rf & 2) {
54
+ const control_r6 = ctx.ngIf;
55
+ const policyType_r2 = i0.ɵɵnextContext(4).$implicit;
56
+ const ctx_r2 = i0.ɵɵnextContext();
57
+ i0.ɵɵadvance(2);
58
+ i0.ɵɵproperty("formControl", control_r6)("baseParams", ctx_r2.baseParams)("policyType", policyType_r2);
59
+ } }
60
+ function NetworkPolicyFormComponent_ng_container_31_ng_container_14_ng_container_1_aui_tab_2_Template(rf, ctx) { if (rf & 1) {
61
+ const _r4 = i0.ɵɵgetCurrentView();
62
+ i0.ɵɵelementStart(0, "aui-tab", 27);
63
+ i0.ɵɵlistener("close", function NetworkPolicyFormComponent_ng_container_31_ng_container_14_ng_container_1_aui_tab_2_Template_aui_tab_close_0_listener() { const index_r5 = i0.ɵɵrestoreView(_r4).index; const policyType_r2 = i0.ɵɵnextContext(3).$implicit; const ctx_r2 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r2.removeRule(index_r5, policyType_r2)); });
64
+ i0.ɵɵtemplate(1, NetworkPolicyFormComponent_ng_container_31_ng_container_14_ng_container_1_aui_tab_2_ng_container_1_Template, 3, 3, "ng-container", 24);
65
+ i0.ɵɵelementEnd();
66
+ } if (rf & 2) {
67
+ const item_r7 = ctx.$implicit;
68
+ i0.ɵɵproperty("closeable", true);
69
+ i0.ɵɵadvance();
70
+ i0.ɵɵproperty("ngIf", item_r7);
71
+ } }
72
+ function NetworkPolicyFormComponent_ng_container_31_ng_container_14_ng_container_1_Template(rf, ctx) { if (rf & 1) {
73
+ i0.ɵɵelementContainerStart(0);
74
+ i0.ɵɵelementStart(1, "aui-tab-group", 25);
75
+ i0.ɵɵtemplate(2, NetworkPolicyFormComponent_ng_container_31_ng_container_14_ng_container_1_aui_tab_2_Template, 2, 2, "aui-tab", 26);
76
+ i0.ɵɵelementEnd();
77
+ i0.ɵɵelementContainerEnd();
78
+ } if (rf & 2) {
79
+ const ruleControls_r8 = i0.ɵɵnextContext().declare;
80
+ i0.ɵɵadvance(2);
81
+ i0.ɵɵproperty("ngForOf", ruleControls_r8);
82
+ } }
83
+ function NetworkPolicyFormComponent_ng_container_31_ng_container_14_ng_container_2_Template(rf, ctx) { if (rf & 1) {
84
+ i0.ɵɵelementContainerStart(0);
85
+ i0.ɵɵelementContainer(1, 32);
86
+ i0.ɵɵelementContainerEnd();
87
+ } if (rf & 2) {
88
+ const policyType_r2 = i0.ɵɵnextContext(2).$implicit;
89
+ const ctx_r2 = i0.ɵɵnextContext();
90
+ const emptyTemplate_r9 = i0.ɵɵreference(33);
91
+ i0.ɵɵadvance();
92
+ i0.ɵɵproperty("ngTemplateOutlet", emptyTemplate_r9)("ngTemplateOutletContext", i0.ɵɵpureFunction2(2, _c4, policyType_r2, ctx_r2.ruleDisabledStateMap[policyType_r2]));
93
+ } }
94
+ function NetworkPolicyFormComponent_ng_container_31_ng_container_14_Template(rf, ctx) { if (rf & 1) {
95
+ i0.ɵɵelementContainerStart(0);
96
+ i0.ɵɵtemplate(1, NetworkPolicyFormComponent_ng_container_31_ng_container_14_ng_container_1_Template, 3, 1, "ng-container", 24)(2, NetworkPolicyFormComponent_ng_container_31_ng_container_14_ng_container_2_Template, 2, 5, "ng-container", 24);
97
+ i0.ɵɵelementContainerEnd();
98
+ } if (rf & 2) {
99
+ const ruleControls_r8 = ctx.declare;
100
+ const policyType_r2 = i0.ɵɵnextContext().$implicit;
101
+ const ctx_r2 = i0.ɵɵnextContext();
102
+ i0.ɵɵadvance();
103
+ i0.ɵɵproperty("ngIf", !ctx_r2.ruleDisabledStateMap[policyType_r2] && ruleControls_r8.length);
104
+ i0.ɵɵadvance();
105
+ i0.ɵɵproperty("ngIf", !ruleControls_r8.length || ctx_r2.ruleDisabledStateMap[policyType_r2]);
106
+ } }
107
+ function NetworkPolicyFormComponent_ng_container_31_Template(rf, ctx) { if (rf & 1) {
108
+ const _r1 = i0.ɵɵgetCurrentView();
109
+ i0.ɵɵelementContainerStart(0);
110
+ i0.ɵɵelementStart(1, "div", 18)(2, "div", 10);
111
+ i0.ɵɵtext(3);
112
+ i0.ɵɵpipe(4, "translate");
113
+ i0.ɵɵelementEnd();
114
+ i0.ɵɵelementStart(5, "div", 19)(6, "button", 20);
115
+ i0.ɵɵlistener("click", function NetworkPolicyFormComponent_ng_container_31_Template_button_click_6_listener() { const policyType_r2 = i0.ɵɵrestoreView(_r1).$implicit; const ctx_r2 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r2.addRule(policyType_r2)); });
116
+ i0.ɵɵelement(7, "aui-icon", 21);
117
+ i0.ɵɵtext(8);
118
+ i0.ɵɵpipe(9, "translate");
119
+ i0.ɵɵpipe(10, "translate");
120
+ i0.ɵɵelementEnd();
121
+ i0.ɵɵelementStart(11, "aui-checkbox", 22);
122
+ i0.ɵɵlistener("valueChange", function NetworkPolicyFormComponent_ng_container_31_Template_aui_checkbox_valueChange_11_listener($event) { const policyType_r2 = i0.ɵɵrestoreView(_r1).$implicit; const ctx_r2 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r2.ruleDisabledChanged($event, policyType_r2)); });
123
+ i0.ɵɵtext(12);
124
+ i0.ɵɵpipe(13, "translate");
125
+ i0.ɵɵelementEnd()()();
126
+ i0.ɵɵtemplate(14, NetworkPolicyFormComponent_ng_container_31_ng_container_14_Template, 3, 2, "ng-container", 23);
127
+ i0.ɵɵelementContainerEnd();
128
+ } if (rf & 2) {
129
+ const policyType_r2 = ctx.$implicit;
130
+ const i_r10 = ctx.index;
131
+ const ctx_r2 = i0.ɵɵnextContext();
132
+ i0.ɵɵadvance();
133
+ i0.ɵɵclassMap(i_r10 === 1 ? "tw-mt-16" : "");
134
+ i0.ɵɵadvance(2);
135
+ i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(4, 9, "network.direction_" + policyType_r2), " ");
136
+ i0.ɵɵadvance(3);
137
+ i0.ɵɵproperty("plain", true)("disabled", ctx_r2.ruleDisabledStateMap[policyType_r2]);
138
+ i0.ɵɵadvance(2);
139
+ i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind2(10, 13, "add_xxx", i0.ɵɵpureFunction1(18, _c2, i0.ɵɵpipeBind1(9, 11, policyType_r2))), " ");
140
+ i0.ɵɵadvance(3);
141
+ i0.ɵɵproperty("value", ctx_r2.ruleDisabledStateMap[policyType_r2]);
142
+ i0.ɵɵadvance();
143
+ i0.ɵɵtextInterpolate(i0.ɵɵpipeBind1(13, 16, "network.block_all_" + policyType_r2 + "_traffic"));
144
+ i0.ɵɵadvance(2);
145
+ i0.ɵɵproperty("declare", ctx_r2.form.get(i0.ɵɵpureFunction1(20, _c3, policyType_r2)).controls);
146
+ } }
147
+ function NetworkPolicyFormComponent_ng_template_32_span_1_Template(rf, ctx) { if (rf & 1) {
148
+ i0.ɵɵelementStart(0, "span", 35);
149
+ i0.ɵɵtext(1);
150
+ i0.ɵɵpipe(2, "translate");
151
+ i0.ɵɵelementEnd();
152
+ } if (rf & 2) {
153
+ const policyType_r11 = i0.ɵɵnextContext().policyType;
154
+ i0.ɵɵadvance();
155
+ i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(2, 1, "network." + policyType_r11 + "_rule_no_data_tip"), " ");
156
+ } }
157
+ function NetworkPolicyFormComponent_ng_template_32_span_2_Template(rf, ctx) { if (rf & 1) {
158
+ i0.ɵɵelementStart(0, "span");
159
+ i0.ɵɵtext(1);
160
+ i0.ɵɵpipe(2, "translate");
161
+ i0.ɵɵelementEnd();
162
+ } if (rf & 2) {
163
+ const policyType_r11 = i0.ɵɵnextContext().policyType;
164
+ i0.ɵɵadvance();
165
+ i0.ɵɵtextInterpolate(i0.ɵɵpipeBind1(2, 1, "network.block_all_" + policyType_r11 + "_tip"));
166
+ } }
167
+ function NetworkPolicyFormComponent_ng_template_32_Template(rf, ctx) { if (rf & 1) {
168
+ i0.ɵɵelementStart(0, "div", 33);
169
+ i0.ɵɵtemplate(1, NetworkPolicyFormComponent_ng_template_32_span_1_Template, 3, 3, "span", 34)(2, NetworkPolicyFormComponent_ng_template_32_span_2_Template, 3, 3, "span", 24);
170
+ i0.ɵɵelementEnd();
171
+ } if (rf & 2) {
172
+ const ruleDisabled_r12 = ctx.ruleDisabled;
173
+ i0.ɵɵadvance();
174
+ i0.ɵɵproperty("ngIf", !ruleDisabled_r12);
175
+ i0.ɵɵadvance();
176
+ i0.ɵɵproperty("ngIf", ruleDisabled_r12);
177
+ } }
178
+ const PolicyTypes = ['ingress', 'egress'];
179
+ export class NetworkPolicyFormComponent extends BaseResourceFormGroupComponent {
180
+ get ingressRuleFormArray() {
181
+ return this.form.get([SPEC, 'ingress']);
182
+ }
183
+ get ingressRuleControls() {
184
+ return this.ingressRuleFormArray.controls ?? [];
185
+ }
186
+ get egressRuleFormArray() {
187
+ return this.form.get([SPEC, 'egress']);
188
+ }
189
+ get egressRuleControls() {
190
+ return [...(this.egressRuleFormArray.controls ?? [])];
191
+ }
192
+ constructor(injector, k8sUtil, translate, dialog) {
193
+ super(injector);
194
+ this.k8sUtil = k8sUtil;
195
+ this.translate = translate;
196
+ this.dialog = dialog;
197
+ this.isUpdate = false;
198
+ this.K8S_RESOURCE_NAME_START_WITH_CHARS_ONLY = K8S_RESOURCE_NAME_START_WITH_CHARS_ONLY;
199
+ this.labelValidator = k8sResourceLabelValidator;
200
+ this.labelErrorMapper$ = getK8sResourceLabelErrorMapper$(this.translate);
201
+ this.PolicyTypes = PolicyTypes;
202
+ this.displayNameKey = this.k8sUtil.normalizeType(DISPLAY_NAME);
203
+ this.ruleDisabledStateMap = {
204
+ ingress: false,
205
+ egress: false,
206
+ };
207
+ }
208
+ createForm() {
209
+ const metadataForm = this.fb.group({
210
+ name: this.fb.control('', [
211
+ Validators.required,
212
+ Validators.pattern(K8S_RESOURCE_NAME_START_WITH_CHARS_ONLY.pattern),
213
+ ]),
214
+ namespace: this.fb.control(''),
215
+ annotations: this.fb.group({
216
+ [this.displayNameKey]: this.fb.control(''),
217
+ }),
218
+ });
219
+ const specForm = this.fb.group({
220
+ podSelector: this.fb.group({
221
+ matchLabels: this.fb.control(null),
222
+ }),
223
+ ingress: this.fb.array([]),
224
+ egress: this.fb.array([]),
225
+ policyTypes: this.fb.control([]),
226
+ });
227
+ return this.fb.group({
228
+ metadata: metadataForm,
229
+ spec: specForm,
230
+ });
231
+ }
232
+ getOnFormArrayResizeFn() {
233
+ return () => {
234
+ return this.fb.control({});
235
+ };
236
+ }
237
+ adaptResourceModel(resource) {
238
+ if (!resource) {
239
+ return resource;
240
+ }
241
+ this.updateRuleDisabledStateMap(resource);
242
+ if (this.ruleDisabledStateMap.ingress) {
243
+ resource.spec.policyTypes = ['Ingress'];
244
+ }
245
+ if (this.ruleDisabledStateMap.egress) {
246
+ resource.spec.policyTypes = uniq([
247
+ ...(resource.spec.policyTypes ?? []),
248
+ 'Egress',
249
+ ]);
250
+ }
251
+ return resource;
252
+ }
253
+ async ruleDisabledChanged(disabled, policyType) {
254
+ const ruleFormArray = this.form.get([SPEC, policyType]);
255
+ if (disabled) {
256
+ if (ruleFormArray.length > 0) {
257
+ const result = await this.ruleDisabledConfirm(policyType);
258
+ if (result !== 'ok') {
259
+ this.ruleDisabledStateMap[policyType] = false;
260
+ return;
261
+ }
262
+ ruleFormArray.clear();
263
+ }
264
+ this.addPolicyType(policyType);
265
+ this.ruleDisabledStateMap[policyType] = true;
266
+ }
267
+ else {
268
+ this.removePolicyType(policyType);
269
+ this.ruleDisabledStateMap[policyType] = false;
270
+ }
271
+ }
272
+ addRule(policyType) {
273
+ this.form.get([SPEC, policyType]).push(this.fb.control({
274
+ ports: [],
275
+ [policyType === 'ingress' ? 'from' : 'to']: [],
276
+ }));
277
+ this.addPolicyType(policyType);
278
+ }
279
+ removeRule(index, policyType) {
280
+ const ruleFormArray = this?.[policyType === 'ingress'
281
+ ? 'ingressRuleFormArray'
282
+ : 'egressRuleFormArray'];
283
+ ruleFormArray.removeAt(index);
284
+ this.removePolicyType(policyType);
285
+ }
286
+ async ruleDisabledConfirm(policyType) {
287
+ return await this.dialog
288
+ .confirm({
289
+ title: this.translate.get('network.disabled_rule_confirm', {
290
+ direction: this.translate.get(`network.direction_${policyType}`),
291
+ }),
292
+ confirmType: ConfirmType.Warning,
293
+ confirmText: this.translate.get('network.block'),
294
+ cancelText: this.translate.get('cancel'),
295
+ })
296
+ .then(() => 'ok')
297
+ .catch(() => 'cancel');
298
+ }
299
+ addPolicyType(policyType) {
300
+ const policyTypesCtrl = this.form.get([SPEC, 'policyTypes']);
301
+ const updatedPolicyTypes = uniq([
302
+ ...policyTypesCtrl.value,
303
+ policyType === 'ingress' ? 'Ingress' : 'Egress',
304
+ ]);
305
+ policyTypesCtrl.setValue(updatedPolicyTypes);
306
+ }
307
+ removePolicyType(policyType) {
308
+ const policyTypesCtrl = this.form.get([SPEC, 'policyTypes']);
309
+ const policyTypes = policyTypesCtrl.value;
310
+ const ruleFormArray = this?.[policyType === 'ingress'
311
+ ? 'ingressRuleFormArray'
312
+ : 'egressRuleFormArray'];
313
+ if (ruleFormArray.length === 0) {
314
+ const policyTypeToRemove = policyType === 'ingress' ? 'Ingress' : 'Egress';
315
+ const updatedPolicyTypes = policyTypes.filter(type => type !== policyTypeToRemove);
316
+ policyTypesCtrl.setValue(updatedPolicyTypes);
317
+ }
318
+ }
319
+ updateRuleDisabledStateMap(resource) {
320
+ const policyTypes = resource?.spec?.policyTypes;
321
+ const ruleTypes = ['ingress', 'egress'];
322
+ if (!policyTypes?.length &&
323
+ !ruleTypes.some(type => has(resource.spec, type))) {
324
+ this.ruleDisabledStateMap.ingress = true;
325
+ return;
326
+ }
327
+ policyTypes?.forEach(policyType => {
328
+ const type = policyType.toLowerCase();
329
+ this.ruleDisabledStateMap[type] = !resource.spec[type]?.length;
330
+ });
331
+ }
332
+ static { this.ɵfac = function NetworkPolicyFormComponent_Factory(t) { return new (t || NetworkPolicyFormComponent)(i0.ɵɵdirectiveInject(i0.Injector), i0.ɵɵdirectiveInject(i1.K8sUtilService), i0.ɵɵdirectiveInject(i1.TranslateService), i0.ɵɵdirectiveInject(i2.DialogService)); }; }
333
+ static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: NetworkPolicyFormComponent, selectors: [["acl-network-policy-form"]], inputs: { baseParams: "baseParams", isUpdate: "isUpdate" }, standalone: true, features: [i0.ɵɵInheritDefinitionFeature, i0.ɵɵStandaloneFeature], decls: 34, vars: 36, consts: [["zeroStateTemplate", ""], ["emptyTemplate", ""], ["auiForm", "", "aclScrollToFirstInvalid", "", 3, "formGroup"], ["formGroupName", "metadata"], ["width", "large"], ["auiFormItemLabel", ""], ["type", "text", "aui-input", "", "required", "", "auiFormItemControl", "", "formControlName", "name", "maxlength", "63", 3, "placeholder", "aclReadonlyField"], ["auiFormItemError", "", 3, "errors", "errorsMapper"], ["formGroupName", "annotations"], ["auiFormItemControl", "", "type", "text", "aui-input", "", 3, "formControlName"], [1, "rc-secondary-title"], ["formGroupName", "spec"], ["formGroupName", "podSelector"], ["auiFormItemControl", "", "formControlName", "matchLabels", 3, "zeroStateTemplate", "validator", "errorMapper"], ["auiFormItemHint", ""], [3, "hint", "baseParams", "podLabelSelector"], [4, "ngFor", "ngForOf"], [1, "empty-placeholder", "!tw-border-0", "!tw-min-h-[48px]", "!tw-py-14"], [1, "tw-flex", "tw-w-full", "tw-items-center"], [1, "tw-flex", "tw-mb-16", "tw-ml-16", "tw-justify-between", "tw-flex-1"], ["aui-button", "primary", "type", "button", 3, "click", "plain", "disabled"], ["icon", "plus_circle_s"], [3, "valueChange", "value"], [4, "declare"], [4, "ngIf"], ["formGroupName", "spec", "type", "card"], [3, "closeable", "close", 4, "ngFor", "ngForOf"], [3, "close", "closeable"], [4, "auiTabLabel"], [3, "formControl", "baseParams", "policyType"], ["class", "icon--error", "icon", "xmark_circle_s", "size", "16", 4, "ngIf"], ["icon", "xmark_circle_s", "size", "16", 1, "icon--error"], [3, "ngTemplateOutlet", "ngTemplateOutletContext"], [1, "tw-pt-[40px]", "tw-text-center", "tw-pb-[40px]", "tw-bg-n-9"], ["class", "tw-text-n-4", 4, "ngIf"], [1, "tw-text-n-4"]], template: function NetworkPolicyFormComponent_Template(rf, ctx) { if (rf & 1) {
334
+ i0.ɵɵelementStart(0, "form", 2);
335
+ i0.ɵɵelementContainerStart(1, 3);
336
+ i0.ɵɵelementStart(2, "aui-form-item", 4)(3, "label", 5);
337
+ i0.ɵɵtext(4);
338
+ i0.ɵɵpipe(5, "translate");
339
+ i0.ɵɵelementEnd();
340
+ i0.ɵɵelement(6, "input", 6);
341
+ i0.ɵɵpipe(7, "translate");
342
+ i0.ɵɵelement(8, "acl-errors-mapper", 7);
343
+ i0.ɵɵpipe(9, "translate");
344
+ i0.ɵɵelementEnd();
345
+ i0.ɵɵelementContainerStart(10, 8);
346
+ i0.ɵɵelementStart(11, "aui-form-item", 4)(12, "label", 5);
347
+ i0.ɵɵtext(13);
348
+ i0.ɵɵpipe(14, "translate");
349
+ i0.ɵɵelementEnd();
350
+ i0.ɵɵelement(15, "input", 9);
351
+ i0.ɵɵelementEnd();
352
+ i0.ɵɵelementContainerEnd()();
353
+ i0.ɵɵelementStart(16, "div", 10);
354
+ i0.ɵɵtext(17);
355
+ i0.ɵɵpipe(18, "translate");
356
+ i0.ɵɵelementEnd();
357
+ i0.ɵɵelementContainerStart(19, 11);
358
+ i0.ɵɵelementStart(20, "aui-form-item", 12)(21, "label", 5);
359
+ i0.ɵɵtext(22);
360
+ i0.ɵɵpipe(23, "translate");
361
+ i0.ɵɵelementEnd();
362
+ i0.ɵɵelement(24, "acl-key-value-form-table", 13);
363
+ i0.ɵɵpipe(25, "async");
364
+ i0.ɵɵelementStart(26, "div", 14);
365
+ i0.ɵɵelement(27, "acl-pod-preview", 15);
366
+ i0.ɵɵpipe(28, "translate");
367
+ i0.ɵɵelementEnd();
368
+ i0.ɵɵtemplate(29, NetworkPolicyFormComponent_ng_template_29_Template, 3, 3, "ng-template", null, 0, i0.ɵɵtemplateRefExtractor);
369
+ i0.ɵɵelementEnd();
370
+ i0.ɵɵelementContainerEnd();
371
+ i0.ɵɵtemplate(31, NetworkPolicyFormComponent_ng_container_31_Template, 15, 22, "ng-container", 16)(32, NetworkPolicyFormComponent_ng_template_32_Template, 3, 2, "ng-template", null, 1, i0.ɵɵtemplateRefExtractor);
372
+ i0.ɵɵelementEnd();
373
+ } if (rf & 2) {
374
+ const zeroStateTemplate_r13 = i0.ɵɵreference(30);
375
+ i0.ɵɵproperty("formGroup", ctx.form);
376
+ i0.ɵɵadvance(4);
377
+ i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(5, 17, "name"), " ");
378
+ i0.ɵɵadvance(2);
379
+ i0.ɵɵproperty("placeholder", i0.ɵɵpipeBind1(7, 19, ctx.K8S_RESOURCE_NAME_START_WITH_CHARS_ONLY.tip))("aclReadonlyField", ctx.isUpdate);
380
+ i0.ɵɵadvance(2);
381
+ i0.ɵɵproperty("errors", ctx.form.get("metadata.name").errors)("errorsMapper", i0.ɵɵpureFunction1(33, _c0, i0.ɵɵpipeBind1(9, 21, ctx.K8S_RESOURCE_NAME_START_WITH_CHARS_ONLY.tip)));
382
+ i0.ɵɵadvance(5);
383
+ i0.ɵɵtextInterpolate(i0.ɵɵpipeBind1(14, 23, "display_name"));
384
+ i0.ɵɵadvance(2);
385
+ i0.ɵɵproperty("formControlName", ctx.displayNameKey);
386
+ i0.ɵɵadvance(2);
387
+ i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(18, 25, "network.target_pod"), " ");
388
+ i0.ɵɵadvance(5);
389
+ i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(23, 27, "network.pod_selector"), " ");
390
+ i0.ɵɵadvance(2);
391
+ i0.ɵɵproperty("zeroStateTemplate", zeroStateTemplate_r13)("validator", ctx.labelValidator)("errorMapper", i0.ɵɵpipeBind1(25, 29, ctx.labelErrorMapper$));
392
+ i0.ɵɵadvance(3);
393
+ i0.ɵɵproperty("hint", i0.ɵɵpipeBind1(28, 31, "network.target_pod_affected_by_strategy_hint"))("baseParams", ctx.baseParams)("podLabelSelector", ctx.form.get(i0.ɵɵpureFunction0(35, _c1)).value);
394
+ i0.ɵɵadvance(4);
395
+ i0.ɵɵproperty("ngForOf", ctx.PolicyTypes);
396
+ } }, dependencies: [EffectDirectiveModule, i1.E2eAttributeBindingDirective, i1.ValidatorsDirective, CommonModule, i3.NgForOf, i3.NgIf, i3.NgTemplateOutlet, i3.AsyncPipe, ReactiveFormsModule, i4.ɵNgNoValidate, i4.DefaultValueAccessor, i4.NgControlStatus, i4.NgControlStatusGroup, i4.RequiredValidator, i4.MaxLengthValidator, i4.FormControlDirective, i4.FormGroupDirective, i4.FormControlName, i4.FormGroupName, FormModule, i2.FormDirective, i2.FormItemComponent, i2.FormItemErrorDirective, i2.FormItemHintDirective, i2.FormItemLabelDirective, i2.FormItemControlDirective, KeyValueFormTableComponent,
397
+ PodPreviewComponent,
398
+ TabsModule, i2.TabGroupComponent, i2.TabComponent, i2.TabLabelDirective, ButtonModule, i2.ButtonComponent, IconModule, i2.IconComponent, InputModule, i2.InputComponent, CheckboxModule, i2.CheckboxComponent, i1.TranslatePipe, i1.ErrorsMapperComponent, DeclareDirective,
399
+ NetworkPolicyRuleFormComponent,
400
+ ReadonlyFieldDirective], encapsulation: 2, changeDetection: 0 }); }
401
+ }
402
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(NetworkPolicyFormComponent, [{
403
+ type: Component,
404
+ args: [{ standalone: true, selector: 'acl-network-policy-form', changeDetection: ChangeDetectionStrategy.OnPush, imports: [
405
+ EffectDirectiveModule,
406
+ CommonModule,
407
+ ReactiveFormsModule,
408
+ FormModule,
409
+ KeyValueFormTableComponent,
410
+ PodPreviewComponent,
411
+ TabsModule,
412
+ ButtonModule,
413
+ IconModule,
414
+ InputModule,
415
+ CheckboxModule,
416
+ TRANSLATE_MODULE,
417
+ ERRORS_MAPPER_MODULE,
418
+ DeclareDirective,
419
+ NetworkPolicyRuleFormComponent,
420
+ ReadonlyFieldDirective,
421
+ ], template: "<form\n [formGroup]=\"form\"\n auiForm\n aclScrollToFirstInvalid\n>\n <ng-container formGroupName=\"metadata\">\n <aui-form-item width=\"large\">\n <label auiFormItemLabel>\n {{ 'name' | translate }}\n </label>\n <input\n type=\"text\"\n aui-input\n required\n auiFormItemControl\n [placeholder]=\"K8S_RESOURCE_NAME_START_WITH_CHARS_ONLY.tip | translate\"\n formControlName=\"name\"\n maxlength=\"63\"\n [aclReadonlyField]=\"isUpdate\"\n />\n <acl-errors-mapper\n auiFormItemError\n [errors]=\"form.get('metadata.name').errors\"\n [errorsMapper]=\"{\n pattern: K8S_RESOURCE_NAME_START_WITH_CHARS_ONLY.tip | translate\n }\"\n ></acl-errors-mapper>\n </aui-form-item>\n\n <ng-container formGroupName=\"annotations\">\n <aui-form-item width=\"large\">\n <label auiFormItemLabel>{{ 'display_name' | translate }}</label>\n <input\n auiFormItemControl\n type=\"text\"\n aui-input\n [formControlName]=\"displayNameKey\"\n />\n </aui-form-item>\n </ng-container>\n </ng-container>\n\n <div class=\"rc-secondary-title\">\n {{ 'network.target_pod' | translate }}\n </div>\n <ng-container formGroupName=\"spec\">\n <aui-form-item formGroupName=\"podSelector\">\n <label auiFormItemLabel>\n {{ 'network.pod_selector' | translate }}\n </label>\n <acl-key-value-form-table\n auiFormItemControl\n [zeroStateTemplate]=\"zeroStateTemplate\"\n formControlName=\"matchLabels\"\n [validator]=\"labelValidator\"\n [errorMapper]=\"labelErrorMapper$ | async\"\n ></acl-key-value-form-table>\n <div auiFormItemHint>\n <acl-pod-preview\n [hint]=\"'network.target_pod_affected_by_strategy_hint' | translate\"\n [baseParams]=\"baseParams\"\n [podLabelSelector]=\"\n form.get(['spec', 'podSelector', 'matchLabels']).value\n \"\n ></acl-pod-preview>\n </div>\n <ng-template #zeroStateTemplate>\n <span\n class=\"empty-placeholder !tw-border-0 !tw-min-h-[48px] !tw-py-14\"\n >{{ 'network.target_pod_selector_no_data_tip' | translate }}</span\n >\n </ng-template>\n </aui-form-item>\n </ng-container>\n\n <ng-container *ngFor=\"let policyType of PolicyTypes; let i = index\">\n <div\n class=\"tw-flex tw-w-full tw-items-center\"\n [class]=\"i === 1 ? 'tw-mt-16' : ''\"\n >\n <div class=\"rc-secondary-title\">\n {{ 'network.direction_' + policyType | translate }}\n </div>\n <div class=\"tw-flex tw-mb-16 tw-ml-16 tw-justify-between tw-flex-1\">\n <button\n aui-button=\"primary\"\n [plain]=\"true\"\n type=\"button\"\n [disabled]=\"ruleDisabledStateMap[policyType]\"\n (click)=\"addRule(policyType)\"\n >\n <aui-icon icon=\"plus_circle_s\"></aui-icon>\n {{ 'add_xxx' | translate: { xxx: (policyType | translate) } }}\n </button>\n <aui-checkbox\n [value]=\"ruleDisabledStateMap[policyType]\"\n (valueChange)=\"ruleDisabledChanged($event, policyType)\"\n >{{\n 'network.block_all_' + policyType + '_traffic' | translate\n }}</aui-checkbox\n >\n </div>\n </div>\n <ng-container\n *declare=\"\n $any(this.form.get(['spec', policyType])).controls as ruleControls\n \"\n >\n <ng-container\n *ngIf=\"!ruleDisabledStateMap[policyType] && ruleControls.length\"\n >\n <aui-tab-group\n formGroupName=\"spec\"\n type=\"card\"\n >\n <aui-tab\n *ngFor=\"let item of ruleControls; index as index\"\n [closeable]=\"true\"\n (close)=\"removeRule(index, policyType)\"\n >\n <ng-container *ngIf=\"item as control\">\n <ng-container *auiTabLabel>\n <aui-icon\n *ngIf=\"control.invalid && control.dirty\"\n class=\"icon--error\"\n icon=\"xmark_circle_s\"\n size=\"16\"\n ></aui-icon>\n <span>\n {{ policyType | translate }}\n </span>\n </ng-container>\n\n <acl-network-policy-rule-form\n [formControl]=\"$any(control)\"\n [baseParams]=\"baseParams\"\n [policyType]=\"policyType\"\n ></acl-network-policy-rule-form>\n </ng-container>\n </aui-tab>\n </aui-tab-group>\n </ng-container>\n <ng-container\n *ngIf=\"!ruleControls.length || ruleDisabledStateMap[policyType]\"\n >\n <ng-container\n [ngTemplateOutlet]=\"emptyTemplate\"\n [ngTemplateOutletContext]=\"{\n policyType: policyType,\n ruleDisabled: ruleDisabledStateMap[policyType]\n }\"\n ></ng-container>\n </ng-container>\n </ng-container>\n </ng-container>\n\n <ng-template\n #emptyTemplate\n let-policyType=\"policyType\"\n let-ruleDisabled=\"ruleDisabled\"\n >\n <div class=\"tw-pt-[40px] tw-text-center tw-pb-[40px] tw-bg-n-9\">\n <span\n class=\"tw-text-n-4\"\n *ngIf=\"!ruleDisabled\"\n >\n {{ 'network.' + policyType + '_rule_no_data_tip' | translate }}\n </span>\n <span *ngIf=\"ruleDisabled\">{{\n 'network.block_all_' + policyType + '_tip' | translate\n }}</span>\n </div>\n </ng-template>\n</form>\n" }]
422
+ }], () => [{ type: i0.Injector }, { type: i1.K8sUtilService }, { type: i1.TranslateService }, { type: i2.DialogService }], { baseParams: [{
423
+ type: Input,
424
+ args: [{ required: true }]
425
+ }], isUpdate: [{
426
+ type: Input
427
+ }] }); })();
428
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(NetworkPolicyFormComponent, { className: "NetworkPolicyFormComponent", filePath: "lib/features/network-policy/form/network-policy/component.ts", lineNumber: 68 }); })();
429
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"component.js","sourceRoot":"","sources":["../../../../../../../../../modules/network/src/lib/features/network-policy/form/network-policy/component.ts","../../../../../../../../../modules/network/src/lib/features/network-policy/form/network-policy/template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ButtonModule,\n  CheckboxModule,\n  ConfirmType,\n  DialogService,\n  FormModule,\n  IconModule,\n  InputModule,\n  TabsModule,\n} from '@alauda/ui';\nimport {\n  DISPLAY_NAME,\n  DeclareDirective,\n  ERRORS_MAPPER_MODULE,\n  EffectDirectiveModule,\n  K8S_RESOURCE_NAME_START_WITH_CHARS_ONLY,\n  K8sUtilService,\n  KeyValueFormTableComponent,\n  ReadonlyFieldDirective,\n  SPEC,\n  TRANSLATE_MODULE,\n  TranslateService,\n  Workspace,\n  getK8sResourceLabelErrorMapper$,\n  k8sResourceLabelValidator,\n} from '@alauda-fe/common';\nimport { CommonModule } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  Injector,\n  Input,\n} from '@angular/core';\nimport { FormArray, Validators, ReactiveFormsModule } from '@angular/forms';\nimport { has, uniq } from 'lodash-es';\nimport { BaseResourceFormGroupComponent } from 'ng-resource-form-util';\n\nimport { NetworkPolicy, PolicyType } from '../../../../types/k8s-exports';\nimport { PodPreviewComponent } from '../../components/pod-review/component';\nimport { NetworkPolicyRuleFormComponent } from '../network-policy-rule/component';\n\nconst PolicyTypes = ['ingress', 'egress'] as const;\n\n@Component({\n  standalone: true,\n  selector: 'acl-network-policy-form',\n  templateUrl: 'template.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [\n    EffectDirectiveModule,\n    CommonModule,\n    ReactiveFormsModule,\n    FormModule,\n    KeyValueFormTableComponent,\n    PodPreviewComponent,\n    TabsModule,\n    ButtonModule,\n    IconModule,\n    InputModule,\n    CheckboxModule,\n    TRANSLATE_MODULE,\n    ERRORS_MAPPER_MODULE,\n    DeclareDirective,\n    NetworkPolicyRuleFormComponent,\n    ReadonlyFieldDirective,\n  ],\n})\nexport class NetworkPolicyFormComponent extends BaseResourceFormGroupComponent<NetworkPolicy> {\n  @Input({ required: true })\n  baseParams: Workspace;\n\n  @Input()\n  isUpdate = false;\n\n  get ingressRuleFormArray() {\n    return this.form.get([SPEC, 'ingress']) as FormArray;\n  }\n\n  get ingressRuleControls() {\n    return this.ingressRuleFormArray.controls ?? [];\n  }\n\n  get egressRuleFormArray() {\n    return this.form.get([SPEC, 'egress']) as FormArray;\n  }\n\n  get egressRuleControls() {\n    return [...(this.egressRuleFormArray.controls ?? [])];\n  }\n\n  K8S_RESOURCE_NAME_START_WITH_CHARS_ONLY =\n    K8S_RESOURCE_NAME_START_WITH_CHARS_ONLY;\n\n  labelValidator = k8sResourceLabelValidator;\n  labelErrorMapper$ = getK8sResourceLabelErrorMapper$(this.translate);\n  PolicyTypes = PolicyTypes;\n  displayNameKey = this.k8sUtil.normalizeType(DISPLAY_NAME);\n  ruleDisabledStateMap: Record<'ingress' | 'egress', boolean> = {\n    ingress: false,\n    egress: false,\n  };\n\n  constructor(\n    injector: Injector,\n    private readonly k8sUtil: K8sUtilService,\n    private readonly translate: TranslateService,\n    private readonly dialog: DialogService,\n  ) {\n    super(injector);\n  }\n\n  override createForm() {\n    const metadataForm = this.fb.group({\n      name: this.fb.control('', [\n        Validators.required,\n        Validators.pattern(K8S_RESOURCE_NAME_START_WITH_CHARS_ONLY.pattern),\n      ]),\n      namespace: this.fb.control(''),\n      annotations: this.fb.group({\n        [this.displayNameKey]: this.fb.control(''),\n      }),\n    });\n    const specForm = this.fb.group({\n      podSelector: this.fb.group({\n        matchLabels: this.fb.control(null),\n      }),\n      ingress: this.fb.array([]),\n      egress: this.fb.array([]),\n      policyTypes: this.fb.control([]),\n    });\n\n    return this.fb.group({\n      metadata: metadataForm,\n      spec: specForm,\n    });\n  }\n\n  override getOnFormArrayResizeFn() {\n    return () => {\n      return this.fb.control({});\n    };\n  }\n\n  override adaptResourceModel(resource: NetworkPolicy): NetworkPolicy {\n    if (!resource) {\n      return resource;\n    }\n\n    this.updateRuleDisabledStateMap(resource);\n\n    if (this.ruleDisabledStateMap.ingress) {\n      resource.spec.policyTypes = ['Ingress'];\n    }\n\n    if (this.ruleDisabledStateMap.egress) {\n      resource.spec.policyTypes = uniq([\n        ...(resource.spec.policyTypes ?? []),\n        'Egress',\n      ]);\n    }\n\n    return resource;\n  }\n\n  async ruleDisabledChanged(\n    disabled: boolean,\n    policyType: Lowercase<PolicyType>,\n  ) {\n    const ruleFormArray = this.form.get([SPEC, policyType]) as FormArray;\n\n    if (disabled) {\n      if (ruleFormArray.length > 0) {\n        const result = await this.ruleDisabledConfirm(policyType);\n        if (result !== 'ok') {\n          this.ruleDisabledStateMap[policyType] = false;\n          return;\n        }\n        ruleFormArray.clear();\n      }\n\n      this.addPolicyType(policyType);\n      this.ruleDisabledStateMap[policyType] = true;\n    } else {\n      this.removePolicyType(policyType);\n      this.ruleDisabledStateMap[policyType] = false;\n    }\n  }\n\n  addRule(policyType: Lowercase<PolicyType>) {\n    (this.form.get([SPEC, policyType]) as FormArray).push(\n      this.fb.control({\n        ports: [],\n        [policyType === 'ingress' ? 'from' : 'to']: [],\n      }),\n    );\n\n    this.addPolicyType(policyType);\n  }\n\n  removeRule(index: number, policyType: Lowercase<PolicyType>) {\n    const ruleFormArray =\n      this?.[\n        policyType === 'ingress'\n          ? 'ingressRuleFormArray'\n          : 'egressRuleFormArray'\n      ];\n\n    ruleFormArray.removeAt(index);\n\n    this.removePolicyType(policyType);\n  }\n\n  private async ruleDisabledConfirm(policyType: Lowercase<PolicyType>) {\n    return await this.dialog\n      .confirm({\n        title: this.translate.get('network.disabled_rule_confirm', {\n          direction: this.translate.get(`network.direction_${policyType}`),\n        }),\n        confirmType: ConfirmType.Warning,\n        confirmText: this.translate.get('network.block'),\n        cancelText: this.translate.get('cancel'),\n      })\n      .then(() => 'ok')\n      .catch(() => 'cancel');\n  }\n\n  private addPolicyType(policyType: Lowercase<PolicyType>) {\n    const policyTypesCtrl = this.form.get([SPEC, 'policyTypes']);\n\n    const updatedPolicyTypes = uniq([\n      ...policyTypesCtrl.value,\n      policyType === 'ingress' ? 'Ingress' : 'Egress',\n    ]);\n\n    policyTypesCtrl.setValue(updatedPolicyTypes);\n  }\n\n  private removePolicyType(policyType: Lowercase<PolicyType>) {\n    const policyTypesCtrl = this.form.get([SPEC, 'policyTypes']);\n    const policyTypes = policyTypesCtrl.value as PolicyType[];\n    const ruleFormArray =\n      this?.[\n        policyType === 'ingress'\n          ? 'ingressRuleFormArray'\n          : 'egressRuleFormArray'\n      ];\n\n    if (ruleFormArray.length === 0) {\n      const policyTypeToRemove =\n        policyType === 'ingress' ? 'Ingress' : 'Egress';\n      const updatedPolicyTypes = policyTypes.filter(\n        type => type !== policyTypeToRemove,\n      );\n      policyTypesCtrl.setValue(updatedPolicyTypes);\n    }\n  }\n\n  private updateRuleDisabledStateMap(resource: NetworkPolicy) {\n    const policyTypes = resource?.spec?.policyTypes;\n    const ruleTypes = ['ingress', 'egress'];\n\n    if (\n      !policyTypes?.length &&\n      !ruleTypes.some(type => has(resource.spec, type))\n    ) {\n      this.ruleDisabledStateMap.ingress = true;\n      return;\n    }\n\n    policyTypes?.forEach(policyType => {\n      const type = policyType.toLowerCase() as Lowercase<PolicyType>;\n      this.ruleDisabledStateMap[type] = !resource.spec[type]?.length;\n    });\n  }\n}\n","<form\n  [formGroup]=\"form\"\n  auiForm\n  aclScrollToFirstInvalid\n>\n  <ng-container formGroupName=\"metadata\">\n    <aui-form-item width=\"large\">\n      <label auiFormItemLabel>\n        {{ 'name' | translate }}\n      </label>\n      <input\n        type=\"text\"\n        aui-input\n        required\n        auiFormItemControl\n        [placeholder]=\"K8S_RESOURCE_NAME_START_WITH_CHARS_ONLY.tip | translate\"\n        formControlName=\"name\"\n        maxlength=\"63\"\n        [aclReadonlyField]=\"isUpdate\"\n      />\n      <acl-errors-mapper\n        auiFormItemError\n        [errors]=\"form.get('metadata.name').errors\"\n        [errorsMapper]=\"{\n          pattern: K8S_RESOURCE_NAME_START_WITH_CHARS_ONLY.tip | translate\n        }\"\n      ></acl-errors-mapper>\n    </aui-form-item>\n\n    <ng-container formGroupName=\"annotations\">\n      <aui-form-item width=\"large\">\n        <label auiFormItemLabel>{{ 'display_name' | translate }}</label>\n        <input\n          auiFormItemControl\n          type=\"text\"\n          aui-input\n          [formControlName]=\"displayNameKey\"\n        />\n      </aui-form-item>\n    </ng-container>\n  </ng-container>\n\n  <div class=\"rc-secondary-title\">\n    {{ 'network.target_pod' | translate }}\n  </div>\n  <ng-container formGroupName=\"spec\">\n    <aui-form-item formGroupName=\"podSelector\">\n      <label auiFormItemLabel>\n        {{ 'network.pod_selector' | translate }}\n      </label>\n      <acl-key-value-form-table\n        auiFormItemControl\n        [zeroStateTemplate]=\"zeroStateTemplate\"\n        formControlName=\"matchLabels\"\n        [validator]=\"labelValidator\"\n        [errorMapper]=\"labelErrorMapper$ | async\"\n      ></acl-key-value-form-table>\n      <div auiFormItemHint>\n        <acl-pod-preview\n          [hint]=\"'network.target_pod_affected_by_strategy_hint' | translate\"\n          [baseParams]=\"baseParams\"\n          [podLabelSelector]=\"\n            form.get(['spec', 'podSelector', 'matchLabels']).value\n          \"\n        ></acl-pod-preview>\n      </div>\n      <ng-template #zeroStateTemplate>\n        <span\n          class=\"empty-placeholder !tw-border-0 !tw-min-h-[48px] !tw-py-14\"\n          >{{ 'network.target_pod_selector_no_data_tip' | translate }}</span\n        >\n      </ng-template>\n    </aui-form-item>\n  </ng-container>\n\n  <ng-container *ngFor=\"let policyType of PolicyTypes; let i = index\">\n    <div\n      class=\"tw-flex tw-w-full tw-items-center\"\n      [class]=\"i === 1 ? 'tw-mt-16' : ''\"\n    >\n      <div class=\"rc-secondary-title\">\n        {{ 'network.direction_' + policyType | translate }}\n      </div>\n      <div class=\"tw-flex tw-mb-16 tw-ml-16 tw-justify-between tw-flex-1\">\n        <button\n          aui-button=\"primary\"\n          [plain]=\"true\"\n          type=\"button\"\n          [disabled]=\"ruleDisabledStateMap[policyType]\"\n          (click)=\"addRule(policyType)\"\n        >\n          <aui-icon icon=\"plus_circle_s\"></aui-icon>\n          {{ 'add_xxx' | translate: { xxx: (policyType | translate) } }}\n        </button>\n        <aui-checkbox\n          [value]=\"ruleDisabledStateMap[policyType]\"\n          (valueChange)=\"ruleDisabledChanged($event, policyType)\"\n          >{{\n            'network.block_all_' + policyType + '_traffic' | translate\n          }}</aui-checkbox\n        >\n      </div>\n    </div>\n    <ng-container\n      *declare=\"\n        $any(this.form.get(['spec', policyType])).controls as ruleControls\n      \"\n    >\n      <ng-container\n        *ngIf=\"!ruleDisabledStateMap[policyType] && ruleControls.length\"\n      >\n        <aui-tab-group\n          formGroupName=\"spec\"\n          type=\"card\"\n        >\n          <aui-tab\n            *ngFor=\"let item of ruleControls; index as index\"\n            [closeable]=\"true\"\n            (close)=\"removeRule(index, policyType)\"\n          >\n            <ng-container *ngIf=\"item as control\">\n              <ng-container *auiTabLabel>\n                <aui-icon\n                  *ngIf=\"control.invalid && control.dirty\"\n                  class=\"icon--error\"\n                  icon=\"xmark_circle_s\"\n                  size=\"16\"\n                ></aui-icon>\n                <span>\n                  {{ policyType | translate }}\n                </span>\n              </ng-container>\n\n              <acl-network-policy-rule-form\n                [formControl]=\"$any(control)\"\n                [baseParams]=\"baseParams\"\n                [policyType]=\"policyType\"\n              ></acl-network-policy-rule-form>\n            </ng-container>\n          </aui-tab>\n        </aui-tab-group>\n      </ng-container>\n      <ng-container\n        *ngIf=\"!ruleControls.length || ruleDisabledStateMap[policyType]\"\n      >\n        <ng-container\n          [ngTemplateOutlet]=\"emptyTemplate\"\n          [ngTemplateOutletContext]=\"{\n            policyType: policyType,\n            ruleDisabled: ruleDisabledStateMap[policyType]\n          }\"\n        ></ng-container>\n      </ng-container>\n    </ng-container>\n  </ng-container>\n\n  <ng-template\n    #emptyTemplate\n    let-policyType=\"policyType\"\n    let-ruleDisabled=\"ruleDisabled\"\n  >\n    <div class=\"tw-pt-[40px] tw-text-center tw-pb-[40px] tw-bg-n-9\">\n      <span\n        class=\"tw-text-n-4\"\n        *ngIf=\"!ruleDisabled\"\n      >\n        {{ 'network.' + policyType + '_rule_no_data_tip' | translate }}\n      </span>\n      <span *ngIf=\"ruleDisabled\">{{\n        'network.block_all_' + policyType + '_tip' | translate\n      }}</span>\n    </div>\n  </ng-template>\n</form>\n"]}
@@ -0,0 +1,102 @@
1
+ import { __decorate, __metadata } from "tslib";
2
+ import { FormModule, InputModule } from '@alauda/ui';
3
+ import { ERRORS_MAPPER_MODULE, EffectDirectiveModule, ObservableInput, TRANSLATE_MODULE, bind, publishRef, } from '@alauda-fe/common';
4
+ import { CommonModule } from '@angular/common';
5
+ import { ChangeDetectionStrategy, Component, Injector, Input, } from '@angular/core';
6
+ import { AbstractControl, ReactiveFormsModule, Validators, } from '@angular/forms';
7
+ import { BaseResourceFormGroupComponent } from 'ng-resource-form-util';
8
+ import { Observable, first, map, switchMap, takeUntil } from 'rxjs';
9
+ import { NetworkUtilService } from '../../../../services/network-util.service';
10
+ import { adaptIpMode, isCidrAddressValid, } from '../../../../utils/cidr-exports';
11
+ import { NetworkPolicyExceptRemoteInputFormComponent } from '../network-policy-remote-except-input/component';
12
+ import * as i0 from "@angular/core";
13
+ import * as i1 from "../../../../services/network-util.service";
14
+ import * as i2 from "@alauda-fe/common";
15
+ import * as i3 from "@angular/common";
16
+ import * as i4 from "@angular/forms";
17
+ import * as i5 from "@alauda/ui";
18
+ const _c0 = a0 => ({ cidrPattern: a0 });
19
+ export class NetworkPolicyIpBlockFormComponent extends BaseResourceFormGroupComponent {
20
+ constructor(injector, networkUtil) {
21
+ super(injector);
22
+ this.networkUtil = networkUtil;
23
+ this.networkMode$ = this.cluster$.pipe(switchMap(cluster => this.networkUtil.getNetworkMode$(cluster)), publishRef());
24
+ }
25
+ createForm() {
26
+ return this.fb.group({
27
+ cidr: this.fb.control('', [Validators.required], [this.asyncValidateCidr]),
28
+ except: this.fb.control([]),
29
+ });
30
+ }
31
+ asyncValidateCidr(ctrl) {
32
+ return this.networkMode$.pipe(map(mode => {
33
+ const cidr = ctrl.value;
34
+ const ipMode = adaptIpMode(cidr, mode);
35
+ return cidr && !isCidrAddressValid(cidr, ipMode)
36
+ ? {
37
+ cidrPattern: true,
38
+ }
39
+ : null;
40
+ }), first(), takeUntil(this.destroy$));
41
+ }
42
+ static { this.ɵfac = function NetworkPolicyIpBlockFormComponent_Factory(t) { return new (t || NetworkPolicyIpBlockFormComponent)(i0.ɵɵdirectiveInject(i0.Injector), i0.ɵɵdirectiveInject(i1.NetworkUtilService)); }; }
43
+ static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: NetworkPolicyIpBlockFormComponent, selectors: [["acl-network-policy-ip-block-form"]], inputs: { cluster: "cluster" }, standalone: true, features: [i0.ɵɵInheritDefinitionFeature, i0.ɵɵStandaloneFeature], decls: 16, vars: 22, consts: [["auiForm", "", 1, "last-form-item-no-margin", 3, "formGroup"], ["width", "medium"], ["auiFormItemLabel", ""], ["aui-input", "", "required", "", "auiFormItemControl", "", "formControlName", "cidr", "type", "text", 3, "placeholder"], ["auiFormItemError", "", 3, "errorsMapper", "errors"], ["auiFormItemControl", "", "formControlName", "except", 1, "tw-w-full", 3, "remoteIpBlock", "networkMode"]], template: function NetworkPolicyIpBlockFormComponent_Template(rf, ctx) { if (rf & 1) {
44
+ i0.ɵɵelementStart(0, "form", 0)(1, "aui-form-item", 1)(2, "label", 2);
45
+ i0.ɵɵtext(3);
46
+ i0.ɵɵpipe(4, "translate");
47
+ i0.ɵɵelementEnd();
48
+ i0.ɵɵelement(5, "input", 3);
49
+ i0.ɵɵpipe(6, "translate");
50
+ i0.ɵɵelement(7, "acl-errors-mapper", 4);
51
+ i0.ɵɵpipe(8, "async");
52
+ i0.ɵɵpipe(9, "translate");
53
+ i0.ɵɵelementEnd();
54
+ i0.ɵɵelementStart(10, "aui-form-item")(11, "label", 2);
55
+ i0.ɵɵtext(12);
56
+ i0.ɵɵpipe(13, "translate");
57
+ i0.ɵɵelementEnd();
58
+ i0.ɵɵelement(14, "acl-network-policy-remote-ip-except-input", 5);
59
+ i0.ɵɵpipe(15, "async");
60
+ i0.ɵɵelementEnd()();
61
+ } if (rf & 2) {
62
+ i0.ɵɵproperty("formGroup", ctx.form);
63
+ i0.ɵɵadvance(3);
64
+ i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(4, 8, "network.cidr"), " ");
65
+ i0.ɵɵadvance(2);
66
+ i0.ɵɵproperty("placeholder", i0.ɵɵpipeBind1(6, 10, "network.please_input_correct_cidr"));
67
+ i0.ɵɵadvance(2);
68
+ i0.ɵɵproperty("errorsMapper", i0.ɵɵpureFunction1(20, _c0, i0.ɵɵpipeBind1(9, 14, i0.ɵɵpipeBind1(8, 12, ctx.networkMode$) === "v6" ? "network.please_input_correct_ipv6_cidr_with_demo" : "network.please_input_correct_cidr")))("errors", ctx.form.get("cidr").errors);
69
+ i0.ɵɵadvance(5);
70
+ i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(13, 16, "network.except"), " ");
71
+ i0.ɵɵadvance(2);
72
+ i0.ɵɵproperty("remoteIpBlock", ctx.form.get("cidr").value)("networkMode", i0.ɵɵpipeBind1(15, 18, ctx.networkMode$));
73
+ } }, dependencies: [EffectDirectiveModule, i2.ValidatorsDirective, CommonModule, i3.AsyncPipe, ReactiveFormsModule, i4.ɵNgNoValidate, i4.DefaultValueAccessor, i4.NgControlStatus, i4.NgControlStatusGroup, i4.RequiredValidator, i4.FormGroupDirective, i4.FormControlName, FormModule, i5.FormDirective, i5.FormItemComponent, i5.FormItemErrorDirective, i5.FormItemLabelDirective, i5.FormItemControlDirective, InputModule, i5.InputComponent, i2.TranslatePipe, i2.ErrorsMapperComponent, NetworkPolicyExceptRemoteInputFormComponent], encapsulation: 2, changeDetection: 0 }); }
74
+ }
75
+ __decorate([
76
+ ObservableInput(),
77
+ __metadata("design:type", Observable)
78
+ ], NetworkPolicyIpBlockFormComponent.prototype, "cluster$", void 0);
79
+ __decorate([
80
+ bind,
81
+ __metadata("design:type", Function),
82
+ __metadata("design:paramtypes", [AbstractControl]),
83
+ __metadata("design:returntype", void 0)
84
+ ], NetworkPolicyIpBlockFormComponent.prototype, "asyncValidateCidr", null);
85
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(NetworkPolicyIpBlockFormComponent, [{
86
+ type: Component,
87
+ args: [{ standalone: true, selector: 'acl-network-policy-ip-block-form', changeDetection: ChangeDetectionStrategy.OnPush, imports: [
88
+ EffectDirectiveModule,
89
+ CommonModule,
90
+ ReactiveFormsModule,
91
+ FormModule,
92
+ InputModule,
93
+ TRANSLATE_MODULE,
94
+ ERRORS_MAPPER_MODULE,
95
+ NetworkPolicyExceptRemoteInputFormComponent,
96
+ ], template: "<form\n [formGroup]=\"form\"\n auiForm\n class=\"last-form-item-no-margin\"\n>\n <aui-form-item width=\"medium\">\n <label auiFormItemLabel>\n {{ 'network.cidr' | translate }}\n </label>\n <input\n aui-input\n required\n auiFormItemControl\n formControlName=\"cidr\"\n type=\"text\"\n [placeholder]=\"'network.please_input_correct_cidr' | translate\"\n />\n <acl-errors-mapper\n auiFormItemError\n [errorsMapper]=\"{\n cidrPattern:\n ((networkMode$ | async) === 'v6'\n ? 'network.please_input_correct_ipv6_cidr_with_demo'\n : 'network.please_input_correct_cidr'\n ) | translate\n }\"\n [errors]=\"form.get('cidr').errors\"\n ></acl-errors-mapper>\n </aui-form-item>\n <aui-form-item>\n <label auiFormItemLabel>\n {{ 'network.except' | translate }}\n </label>\n <acl-network-policy-remote-ip-except-input\n auiFormItemControl\n class=\"tw-w-full\"\n [remoteIpBlock]=\"form.get('cidr').value\"\n formControlName=\"except\"\n [networkMode]=\"networkMode$ | async\"\n ></acl-network-policy-remote-ip-except-input>\n </aui-form-item>\n</form>\n" }]
97
+ }], () => [{ type: i0.Injector }, { type: i1.NetworkUtilService }], { cluster: [{
98
+ type: Input,
99
+ args: [{ required: true }]
100
+ }], cluster$: [], asyncValidateCidr: [] }); })();
101
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(NetworkPolicyIpBlockFormComponent, { className: "NetworkPolicyIpBlockFormComponent", filePath: "lib/features/network-policy/form/network-policy-ip-block/component.ts", lineNumber: 49 }); })();
102
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"component.js","sourceRoot":"","sources":["../../../../../../../../../modules/network/src/lib/features/network-policy/form/network-policy-ip-block/component.ts","../../../../../../../../../modules/network/src/lib/features/network-policy/form/network-policy-ip-block/template.html"],"names":[],"mappings":"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","sourcesContent":["import { FormModule, InputModule } from '@alauda/ui';\nimport {\n  ERRORS_MAPPER_MODULE,\n  EffectDirectiveModule,\n  ObservableInput,\n  TRANSLATE_MODULE,\n  bind,\n  publishRef,\n} from '@alauda-fe/common';\nimport { CommonModule } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  Injector,\n  Input,\n} from '@angular/core';\nimport {\n  AbstractControl,\n  ReactiveFormsModule,\n  Validators,\n} from '@angular/forms';\nimport { BaseResourceFormGroupComponent } from 'ng-resource-form-util';\nimport { Observable, first, map, switchMap, takeUntil } from 'rxjs';\n\nimport { NetworkUtilService } from '../../../../services/network-util.service';\nimport { IPBlock } from '../../../../types/k8s-exports';\nimport {\n  adaptIpMode,\n  isCidrAddressValid,\n} from '../../../../utils/cidr-exports';\nimport { NetworkPolicyExceptRemoteInputFormComponent } from '../network-policy-remote-except-input/component';\n\n@Component({\n  standalone: true,\n  selector: 'acl-network-policy-ip-block-form',\n  templateUrl: 'template.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [\n    EffectDirectiveModule,\n    CommonModule,\n    ReactiveFormsModule,\n    FormModule,\n    InputModule,\n    TRANSLATE_MODULE,\n    ERRORS_MAPPER_MODULE,\n    NetworkPolicyExceptRemoteInputFormComponent,\n  ],\n})\nexport class NetworkPolicyIpBlockFormComponent extends BaseResourceFormGroupComponent<IPBlock> {\n  @Input({ required: true })\n  cluster: string;\n\n  @ObservableInput()\n  cluster$!: Observable<string>;\n\n  networkMode$ = this.cluster$.pipe(\n    switchMap(cluster => this.networkUtil.getNetworkMode$(cluster)),\n    publishRef(),\n  );\n\n  constructor(\n    injector: Injector,\n    private readonly networkUtil: NetworkUtilService,\n  ) {\n    super(injector);\n  }\n\n  override createForm() {\n    return this.fb.group({\n      cidr: this.fb.control(\n        '',\n        [Validators.required],\n        [this.asyncValidateCidr],\n      ),\n      except: this.fb.control([]),\n    });\n  }\n\n  @bind\n  asyncValidateCidr(ctrl: AbstractControl) {\n    return this.networkMode$.pipe(\n      map(mode => {\n        const cidr = ctrl.value as string;\n        const ipMode = adaptIpMode(cidr, mode);\n\n        return cidr && !isCidrAddressValid(cidr, ipMode)\n          ? {\n              cidrPattern: true,\n            }\n          : null;\n      }),\n      first(),\n      takeUntil(this.destroy$),\n    );\n  }\n}\n","<form\n  [formGroup]=\"form\"\n  auiForm\n  class=\"last-form-item-no-margin\"\n>\n  <aui-form-item width=\"medium\">\n    <label auiFormItemLabel>\n      {{ 'network.cidr' | translate }}\n    </label>\n    <input\n      aui-input\n      required\n      auiFormItemControl\n      formControlName=\"cidr\"\n      type=\"text\"\n      [placeholder]=\"'network.please_input_correct_cidr' | translate\"\n    />\n    <acl-errors-mapper\n      auiFormItemError\n      [errorsMapper]=\"{\n        cidrPattern:\n          ((networkMode$ | async) === 'v6'\n            ? 'network.please_input_correct_ipv6_cidr_with_demo'\n            : 'network.please_input_correct_cidr'\n          ) | translate\n      }\"\n      [errors]=\"form.get('cidr').errors\"\n    ></acl-errors-mapper>\n  </aui-form-item>\n  <aui-form-item>\n    <label auiFormItemLabel>\n      {{ 'network.except' | translate }}\n    </label>\n    <acl-network-policy-remote-ip-except-input\n      auiFormItemControl\n      class=\"tw-w-full\"\n      [remoteIpBlock]=\"form.get('cidr').value\"\n      formControlName=\"except\"\n      [networkMode]=\"networkMode$ | async\"\n    ></acl-network-policy-remote-ip-except-input>\n  </aui-form-item>\n</form>\n"]}