@alauda-fe/network 1.0.0-beta.0

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 (46) hide show
  1. package/esm2022/alauda-fe-network.mjs +5 -0
  2. package/esm2022/index.mjs +19 -0
  3. package/esm2022/lib/components/certificate-status/component.mjs +37 -0
  4. package/esm2022/lib/components/fixed-ip/component.mjs +503 -0
  5. package/esm2022/lib/components/loadbalancer-spec-form/component.mjs +251 -0
  6. package/esm2022/lib/components/service-annotations-form/annotations.component.mjs +681 -0
  7. package/esm2022/lib/components/service-annotations-form-item/annotations.component.mjs +106 -0
  8. package/esm2022/lib/components/service-form/component.mjs +307 -0
  9. package/esm2022/lib/components/service-form/fieldset/component.mjs +407 -0
  10. package/esm2022/lib/directives/subnet-validator.directive.mjs +111 -0
  11. package/esm2022/lib/services/alb-api.service.mjs +48 -0
  12. package/esm2022/lib/services/certificate-api.service.mjs +111 -0
  13. package/esm2022/lib/services/network-util.service.mjs +116 -0
  14. package/esm2022/lib/types/alb-exports.mjs +14 -0
  15. package/esm2022/lib/types/k8s-exports.mjs +13 -0
  16. package/esm2022/lib/types/resource-definition.mjs +16 -0
  17. package/esm2022/lib/utils/alb-exports.mjs +108 -0
  18. package/esm2022/lib/utils/alb-internals.mjs +2 -0
  19. package/esm2022/lib/utils/cidr-exports.mjs +359 -0
  20. package/esm2022/lib/utils/cluster-exports.mjs +18 -0
  21. package/esm2022/lib/utils/service-exports.mjs +58 -0
  22. package/esm2022/lib/utils/service-internals.mjs +7 -0
  23. package/esm2022/lib/utils/subnet-exports.mjs +18 -0
  24. package/index.d.ts +18 -0
  25. package/lib/components/certificate-status/component.d.ts +17 -0
  26. package/lib/components/fixed-ip/component.d.ts +67 -0
  27. package/lib/components/loadbalancer-spec-form/component.d.ts +34 -0
  28. package/lib/components/service-annotations-form/annotations.component.d.ts +74 -0
  29. package/lib/components/service-annotations-form-item/annotations.component.d.ts +14 -0
  30. package/lib/components/service-form/component.d.ts +56 -0
  31. package/lib/components/service-form/fieldset/component.d.ts +46 -0
  32. package/lib/directives/subnet-validator.directive.d.ts +34 -0
  33. package/lib/services/alb-api.service.d.ts +16 -0
  34. package/lib/services/certificate-api.service.d.ts +38 -0
  35. package/lib/services/network-util.service.d.ts +21 -0
  36. package/lib/types/alb-exports.d.ts +29 -0
  37. package/lib/types/k8s-exports.d.ts +130 -0
  38. package/lib/types/resource-definition.d.ts +25 -0
  39. package/lib/utils/alb-exports.d.ts +16 -0
  40. package/lib/utils/alb-internals.d.ts +10 -0
  41. package/lib/utils/cidr-exports.d.ts +85 -0
  42. package/lib/utils/cluster-exports.d.ts +14 -0
  43. package/lib/utils/service-exports.d.ts +18 -0
  44. package/lib/utils/service-internals.d.ts +2 -0
  45. package/lib/utils/subnet-exports.d.ts +20 -0
  46. package/package.json +31 -0
@@ -0,0 +1,681 @@
1
+ import { AutocompleteModule, ButtonModule, IconModule, InputModule, } from '@alauda/ui';
2
+ import { ArrayFormTableComponent, ArrayFormTableHeaderDirective, ArrayFormTableRowControlDirective, ArrayFormTableRowDirective, ArrayFormTableRowErrorDirective, BaseStringMapFormComponent, ErrorsMapperModule, FALSE, HelpDocumentModule, PurePipe, TOKEN_BASE_DOMAIN, TOKEN_BASE_HREF, TRUE, TranslateModule, TranslateService, getK8sResourceAnnotationErrorMapper$, k8sResourceAnnotationKeyValidator, } from '@alauda-fe/common';
3
+ import { AsyncPipe, NgForOf, NgIf } from '@angular/common';
4
+ import { ChangeDetectionStrategy, Component, Inject, Injector, Input, inject, } from '@angular/core';
5
+ import { ReactiveFormsModule } from '@angular/forms';
6
+ import { sortBy } from 'lodash-es';
7
+ import { ClusterType } from '../../utils/cluster-exports';
8
+ import * as i0 from "@angular/core";
9
+ import * as i1 from "@angular/forms";
10
+ import * as i2 from "@alauda-fe/common";
11
+ import * as i3 from "@alauda/ui";
12
+ function ServiceAnnotationsFormComponent_ng_container_1_Template(rf, ctx) { if (rf & 1) {
13
+ i0.ɵɵelementContainerStart(0);
14
+ i0.ɵɵelementStart(1, "th", 6);
15
+ i0.ɵɵtext(2);
16
+ i0.ɵɵpipe(3, "translate");
17
+ i0.ɵɵelementEnd();
18
+ i0.ɵɵelementStart(4, "th", 6);
19
+ i0.ɵɵtext(5);
20
+ i0.ɵɵpipe(6, "translate");
21
+ i0.ɵɵelementEnd();
22
+ i0.ɵɵelementContainerEnd();
23
+ } if (rf & 2) {
24
+ i0.ɵɵadvance(2);
25
+ i0.ɵɵtextInterpolate(i0.ɵɵpipeBind1(3, 2, "key"));
26
+ i0.ɵɵadvance(3);
27
+ i0.ɵɵtextInterpolate(i0.ɵɵpipeBind1(6, 4, "value"));
28
+ } }
29
+ function ServiceAnnotationsFormComponent_ng_container_2_ng_container_1_aui_suggestion_5_div_2_Template(rf, ctx) { if (rf & 1) {
30
+ i0.ɵɵelementStart(0, "div", 16);
31
+ i0.ɵɵtext(1);
32
+ i0.ɵɵelementEnd();
33
+ } if (rf & 2) {
34
+ const tip_r17 = ctx.ngIf;
35
+ i0.ɵɵadvance(1);
36
+ i0.ɵɵtextInterpolate1(" ", tip_r17, " ");
37
+ } }
38
+ function ServiceAnnotationsFormComponent_ng_container_2_ng_container_1_aui_suggestion_5_Template(rf, ctx) { if (rf & 1) {
39
+ i0.ɵɵelementStart(0, "aui-suggestion", 15);
40
+ i0.ɵɵtext(1);
41
+ i0.ɵɵtemplate(2, ServiceAnnotationsFormComponent_ng_container_2_ng_container_1_aui_suggestion_5_div_2_Template, 2, 1, "div", 14);
42
+ i0.ɵɵpipe(3, "translate");
43
+ i0.ɵɵelementEnd();
44
+ } if (rf & 2) {
45
+ const option_r15 = ctx.$implicit;
46
+ i0.ɵɵproperty("value", option_r15.key);
47
+ i0.ɵɵadvance(1);
48
+ i0.ɵɵtextInterpolate1(" ", option_r15.key, " ");
49
+ i0.ɵɵadvance(1);
50
+ i0.ɵɵproperty("ngIf", i0.ɵɵpipeBind1(3, 3, option_r15.tip));
51
+ } }
52
+ function ServiceAnnotationsFormComponent_ng_container_2_ng_container_1_ng_container_6_div_1_ng_container_1_Template(rf, ctx) { if (rf & 1) {
53
+ i0.ɵɵelementContainerStart(0);
54
+ i0.ɵɵtext(1);
55
+ i0.ɵɵpipe(2, "translate");
56
+ i0.ɵɵelementContainerEnd();
57
+ } if (rf & 2) {
58
+ const doc_r18 = i0.ɵɵnextContext(2).ngIf;
59
+ i0.ɵɵadvance(1);
60
+ i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(2, 1, doc_r18.tipPrefix), " ");
61
+ } }
62
+ const _c0 = function (a0, a1) { return { path: a0, rawUrl: a1, type: "page" }; };
63
+ function ServiceAnnotationsFormComponent_ng_container_2_ng_container_1_ng_container_6_div_1_Template(rf, ctx) { if (rf & 1) {
64
+ i0.ɵɵelementStart(0, "div", 17);
65
+ i0.ɵɵtemplate(1, ServiceAnnotationsFormComponent_ng_container_2_ng_container_1_ng_container_6_div_1_ng_container_1_Template, 3, 3, "ng-container", 8);
66
+ i0.ɵɵelementStart(2, "a", 18);
67
+ i0.ɵɵtext(3);
68
+ i0.ɵɵpipe(4, "translate");
69
+ i0.ɵɵelement(5, "aui-icon", 19);
70
+ i0.ɵɵelementEnd()();
71
+ } if (rf & 2) {
72
+ const doc_r18 = i0.ɵɵnextContext().ngIf;
73
+ i0.ɵɵadvance(1);
74
+ i0.ɵɵproperty("ngIf", doc_r18.tipPrefix);
75
+ i0.ɵɵadvance(1);
76
+ i0.ɵɵproperty("aclDocs", i0.ɵɵpureFunction2(5, _c0, doc_r18.path, doc_r18.rawUrl));
77
+ i0.ɵɵadvance(1);
78
+ i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(4, 3, doc_r18.tip), " ");
79
+ } }
80
+ function ServiceAnnotationsFormComponent_ng_container_2_ng_container_1_ng_container_6_Template(rf, ctx) { if (rf & 1) {
81
+ i0.ɵɵelementContainerStart(0);
82
+ i0.ɵɵtemplate(1, ServiceAnnotationsFormComponent_ng_container_2_ng_container_1_ng_container_6_div_1_Template, 6, 8, "div", 5);
83
+ i0.ɵɵpipe(2, "pure");
84
+ i0.ɵɵelementContainerEnd();
85
+ } if (rf & 2) {
86
+ const doc_r18 = ctx.ngIf;
87
+ const ctx_r11 = i0.ɵɵnextContext(3);
88
+ i0.ɵɵadvance(1);
89
+ i0.ɵɵproperty("ngIf", i0.ɵɵpipeBind3(2, 1, ctx_r11.baseHref, ctx_r11.showDocLink, doc_r18.product));
90
+ } }
91
+ function ServiceAnnotationsFormComponent_ng_container_2_ng_container_1_aui_suggestion_12_div_2_Template(rf, ctx) { if (rf & 1) {
92
+ i0.ɵɵelementStart(0, "div", 16);
93
+ i0.ɵɵtext(1);
94
+ i0.ɵɵelementEnd();
95
+ } if (rf & 2) {
96
+ const tip_r25 = ctx.ngIf;
97
+ i0.ɵɵadvance(1);
98
+ i0.ɵɵtextInterpolate1(" ", tip_r25, " ");
99
+ } }
100
+ function ServiceAnnotationsFormComponent_ng_container_2_ng_container_1_aui_suggestion_12_Template(rf, ctx) { if (rf & 1) {
101
+ i0.ɵɵelementStart(0, "aui-suggestion", 15);
102
+ i0.ɵɵtext(1);
103
+ i0.ɵɵtemplate(2, ServiceAnnotationsFormComponent_ng_container_2_ng_container_1_aui_suggestion_12_div_2_Template, 2, 1, "div", 14);
104
+ i0.ɵɵpipe(3, "translate");
105
+ i0.ɵɵelementEnd();
106
+ } if (rf & 2) {
107
+ const option_r23 = ctx.$implicit;
108
+ i0.ɵɵproperty("value", option_r23.value);
109
+ i0.ɵɵadvance(1);
110
+ i0.ɵɵtextInterpolate1(" ", option_r23.value, " ");
111
+ i0.ɵɵadvance(1);
112
+ i0.ɵɵproperty("ngIf", i0.ɵɵpipeBind1(3, 3, option_r23.tip));
113
+ } }
114
+ function ServiceAnnotationsFormComponent_ng_container_2_ng_container_1_div_14_div_1_Template(rf, ctx) { if (rf & 1) {
115
+ i0.ɵɵelementStart(0, "div", 24);
116
+ i0.ɵɵtext(1);
117
+ i0.ɵɵpipe(2, "translate");
118
+ i0.ɵɵelementEnd();
119
+ } if (rf & 2) {
120
+ i0.ɵɵadvance(1);
121
+ i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(2, 1, "read_filling_instructions_tip"), " ");
122
+ } }
123
+ const _c1 = function (a0) { return { example: a0 }; };
124
+ function ServiceAnnotationsFormComponent_ng_container_2_ng_container_1_div_14_Template(rf, ctx) { if (rf & 1) {
125
+ const _r29 = i0.ɵɵgetCurrentView();
126
+ i0.ɵɵelementStart(0, "div", 16);
127
+ i0.ɵɵtemplate(1, ServiceAnnotationsFormComponent_ng_container_2_ng_container_1_div_14_div_1_Template, 3, 3, "div", 20);
128
+ i0.ɵɵelementStart(2, "div", 21);
129
+ i0.ɵɵtext(3);
130
+ i0.ɵɵpipe(4, "translate");
131
+ i0.ɵɵelementStart(5, "aui-icon", 22);
132
+ i0.ɵɵlistener("click", function ServiceAnnotationsFormComponent_ng_container_2_ng_container_1_div_14_Template_aui_icon_click_5_listener() { const restoredCtx = i0.ɵɵrestoreView(_r29); const valueConfig_r26 = restoredCtx.ngIf; const control_r5 = i0.ɵɵnextContext(2).$implicit; return i0.ɵɵresetView(control_r5.get("1").setValue(valueConfig_r26.example)); });
133
+ i0.ɵɵelementEnd()();
134
+ i0.ɵɵelementStart(6, "a", 23);
135
+ i0.ɵɵtext(7);
136
+ i0.ɵɵpipe(8, "translate");
137
+ i0.ɵɵelement(9, "aui-icon", 19);
138
+ i0.ɵɵelementEnd()();
139
+ } if (rf & 2) {
140
+ const valueConfig_r26 = ctx.ngIf;
141
+ const control_r5 = i0.ɵɵnextContext(2).$implicit;
142
+ i0.ɵɵadvance(1);
143
+ i0.ɵɵproperty("ngIf", control_r5.get("1").value === valueConfig_r26.example);
144
+ i0.ɵɵadvance(2);
145
+ i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind2(4, 4, valueConfig_r26.tip, i0.ɵɵpureFunction1(9, _c1, valueConfig_r26.example)), " ");
146
+ i0.ɵɵadvance(3);
147
+ i0.ɵɵproperty("href", valueConfig_r26.docLink, i0.ɵɵsanitizeUrl);
148
+ i0.ɵɵadvance(1);
149
+ i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(8, 7, "filling_instructions"), " ");
150
+ } }
151
+ function ServiceAnnotationsFormComponent_ng_container_2_ng_container_1_Template(rf, ctx) { if (rf & 1) {
152
+ const _r33 = i0.ɵɵgetCurrentView();
153
+ i0.ɵɵelementContainerStart(0);
154
+ i0.ɵɵelementStart(1, "td", 6)(2, "input", 9);
155
+ i0.ɵɵlistener("blur", function ServiceAnnotationsFormComponent_ng_container_2_ng_container_1_Template_input_blur_2_listener() { i0.ɵɵrestoreView(_r33); const ctx_r32 = i0.ɵɵnextContext(2); return i0.ɵɵresetView(ctx_r32.onBlur()); })("auiAutocompleteSelected", function ServiceAnnotationsFormComponent_ng_container_2_ng_container_1_Template_input_auiAutocompleteSelected_2_listener() { i0.ɵɵrestoreView(_r33); const control_r5 = i0.ɵɵnextContext().$implicit; const ctx_r34 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r34.onKeySelected(control_r5)); });
156
+ i0.ɵɵelementEnd();
157
+ i0.ɵɵelementStart(3, "aui-autocomplete", null, 10);
158
+ i0.ɵɵtemplate(5, ServiceAnnotationsFormComponent_ng_container_2_ng_container_1_aui_suggestion_5_Template, 4, 5, "aui-suggestion", 11);
159
+ i0.ɵɵelementEnd();
160
+ i0.ɵɵtemplate(6, ServiceAnnotationsFormComponent_ng_container_2_ng_container_1_ng_container_6_Template, 3, 5, "ng-container", 8);
161
+ i0.ɵɵpipe(7, "pure");
162
+ i0.ɵɵelementEnd();
163
+ i0.ɵɵelementStart(8, "td", 6)(9, "input", 12);
164
+ i0.ɵɵlistener("blur", function ServiceAnnotationsFormComponent_ng_container_2_ng_container_1_Template_input_blur_9_listener() { i0.ɵɵrestoreView(_r33); const ctx_r36 = i0.ɵɵnextContext(2); return i0.ɵɵresetView(ctx_r36.onBlur()); });
165
+ i0.ɵɵelementEnd();
166
+ i0.ɵɵelementStart(10, "aui-autocomplete", null, 13);
167
+ i0.ɵɵtemplate(12, ServiceAnnotationsFormComponent_ng_container_2_ng_container_1_aui_suggestion_12_Template, 4, 5, "aui-suggestion", 11);
168
+ i0.ɵɵpipe(13, "pure");
169
+ i0.ɵɵelementEnd();
170
+ i0.ɵɵtemplate(14, ServiceAnnotationsFormComponent_ng_container_2_ng_container_1_div_14_Template, 10, 11, "div", 14);
171
+ i0.ɵɵpipe(15, "pure");
172
+ i0.ɵɵelementEnd();
173
+ i0.ɵɵelementContainerEnd();
174
+ } if (rf & 2) {
175
+ const __r8 = ctx.ngIf;
176
+ const _r9 = i0.ɵɵreference(4);
177
+ const _r12 = i0.ɵɵreference(11);
178
+ const ctx_r37 = i0.ɵɵnextContext();
179
+ const index_r6 = ctx_r37.index;
180
+ const control_r5 = ctx_r37.$implicit;
181
+ const ctx_r7 = i0.ɵɵnextContext();
182
+ let tmp_3_0;
183
+ let tmp_6_0;
184
+ let tmp_7_0;
185
+ i0.ɵɵadvance(2);
186
+ i0.ɵɵproperty("readonly", __r8.readonly)("auiAutocomplete", _r9);
187
+ i0.ɵɵadvance(3);
188
+ i0.ɵɵproperty("ngForOf", __r8.readonly ? null : ctx_r7.filterOptions(__r8.config == null ? null : __r8.config.options, index_r6));
189
+ i0.ɵɵadvance(1);
190
+ i0.ɵɵproperty("ngIf", (tmp_3_0 = i0.ɵɵpipeBind3(7, 8, __r8.config == null ? null : __r8.config.options, ctx_r7.getActiveConfigOption, control_r5.get("0").value)) == null ? null : tmp_3_0.doc);
191
+ i0.ɵɵadvance(3);
192
+ i0.ɵɵproperty("readonly", __r8.readonly)("auiAutocomplete", _r12);
193
+ i0.ɵɵadvance(3);
194
+ i0.ɵɵproperty("ngForOf", __r8.readonly ? null : (tmp_6_0 = i0.ɵɵpipeBind3(13, 12, __r8.config == null ? null : __r8.config.options, ctx_r7.getConfigOption, control_r5.get("0").value)) == null ? null : tmp_6_0.values);
195
+ i0.ɵɵadvance(2);
196
+ i0.ɵɵproperty("ngIf", (tmp_7_0 = i0.ɵɵpipeBind3(15, 16, __r8.config == null ? null : __r8.config.options, ctx_r7.getActiveConfigOption, control_r5.get("0").value)) == null ? null : tmp_7_0.value);
197
+ } }
198
+ const _c2 = function (a0, a1) { return { config: a0, readonly: a1 }; };
199
+ function ServiceAnnotationsFormComponent_ng_container_2_Template(rf, ctx) { if (rf & 1) {
200
+ i0.ɵɵelementContainerStart(0, 7);
201
+ i0.ɵɵtemplate(1, ServiceAnnotationsFormComponent_ng_container_2_ng_container_1_Template, 16, 20, "ng-container", 8);
202
+ i0.ɵɵelementContainerEnd();
203
+ } if (rf & 2) {
204
+ const control_r5 = ctx.$implicit;
205
+ const index_r6 = ctx.index;
206
+ const ctx_r1 = i0.ɵɵnextContext();
207
+ i0.ɵɵproperty("formGroupName", index_r6);
208
+ i0.ɵɵadvance(1);
209
+ i0.ɵɵproperty("ngIf", i0.ɵɵpureFunction2(2, _c2, ctx_r1.KNOWN_ANNOTATIONS[ctx_r1.clusterType], ctx_r1.isLabelReadonly(control_r5)));
210
+ } }
211
+ function ServiceAnnotationsFormComponent_ng_container_3_td_1_ng_container_1_Template(rf, ctx) { if (rf & 1) {
212
+ i0.ɵɵelementContainerStart(0);
213
+ i0.ɵɵtext(1);
214
+ i0.ɵɵpipe(2, "translate");
215
+ i0.ɵɵelementContainerEnd();
216
+ } if (rf & 2) {
217
+ i0.ɵɵadvance(1);
218
+ i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(2, 1, "k8s_resource_label_key_required"), " ");
219
+ } }
220
+ function ServiceAnnotationsFormComponent_ng_container_3_td_1_ng_container_2_Template(rf, ctx) { if (rf & 1) {
221
+ i0.ɵɵelementContainerStart(0);
222
+ i0.ɵɵtext(1);
223
+ i0.ɵɵpipe(2, "translate");
224
+ i0.ɵɵelementContainerEnd();
225
+ } if (rf & 2) {
226
+ i0.ɵɵadvance(1);
227
+ i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(2, 1, "k8s_resource_label_key_duplicated"), " ");
228
+ } }
229
+ function ServiceAnnotationsFormComponent_ng_container_3_td_1_Template(rf, ctx) { if (rf & 1) {
230
+ i0.ɵɵelementStart(0, "td", 26);
231
+ i0.ɵɵtemplate(1, ServiceAnnotationsFormComponent_ng_container_3_td_1_ng_container_1_Template, 3, 3, "ng-container", 8);
232
+ i0.ɵɵtemplate(2, ServiceAnnotationsFormComponent_ng_container_3_td_1_ng_container_2_Template, 3, 3, "ng-container", 8);
233
+ i0.ɵɵelement(3, "acl-errors-mapper", 27);
234
+ i0.ɵɵpipe(4, "async");
235
+ i0.ɵɵelement(5, "acl-errors-mapper", 28);
236
+ i0.ɵɵelementEnd();
237
+ } if (rf & 2) {
238
+ const control_r38 = i0.ɵɵnextContext().$implicit;
239
+ const ctx_r39 = i0.ɵɵnextContext();
240
+ i0.ɵɵadvance(1);
241
+ i0.ɵɵproperty("ngIf", control_r38.errors == null ? null : control_r38.errors.keyIsMissing);
242
+ i0.ɵɵadvance(1);
243
+ i0.ɵɵproperty("ngIf", control_r38.errors == null ? null : control_r38.errors.duplicateError);
244
+ i0.ɵɵadvance(1);
245
+ i0.ɵɵproperty("errors", control_r38.get("0").errors)("errorsMapper", i0.ɵɵpipeBind1(4, 5, ctx_r39.annotationsErrorsMapper).key);
246
+ i0.ɵɵadvance(2);
247
+ i0.ɵɵproperty("errors", control_r38.get("1").errors);
248
+ } }
249
+ function ServiceAnnotationsFormComponent_ng_container_3_Template(rf, ctx) { if (rf & 1) {
250
+ i0.ɵɵelementContainerStart(0);
251
+ i0.ɵɵtemplate(1, ServiceAnnotationsFormComponent_ng_container_3_td_1_Template, 6, 7, "td", 25);
252
+ i0.ɵɵelementContainerEnd();
253
+ } if (rf & 2) {
254
+ const control_r38 = ctx.$implicit;
255
+ i0.ɵɵadvance(1);
256
+ i0.ɵɵproperty("ngIf", control_r38.invalid);
257
+ } }
258
+ function ServiceAnnotationsFormComponent_ng_container_4_Template(rf, ctx) { if (rf & 1) {
259
+ const _r46 = i0.ɵɵgetCurrentView();
260
+ i0.ɵɵelementContainerStart(0);
261
+ i0.ɵɵelementStart(1, "button", 29);
262
+ i0.ɵɵlistener("click", function ServiceAnnotationsFormComponent_ng_container_4_Template_button_click_1_listener() { const restoredCtx = i0.ɵɵrestoreView(_r46); const index_r44 = restoredCtx.index; const ctx_r45 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r45.remove(index_r44)); });
263
+ i0.ɵɵelement(2, "aui-icon", 30);
264
+ i0.ɵɵelementEnd();
265
+ i0.ɵɵelementContainerEnd();
266
+ } if (rf & 2) {
267
+ const item_r43 = ctx.$implicit;
268
+ const ctx_r3 = i0.ɵɵnextContext();
269
+ i0.ɵɵadvance(1);
270
+ i0.ɵɵproperty("square", true)("plain", true)("disabled", ctx_r3.isLabelReadonly(item_r43));
271
+ } }
272
+ function ServiceAnnotationsFormComponent_div_6_ng_container_2_Template(rf, ctx) { if (rf & 1) {
273
+ i0.ɵɵelementContainerStart(0);
274
+ i0.ɵɵtext(1);
275
+ i0.ɵɵelementContainerEnd();
276
+ } if (rf & 2) {
277
+ const text_r51 = ctx.$implicit;
278
+ i0.ɵɵadvance(1);
279
+ i0.ɵɵtextInterpolate(text_r51);
280
+ } }
281
+ function ServiceAnnotationsFormComponent_div_6_ng_container_3_Template(rf, ctx) { if (rf & 1) {
282
+ i0.ɵɵelementContainerStart(0);
283
+ i0.ɵɵtext(1);
284
+ i0.ɵɵelementContainerEnd();
285
+ } if (rf & 2) {
286
+ const config_r47 = i0.ɵɵnextContext().ngIf;
287
+ i0.ɵɵadvance(1);
288
+ i0.ɵɵtextInterpolate(config_r47.label);
289
+ } }
290
+ function ServiceAnnotationsFormComponent_div_6_a_4_Template(rf, ctx) { if (rf & 1) {
291
+ i0.ɵɵelementStart(0, "a", 35);
292
+ i0.ɵɵtext(1);
293
+ i0.ɵɵpipe(2, "translate");
294
+ i0.ɵɵelement(3, "aui-icon", 19);
295
+ i0.ɵɵelementEnd();
296
+ } if (rf & 2) {
297
+ const config_r47 = i0.ɵɵnextContext().ngIf;
298
+ i0.ɵɵproperty("href", config_r47.docLink, i0.ɵɵsanitizeUrl);
299
+ i0.ɵɵadvance(1);
300
+ i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(2, 2, "documentation"), " ");
301
+ } }
302
+ function ServiceAnnotationsFormComponent_div_6_Template(rf, ctx) { if (rf & 1) {
303
+ i0.ɵɵelementStart(0, "div", 17);
304
+ i0.ɵɵelementContainerStart(1, 31);
305
+ i0.ɵɵtemplate(2, ServiceAnnotationsFormComponent_div_6_ng_container_2_Template, 2, 1, "ng-container", 32);
306
+ i0.ɵɵtemplate(3, ServiceAnnotationsFormComponent_div_6_ng_container_3_Template, 2, 1, "ng-container", 33);
307
+ i0.ɵɵtemplate(4, ServiceAnnotationsFormComponent_div_6_a_4_Template, 4, 4, "a", 34);
308
+ i0.ɵɵelementContainerEnd();
309
+ i0.ɵɵelementEnd();
310
+ } if (rf & 2) {
311
+ i0.ɵɵadvance(1);
312
+ i0.ɵɵproperty("aclTranslate", "documentation_for_lb_service_annotations");
313
+ i0.ɵɵadvance(2);
314
+ i0.ɵɵproperty("aclTranslateMatch", "type");
315
+ i0.ɵɵadvance(1);
316
+ i0.ɵɵproperty("aclTranslateMatch", "documentation");
317
+ } }
318
+ const _c3 = ["*"];
319
+ var PRODUCT_BASE_HREF_MAP;
320
+ (function (PRODUCT_BASE_HREF_MAP) {
321
+ PRODUCT_BASE_HREF_MAP["devops"] = "/console-devops/";
322
+ PRODUCT_BASE_HREF_MAP["acp"] = "/console-acp/";
323
+ PRODUCT_BASE_HREF_MAP["asm"] = "/console-asm/";
324
+ PRODUCT_BASE_HREF_MAP["dataservices"] = "/console-dataservices/";
325
+ PRODUCT_BASE_HREF_MAP["cec"] = "/console-cec/";
326
+ PRODUCT_BASE_HREF_MAP["platform"] = "/console-platform/";
327
+ })(PRODUCT_BASE_HREF_MAP || (PRODUCT_BASE_HREF_MAP = {}));
328
+ export const KNOWN_ANNOTATIONS = {
329
+ [ClusterType.AzureAKS]: {
330
+ label: 'AKS',
331
+ docLink: 'https://cloud-provider-azure.sigs.k8s.io/topics/loadbalancer/#loadbalancer-annotations',
332
+ options: [
333
+ {
334
+ key: 'service.beta.kubernetes.io/azure-load-balancer-internal',
335
+ tip: {
336
+ en: 'Specify the use of intranet/public network',
337
+ zh: '指定使用内网/公网',
338
+ },
339
+ values: [
340
+ {
341
+ value: TRUE,
342
+ tip: {
343
+ en: 'Intranet',
344
+ zh: '内网',
345
+ },
346
+ },
347
+ {
348
+ value: FALSE,
349
+ tip: {
350
+ en: 'Public network',
351
+ zh: '公网',
352
+ },
353
+ },
354
+ ],
355
+ },
356
+ ],
357
+ },
358
+ [ClusterType.AmazonEKS]: {
359
+ label: 'EKS',
360
+ docLink: 'https://kubernetes-sigs.github.io/aws-load-balancer-controller/v2.5/guide/service/annotations/',
361
+ options: [
362
+ {
363
+ key: 'service.beta.kubernetes.io/aws-load-balancer-type',
364
+ tip: {
365
+ en: 'Specify the LoadBalancer Service Controller in use',
366
+ zh: '指定所使用的 LoadBalancer 类型内部路由控制器',
367
+ },
368
+ doc: {
369
+ tip: {
370
+ en: 'Controller Installation',
371
+ zh: '控制器安装',
372
+ },
373
+ product: 'platform',
374
+ path: 'platform-usermanual/clusterall/1cluster/cloudinit/network1/eksingresscontroller/#2',
375
+ },
376
+ values: [
377
+ {
378
+ value: 'external',
379
+ tip: {
380
+ en: 'Using the official AWS LoadBalancer Controller',
381
+ zh: '使用 AWS 官方的 AWS LoadBalancer Controller',
382
+ },
383
+ },
384
+ ],
385
+ },
386
+ {
387
+ key: 'service.beta.kubernetes.io/aws-load-balancer-nlb-target-type',
388
+ tip: {
389
+ en: 'Specify the way traffic is delivered to the pods',
390
+ zh: '指定流量送达容器组的方式',
391
+ },
392
+ values: [
393
+ {
394
+ value: 'instance',
395
+ tip: {
396
+ en: 'Traffic will be sent to the pods via NodePort',
397
+ zh: '流量将通过 NodePort 送往容器组',
398
+ },
399
+ },
400
+ {
401
+ value: 'ip',
402
+ tip: {
403
+ en: 'Traffic is directly routed to the pods (Amazon VPC CNI is required for the cluster)',
404
+ zh: '流量直接路由到容器组(集群需使用 Amazon VPC CNI)',
405
+ },
406
+ },
407
+ ],
408
+ },
409
+ {
410
+ key: 'service.beta.kubernetes.io/aws-load-balancer-scheme',
411
+ tip: {
412
+ en: 'Specify the use of intranet/public network',
413
+ zh: '指定使用内网/公网',
414
+ },
415
+ values: [
416
+ {
417
+ value: 'internal',
418
+ tip: {
419
+ en: 'Intranet',
420
+ zh: '内网',
421
+ },
422
+ },
423
+ {
424
+ value: 'internet-facing',
425
+ tip: {
426
+ en: 'Public network',
427
+ zh: '公网',
428
+ },
429
+ },
430
+ ],
431
+ },
432
+ {
433
+ key: 'service.beta.kubernetes.io/aws-load-balancer-ip-address-type',
434
+ tip: {
435
+ en: 'Specify the supported IP protocol stack',
436
+ zh: '指定支持的 IP 协议栈',
437
+ },
438
+ values: [
439
+ {
440
+ value: 'ipv4',
441
+ },
442
+ {
443
+ value: 'dualstack',
444
+ },
445
+ ],
446
+ },
447
+ ],
448
+ },
449
+ [ClusterType.HuaweiCloudCCE]: {
450
+ label: 'CCE',
451
+ docLink: 'https://support.huaweicloud.com/intl/en-us/usermanual-cce/cce_10_0385.html',
452
+ options: [
453
+ {
454
+ key: 'kubernetes.io/elb.id',
455
+ tip: {
456
+ en: 'Please provide the ID of the cloud LoadBalancer, You should use an existing cloud LoadBalancer.',
457
+ zh: '填写云上负载均衡器的 ID,需使用已有云上负载均衡器',
458
+ },
459
+ },
460
+ {
461
+ key: 'kubernetes.io/elb.autocreate',
462
+ tip: {
463
+ en: 'Create a new cloud LoadBalancer',
464
+ zh: '新创建云上负载均衡器',
465
+ },
466
+ value: {
467
+ example: `{"type":"public","bandwidth_name":"cce-bandwidth-1551163379627","bandwidth_chargemode":"bandwidth","bandwidth_size":5,"bandwidth_sharetype":"PER","eip_type":"5_bgp","available_zone":["cn-north-4b"],"l4_flavor_name":"L4_flavor.elb.s1.small"}`,
468
+ tip: {
469
+ en: 'For example: {{ example }}',
470
+ zh: '例如:{{ example }}',
471
+ },
472
+ docLink: 'https://support.huaweicloud.com/intl/en-us/usermanual-cce/cce_10_0385.html#section8',
473
+ },
474
+ },
475
+ {
476
+ key: 'kubernetes.io/elb.subnet-id',
477
+ tip: {
478
+ en: 'Subnet ID of the cluster, which is required when creating a new cloud LoadBalancer and Kubernetes version is 1.11.7-r0 and below.',
479
+ zh: '集群所在子网的 ID,当 Kubernetes 版本为 1.11.7-r0 及以下,新创建云上负载均衡器时必须填写此项',
480
+ },
481
+ },
482
+ {
483
+ key: 'kubernetes.io/elb.class',
484
+ tip: {
485
+ en: 'Specify the type of the newly created cloud LoadBalancer',
486
+ zh: '指定新创建的云上负载均衡器的类型',
487
+ },
488
+ doc: {
489
+ tip: {
490
+ en: 'Differences Between Dedicated and Shared Load Balancers',
491
+ zh: '共享型弹性负载均衡与独享型负载均衡的功能区别',
492
+ },
493
+ rawUrl: 'https://support.huaweicloud.com/intl/zh-cn/productdesc-elb/elb_pro_0004.html',
494
+ tipPrefix: {
495
+ en: 'For more details, please refer to ',
496
+ zh: '详情请参见',
497
+ },
498
+ },
499
+ values: [
500
+ {
501
+ value: 'union',
502
+ tip: {
503
+ en: 'Shared LoadBalancer',
504
+ zh: '共享型负载均衡',
505
+ },
506
+ },
507
+ {
508
+ value: 'performance',
509
+ tip: {
510
+ en: 'Dedicated LoadBalancer, which can be used only in clusters of v1.17 and later',
511
+ zh: '独享型负载均衡,仅支持在 Kubernetes 版本为 1.17 及以上的集群中使用',
512
+ },
513
+ },
514
+ ],
515
+ },
516
+ {
517
+ key: 'kubernetes.io/elb.enterpriseID',
518
+ tip: {
519
+ en: 'Specify the enterprise project to which the newly created cloud LoadBalancer will belong',
520
+ zh: '指定新创建云上负载均衡器所属的企业项目',
521
+ },
522
+ },
523
+ ],
524
+ },
525
+ [ClusterType.GoogleCloudGKE]: {
526
+ label: 'GKE',
527
+ docLink: 'https://cloud.google.com/kubernetes-engine/docs/concepts/service-load-balancer-parameters',
528
+ options: [
529
+ {
530
+ key: 'networking.gke.io/load-balancer-type',
531
+ tip: {
532
+ en: 'Specify the use of Intranet',
533
+ zh: '指定使用内网',
534
+ },
535
+ values: [
536
+ {
537
+ value: 'Internal',
538
+ },
539
+ ],
540
+ },
541
+ {
542
+ key: 'cloud.google.com/l4-rbs',
543
+ tip: {
544
+ en: 'The default is public network, when this parameter is configured, traffic will be routed directly to the pods',
545
+ zh: '默认为公网,配置此参数时,流量将直接路由至容器组',
546
+ },
547
+ values: [
548
+ {
549
+ value: 'enabled',
550
+ },
551
+ ],
552
+ },
553
+ ],
554
+ },
555
+ };
556
+ export class ServiceAnnotationsFormComponent extends BaseStringMapFormComponent {
557
+ constructor(injector, baseDomain) {
558
+ super(injector);
559
+ this.baseDomain = baseDomain;
560
+ this.translate = inject(TranslateService);
561
+ this.baseHref = inject(TOKEN_BASE_HREF);
562
+ // 禁用掉包含 cpaas.io 及 ovn.kubernetes.io 的 key
563
+ this.readonlyPartialKeys = ['ovn.kubernetes.io', this.baseDomain];
564
+ this.annotationsErrorsMapper = getK8sResourceAnnotationErrorMapper$(this.translate);
565
+ this.KNOWN_ANNOTATIONS = KNOWN_ANNOTATIONS;
566
+ }
567
+ filterOptions(options, index) {
568
+ const keys = this.form.value.map(([key]) => key);
569
+ return options?.filter(o => {
570
+ const keyIndex = keys.indexOf(o.key);
571
+ return keyIndex === -1 || keyIndex === index;
572
+ });
573
+ }
574
+ getConfigOption(options, key) {
575
+ return options?.find(option => option.key === key);
576
+ }
577
+ isReadonly(key) {
578
+ return this.isUpdate && this.readonlyPartialKeys.some(k => key.includes(k));
579
+ }
580
+ getDefaultFormModel() {
581
+ return [['', '']];
582
+ }
583
+ adaptResourceModel(resource) {
584
+ let newFormModel = Object.entries(resource || {});
585
+ // 排序,先按字母排序,再把 readonly 的放前面
586
+ newFormModel = sortBy(newFormModel, (arr) => arr[0]);
587
+ newFormModel.sort((arr1, arr2) => {
588
+ const flag1 = this.isReadonly(arr1[0]);
589
+ const flag2 = this.isReadonly(arr2[0]);
590
+ if ((flag1 && flag2) || (!flag1 && !flag2)) {
591
+ return 0;
592
+ }
593
+ return flag1 ? -1 : 1;
594
+ });
595
+ if (newFormModel.length === 0) {
596
+ newFormModel = this.getDefaultFormModel();
597
+ }
598
+ return newFormModel;
599
+ }
600
+ getKeyValidators() {
601
+ return k8sResourceAnnotationKeyValidator;
602
+ }
603
+ isLabelReadonly(control) {
604
+ return control.valid && this.isReadonly(control.get('0').value);
605
+ }
606
+ getActiveConfigOption(options, key) {
607
+ return options?.find(o => o.key === key);
608
+ }
609
+ onKeySelected(control) {
610
+ const keyCtrl = control.get('0');
611
+ keyCtrl.markAsDirty();
612
+ keyCtrl.updateValueAndValidity();
613
+ }
614
+ // AnnotationConfigOption.doc 配置了产品 (product)属性之后需要当前视图隶属于该产品时才展示 doc 链接,未配置的话不受限制
615
+ showDocLink(baseHref, product) {
616
+ if (!product) {
617
+ return true;
618
+ }
619
+ return PRODUCT_BASE_HREF_MAP[product] === baseHref;
620
+ }
621
+ static { this.ɵfac = function ServiceAnnotationsFormComponent_Factory(t) { return new (t || ServiceAnnotationsFormComponent)(i0.ɵɵdirectiveInject(i0.Injector), i0.ɵɵdirectiveInject(TOKEN_BASE_DOMAIN)); }; }
622
+ static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: ServiceAnnotationsFormComponent, selectors: [["acl-service-annotations-form"]], inputs: { isUpdate: "isUpdate", clusterType: "clusterType", resourceName: "resourceName" }, standalone: true, features: [i0.ɵɵInheritDefinitionFeature, i0.ɵɵStandaloneFeature], ngContentSelectors: _c3, decls: 7, vars: 4, consts: [[3, "formGroup", "rows", "resourceName", "add", "remove"], [4, "aclArrayFormTableHeader"], [3, "formGroupName", 4, "aclArrayFormTableRow"], [4, "aclArrayFormTableRowError"], [4, "aclArrayFormTableRowControl"], ["class", "tw-text-help-text tw-text-s tw-mt-4", 4, "ngIf"], [1, "column"], [3, "formGroupName"], [4, "ngIf"], ["aui-input", "", "formControlName", "0", 3, "readonly", "auiAutocomplete", "blur", "auiAutocompleteSelected"], ["keySuggestion", ""], [3, "value", 4, "ngFor", "ngForOf"], ["aui-input", "", "formControlName", "1", 3, "readonly", "auiAutocomplete", "blur"], ["valueSuggestion", ""], ["class", "tw-text-help-text tw-text-s", 4, "ngIf"], [3, "value"], [1, "tw-text-help-text", "tw-text-s"], [1, "tw-text-help-text", "tw-text-s", "tw-mt-4"], [3, "aclDocs"], ["icon", "jump"], ["class", "tw-text-yellow tw-mt-4", 4, "ngIf"], [1, "tw-break-all", "tw-my-4"], ["icon", "arrow_turn_up", 1, "tw-text-primary", "tw-cursor-pointer", 3, "click"], ["rel", "noopener noreferrer", "target", "_blank", 3, "href"], [1, "tw-text-yellow", "tw-mt-4"], ["colspan", "3", "class", "acl-table-form-error-hint", 4, "ngIf"], ["colspan", "3", 1, "acl-table-form-error-hint"], ["auiFormItemError", "", 3, "errors", "errorsMapper"], ["auiFormItemError", "", 3, "errors"], ["aui-button", "text", "type", "button", 3, "square", "plain", "disabled", "click"], ["icon", "minus_circle"], [3, "aclTranslate"], [4, "aclTranslateText"], [4, "aclTranslateMatch"], ["target", "_blank", "rel", "noopener noreferrer", 3, "href", 4, "aclTranslateMatch"], ["target", "_blank", "rel", "noopener noreferrer", 3, "href"]], template: function ServiceAnnotationsFormComponent_Template(rf, ctx) { if (rf & 1) {
623
+ i0.ɵɵprojectionDef();
624
+ i0.ɵɵelementStart(0, "acl-array-form-table", 0);
625
+ i0.ɵɵlistener("add", function ServiceAnnotationsFormComponent_Template_acl_array_form_table_add_0_listener() { return ctx.form.push(ctx.createNewControl()); })("remove", function ServiceAnnotationsFormComponent_Template_acl_array_form_table_remove_0_listener($event) { return ctx.remove($event); });
626
+ i0.ɵɵtemplate(1, ServiceAnnotationsFormComponent_ng_container_1_Template, 7, 6, "ng-container", 1);
627
+ i0.ɵɵtemplate(2, ServiceAnnotationsFormComponent_ng_container_2_Template, 2, 5, "ng-container", 2);
628
+ i0.ɵɵtemplate(3, ServiceAnnotationsFormComponent_ng_container_3_Template, 2, 1, "ng-container", 3);
629
+ i0.ɵɵtemplate(4, ServiceAnnotationsFormComponent_ng_container_4_Template, 3, 3, "ng-container", 4);
630
+ i0.ɵɵelementEnd();
631
+ i0.ɵɵprojection(5);
632
+ i0.ɵɵtemplate(6, ServiceAnnotationsFormComponent_div_6_Template, 5, 3, "div", 5);
633
+ } if (rf & 2) {
634
+ i0.ɵɵproperty("formGroup", ctx.form)("rows", ctx.form.controls)("resourceName", ctx.resourceName);
635
+ i0.ɵɵadvance(6);
636
+ i0.ɵɵproperty("ngIf", ctx.KNOWN_ANNOTATIONS[ctx.clusterType]);
637
+ } }, dependencies: [AsyncPipe,
638
+ NgIf,
639
+ NgForOf,
640
+ ReactiveFormsModule, i1.DefaultValueAccessor, i1.NgControlStatus, i1.NgControlStatusGroup, i1.FormGroupDirective, i1.FormControlName, i1.FormGroupName, TranslateModule, i2.TranslateDirective, i2.TranslateMatchDirective, i2.TranslateTextDirective, i2.TranslatePipe, AutocompleteModule, i3.AutoCompleteDirective, i3.AutocompleteComponent, i3.SuggestionComponent, ButtonModule, i3.ButtonComponent, IconModule, i3.IconComponent, InputModule, i3.InputComponent, ArrayFormTableComponent,
641
+ ArrayFormTableHeaderDirective,
642
+ ArrayFormTableRowDirective,
643
+ ArrayFormTableRowControlDirective,
644
+ ArrayFormTableRowErrorDirective,
645
+ ErrorsMapperModule, i2.ErrorsMapperComponent, HelpDocumentModule, i2.DocsDirective, PurePipe], styles: ["[_nghost-%COMP%]{flex:1}.column[_ngcontent-%COMP%]{width:50%;vertical-align:top}"], changeDetection: 0 }); }
646
+ }
647
+ (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ServiceAnnotationsFormComponent, [{
648
+ type: Component,
649
+ args: [{ selector: 'acl-service-annotations-form', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [
650
+ AsyncPipe,
651
+ NgIf,
652
+ NgForOf,
653
+ ReactiveFormsModule,
654
+ TranslateModule,
655
+ AutocompleteModule,
656
+ ButtonModule,
657
+ IconModule,
658
+ InputModule,
659
+ ArrayFormTableComponent,
660
+ ArrayFormTableHeaderDirective,
661
+ ArrayFormTableRowDirective,
662
+ ArrayFormTableRowControlDirective,
663
+ ArrayFormTableRowErrorDirective,
664
+ ErrorsMapperModule,
665
+ HelpDocumentModule,
666
+ PurePipe,
667
+ ], template: "<acl-array-form-table\n [formGroup]=\"$any(form)\"\n [rows]=\"form.controls\"\n (add)=\"form.push(createNewControl())\"\n (remove)=\"remove($event)\"\n [resourceName]=\"resourceName\"\n>\n <ng-container *aclArrayFormTableHeader>\n <th class=\"column\">{{ 'key' | translate }}</th>\n <th class=\"column\">{{ 'value' | translate }}</th>\n </ng-container>\n\n <ng-container\n *aclArrayFormTableRow=\"let control; let index = index\"\n [formGroupName]=\"index\"\n >\n <ng-container\n *ngIf=\"{\n config: KNOWN_ANNOTATIONS[clusterType],\n readonly: isLabelReadonly(control)\n } as _\"\n >\n <td class=\"column\">\n <input\n aui-input\n [readonly]=\"_.readonly\"\n (blur)=\"onBlur()\"\n formControlName=\"0\"\n [auiAutocomplete]=\"keySuggestion\"\n (auiAutocompleteSelected)=\"onKeySelected(control)\"\n />\n <aui-autocomplete #keySuggestion>\n <aui-suggestion\n *ngFor=\"\n let option of _.readonly\n ? null\n : filterOptions(_.config?.options, index)\n \"\n [value]=\"option.key\"\n >\n {{ option.key }}\n <div\n *ngIf=\"option.tip | translate as tip\"\n class=\"tw-text-help-text tw-text-s\"\n >\n {{ tip }}\n </div>\n </aui-suggestion>\n </aui-autocomplete>\n <ng-container\n *ngIf=\"\n (\n _.config?.options\n | pure: getActiveConfigOption:control.get('0').value\n )?.doc as doc\n \"\n >\n <div\n *ngIf=\"baseHref | pure: showDocLink:doc.product\"\n class=\"tw-text-help-text tw-text-s tw-mt-4\"\n >\n <ng-container *ngIf=\"doc.tipPrefix\">\n {{ doc.tipPrefix | translate }}\n </ng-container>\n <a\n [aclDocs]=\"{\n path: doc.path,\n rawUrl: doc.rawUrl,\n type: 'page',\n }\"\n >\n {{ doc.tip | translate }}\n <aui-icon icon=\"jump\"></aui-icon>\n </a>\n </div>\n </ng-container>\n </td>\n <td class=\"column\">\n <input\n aui-input\n [readonly]=\"_.readonly\"\n (blur)=\"onBlur()\"\n formControlName=\"1\"\n [auiAutocomplete]=\"valueSuggestion\"\n />\n <aui-autocomplete #valueSuggestion>\n <aui-suggestion\n *ngFor=\"\n let option of _.readonly\n ? null\n : (\n _.config?.options\n | pure: getConfigOption:control.get('0').value\n )?.values\n \"\n [value]=\"option.value\"\n >\n {{ option.value }}\n <div\n *ngIf=\"option.tip | translate as tip\"\n class=\"tw-text-help-text tw-text-s\"\n >\n {{ tip }}\n </div>\n </aui-suggestion>\n </aui-autocomplete>\n <div\n *ngIf=\"\n (\n _.config?.options\n | pure: getActiveConfigOption:control.get('0').value\n )?.value as valueConfig\n \"\n class=\"tw-text-help-text tw-text-s\"\n >\n <div\n *ngIf=\"control.get('1').value === valueConfig.example\"\n class=\"tw-text-yellow tw-mt-4\"\n >\n {{ 'read_filling_instructions_tip' | translate }}\n </div>\n <div class=\"tw-break-all tw-my-4\">\n {{ valueConfig.tip | translate: { example: valueConfig.example } }}\n <aui-icon\n class=\"tw-text-primary tw-cursor-pointer\"\n icon=\"arrow_turn_up\"\n (click)=\"control.get('1').setValue(valueConfig.example)\"\n ></aui-icon>\n </div>\n <a\n [href]=\"valueConfig.docLink\"\n rel=\"noopener noreferrer\"\n target=\"_blank\"\n >\n {{ 'filling_instructions' | translate }}\n <aui-icon icon=\"jump\"></aui-icon>\n </a>\n </div>\n </td>\n </ng-container>\n </ng-container>\n\n <ng-container *aclArrayFormTableRowError=\"let control\">\n <td\n *ngIf=\"control.invalid\"\n colspan=\"3\"\n class=\"acl-table-form-error-hint\"\n >\n <ng-container *ngIf=\"control.errors?.keyIsMissing\">\n {{ 'k8s_resource_label_key_required' | translate }}\n </ng-container>\n\n <ng-container *ngIf=\"control.errors?.duplicateError\">\n {{ 'k8s_resource_label_key_duplicated' | translate }}\n </ng-container>\n\n <acl-errors-mapper\n auiFormItemError\n [errors]=\"control.get('0').errors\"\n [errorsMapper]=\"(annotationsErrorsMapper | async).key\"\n ></acl-errors-mapper>\n <acl-errors-mapper\n auiFormItemError\n [errors]=\"control.get('1').errors\"\n ></acl-errors-mapper>\n </td>\n </ng-container>\n\n <ng-container *aclArrayFormTableRowControl=\"let item; let index = index\">\n <button\n aui-button=\"text\"\n type=\"button\"\n [square]=\"true\"\n [plain]=\"true\"\n [disabled]=\"isLabelReadonly(item)\"\n (click)=\"remove(index)\"\n >\n <aui-icon icon=\"minus_circle\"></aui-icon>\n </button>\n </ng-container>\n</acl-array-form-table>\n\n<ng-content></ng-content>\n\n<div\n *ngIf=\"KNOWN_ANNOTATIONS[clusterType] as config\"\n class=\"tw-text-help-text tw-text-s tw-mt-4\"\n>\n <ng-container [aclTranslate]=\"'documentation_for_lb_service_annotations'\">\n <ng-container *aclTranslateText=\"let text\">{{ text }}</ng-container>\n <ng-container *aclTranslateMatch=\"'type'\">{{ config.label }}</ng-container>\n <a\n *aclTranslateMatch=\"'documentation'\"\n [href]=\"config.docLink\"\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n >\n {{ 'documentation' | translate }}\n <aui-icon icon=\"jump\"></aui-icon> </a\n ></ng-container>\n</div>\n", styles: [":host{flex:1}.column{width:50%;vertical-align:top}\n"] }]
668
+ }], function () { return [{ type: i0.Injector }, { type: undefined, decorators: [{
669
+ type: Inject,
670
+ args: [TOKEN_BASE_DOMAIN]
671
+ }] }]; }, { isUpdate: [{
672
+ type: Input,
673
+ args: [{ required: true }]
674
+ }], clusterType: [{
675
+ type: Input,
676
+ args: [{ required: true }]
677
+ }], resourceName: [{
678
+ type: Input,
679
+ args: [{ required: true }]
680
+ }] }); })();
681
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"annotations.component.js","sourceRoot":"","sources":["../../../../../../../modules/network/src/lib/components/service-annotations-form/annotations.component.ts","../../../../../../../modules/network/src/lib/components/service-annotations-form/annotations.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AutocompleteModule,\n  ButtonModule,\n  IconModule,\n  InputModule,\n} from '@alauda/ui';\nimport {\n  ArrayFormTableComponent,\n  ArrayFormTableHeaderDirective,\n  ArrayFormTableRowControlDirective,\n  ArrayFormTableRowDirective,\n  ArrayFormTableRowErrorDirective,\n  BaseStringMapFormComponent,\n  KeyValueTuple,\n  ErrorsMapperModule,\n  FALSE,\n  HelpDocumentModule,\n  Locale,\n  PurePipe,\n  StringMap,\n  TOKEN_BASE_DOMAIN,\n  TOKEN_BASE_HREF,\n  TRUE,\n  TranslateKey,\n  TranslateModule,\n  TranslateService,\n  getK8sResourceAnnotationErrorMapper$,\n  k8sResourceAnnotationKeyValidator,\n} from '@alauda-fe/common';\nimport { AsyncPipe, NgForOf, NgIf } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  Inject,\n  Injector,\n  Input,\n  inject,\n} from '@angular/core';\nimport { FormArray, FormControl, ReactiveFormsModule } from '@angular/forms';\nimport { sortBy } from 'lodash-es';\n\nimport { ClusterType } from '../../utils/cluster-exports';\n\nenum PRODUCT_BASE_HREF_MAP {\n  devops = '/console-devops/',\n  acp = '/console-acp/',\n  asm = '/console-asm/',\n  dataservices = '/console-dataservices/',\n  cec = '/console-cec/',\n  platform = '/console-platform/',\n}\n\nexport interface AnnotationConfigOption {\n  key: string;\n  tip: TranslateKey<Locale>;\n  doc?: {\n    tip: TranslateKey<Locale>;\n    tipPrefix?: TranslateKey<Locale>;\n    path?: string; // 标准文档链接, 对应 DocsOption.path\n    rawUrl?: string; // 非标准文档链接, 对应 DocsOption.rawUrl\n    product?: keyof typeof PRODUCT_BASE_HREF_MAP;\n  };\n  value?: {\n    example: string;\n    tip: TranslateKey<Locale>;\n    docLink: string;\n  };\n  values?: Array<{\n    value: string;\n    tip?: TranslateKey<Locale>;\n  }>;\n}\n\nexport const KNOWN_ANNOTATIONS: Partial<\n  Record<\n    ClusterType,\n    {\n      label: string;\n      docLink: string;\n      options: AnnotationConfigOption[];\n    }\n  >\n> = {\n  [ClusterType.AzureAKS]: {\n    label: 'AKS',\n    docLink:\n      'https://cloud-provider-azure.sigs.k8s.io/topics/loadbalancer/#loadbalancer-annotations',\n    options: [\n      {\n        key: 'service.beta.kubernetes.io/azure-load-balancer-internal',\n        tip: {\n          en: 'Specify the use of intranet/public network',\n          zh: '指定使用内网/公网',\n        },\n        values: [\n          {\n            value: TRUE,\n            tip: {\n              en: 'Intranet',\n              zh: '内网',\n            },\n          },\n          {\n            value: FALSE,\n            tip: {\n              en: 'Public network',\n              zh: '公网',\n            },\n          },\n        ],\n      },\n    ],\n  },\n  [ClusterType.AmazonEKS]: {\n    label: 'EKS',\n    docLink:\n      'https://kubernetes-sigs.github.io/aws-load-balancer-controller/v2.5/guide/service/annotations/',\n    options: [\n      {\n        key: 'service.beta.kubernetes.io/aws-load-balancer-type',\n        tip: {\n          en: 'Specify the LoadBalancer Service Controller in use',\n          zh: '指定所使用的 LoadBalancer 类型内部路由控制器',\n        },\n        doc: {\n          tip: {\n            en: 'Controller Installation',\n            zh: '控制器安装',\n          },\n          product: 'platform',\n          path: 'platform-usermanual/clusterall/1cluster/cloudinit/network1/eksingresscontroller/#2',\n        },\n        values: [\n          {\n            value: 'external',\n            tip: {\n              en: 'Using the official AWS LoadBalancer Controller',\n              zh: '使用 AWS 官方的 AWS LoadBalancer Controller',\n            },\n          },\n        ],\n      },\n      {\n        key: 'service.beta.kubernetes.io/aws-load-balancer-nlb-target-type',\n        tip: {\n          en: 'Specify the way traffic is delivered to the pods',\n          zh: '指定流量送达容器组的方式',\n        },\n        values: [\n          {\n            value: 'instance',\n            tip: {\n              en: 'Traffic will be sent to the pods via NodePort',\n              zh: '流量将通过 NodePort 送往容器组',\n            },\n          },\n          {\n            value: 'ip',\n            tip: {\n              en: 'Traffic is directly routed to the pods (Amazon VPC CNI is required for the cluster)',\n              zh: '流量直接路由到容器组（集群需使用 Amazon VPC CNI）',\n            },\n          },\n        ],\n      },\n      {\n        key: 'service.beta.kubernetes.io/aws-load-balancer-scheme',\n        tip: {\n          en: 'Specify the use of intranet/public network',\n          zh: '指定使用内网/公网',\n        },\n        values: [\n          {\n            value: 'internal',\n            tip: {\n              en: 'Intranet',\n              zh: '内网',\n            },\n          },\n          {\n            value: 'internet-facing',\n            tip: {\n              en: 'Public network',\n              zh: '公网',\n            },\n          },\n        ],\n      },\n      {\n        key: 'service.beta.kubernetes.io/aws-load-balancer-ip-address-type',\n        tip: {\n          en: 'Specify the supported IP protocol stack',\n          zh: '指定支持的 IP 协议栈',\n        },\n        values: [\n          {\n            value: 'ipv4',\n          },\n          {\n            value: 'dualstack',\n          },\n        ],\n      },\n    ],\n  },\n  [ClusterType.HuaweiCloudCCE]: {\n    label: 'CCE',\n    docLink:\n      'https://support.huaweicloud.com/intl/en-us/usermanual-cce/cce_10_0385.html',\n    options: [\n      {\n        key: 'kubernetes.io/elb.id',\n        tip: {\n          en: 'Please provide the ID of the cloud LoadBalancer, You should use an existing cloud LoadBalancer.',\n          zh: '填写云上负载均衡器的 ID，需使用已有云上负载均衡器',\n        },\n      },\n      {\n        key: 'kubernetes.io/elb.autocreate',\n        tip: {\n          en: 'Create a new cloud LoadBalancer',\n          zh: '新创建云上负载均衡器',\n        },\n        value: {\n          example: `{\"type\":\"public\",\"bandwidth_name\":\"cce-bandwidth-1551163379627\",\"bandwidth_chargemode\":\"bandwidth\",\"bandwidth_size\":5,\"bandwidth_sharetype\":\"PER\",\"eip_type\":\"5_bgp\",\"available_zone\":[\"cn-north-4b\"],\"l4_flavor_name\":\"L4_flavor.elb.s1.small\"}`,\n          tip: {\n            en: 'For example: {{ example }}',\n            zh: '例如：{{ example }}',\n          },\n          docLink:\n            'https://support.huaweicloud.com/intl/en-us/usermanual-cce/cce_10_0385.html#section8',\n        },\n      },\n      {\n        key: 'kubernetes.io/elb.subnet-id',\n        tip: {\n          en: 'Subnet ID of the cluster, which is required when creating a new cloud LoadBalancer and Kubernetes version is 1.11.7-r0 and below.',\n          zh: '集群所在子网的 ID，当 Kubernetes 版本为 1.11.7-r0 及以下，新创建云上负载均衡器时必须填写此项',\n        },\n      },\n      {\n        key: 'kubernetes.io/elb.class',\n        tip: {\n          en: 'Specify the type of the newly created cloud LoadBalancer',\n          zh: '指定新创建的云上负载均衡器的类型',\n        },\n        doc: {\n          tip: {\n            en: 'Differences Between Dedicated and Shared Load Balancers',\n            zh: '共享型弹性负载均衡与独享型负载均衡的功能区别',\n          },\n          rawUrl:\n            'https://support.huaweicloud.com/intl/zh-cn/productdesc-elb/elb_pro_0004.html',\n          tipPrefix: {\n            en: 'For more details, please refer to ',\n            zh: '详情请参见',\n          },\n        },\n        values: [\n          {\n            value: 'union',\n            tip: {\n              en: 'Shared LoadBalancer',\n              zh: '共享型负载均衡',\n            },\n          },\n          {\n            value: 'performance',\n            tip: {\n              en: 'Dedicated LoadBalancer, which can be used only in clusters of v1.17 and later',\n              zh: '独享型负载均衡，仅支持在 Kubernetes 版本为 1.17 及以上的集群中使用',\n            },\n          },\n        ],\n      },\n      {\n        key: 'kubernetes.io/elb.enterpriseID',\n        tip: {\n          en: 'Specify the enterprise project to which the newly created cloud LoadBalancer will belong',\n          zh: '指定新创建云上负载均衡器所属的企业项目',\n        },\n      },\n    ],\n  },\n  [ClusterType.GoogleCloudGKE]: {\n    label: 'GKE',\n    docLink:\n      'https://cloud.google.com/kubernetes-engine/docs/concepts/service-load-balancer-parameters',\n    options: [\n      {\n        key: 'networking.gke.io/load-balancer-type',\n        tip: {\n          en: 'Specify the use of Intranet',\n          zh: '指定使用内网',\n        },\n        values: [\n          {\n            value: 'Internal',\n          },\n        ],\n      },\n      {\n        key: 'cloud.google.com/l4-rbs',\n        tip: {\n          en: 'The default is public network, when this parameter is configured, traffic will be routed directly to the pods',\n          zh: '默认为公网，配置此参数时，流量将直接路由至容器组',\n        },\n        values: [\n          {\n            value: 'enabled',\n          },\n        ],\n      },\n    ],\n  },\n};\n\n@Component({\n  selector: 'acl-service-annotations-form',\n  templateUrl: 'annotations.component.html',\n  styleUrls: ['annotations.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    AsyncPipe,\n    NgIf,\n    NgForOf,\n    ReactiveFormsModule,\n    TranslateModule,\n    AutocompleteModule,\n    ButtonModule,\n    IconModule,\n    InputModule,\n    ArrayFormTableComponent,\n    ArrayFormTableHeaderDirective,\n    ArrayFormTableRowDirective,\n    ArrayFormTableRowControlDirective,\n    ArrayFormTableRowErrorDirective,\n    ErrorsMapperModule,\n    HelpDocumentModule,\n    PurePipe,\n  ],\n})\nexport class ServiceAnnotationsFormComponent extends BaseStringMapFormComponent {\n  @Input({ required: true })\n  isUpdate: boolean;\n\n  @Input({ required: true })\n  clusterType: ClusterType;\n\n  @Input({ required: true })\n  resourceName: string;\n\n  private readonly translate = inject(TranslateService);\n\n  protected readonly baseHref = inject(TOKEN_BASE_HREF);\n\n  // 禁用掉包含 cpaas.io 及 ovn.kubernetes.io 的 key\n  readonly readonlyPartialKeys = ['ovn.kubernetes.io', this.baseDomain];\n\n  annotationsErrorsMapper = getK8sResourceAnnotationErrorMapper$(\n    this.translate,\n  );\n\n  KNOWN_ANNOTATIONS = KNOWN_ANNOTATIONS;\n\n  constructor(\n    injector: Injector,\n    @Inject(TOKEN_BASE_DOMAIN) private readonly baseDomain: string,\n  ) {\n    super(injector);\n  }\n\n  filterOptions(options: AnnotationConfigOption[] | undefined, index: number) {\n    const keys = (this.form.value as KeyValueTuple[]).map(([key]) => key);\n    return options?.filter(o => {\n      const keyIndex = keys.indexOf(o.key);\n      return keyIndex === -1 || keyIndex === index;\n    });\n  }\n\n  getConfigOption(options: AnnotationConfigOption[] | undefined, key: string) {\n    return options?.find(option => option.key === key);\n  }\n\n  isReadonly(key: string) {\n    return this.isUpdate && this.readonlyPartialKeys.some(k => key.includes(k));\n  }\n\n  override getDefaultFormModel(): KeyValueTuple[] {\n    return [['', '']];\n  }\n\n  override adaptResourceModel(resource: StringMap) {\n    let newFormModel = Object.entries(resource || {});\n    // 排序，先按字母排序，再把 readonly 的放前面\n    newFormModel = sortBy(newFormModel, (arr: [string, string]) => arr[0]);\n    newFormModel.sort((arr1: [string, string], arr2: [string, string]) => {\n      const flag1 = this.isReadonly(arr1[0]);\n      const flag2 = this.isReadonly(arr2[0]);\n      if ((flag1 && flag2) || (!flag1 && !flag2)) {\n        return 0;\n      }\n      return flag1 ? -1 : 1;\n    });\n\n    if (newFormModel.length === 0) {\n      newFormModel = this.getDefaultFormModel();\n    }\n\n    return newFormModel;\n  }\n\n  override getKeyValidators() {\n    return k8sResourceAnnotationKeyValidator;\n  }\n\n  isLabelReadonly(control: FormArray<FormControl<string>>) {\n    return control.valid && this.isReadonly(control.get('0').value);\n  }\n\n  getActiveConfigOption(\n    options: AnnotationConfigOption[] | undefined,\n    key: string,\n  ) {\n    return options?.find(o => o.key === key);\n  }\n\n  onKeySelected(control: FormArray<FormControl<string>>) {\n    const keyCtrl = control.get('0');\n    keyCtrl.markAsDirty();\n    keyCtrl.updateValueAndValidity();\n  }\n\n  // AnnotationConfigOption.doc 配置了产品 （product）属性之后需要当前视图隶属于该产品时才展示 doc 链接，未配置的话不受限制\n  showDocLink(baseHref: string, product?: keyof typeof PRODUCT_BASE_HREF_MAP) {\n    if (!product) {\n      return true;\n    }\n\n    return PRODUCT_BASE_HREF_MAP[product] === baseHref;\n  }\n}\n","<acl-array-form-table\n  [formGroup]=\"$any(form)\"\n  [rows]=\"form.controls\"\n  (add)=\"form.push(createNewControl())\"\n  (remove)=\"remove($event)\"\n  [resourceName]=\"resourceName\"\n>\n  <ng-container *aclArrayFormTableHeader>\n    <th class=\"column\">{{ 'key' | translate }}</th>\n    <th class=\"column\">{{ 'value' | translate }}</th>\n  </ng-container>\n\n  <ng-container\n    *aclArrayFormTableRow=\"let control; let index = index\"\n    [formGroupName]=\"index\"\n  >\n    <ng-container\n      *ngIf=\"{\n        config: KNOWN_ANNOTATIONS[clusterType],\n        readonly: isLabelReadonly(control)\n      } as _\"\n    >\n      <td class=\"column\">\n        <input\n          aui-input\n          [readonly]=\"_.readonly\"\n          (blur)=\"onBlur()\"\n          formControlName=\"0\"\n          [auiAutocomplete]=\"keySuggestion\"\n          (auiAutocompleteSelected)=\"onKeySelected(control)\"\n        />\n        <aui-autocomplete #keySuggestion>\n          <aui-suggestion\n            *ngFor=\"\n              let option of _.readonly\n                ? null\n                : filterOptions(_.config?.options, index)\n            \"\n            [value]=\"option.key\"\n          >\n            {{ option.key }}\n            <div\n              *ngIf=\"option.tip | translate as tip\"\n              class=\"tw-text-help-text tw-text-s\"\n            >\n              {{ tip }}\n            </div>\n          </aui-suggestion>\n        </aui-autocomplete>\n        <ng-container\n          *ngIf=\"\n            (\n              _.config?.options\n              | pure: getActiveConfigOption:control.get('0').value\n            )?.doc as doc\n          \"\n        >\n          <div\n            *ngIf=\"baseHref | pure: showDocLink:doc.product\"\n            class=\"tw-text-help-text tw-text-s tw-mt-4\"\n          >\n            <ng-container *ngIf=\"doc.tipPrefix\">\n              {{ doc.tipPrefix | translate }}\n            </ng-container>\n            <a\n              [aclDocs]=\"{\n                path: doc.path,\n                rawUrl: doc.rawUrl,\n                type: 'page',\n              }\"\n            >\n              {{ doc.tip | translate }}\n              <aui-icon icon=\"jump\"></aui-icon>\n            </a>\n          </div>\n        </ng-container>\n      </td>\n      <td class=\"column\">\n        <input\n          aui-input\n          [readonly]=\"_.readonly\"\n          (blur)=\"onBlur()\"\n          formControlName=\"1\"\n          [auiAutocomplete]=\"valueSuggestion\"\n        />\n        <aui-autocomplete #valueSuggestion>\n          <aui-suggestion\n            *ngFor=\"\n              let option of _.readonly\n                ? null\n                : (\n                    _.config?.options\n                    | pure: getConfigOption:control.get('0').value\n                  )?.values\n            \"\n            [value]=\"option.value\"\n          >\n            {{ option.value }}\n            <div\n              *ngIf=\"option.tip | translate as tip\"\n              class=\"tw-text-help-text tw-text-s\"\n            >\n              {{ tip }}\n            </div>\n          </aui-suggestion>\n        </aui-autocomplete>\n        <div\n          *ngIf=\"\n            (\n              _.config?.options\n              | pure: getActiveConfigOption:control.get('0').value\n            )?.value as valueConfig\n          \"\n          class=\"tw-text-help-text tw-text-s\"\n        >\n          <div\n            *ngIf=\"control.get('1').value === valueConfig.example\"\n            class=\"tw-text-yellow tw-mt-4\"\n          >\n            {{ 'read_filling_instructions_tip' | translate }}\n          </div>\n          <div class=\"tw-break-all tw-my-4\">\n            {{ valueConfig.tip | translate: { example: valueConfig.example } }}\n            <aui-icon\n              class=\"tw-text-primary tw-cursor-pointer\"\n              icon=\"arrow_turn_up\"\n              (click)=\"control.get('1').setValue(valueConfig.example)\"\n            ></aui-icon>\n          </div>\n          <a\n            [href]=\"valueConfig.docLink\"\n            rel=\"noopener noreferrer\"\n            target=\"_blank\"\n          >\n            {{ 'filling_instructions' | translate }}\n            <aui-icon icon=\"jump\"></aui-icon>\n          </a>\n        </div>\n      </td>\n    </ng-container>\n  </ng-container>\n\n  <ng-container *aclArrayFormTableRowError=\"let control\">\n    <td\n      *ngIf=\"control.invalid\"\n      colspan=\"3\"\n      class=\"acl-table-form-error-hint\"\n    >\n      <ng-container *ngIf=\"control.errors?.keyIsMissing\">\n        {{ 'k8s_resource_label_key_required' | translate }}\n      </ng-container>\n\n      <ng-container *ngIf=\"control.errors?.duplicateError\">\n        {{ 'k8s_resource_label_key_duplicated' | translate }}\n      </ng-container>\n\n      <acl-errors-mapper\n        auiFormItemError\n        [errors]=\"control.get('0').errors\"\n        [errorsMapper]=\"(annotationsErrorsMapper | async).key\"\n      ></acl-errors-mapper>\n      <acl-errors-mapper\n        auiFormItemError\n        [errors]=\"control.get('1').errors\"\n      ></acl-errors-mapper>\n    </td>\n  </ng-container>\n\n  <ng-container *aclArrayFormTableRowControl=\"let item; let index = index\">\n    <button\n      aui-button=\"text\"\n      type=\"button\"\n      [square]=\"true\"\n      [plain]=\"true\"\n      [disabled]=\"isLabelReadonly(item)\"\n      (click)=\"remove(index)\"\n    >\n      <aui-icon icon=\"minus_circle\"></aui-icon>\n    </button>\n  </ng-container>\n</acl-array-form-table>\n\n<ng-content></ng-content>\n\n<div\n  *ngIf=\"KNOWN_ANNOTATIONS[clusterType] as config\"\n  class=\"tw-text-help-text tw-text-s tw-mt-4\"\n>\n  <ng-container [aclTranslate]=\"'documentation_for_lb_service_annotations'\">\n    <ng-container *aclTranslateText=\"let text\">{{ text }}</ng-container>\n    <ng-container *aclTranslateMatch=\"'type'\">{{ config.label }}</ng-container>\n    <a\n      *aclTranslateMatch=\"'documentation'\"\n      [href]=\"config.docLink\"\n      target=\"_blank\"\n      rel=\"noopener noreferrer\"\n    >\n      {{ 'documentation' | translate }}\n      <aui-icon icon=\"jump\"></aui-icon> </a\n  ></ng-container>\n</div>\n"]}