@alauda-fe/crd-form 0.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (95) hide show
  1. package/esm2022/alauda-fe-crd-form.mjs +5 -0
  2. package/esm2022/lib/abstract/base-array.mjs +117 -0
  3. package/esm2022/lib/crd-form/component.mjs +334 -0
  4. package/esm2022/lib/crd-form/helper.mjs +32 -0
  5. package/esm2022/lib/crd-form.module.mjs +117 -0
  6. package/esm2022/lib/field-controls/expressions/expression-core.mjs +2 -0
  7. package/esm2022/lib/field-controls/expressions/props-expression.mjs +58 -0
  8. package/esm2022/lib/field-controls/form-item.component.mjs +121 -0
  9. package/esm2022/lib/field-controls/index.mjs +8 -0
  10. package/esm2022/lib/field-controls/module.mjs +141 -0
  11. package/esm2022/lib/field-controls/operand-advanced-field-group.component.mjs +80 -0
  12. package/esm2022/lib/field-controls/operand-array-field-group.component.mjs +112 -0
  13. package/esm2022/lib/field-controls/operand-field-group.component.mjs +98 -0
  14. package/esm2022/lib/field-controls/operand-field.component.mjs +870 -0
  15. package/esm2022/lib/field-controls/widgets/array-table/component.mjs +109 -0
  16. package/esm2022/lib/field-controls/widgets/basic-auth-secret/component.mjs +116 -0
  17. package/esm2022/lib/field-controls/widgets/basic-auth-secret/create/component.mjs +211 -0
  18. package/esm2022/lib/field-controls/widgets/basic-auth-secret/type.mjs +2 -0
  19. package/esm2022/lib/field-controls/widgets/index.mjs +8 -0
  20. package/esm2022/lib/field-controls/widgets/k8s-resource-prefix/component.mjs +169 -0
  21. package/esm2022/lib/field-controls/widgets/k8s-resource-prefix/util.mjs +40 -0
  22. package/esm2022/lib/field-controls/widgets/link/component.mjs +68 -0
  23. package/esm2022/lib/field-controls/widgets/resource-requirements/resource-requirements.component.mjs +524 -0
  24. package/esm2022/lib/field-controls/widgets/utils.mjs +73 -0
  25. package/esm2022/lib/field-controls/widgets/yaml-editor/yaml-editor.component.mjs +94 -0
  26. package/esm2022/lib/field-widgets/htpasswd/component.mjs +35 -0
  27. package/esm2022/lib/field-widgets/htpasswd/form.mjs +171 -0
  28. package/esm2022/lib/field-widgets/htpasswd/index.mjs +4 -0
  29. package/esm2022/lib/field-widgets/htpasswd/module.mjs +54 -0
  30. package/esm2022/lib/field-widgets/index.mjs +2 -0
  31. package/esm2022/lib/remote-widgets/constants.mjs +4 -0
  32. package/esm2022/lib/remote-widgets/index.mjs +4 -0
  33. package/esm2022/lib/remote-widgets/remote-widget.service.mjs +42 -0
  34. package/esm2022/lib/remote-widgets/token.mjs +7 -0
  35. package/esm2022/lib/spec-descriptors/capability/capability.component.mjs +139 -0
  36. package/esm2022/lib/spec-descriptors/capability-list/capability-list.component.mjs +189 -0
  37. package/esm2022/lib/spec-descriptors/index.mjs +4 -0
  38. package/esm2022/lib/spec-descriptors/util.mjs +13 -0
  39. package/esm2022/lib/types/index.mjs +73 -0
  40. package/esm2022/lib/utils/capability.mjs +295 -0
  41. package/esm2022/lib/utils/constant.mjs +22 -0
  42. package/esm2022/lib/utils/directives.mjs +19 -0
  43. package/esm2022/lib/utils/helper.mjs +201 -0
  44. package/esm2022/lib/utils/index.mjs +7 -0
  45. package/esm2022/lib/utils/service-model.mjs +12 -0
  46. package/esm2022/lib/utils/util.mjs +310 -0
  47. package/esm2022/public-api.mjs +13 -0
  48. package/index.d.ts +5 -0
  49. package/lib/abstract/base-array.d.ts +31 -0
  50. package/lib/crd-form/component.d.ts +61 -0
  51. package/lib/crd-form/helper.d.ts +7 -0
  52. package/lib/crd-form.module.d.ts +16 -0
  53. package/lib/field-controls/expressions/expression-core.d.ts +6 -0
  54. package/lib/field-controls/expressions/props-expression.d.ts +36 -0
  55. package/lib/field-controls/form-item.component.d.ts +11 -0
  56. package/lib/field-controls/index.d.ts +7 -0
  57. package/lib/field-controls/module.d.ts +23 -0
  58. package/lib/field-controls/operand-advanced-field-group.component.d.ts +16 -0
  59. package/lib/field-controls/operand-array-field-group.component.d.ts +8 -0
  60. package/lib/field-controls/operand-field-group.component.d.ts +24 -0
  61. package/lib/field-controls/operand-field.component.d.ts +110 -0
  62. package/lib/field-controls/widgets/array-table/component.d.ts +8 -0
  63. package/lib/field-controls/widgets/basic-auth-secret/component.d.ts +26 -0
  64. package/lib/field-controls/widgets/basic-auth-secret/create/component.d.ts +45 -0
  65. package/lib/field-controls/widgets/basic-auth-secret/type.d.ts +11 -0
  66. package/lib/field-controls/widgets/index.d.ts +7 -0
  67. package/lib/field-controls/widgets/k8s-resource-prefix/component.d.ts +35 -0
  68. package/lib/field-controls/widgets/k8s-resource-prefix/util.d.ts +3 -0
  69. package/lib/field-controls/widgets/link/component.d.ts +20 -0
  70. package/lib/field-controls/widgets/resource-requirements/resource-requirements.component.d.ts +88 -0
  71. package/lib/field-controls/widgets/utils.d.ts +17 -0
  72. package/lib/field-controls/widgets/yaml-editor/yaml-editor.component.d.ts +36 -0
  73. package/lib/field-widgets/htpasswd/component.d.ts +9 -0
  74. package/lib/field-widgets/htpasswd/form.d.ts +32 -0
  75. package/lib/field-widgets/htpasswd/index.d.ts +3 -0
  76. package/lib/field-widgets/htpasswd/module.d.ts +13 -0
  77. package/lib/field-widgets/index.d.ts +1 -0
  78. package/lib/remote-widgets/constants.d.ts +3 -0
  79. package/lib/remote-widgets/index.d.ts +3 -0
  80. package/lib/remote-widgets/remote-widget.service.d.ts +28 -0
  81. package/lib/remote-widgets/token.d.ts +3 -0
  82. package/lib/spec-descriptors/capability/capability.component.d.ts +20 -0
  83. package/lib/spec-descriptors/capability-list/capability-list.component.d.ts +34 -0
  84. package/lib/spec-descriptors/index.d.ts +3 -0
  85. package/lib/spec-descriptors/util.d.ts +4 -0
  86. package/lib/types/index.d.ts +122 -0
  87. package/lib/utils/capability.d.ts +54 -0
  88. package/lib/utils/constant.d.ts +12 -0
  89. package/lib/utils/directives.d.ts +9 -0
  90. package/lib/utils/helper.d.ts +61 -0
  91. package/lib/utils/index.d.ts +6 -0
  92. package/lib/utils/service-model.d.ts +44 -0
  93. package/lib/utils/util.d.ts +48 -0
  94. package/package.json +30 -0
  95. package/public-api.d.ts +9 -0
@@ -0,0 +1,109 @@
1
+ import { ChangeDetectionStrategy, Component } from '@angular/core';
2
+ import { get } from 'lodash-es';
3
+ import { BaseOperandFiledArrayComponent } from '../../../abstract/base-array';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "@angular/common";
6
+ import * as i2 from "@alauda/ui";
7
+ import * as i3 from "@alauda-fe/common";
8
+ import * as i4 from "../../operand-field.component";
9
+ function CrdFormArrayTableComponent_ng_container_8_ng_container_1_th_1_Template(rf, ctx) { if (rf & 1) {
10
+ i0.ɵɵelementStart(0, "th", 8);
11
+ i0.ɵɵtext(1);
12
+ i0.ɵɵpipe(2, "pure");
13
+ i0.ɵɵpipe(3, "translate");
14
+ i0.ɵɵelementEnd();
15
+ } if (rf & 2) {
16
+ const field_r1 = i0.ɵɵnextContext().$implicit;
17
+ const ctx_r1 = i0.ɵɵnextContext(2);
18
+ i0.ɵɵadvance();
19
+ i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(3, 4, i0.ɵɵpipeBind2(2, 1, field_r1, ctx_r1.getFieldDisplayName)), " ");
20
+ } }
21
+ function CrdFormArrayTableComponent_ng_container_8_ng_container_1_ng_template_3_Template(rf, ctx) { if (rf & 1) {
22
+ i0.ɵɵelementStart(0, "th");
23
+ i0.ɵɵtext(1);
24
+ i0.ɵɵpipe(2, "pure");
25
+ i0.ɵɵpipe(3, "translate");
26
+ i0.ɵɵelementEnd();
27
+ } if (rf & 2) {
28
+ const field_r1 = i0.ɵɵnextContext().$implicit;
29
+ const ctx_r1 = i0.ɵɵnextContext(2);
30
+ i0.ɵɵadvance();
31
+ i0.ɵɵtextInterpolate(i0.ɵɵpipeBind1(3, 4, i0.ɵɵpipeBind2(2, 1, field_r1, ctx_r1.getFieldDisplayName)));
32
+ } }
33
+ function CrdFormArrayTableComponent_ng_container_8_ng_container_1_Template(rf, ctx) { if (rf & 1) {
34
+ i0.ɵɵelementContainerStart(0);
35
+ i0.ɵɵtemplate(1, CrdFormArrayTableComponent_ng_container_8_ng_container_1_th_1_Template, 4, 6, "th", 7);
36
+ i0.ɵɵpipe(2, "pure");
37
+ i0.ɵɵtemplate(3, CrdFormArrayTableComponent_ng_container_8_ng_container_1_ng_template_3_Template, 4, 6, "ng-template", null, 0, i0.ɵɵtemplateRefExtractor);
38
+ i0.ɵɵelementContainerEnd();
39
+ } if (rf & 2) {
40
+ const field_r1 = ctx.$implicit;
41
+ const defaultTh_r3 = i0.ɵɵreference(4);
42
+ const ctx_r1 = i0.ɵɵnextContext(2);
43
+ i0.ɵɵadvance();
44
+ i0.ɵɵproperty("ngIf", i0.ɵɵpipeBind2(2, 2, field_r1, ctx_r1.fieldIsRequired))("ngIfElse", defaultTh_r3);
45
+ } }
46
+ function CrdFormArrayTableComponent_ng_container_8_Template(rf, ctx) { if (rf & 1) {
47
+ i0.ɵɵelementContainerStart(0);
48
+ i0.ɵɵtemplate(1, CrdFormArrayTableComponent_ng_container_8_ng_container_1_Template, 5, 5, "ng-container", 6);
49
+ i0.ɵɵelementContainerEnd();
50
+ } if (rf & 2) {
51
+ const ctx_r1 = i0.ɵɵnextContext();
52
+ i0.ɵɵadvance();
53
+ i0.ɵɵproperty("ngForOf", ctx_r1.basicArrayFieldTemplate);
54
+ } }
55
+ function CrdFormArrayTableComponent_ng_container_9_td_1_Template(rf, ctx) { if (rf & 1) {
56
+ const _r4 = i0.ɵɵgetCurrentView();
57
+ i0.ɵɵelementStart(0, "td")(1, "acl-operand-field", 10);
58
+ i0.ɵɵlistener("valueChange", function CrdFormArrayTableComponent_ng_container_9_td_1_Template_acl_operand_field_valueChange_1_listener($event) { i0.ɵɵrestoreView(_r4); const ctx_r1 = i0.ɵɵnextContext(2); return i0.ɵɵresetView(ctx_r1.fieldValueChange($event)); });
59
+ i0.ɵɵelementEnd()();
60
+ } if (rf & 2) {
61
+ const field_r5 = ctx.$implicit;
62
+ const ctx_r1 = i0.ɵɵnextContext(2);
63
+ i0.ɵɵadvance();
64
+ i0.ɵɵproperty("field", field_r5)("formDataState", ctx_r1.formDataState)("formErrors", ctx_r1.formErrors)("readonly", ctx_r1.readonly);
65
+ } }
66
+ function CrdFormArrayTableComponent_ng_container_9_Template(rf, ctx) { if (rf & 1) {
67
+ i0.ɵɵelementContainerStart(0);
68
+ i0.ɵɵtemplate(1, CrdFormArrayTableComponent_ng_container_9_td_1_Template, 2, 4, "td", 9);
69
+ i0.ɵɵelementContainerEnd();
70
+ } if (rf & 2) {
71
+ const fieldList_r6 = ctx.$implicit;
72
+ const ctx_r1 = i0.ɵɵnextContext();
73
+ i0.ɵɵadvance();
74
+ i0.ɵɵproperty("ngForOf", fieldList_r6)("ngForTrackBy", ctx_r1.trackByFn);
75
+ } }
76
+ export class CrdFormArrayTableComponent extends BaseOperandFiledArrayComponent {
77
+ ngOnInit() {
78
+ // arrayField group 不需要默认保留一项
79
+ if (!get(this.arrayFieldGroup.value, 'length')) {
80
+ this.removeItem(0);
81
+ }
82
+ }
83
+ static { this.ɵfac = /*@__PURE__*/ (() => { let ɵCrdFormArrayTableComponent_BaseFactory; return function CrdFormArrayTableComponent_Factory(t) { return (ɵCrdFormArrayTableComponent_BaseFactory || (ɵCrdFormArrayTableComponent_BaseFactory = i0.ɵɵgetInheritedFactory(CrdFormArrayTableComponent)))(t || CrdFormArrayTableComponent); }; })(); }
84
+ static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: CrdFormArrayTableComponent, selectors: [["acl-crd-array-table"]], features: [i0.ɵɵInheritDefinitionFeature], decls: 10, vars: 15, consts: [["defaultTh", ""], [3, "emptyAddon"], ["auiFormItemLabel", ""], [1, "form-table__flex-layout", 2, "flex", "1", 3, "remove", "add", "rows", "readonly", "resourceName"], [4, "aclArrayFormTableHeader"], [4, "aclArrayFormTableRow"], [4, "ngFor", "ngForOf"], ["required", "", 4, "ngIf", "ngIfElse"], ["required", ""], [4, "ngFor", "ngForOf", "ngForTrackBy"], [3, "valueChange", "field", "formDataState", "formErrors", "readonly"]], template: function CrdFormArrayTableComponent_Template(rf, ctx) { if (rf & 1) {
85
+ i0.ɵɵelementStart(0, "aui-form-item", 1)(1, "label", 2);
86
+ i0.ɵɵtext(2);
87
+ i0.ɵɵpipe(3, "pure");
88
+ i0.ɵɵpipe(4, "translate");
89
+ i0.ɵɵelementEnd();
90
+ i0.ɵɵelementStart(5, "acl-array-form-table", 3);
91
+ i0.ɵɵpipe(6, "pure");
92
+ i0.ɵɵpipe(7, "translate");
93
+ i0.ɵɵlistener("remove", function CrdFormArrayTableComponent_Template_acl_array_form_table_remove_5_listener($event) { return ctx.removeItem($event); })("add", function CrdFormArrayTableComponent_Template_acl_array_form_table_add_5_listener() { return ctx.addItem(); });
94
+ i0.ɵɵtemplate(8, CrdFormArrayTableComponent_ng_container_8_Template, 2, 1, "ng-container", 4)(9, CrdFormArrayTableComponent_ng_container_9_Template, 2, 2, "ng-container", 5);
95
+ i0.ɵɵelementEnd()();
96
+ } if (rf & 2) {
97
+ i0.ɵɵproperty("emptyAddon", false);
98
+ i0.ɵɵadvance(2);
99
+ i0.ɵɵtextInterpolate(i0.ɵɵpipeBind1(4, 8, i0.ɵɵpipeBind2(3, 5, ctx.arrayFieldGroup, ctx.getFieldDisplayName)));
100
+ i0.ɵɵadvance(3);
101
+ i0.ɵɵproperty("rows", ctx.arrayFieldGroup.fieldLists)("readonly", ctx.readonly)("resourceName", i0.ɵɵpipeBind1(7, 13, i0.ɵɵpipeBind2(6, 10, ctx.arrayFieldGroup, ctx.getFieldDisplayName)));
102
+ } }, dependencies: [i1.NgForOf, i1.NgIf, i2.FormItemComponent, i2.FormItemLabelDirective, i3.ArrayFormTableComponent, i3.ArrayFormTableHeaderDirective, i3.ArrayFormTableRowDirective, i4.OperandFieldComponent, i3.TranslatePipe, i3.PurePipe], styles: ["[_nghost-%COMP%]{flex:1}[_nghost-%COMP%] acl-array-form-table .acl-array-form-table__readonly-mode tbody tr{height:auto}[_nghost-%COMP%] acl-array-form-table .aui-form-item{margin-bottom:0}[_nghost-%COMP%] acl-array-form-table .aui-form-item .aui-form-item__label-wrapper{display:none}[_nghost-%COMP%] acl-array-form-table .aui-form-item .aui-form-item__content{min-height:auto}[_nghost-%COMP%] acl-array-form-table .aui-form-item .aui-form-item__content .aui-form-item__control{max-width:100%}[_nghost-%COMP%] acl-array-form-table .acl-array-form-table tbody td{vertical-align:top}"], changeDetection: 0 }); }
103
+ }
104
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(CrdFormArrayTableComponent, [{
105
+ type: Component,
106
+ args: [{ selector: 'acl-crd-array-table', changeDetection: ChangeDetectionStrategy.OnPush, template: "<aui-form-item [emptyAddon]=\"false\">\n <label auiFormItemLabel>{{\n arrayFieldGroup | pure: getFieldDisplayName | translate\n }}</label>\n\n <acl-array-form-table\n style=\"flex: 1\"\n (remove)=\"removeItem($event)\"\n (add)=\"addItem()\"\n [rows]=\"arrayFieldGroup.fieldLists\"\n [readonly]=\"readonly\"\n class=\"form-table__flex-layout\"\n [resourceName]=\"arrayFieldGroup | pure: getFieldDisplayName | translate\"\n >\n <ng-container *aclArrayFormTableHeader>\n <ng-container *ngFor=\"let field of basicArrayFieldTemplate\">\n <th\n required\n *ngIf=\"field | pure: fieldIsRequired; else defaultTh\"\n >\n {{ field | pure: getFieldDisplayName | translate }}\n </th>\n <ng-template #defaultTh>\n <th>{{ field | pure: getFieldDisplayName | translate }}</th>\n </ng-template>\n </ng-container>\n </ng-container>\n\n <!-- Input row -->\n <ng-container *aclArrayFormTableRow=\"let fieldList; let index = index\">\n <td\n *ngFor=\"let field of fieldList; let index = index; trackBy: trackByFn\"\n >\n <acl-operand-field\n [field]=\"field\"\n [formDataState]=\"formDataState\"\n [formErrors]=\"formErrors\"\n [readonly]=\"readonly\"\n (valueChange)=\"fieldValueChange($event)\"\n >\n </acl-operand-field>\n </td>\n </ng-container>\n </acl-array-form-table>\n</aui-form-item>\n", styles: [":host{flex:1}:host ::ng-deep acl-array-form-table .acl-array-form-table__readonly-mode tbody tr{height:auto}:host ::ng-deep acl-array-form-table .aui-form-item{margin-bottom:0}:host ::ng-deep acl-array-form-table .aui-form-item .aui-form-item__label-wrapper{display:none}:host ::ng-deep acl-array-form-table .aui-form-item .aui-form-item__content{min-height:auto}:host ::ng-deep acl-array-form-table .aui-form-item .aui-form-item__content .aui-form-item__control{max-width:100%}:host ::ng-deep acl-array-form-table .acl-array-form-table tbody td{vertical-align:top}\n"] }]
107
+ }], null, null); })();
108
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(CrdFormArrayTableComponent, { className: "CrdFormArrayTableComponent", filePath: "lib/field-controls/widgets/array-table/component.ts", lineNumber: 12 }); })();
109
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jcmQtZm9ybS9zcmMvbGliL2ZpZWxkLWNvbnRyb2xzL3dpZGdldHMvYXJyYXktdGFibGUvY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jcmQtZm9ybS9zcmMvbGliL2ZpZWxkLWNvbnRyb2xzL3dpZGdldHMvYXJyYXktdGFibGUvdGVtcGxhdGUuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFVLE1BQU0sZUFBZSxDQUFDO0FBQzNFLE9BQU8sRUFBRSxHQUFHLEVBQUUsTUFBTSxXQUFXLENBQUM7QUFFaEMsT0FBTyxFQUFFLDhCQUE4QixFQUFFLE1BQU0sOEJBQThCLENBQUM7Ozs7Ozs7SUNhdEUsNkJBR0M7SUFDQyxZQUNGOzs7SUFBQSxpQkFBSzs7OztJQURILGNBQ0Y7SUFERSxpSEFDRjs7O0lBRUUsMEJBQUk7SUFBQSxZQUFtRDs7O0lBQUEsaUJBQUs7Ozs7SUFBeEQsY0FBbUQ7SUFBbkQsc0dBQW1EOzs7SUFSM0QsNkJBQTREO0lBQzFELHVHQUdDOztJQUdELDBKQUF3Qjs7Ozs7O0lBSnJCLGNBQXFDO0lBQUEsQUFBckMsNkVBQXFDLDBCQUFjOzs7SUFKMUQsNkJBQXVDO0lBQ3JDLDRHQUE0RDs7OztJQUE1QixjQUEwQjtJQUExQix3REFBMEI7Ozs7SUFrQnhELEFBSEYsMEJBRUMsNEJBT0U7SUFEQyxrT0FBZSwrQkFBd0IsS0FBQztJQUc1QyxBQURFLGlCQUFvQixFQUNqQjs7OztJQVBELGNBQWU7SUFHZixBQURBLEFBREEsQUFEQSxnQ0FBZSx1Q0FDZ0IsaUNBQ04sNkJBQ0o7OztJQVIzQiw2QkFBdUU7SUFDckUsd0ZBRUM7Ozs7O0lBRG1CLGNBQWM7SUFBbUIsQUFBakMsc0NBQWMsa0NBQXFDOztBRHBCN0UsTUFBTSxPQUFPLDBCQUNYLFNBQVEsOEJBQThCO0lBR3RDLFFBQVE7UUFDTiw2QkFBNkI7UUFDN0IsSUFBSSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsZUFBZSxDQUFDLEtBQUssRUFBRSxRQUFRLENBQUMsRUFBRSxDQUFDO1lBQy9DLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDckIsQ0FBQztJQUNILENBQUM7NFFBVFUsMEJBQTBCLFNBQTFCLDBCQUEwQjtvRUFBMUIsMEJBQTBCO1lDVnJDLEFBREYsd0NBQW9DLGVBQ1Y7WUFBQSxZQUV0Qjs7O1lBQUEsaUJBQVE7WUFFViwrQ0FRQzs7O1lBTEMsQUFEQSw2SEFBVSxzQkFBa0IsSUFBQyxvR0FDdEIsYUFBUyxJQUFDO1lBcUJqQixBQWZBLDZGQUF1QyxnRkFlZ0M7WUFlM0UsQUFERSxpQkFBdUIsRUFDVDs7WUE1Q0Qsa0NBQW9CO1lBQ1QsZUFFdEI7WUFGc0IsOEdBRXRCO1lBTUEsZUFBbUM7WUFHbkMsQUFGQSxBQURBLHFEQUFtQywwQkFDZCw0R0FFbUQ7OztpRkREL0QsMEJBQTBCO2NBTnRDLFNBQVM7MkJBQ0UscUJBQXFCLG1CQUdkLHVCQUF1QixDQUFDLE1BQU07O2tGQUVwQywwQkFBMEIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IGdldCB9IGZyb20gJ2xvZGFzaC1lcyc7XG5cbmltcG9ydCB7IEJhc2VPcGVyYW5kRmlsZWRBcnJheUNvbXBvbmVudCB9IGZyb20gJy4uLy4uLy4uL2Fic3RyYWN0L2Jhc2UtYXJyYXknO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdhY2wtY3JkLWFycmF5LXRhYmxlJyxcbiAgdGVtcGxhdGVVcmw6ICcuL3RlbXBsYXRlLmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9zdHlsZXMuc2NzcyddLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbn0pXG5leHBvcnQgY2xhc3MgQ3JkRm9ybUFycmF5VGFibGVDb21wb25lbnRcbiAgZXh0ZW5kcyBCYXNlT3BlcmFuZEZpbGVkQXJyYXlDb21wb25lbnRcbiAgaW1wbGVtZW50cyBPbkluaXRcbntcbiAgbmdPbkluaXQoKSB7XG4gICAgLy8gYXJyYXlGaWVsZCBncm91cCDkuI3pnIDopoHpu5jorqTkv53nlZnkuIDpoblcbiAgICBpZiAoIWdldCh0aGlzLmFycmF5RmllbGRHcm91cC52YWx1ZSwgJ2xlbmd0aCcpKSB7XG4gICAgICB0aGlzLnJlbW92ZUl0ZW0oMCk7XG4gICAgfVxuICB9XG59XG4iLCI8YXVpLWZvcm0taXRlbSBbZW1wdHlBZGRvbl09XCJmYWxzZVwiPlxuICA8bGFiZWwgYXVpRm9ybUl0ZW1MYWJlbD57e1xuICAgIGFycmF5RmllbGRHcm91cCB8IHB1cmU6IGdldEZpZWxkRGlzcGxheU5hbWUgfCB0cmFuc2xhdGVcbiAgfX08L2xhYmVsPlxuXG4gIDxhY2wtYXJyYXktZm9ybS10YWJsZVxuICAgIHN0eWxlPVwiZmxleDogMVwiXG4gICAgKHJlbW92ZSk9XCJyZW1vdmVJdGVtKCRldmVudClcIlxuICAgIChhZGQpPVwiYWRkSXRlbSgpXCJcbiAgICBbcm93c109XCJhcnJheUZpZWxkR3JvdXAuZmllbGRMaXN0c1wiXG4gICAgW3JlYWRvbmx5XT1cInJlYWRvbmx5XCJcbiAgICBjbGFzcz1cImZvcm0tdGFibGVfX2ZsZXgtbGF5b3V0XCJcbiAgICBbcmVzb3VyY2VOYW1lXT1cImFycmF5RmllbGRHcm91cCB8IHB1cmU6IGdldEZpZWxkRGlzcGxheU5hbWUgfCB0cmFuc2xhdGVcIlxuICA+XG4gICAgPG5nLWNvbnRhaW5lciAqYWNsQXJyYXlGb3JtVGFibGVIZWFkZXI+XG4gICAgICA8bmctY29udGFpbmVyICpuZ0Zvcj1cImxldCBmaWVsZCBvZiBiYXNpY0FycmF5RmllbGRUZW1wbGF0ZVwiPlxuICAgICAgICA8dGhcbiAgICAgICAgICByZXF1aXJlZFxuICAgICAgICAgICpuZ0lmPVwiZmllbGQgfCBwdXJlOiBmaWVsZElzUmVxdWlyZWQ7IGVsc2UgZGVmYXVsdFRoXCJcbiAgICAgICAgPlxuICAgICAgICAgIHt7IGZpZWxkIHwgcHVyZTogZ2V0RmllbGREaXNwbGF5TmFtZSB8IHRyYW5zbGF0ZSB9fVxuICAgICAgICA8L3RoPlxuICAgICAgICA8bmctdGVtcGxhdGUgI2RlZmF1bHRUaD5cbiAgICAgICAgICA8dGg+e3sgZmllbGQgfCBwdXJlOiBnZXRGaWVsZERpc3BsYXlOYW1lIHwgdHJhbnNsYXRlIH19PC90aD5cbiAgICAgICAgPC9uZy10ZW1wbGF0ZT5cbiAgICAgIDwvbmctY29udGFpbmVyPlxuICAgIDwvbmctY29udGFpbmVyPlxuXG4gICAgPCEtLSBJbnB1dCByb3cgLS0+XG4gICAgPG5nLWNvbnRhaW5lciAqYWNsQXJyYXlGb3JtVGFibGVSb3c9XCJsZXQgZmllbGRMaXN0OyBsZXQgaW5kZXggPSBpbmRleFwiPlxuICAgICAgPHRkXG4gICAgICAgICpuZ0Zvcj1cImxldCBmaWVsZCBvZiBmaWVsZExpc3Q7IGxldCBpbmRleCA9IGluZGV4OyB0cmFja0J5OiB0cmFja0J5Rm5cIlxuICAgICAgPlxuICAgICAgICA8YWNsLW9wZXJhbmQtZmllbGRcbiAgICAgICAgICBbZmllbGRdPVwiZmllbGRcIlxuICAgICAgICAgIFtmb3JtRGF0YVN0YXRlXT1cImZvcm1EYXRhU3RhdGVcIlxuICAgICAgICAgIFtmb3JtRXJyb3JzXT1cImZvcm1FcnJvcnNcIlxuICAgICAgICAgIFtyZWFkb25seV09XCJyZWFkb25seVwiXG4gICAgICAgICAgKHZhbHVlQ2hhbmdlKT1cImZpZWxkVmFsdWVDaGFuZ2UoJGV2ZW50KVwiXG4gICAgICAgID5cbiAgICAgICAgPC9hY2wtb3BlcmFuZC1maWVsZD5cbiAgICAgIDwvdGQ+XG4gICAgPC9uZy1jb250YWluZXI+XG4gIDwvYWNsLWFycmF5LWZvcm0tdGFibGU+XG48L2F1aS1mb3JtLWl0ZW0+XG4iXX0=
@@ -0,0 +1,116 @@
1
+ import { __decorate, __metadata } from "tslib";
2
+ import { DialogService, DialogSize } from '@alauda/ui';
3
+ import { COMMON_RESOURCE_DEFINITIONS, K8sApiService, K8sUtilService, ObservableInput, publishRef, SecretType, skipError, } from '@alauda-fe/common';
4
+ import { ChangeDetectionStrategy, Component, Injector, Input, } from '@angular/core';
5
+ import { Validators } from '@angular/forms';
6
+ import { BaseResourceFormComponent } from 'ng-resource-form-util';
7
+ import { combineLatest, filter, map, Observable, startWith, Subject, switchMap, takeUntil, } from 'rxjs';
8
+ import { CrdFormComponent } from '../../../crd-form/component';
9
+ import { getBasicAuthSecretConfig } from '../../../utils';
10
+ import { BasicAuthCreateSecretDialogComponent } from './create/component';
11
+ import * as i0 from "@angular/core";
12
+ import * as i1 from "@alauda-fe/common";
13
+ import * as i2 from "../../../crd-form/component";
14
+ import * as i3 from "@alauda/ui";
15
+ import * as i4 from "@angular/common";
16
+ import * as i5 from "@angular/forms";
17
+ function BasicAuthSecretComponent_aui_option_1_Template(rf, ctx) { if (rf & 1) {
18
+ i0.ɵɵelementStart(0, "aui-option", 3);
19
+ i0.ɵɵpipe(1, "aclName");
20
+ i0.ɵɵpipe(2, "aclName");
21
+ i0.ɵɵtext(3);
22
+ i0.ɵɵpipe(4, "aclName");
23
+ i0.ɵɵelementEnd();
24
+ } if (rf & 2) {
25
+ const item_r1 = ctx.$implicit;
26
+ i0.ɵɵproperty("value", i0.ɵɵpipeBind1(1, 3, item_r1))("label", i0.ɵɵpipeBind1(2, 5, item_r1));
27
+ i0.ɵɵadvance(3);
28
+ i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(4, 7, item_r1), " ");
29
+ } }
30
+ export class BasicAuthSecretComponent extends BaseResourceFormComponent {
31
+ constructor(injector, k8sApi, crdForm, dialog, k8sUtil) {
32
+ super(injector);
33
+ this.k8sApi = k8sApi;
34
+ this.crdForm = crdForm;
35
+ this.dialog = dialog;
36
+ this.k8sUtil = k8sUtil;
37
+ this.config$ = this.field$.pipe(filter(field => !!field), map(field => getBasicAuthSecretConfig(field)), publishRef());
38
+ this.reload$ = new Subject();
39
+ this.resources$ = combineLatest([
40
+ this.crdForm.formContext$,
41
+ this.config$,
42
+ this.reload$.pipe(startWith(null)),
43
+ ]).pipe(switchMap(([{ cluster, namespace }, config]) => this.k8sApi
44
+ .getResourceList({
45
+ definition: COMMON_RESOURCE_DEFINITIONS.SECRET,
46
+ namespace: config?.namespace ?? namespace,
47
+ cluster: config?.cluster ?? cluster,
48
+ })
49
+ .pipe(map(res => res.items), skipError([]), map(items => items.filter(item => [SecretType.Opaque, SecretType.BasicAuth].includes(item.type))))), publishRef());
50
+ this.resources$.pipe(takeUntil(this.destroy$)).subscribe(items => {
51
+ if (this.form.value &&
52
+ !items.some(item => this.k8sUtil.getName(item) === this.form.value)) {
53
+ this.form.reset();
54
+ }
55
+ });
56
+ }
57
+ createForm() {
58
+ // 使用 control 的 validators 而非 required 指令目地是后者会导致 control 实例化后 dirty
59
+ return this.fb.control(null, this.required ? Validators.required : null);
60
+ }
61
+ create() {
62
+ this.config$.subscribe(config => {
63
+ const dialogRef = this.dialog.open(BasicAuthCreateSecretDialogComponent, {
64
+ size: DialogSize.Big,
65
+ data: {
66
+ cluster: config?.cluster ?? this.crdForm.formContext.cluster,
67
+ namespace: config?.namespace ?? this.crdForm.formContext.namespace,
68
+ config,
69
+ },
70
+ });
71
+ return dialogRef.afterClosed().subscribe((res) => {
72
+ if (res) {
73
+ this.reload$.next();
74
+ this.form.setValue(res.metadata.name);
75
+ }
76
+ });
77
+ });
78
+ }
79
+ static { this.ɵfac = function BasicAuthSecretComponent_Factory(t) { return new (t || BasicAuthSecretComponent)(i0.ɵɵdirectiveInject(i0.Injector), i0.ɵɵdirectiveInject(i1.K8sApiService), i0.ɵɵdirectiveInject(i2.CrdFormComponent), i0.ɵɵdirectiveInject(i3.DialogService), i0.ɵɵdirectiveInject(i1.K8sUtilService)); }; }
80
+ static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: BasicAuthSecretComponent, selectors: [["acl-crd-basic-auth-secret"]], inputs: { required: "required", field: "field" }, features: [i0.ɵɵInheritDefinitionFeature], decls: 9, vars: 10, consts: [[1, "tw-flex-1", "tw-mr-[4px]", 3, "formControl"], [3, "value", "label", 4, "ngFor", "ngForOf"], ["aui-button", "default", "type", "button", 3, "click"], [3, "value", "label"]], template: function BasicAuthSecretComponent_Template(rf, ctx) { if (rf & 1) {
81
+ i0.ɵɵelementStart(0, "aui-select", 0);
82
+ i0.ɵɵtemplate(1, BasicAuthSecretComponent_aui_option_1_Template, 5, 9, "aui-option", 1);
83
+ i0.ɵɵpipe(2, "async");
84
+ i0.ɵɵelementStart(3, "aui-option-placeholder");
85
+ i0.ɵɵtext(4);
86
+ i0.ɵɵpipe(5, "translate");
87
+ i0.ɵɵelementEnd()();
88
+ i0.ɵɵelementStart(6, "button", 2);
89
+ i0.ɵɵlistener("click", function BasicAuthSecretComponent_Template_button_click_6_listener() { return ctx.create(); });
90
+ i0.ɵɵtext(7);
91
+ i0.ɵɵpipe(8, "translate");
92
+ i0.ɵɵelementEnd();
93
+ } if (rf & 2) {
94
+ i0.ɵɵproperty("formControl", ctx.form);
95
+ i0.ɵɵadvance();
96
+ i0.ɵɵproperty("ngForOf", i0.ɵɵpipeBind1(2, 4, ctx.resources$));
97
+ i0.ɵɵadvance(3);
98
+ i0.ɵɵtextInterpolate(i0.ɵɵpipeBind1(5, 6, "no_data"));
99
+ i0.ɵɵadvance(3);
100
+ i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(8, 8, "create"), "\n");
101
+ } }, dependencies: [i4.NgForOf, i5.NgControlStatus, i5.FormControlDirective, i3.SelectComponent, i3.OptionComponent, i3.OptionPlaceholderComponent, i3.ButtonComponent, i1.E2eAttributeBindingDirective, i4.AsyncPipe, i1.TranslatePipe, i1.K8sNamePipe], styles: ["[_nghost-%COMP%]{display:flex}"], changeDetection: 0 }); }
102
+ }
103
+ __decorate([
104
+ ObservableInput(),
105
+ __metadata("design:type", Observable)
106
+ ], BasicAuthSecretComponent.prototype, "field$", void 0);
107
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(BasicAuthSecretComponent, [{
108
+ type: Component,
109
+ args: [{ selector: 'acl-crd-basic-auth-secret', changeDetection: ChangeDetectionStrategy.OnPush, template: "<aui-select\n class=\"tw-flex-1 tw-mr-[4px]\"\n [formControl]=\"form\"\n>\n <aui-option\n *ngFor=\"let item of resources$ | async\"\n [value]=\"item | aclName\"\n [label]=\"item | aclName\"\n >\n {{ item | aclName }}\n </aui-option>\n <aui-option-placeholder>{{ 'no_data' | translate }}</aui-option-placeholder>\n</aui-select>\n<button\n aui-button=\"default\"\n type=\"button\"\n (click)=\"create()\"\n>\n {{ 'create' | translate }}\n</button>\n", styles: [":host{display:flex}\n"] }]
110
+ }], () => [{ type: i0.Injector }, { type: i1.K8sApiService }, { type: i2.CrdFormComponent }, { type: i3.DialogService }, { type: i1.K8sUtilService }], { required: [{
111
+ type: Input
112
+ }], field: [{
113
+ type: Input
114
+ }], field$: [] }); })();
115
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(BasicAuthSecretComponent, { className: "BasicAuthSecretComponent", filePath: "lib/field-controls/widgets/basic-auth-secret/component.ts", lineNumber: 51 }); })();
116
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"component.js","sourceRoot":"","sources":["../../../../../../../../libs/crd-form/src/lib/field-controls/widgets/basic-auth-secret/component.ts","../../../../../../../../libs/crd-form/src/lib/field-controls/widgets/basic-auth-secret/template.html"],"names":[],"mappings":"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","sourcesContent":["import { DialogService, DialogSize } from '@alauda/ui';\nimport {\n  COMMON_RESOURCE_DEFINITIONS,\n  K8sApiService,\n  K8sUtilService,\n  KubernetesResource,\n  ObservableInput,\n  publishRef,\n  Secret,\n  SecretType,\n  skipError,\n} from '@alauda-fe/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  Injector,\n  Input,\n} from '@angular/core';\nimport { Validators } from '@angular/forms';\nimport { BaseResourceFormComponent } from 'ng-resource-form-util';\nimport {\n  combineLatest,\n  filter,\n  map,\n  Observable,\n  startWith,\n  Subject,\n  switchMap,\n  takeUntil,\n} from 'rxjs';\n\nimport { CrdFormComponent } from '../../../crd-form/component';\nimport { OperandField } from '../../../types';\nimport { getBasicAuthSecretConfig } from '../../../utils';\n\nimport { BasicAuthCreateSecretDialogComponent } from './create/component';\nimport { BasicAuthSecretConfig } from './type';\n\n@Component({\n  selector: 'acl-crd-basic-auth-secret',\n  styles: [\n    `\n      :host {\n        display: flex;\n      }\n    `,\n  ],\n  templateUrl: 'template.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class BasicAuthSecretComponent extends BaseResourceFormComponent<string> {\n  @Input()\n  required: boolean;\n\n  @Input()\n  field: OperandField;\n\n  @ObservableInput()\n  field$!: Observable<OperandField>;\n\n  config$: Observable<BasicAuthSecretConfig> = this.field$.pipe(\n    filter(field => !!field),\n    map(field => getBasicAuthSecretConfig(field)),\n    publishRef(),\n  );\n\n  reload$ = new Subject<void>();\n  resources$ = combineLatest([\n    this.crdForm.formContext$,\n    this.config$,\n    this.reload$.pipe(startWith(null)),\n  ]).pipe(\n    switchMap(([{ cluster, namespace }, config]) =>\n      this.k8sApi\n        .getResourceList<Secret>({\n          definition: COMMON_RESOURCE_DEFINITIONS.SECRET,\n          namespace: config?.namespace ?? namespace,\n          cluster: config?.cluster ?? cluster,\n        })\n        .pipe(\n          map(res => res.items),\n          skipError([] as Secret[]),\n          map(items =>\n            items.filter(item =>\n              [SecretType.Opaque, SecretType.BasicAuth].includes(item.type),\n            ),\n          ),\n        ),\n    ),\n    publishRef(),\n  );\n\n  constructor(\n    injector: Injector,\n    private readonly k8sApi: K8sApiService,\n    private readonly crdForm: CrdFormComponent,\n    private readonly dialog: DialogService,\n    private readonly k8sUtil: K8sUtilService,\n  ) {\n    super(injector);\n\n    this.resources$.pipe(takeUntil(this.destroy$)).subscribe(items => {\n      if (\n        this.form.value &&\n        !items.some(item => this.k8sUtil.getName(item) === this.form.value)\n      ) {\n        this.form.reset();\n      }\n    });\n  }\n\n  createForm() {\n    // 使用 control 的 validators 而非 required 指令目地是后者会导致 control 实例化后 dirty\n    return this.fb.control(null, this.required ? Validators.required : null);\n  }\n\n  create() {\n    this.config$.subscribe(config => {\n      const dialogRef = this.dialog.open(BasicAuthCreateSecretDialogComponent, {\n        size: DialogSize.Big,\n        data: {\n          cluster: config?.cluster ?? this.crdForm.formContext.cluster,\n          namespace: config?.namespace ?? this.crdForm.formContext.namespace,\n          config,\n        },\n      });\n      return dialogRef.afterClosed().subscribe((res: KubernetesResource) => {\n        if (res) {\n          this.reload$.next();\n          this.form.setValue(res.metadata.name);\n        }\n      });\n    });\n  }\n}\n","<aui-select\n  class=\"tw-flex-1 tw-mr-[4px]\"\n  [formControl]=\"form\"\n>\n  <aui-option\n    *ngFor=\"let item of resources$ | async\"\n    [value]=\"item | aclName\"\n    [label]=\"item | aclName\"\n  >\n    {{ item | aclName }}\n  </aui-option>\n  <aui-option-placeholder>{{ 'no_data' | translate }}</aui-option-placeholder>\n</aui-select>\n<button\n  aui-button=\"default\"\n  type=\"button\"\n  (click)=\"create()\"\n>\n  {{ 'create' | translate }}\n</button>\n"]}
@@ -0,0 +1,211 @@
1
+ import { DialogRef, DIALOG_DATA, MessageService } from '@alauda/ui';
2
+ import { COMMON_RESOURCE_DEFINITIONS, K8sApiService, K8S_RESOURCE_NAME_BASE, SecretType, TranslateService, } from '@alauda-fe/common';
3
+ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Inject, ViewChild, } from '@angular/core';
4
+ import { FormBuilder, FormGroupDirective, Validators } from '@angular/forms';
5
+ import { encode } from 'ab64';
6
+ import { finalize } from 'rxjs';
7
+ import * as i0 from "@angular/core";
8
+ import * as i1 from "@alauda/ui";
9
+ import * as i2 from "@angular/forms";
10
+ import * as i3 from "@alauda-fe/common";
11
+ import * as i4 from "@angular/common";
12
+ const _c0 = a0 => ({ pattern: a0 });
13
+ const _c1 = () => ({ standalone: true });
14
+ function BasicAuthCreateSecretDialogComponent_input_36_Template(rf, ctx) { if (rf & 1) {
15
+ i0.ɵɵelement(0, "input", 14);
16
+ } }
17
+ function BasicAuthCreateSecretDialogComponent_input_37_Template(rf, ctx) { if (rf & 1) {
18
+ i0.ɵɵelement(0, "input", 15);
19
+ } }
20
+ function BasicAuthCreateSecretDialogComponent_ng_container_38_Template(rf, ctx) { if (rf & 1) {
21
+ const _r1 = i0.ɵɵgetCurrentView();
22
+ i0.ɵɵelementContainerStart(0);
23
+ i0.ɵɵelementStart(1, "aui-input-group", 16);
24
+ i0.ɵɵelement(2, "input", 17);
25
+ i0.ɵɵelementStart(3, "div", 18);
26
+ i0.ɵɵlistener("click", function BasicAuthCreateSecretDialogComponent_ng_container_38_Template_div_click_3_listener() { i0.ɵɵrestoreView(_r1); const ctx_r1 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r1.toggleShowPassword()); });
27
+ i0.ɵɵelement(4, "aui-icon", 19);
28
+ i0.ɵɵelementEnd()();
29
+ i0.ɵɵelementContainerEnd();
30
+ } if (rf & 2) {
31
+ const ctx_r1 = i0.ɵɵnextContext();
32
+ i0.ɵɵadvance(2);
33
+ i0.ɵɵproperty("type", ctx_r1.showPassword ? "text" : "password");
34
+ i0.ɵɵadvance(2);
35
+ i0.ɵɵproperty("icon", ctx_r1.showPassword ? "eye_s" : "eye_slash_s");
36
+ } }
37
+ function BasicAuthCreateSecretDialogComponent_acl_errors_mapper_39_Template(rf, ctx) { if (rf & 1) {
38
+ i0.ɵɵelement(0, "acl-errors-mapper", 20);
39
+ } if (rf & 2) {
40
+ const ctx_r1 = i0.ɵɵnextContext();
41
+ i0.ɵɵproperty("errors", ctx_r1.formGroup.get("password").errors);
42
+ } }
43
+ export class BasicAuthCreateSecretDialogComponent {
44
+ constructor(dialogData, dialogRef, fb, k8sApi, cdr, message, translate) {
45
+ this.dialogData = dialogData;
46
+ this.dialogRef = dialogRef;
47
+ this.fb = fb;
48
+ this.k8sApi = k8sApi;
49
+ this.cdr = cdr;
50
+ this.message = message;
51
+ this.translate = translate;
52
+ this.submitting = false;
53
+ this.K8S_RESOURCE_NAME_BASE = K8S_RESOURCE_NAME_BASE;
54
+ this.usernameKey = this.dialogData.config?.usernameKey ?? 'username';
55
+ this.passwordKey = this.dialogData.config?.passwordKey ?? 'password';
56
+ this.usernameReadonly = !!this.dialogData.config?.usernameReadonly;
57
+ this.strongPassword = !!this.dialogData.config?.strongPassword;
58
+ this.password = !!this.dialogData.config?.password;
59
+ this.showPassword = false;
60
+ this.formGroup = this.fb.group({
61
+ name: this.fb.control(this.dialogData.config?.secretName || '', [
62
+ Validators.required,
63
+ Validators.pattern(K8S_RESOURCE_NAME_BASE.pattern),
64
+ Validators.maxLength(63),
65
+ ]),
66
+ username: this.fb.control(this.dialogData.config?.usernameDefault || ''),
67
+ password: this.fb.control('', [Validators.required]),
68
+ });
69
+ }
70
+ confirm() {
71
+ this.form.onSubmit(null);
72
+ if (!this.form.valid) {
73
+ return;
74
+ }
75
+ this.submitting = true;
76
+ const value = this.form.value;
77
+ const data = {
78
+ [this.passwordKey]: encode(value.password),
79
+ };
80
+ if (value.username) {
81
+ data[this.usernameKey] = encode(value.username);
82
+ }
83
+ const resource = {
84
+ kind: 'Secret',
85
+ apiVersion: 'v1',
86
+ metadata: {
87
+ name: value.name,
88
+ namespace: this.dialogData.namespace,
89
+ },
90
+ type: SecretType.Opaque,
91
+ data,
92
+ };
93
+ this.k8sApi
94
+ .postResource({
95
+ definition: COMMON_RESOURCE_DEFINITIONS.SECRET,
96
+ cluster: this.dialogData.cluster,
97
+ namespace: this.dialogData.namespace,
98
+ resource,
99
+ })
100
+ .pipe(finalize(() => {
101
+ this.submitting = false;
102
+ this.cdr.markForCheck();
103
+ }))
104
+ .subscribe(res => {
105
+ this.dialogRef.close(res);
106
+ this.message.success(this.translate.get('create_success'));
107
+ });
108
+ }
109
+ toggleShowPassword() {
110
+ this.showPassword = !this.showPassword;
111
+ }
112
+ static { this.ɵfac = function BasicAuthCreateSecretDialogComponent_Factory(t) { return new (t || BasicAuthCreateSecretDialogComponent)(i0.ɵɵdirectiveInject(DIALOG_DATA), i0.ɵɵdirectiveInject(i1.DialogRef), i0.ɵɵdirectiveInject(i2.FormBuilder), i0.ɵɵdirectiveInject(i3.K8sApiService), i0.ɵɵdirectiveInject(i0.ChangeDetectorRef), i0.ɵɵdirectiveInject(i1.MessageService), i0.ɵɵdirectiveInject(i3.TranslateService)); }; }
113
+ static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: BasicAuthCreateSecretDialogComponent, selectors: [["ng-component"]], viewQuery: function BasicAuthCreateSecretDialogComponent_Query(rf, ctx) { if (rf & 1) {
114
+ i0.ɵɵviewQuery(FormGroupDirective, 7);
115
+ } if (rf & 2) {
116
+ let _t;
117
+ i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.form = _t.first);
118
+ } }, decls: 47, vars: 41, consts: [["auiForm", "", 3, "formGroup"], ["auiFormItemLabel", ""], ["type", "text", "required", "", "aui-input", "", "auiFormItemControl", "", "formControlName", "name"], ["auiFormItemError", "", 3, "errors", "errorsMapper"], [1, "form-table__flex-layout", "tw-flex-1"], [1, "acl-array-form-table"], ["type", "text", "required", "", "aui-input", "", "readonly", "", 3, "ngModel", "ngModelOptions"], ["type", "text", "aui-input", "", "auiFormItemControl", "", "formControlName", "username", 3, "readonly"], ["type", "password", "required", "", "aui-input", "", "auiFormItemControl", "", "formControlName", "password", "aclStrongPassword", "", 4, "ngIf"], ["type", "text", "required", "", "aui-input", "", "auiFormItemControl", "", "formControlName", "password", 4, "ngIf"], [4, "ngIf"], ["auiFormItemError", "", 3, "errors", 4, "ngIf"], ["aui-button", "primary", 3, "click", "loading", "disabled"], ["aui-button", "", "auiDialogClose", ""], ["type", "password", "required", "", "aui-input", "", "auiFormItemControl", "", "formControlName", "password", "aclStrongPassword", ""], ["type", "text", "required", "", "aui-input", "", "auiFormItemControl", "", "formControlName", "password"], ["auiFormItemControl", "", "required", ""], ["auiFormItemControl", "", "aui-input", "", "required", "", "formControlName", "password", 3, "type"], ["auiInputSuffix", "", 1, "password__suffix", 3, "click"], [3, "icon"], ["auiFormItemError", "", 3, "errors"]], template: function BasicAuthCreateSecretDialogComponent_Template(rf, ctx) { if (rf & 1) {
119
+ i0.ɵɵelementStart(0, "aui-dialog-header");
120
+ i0.ɵɵtext(1);
121
+ i0.ɵɵpipe(2, "translate");
122
+ i0.ɵɵelementEnd();
123
+ i0.ɵɵelementStart(3, "aui-dialog-content")(4, "form", 0)(5, "aui-form-item")(6, "label", 1);
124
+ i0.ɵɵtext(7);
125
+ i0.ɵɵpipe(8, "translate");
126
+ i0.ɵɵelementEnd();
127
+ i0.ɵɵelement(9, "input", 2)(10, "acl-errors-mapper", 3);
128
+ i0.ɵɵpipe(11, "translate");
129
+ i0.ɵɵelementEnd();
130
+ i0.ɵɵelementStart(12, "aui-form-item")(13, "label", 1);
131
+ i0.ɵɵtext(14);
132
+ i0.ɵɵpipe(15, "translate");
133
+ i0.ɵɵelementEnd();
134
+ i0.ɵɵelementStart(16, "div", 4)(17, "table", 5)(18, "thead")(19, "tr")(20, "th");
135
+ i0.ɵɵtext(21);
136
+ i0.ɵɵpipe(22, "translate");
137
+ i0.ɵɵelementEnd();
138
+ i0.ɵɵelementStart(23, "th");
139
+ i0.ɵɵtext(24);
140
+ i0.ɵɵpipe(25, "translate");
141
+ i0.ɵɵelementEnd()()();
142
+ i0.ɵɵelementStart(26, "tbody")(27, "tr")(28, "td");
143
+ i0.ɵɵelement(29, "input", 6);
144
+ i0.ɵɵelementEnd();
145
+ i0.ɵɵelementStart(30, "td");
146
+ i0.ɵɵelement(31, "input", 7);
147
+ i0.ɵɵelementEnd()();
148
+ i0.ɵɵelementStart(32, "tr")(33, "td");
149
+ i0.ɵɵelement(34, "input", 6);
150
+ i0.ɵɵelementEnd();
151
+ i0.ɵɵelementStart(35, "td");
152
+ i0.ɵɵtemplate(36, BasicAuthCreateSecretDialogComponent_input_36_Template, 1, 0, "input", 8)(37, BasicAuthCreateSecretDialogComponent_input_37_Template, 1, 0, "input", 9)(38, BasicAuthCreateSecretDialogComponent_ng_container_38_Template, 5, 2, "ng-container", 10)(39, BasicAuthCreateSecretDialogComponent_acl_errors_mapper_39_Template, 1, 1, "acl-errors-mapper", 11);
153
+ i0.ɵɵelementEnd()()()()()()()();
154
+ i0.ɵɵelementStart(40, "aui-dialog-footer")(41, "button", 12);
155
+ i0.ɵɵlistener("click", function BasicAuthCreateSecretDialogComponent_Template_button_click_41_listener() { return ctx.confirm(); });
156
+ i0.ɵɵtext(42);
157
+ i0.ɵɵpipe(43, "translate");
158
+ i0.ɵɵelementEnd();
159
+ i0.ɵɵelementStart(44, "button", 13);
160
+ i0.ɵɵtext(45);
161
+ i0.ɵɵpipe(46, "translate");
162
+ i0.ɵɵelementEnd()();
163
+ } if (rf & 2) {
164
+ i0.ɵɵadvance();
165
+ i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(2, 21, "create_secret"), "\n");
166
+ i0.ɵɵadvance(3);
167
+ i0.ɵɵproperty("formGroup", ctx.formGroup);
168
+ i0.ɵɵadvance(3);
169
+ i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(8, 23, "name"), " ");
170
+ i0.ɵɵadvance(3);
171
+ i0.ɵɵproperty("errors", ctx.formGroup.get("name").errors)("errorsMapper", i0.ɵɵpureFunction1(37, _c0, i0.ɵɵpipeBind1(11, 25, ctx.K8S_RESOURCE_NAME_BASE.tip)));
172
+ i0.ɵɵadvance(4);
173
+ i0.ɵɵtextInterpolate(i0.ɵɵpipeBind1(15, 27, "config"));
174
+ i0.ɵɵadvance(7);
175
+ i0.ɵɵtextInterpolate(i0.ɵɵpipeBind1(22, 29, "key"));
176
+ i0.ɵɵadvance(3);
177
+ i0.ɵɵtextInterpolate(i0.ɵɵpipeBind1(25, 31, "value"));
178
+ i0.ɵɵadvance(5);
179
+ i0.ɵɵproperty("ngModel", ctx.usernameKey)("ngModelOptions", i0.ɵɵpureFunction0(39, _c1));
180
+ i0.ɵɵadvance(2);
181
+ i0.ɵɵproperty("readonly", ctx.usernameReadonly);
182
+ i0.ɵɵadvance(3);
183
+ i0.ɵɵproperty("ngModel", ctx.passwordKey)("ngModelOptions", i0.ɵɵpureFunction0(40, _c1));
184
+ i0.ɵɵadvance(2);
185
+ i0.ɵɵproperty("ngIf", ctx.strongPassword && !ctx.password);
186
+ i0.ɵɵadvance();
187
+ i0.ɵɵproperty("ngIf", !ctx.strongPassword && !ctx.password);
188
+ i0.ɵɵadvance();
189
+ i0.ɵɵproperty("ngIf", ctx.password && !ctx.strongPassword);
190
+ i0.ɵɵadvance();
191
+ i0.ɵɵproperty("ngIf", ctx.formGroup.get("password").dirty || (ctx.form == null ? null : ctx.form.submitted));
192
+ i0.ɵɵadvance(2);
193
+ i0.ɵɵproperty("loading", ctx.submitting)("disabled", ctx.submitting);
194
+ i0.ɵɵadvance();
195
+ i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(43, 33, "create"), " ");
196
+ i0.ɵɵadvance(3);
197
+ i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(46, 35, "cancel"), " ");
198
+ } }, dependencies: [i4.NgIf, i2.ɵNgNoValidate, i2.DefaultValueAccessor, i2.NgControlStatus, i2.NgControlStatusGroup, i2.RequiredValidator, i2.NgModel, i2.FormGroupDirective, i2.FormControlName, i1.FormDirective, i1.FormItemComponent, i1.FormItemErrorDirective, i1.FormItemLabelDirective, i1.FormItemControlDirective, i1.IconComponent, i1.InputComponent, i1.InputGroupComponent, i1.InputSuffixDirective, i1.DialogHeaderComponent, i1.DialogContentComponent, i1.DialogFooterComponent, i1.DialogCloseDirective, i1.ButtonComponent, i3.ErrorsMapperComponent, i3.StrongPasswordDirective, i3.E2eAttributeBindingDirective, i3.ValidatorsDirective, i3.TranslatePipe], styles: ["[_nghost-%COMP%] .aui-form-item__label-wrapper{width:114px}[_nghost-%COMP%] label{word-break:break-all}"], changeDetection: 0 }); }
199
+ }
200
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(BasicAuthCreateSecretDialogComponent, [{
201
+ type: Component,
202
+ args: [{ changeDetection: ChangeDetectionStrategy.OnPush, template: "<aui-dialog-header>\n {{ 'create_secret' | translate }}\n</aui-dialog-header>\n\n<aui-dialog-content>\n <form\n auiForm\n [formGroup]=\"formGroup\"\n >\n <aui-form-item>\n <label auiFormItemLabel>\n {{ 'name' | translate }}\n </label>\n <input\n type=\"text\"\n required\n aui-input\n auiFormItemControl\n formControlName=\"name\"\n />\n <acl-errors-mapper\n auiFormItemError\n [errors]=\"formGroup.get('name').errors\"\n [errorsMapper]=\"{\n pattern: K8S_RESOURCE_NAME_BASE.tip | translate\n }\"\n ></acl-errors-mapper>\n </aui-form-item>\n <aui-form-item>\n <label auiFormItemLabel>{{ 'config' | translate }}</label>\n <div class=\"form-table__flex-layout tw-flex-1\">\n <table class=\"acl-array-form-table\">\n <thead>\n <tr>\n <th>{{ 'key' | translate }}</th>\n <th>{{ 'value' | translate }}</th>\n </tr>\n </thead>\n <tbody>\n <tr>\n <td>\n <input\n type=\"text\"\n required\n aui-input\n readonly\n [ngModel]=\"usernameKey\"\n [ngModelOptions]=\"{ standalone: true }\"\n />\n </td>\n <td>\n <input\n type=\"text\"\n aui-input\n auiFormItemControl\n formControlName=\"username\"\n [readonly]=\"usernameReadonly\"\n />\n </td>\n </tr>\n <tr>\n <td>\n <input\n type=\"text\"\n required\n aui-input\n readonly\n [ngModel]=\"passwordKey\"\n [ngModelOptions]=\"{ standalone: true }\"\n />\n </td>\n <td>\n <input\n *ngIf=\"strongPassword && !password\"\n type=\"password\"\n required\n aui-input\n auiFormItemControl\n formControlName=\"password\"\n aclStrongPassword\n />\n <input\n *ngIf=\"!strongPassword && !password\"\n type=\"text\"\n required\n aui-input\n auiFormItemControl\n formControlName=\"password\"\n />\n <ng-container *ngIf=\"password && !strongPassword\">\n <aui-input-group\n auiFormItemControl\n required\n >\n <input\n auiFormItemControl\n aui-input\n required\n formControlName=\"password\"\n [type]=\"showPassword ? 'text' : 'password'\"\n />\n <div\n auiInputSuffix\n class=\"password__suffix\"\n (click)=\"toggleShowPassword()\"\n >\n <aui-icon\n [icon]=\"showPassword ? 'eye_s' : 'eye_slash_s'\"\n ></aui-icon>\n </div>\n </aui-input-group>\n </ng-container>\n\n <acl-errors-mapper\n *ngIf=\"formGroup.get('password').dirty || form?.submitted\"\n auiFormItemError\n [errors]=\"formGroup.get('password').errors\"\n ></acl-errors-mapper>\n </td>\n </tr>\n </tbody>\n </table>\n </div>\n </aui-form-item>\n </form>\n</aui-dialog-content>\n\n<aui-dialog-footer>\n <button\n aui-button=\"primary\"\n (click)=\"confirm()\"\n [loading]=\"submitting\"\n [disabled]=\"submitting\"\n >\n {{ 'create' | translate }}\n </button>\n <button\n aui-button\n auiDialogClose\n >\n {{ 'cancel' | translate }}\n </button>\n</aui-dialog-footer>\n", styles: [":host::ng-deep .aui-form-item__label-wrapper{width:114px}:host::ng-deep label{word-break:break-all}\n"] }]
203
+ }], () => [{ type: undefined, decorators: [{
204
+ type: Inject,
205
+ args: [DIALOG_DATA]
206
+ }] }, { type: i1.DialogRef }, { type: i2.FormBuilder }, { type: i3.K8sApiService }, { type: i0.ChangeDetectorRef }, { type: i1.MessageService }, { type: i3.TranslateService }], { form: [{
207
+ type: ViewChild,
208
+ args: [FormGroupDirective, { static: true }]
209
+ }] }); })();
210
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(BasicAuthCreateSecretDialogComponent, { className: "BasicAuthCreateSecretDialogComponent", filePath: "lib/field-controls/widgets/basic-auth-secret/create/component.ts", lineNumber: 28 }); })();
211
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"component.js","sourceRoot":"","sources":["../../../../../../../../../libs/crd-form/src/lib/field-controls/widgets/basic-auth-secret/create/component.ts","../../../../../../../../../libs/crd-form/src/lib/field-controls/widgets/basic-auth-secret/create/template.html"],"names":[],"mappings":"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","sourcesContent":["import { DialogRef, DIALOG_DATA, MessageService } from '@alauda/ui';\nimport {\n  COMMON_RESOURCE_DEFINITIONS,\n  K8sApiService,\n  K8S_RESOURCE_NAME_BASE,\n  SecretType,\n  StringMap,\n  TranslateService,\n} from '@alauda-fe/common';\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  Inject,\n  ViewChild,\n} from '@angular/core';\nimport { FormBuilder, FormGroupDirective, Validators } from '@angular/forms';\nimport { encode } from 'ab64';\nimport { finalize } from 'rxjs';\n\nimport { BasicAuthSecretConfig } from '../type';\n\n@Component({\n  templateUrl: 'template.html',\n  styleUrls: ['styles.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class BasicAuthCreateSecretDialogComponent {\n  @ViewChild(FormGroupDirective, { static: true })\n  readonly form: FormGroupDirective;\n\n  submitting = false;\n\n  K8S_RESOURCE_NAME_BASE = K8S_RESOURCE_NAME_BASE;\n\n  usernameKey = this.dialogData.config?.usernameKey ?? 'username';\n  passwordKey = this.dialogData.config?.passwordKey ?? 'password';\n  usernameReadonly = !!this.dialogData.config?.usernameReadonly;\n  strongPassword = !!this.dialogData.config?.strongPassword;\n  password = !!this.dialogData.config?.password;\n  showPassword = false;\n\n  formGroup = this.fb.group({\n    name: this.fb.control(this.dialogData.config?.secretName || '', [\n      Validators.required,\n      Validators.pattern(K8S_RESOURCE_NAME_BASE.pattern),\n      Validators.maxLength(63),\n    ]),\n    username: this.fb.control(this.dialogData.config?.usernameDefault || ''),\n    password: this.fb.control('', [Validators.required]),\n  });\n\n  constructor(\n    @Inject(DIALOG_DATA)\n    public readonly dialogData: {\n      cluster: string;\n      namespace: string;\n      config?: BasicAuthSecretConfig;\n    },\n    private readonly dialogRef: DialogRef,\n    private readonly fb: FormBuilder,\n    private readonly k8sApi: K8sApiService,\n    private readonly cdr: ChangeDetectorRef,\n    private readonly message: MessageService,\n    private readonly translate: TranslateService,\n  ) {}\n\n  confirm() {\n    this.form.onSubmit(null);\n    if (!this.form.valid) {\n      return;\n    }\n    this.submitting = true;\n    const value = this.form.value;\n    const data: StringMap = {\n      [this.passwordKey]: encode(value.password),\n    };\n    if (value.username) {\n      data[this.usernameKey] = encode(value.username);\n    }\n    const resource = {\n      kind: 'Secret',\n      apiVersion: 'v1',\n      metadata: {\n        name: value.name,\n        namespace: this.dialogData.namespace,\n      },\n      type: SecretType.Opaque,\n      data,\n    };\n    this.k8sApi\n      .postResource({\n        definition: COMMON_RESOURCE_DEFINITIONS.SECRET,\n        cluster: this.dialogData.cluster,\n        namespace: this.dialogData.namespace,\n        resource,\n      })\n      .pipe(\n        finalize(() => {\n          this.submitting = false;\n          this.cdr.markForCheck();\n        }),\n      )\n      .subscribe(res => {\n        this.dialogRef.close(res);\n        this.message.success(this.translate.get('create_success'));\n      });\n  }\n\n  toggleShowPassword() {\n    this.showPassword = !this.showPassword;\n  }\n}\n","<aui-dialog-header>\n  {{ 'create_secret' | translate }}\n</aui-dialog-header>\n\n<aui-dialog-content>\n  <form\n    auiForm\n    [formGroup]=\"formGroup\"\n  >\n    <aui-form-item>\n      <label auiFormItemLabel>\n        {{ 'name' | translate }}\n      </label>\n      <input\n        type=\"text\"\n        required\n        aui-input\n        auiFormItemControl\n        formControlName=\"name\"\n      />\n      <acl-errors-mapper\n        auiFormItemError\n        [errors]=\"formGroup.get('name').errors\"\n        [errorsMapper]=\"{\n          pattern: K8S_RESOURCE_NAME_BASE.tip | translate\n        }\"\n      ></acl-errors-mapper>\n    </aui-form-item>\n    <aui-form-item>\n      <label auiFormItemLabel>{{ 'config' | translate }}</label>\n      <div class=\"form-table__flex-layout tw-flex-1\">\n        <table class=\"acl-array-form-table\">\n          <thead>\n            <tr>\n              <th>{{ 'key' | translate }}</th>\n              <th>{{ 'value' | translate }}</th>\n            </tr>\n          </thead>\n          <tbody>\n            <tr>\n              <td>\n                <input\n                  type=\"text\"\n                  required\n                  aui-input\n                  readonly\n                  [ngModel]=\"usernameKey\"\n                  [ngModelOptions]=\"{ standalone: true }\"\n                />\n              </td>\n              <td>\n                <input\n                  type=\"text\"\n                  aui-input\n                  auiFormItemControl\n                  formControlName=\"username\"\n                  [readonly]=\"usernameReadonly\"\n                />\n              </td>\n            </tr>\n            <tr>\n              <td>\n                <input\n                  type=\"text\"\n                  required\n                  aui-input\n                  readonly\n                  [ngModel]=\"passwordKey\"\n                  [ngModelOptions]=\"{ standalone: true }\"\n                />\n              </td>\n              <td>\n                <input\n                  *ngIf=\"strongPassword && !password\"\n                  type=\"password\"\n                  required\n                  aui-input\n                  auiFormItemControl\n                  formControlName=\"password\"\n                  aclStrongPassword\n                />\n                <input\n                  *ngIf=\"!strongPassword && !password\"\n                  type=\"text\"\n                  required\n                  aui-input\n                  auiFormItemControl\n                  formControlName=\"password\"\n                />\n                <ng-container *ngIf=\"password && !strongPassword\">\n                  <aui-input-group\n                    auiFormItemControl\n                    required\n                  >\n                    <input\n                      auiFormItemControl\n                      aui-input\n                      required\n                      formControlName=\"password\"\n                      [type]=\"showPassword ? 'text' : 'password'\"\n                    />\n                    <div\n                      auiInputSuffix\n                      class=\"password__suffix\"\n                      (click)=\"toggleShowPassword()\"\n                    >\n                      <aui-icon\n                        [icon]=\"showPassword ? 'eye_s' : 'eye_slash_s'\"\n                      ></aui-icon>\n                    </div>\n                  </aui-input-group>\n                </ng-container>\n\n                <acl-errors-mapper\n                  *ngIf=\"formGroup.get('password').dirty || form?.submitted\"\n                  auiFormItemError\n                  [errors]=\"formGroup.get('password').errors\"\n                ></acl-errors-mapper>\n              </td>\n            </tr>\n          </tbody>\n        </table>\n      </div>\n    </aui-form-item>\n  </form>\n</aui-dialog-content>\n\n<aui-dialog-footer>\n  <button\n    aui-button=\"primary\"\n    (click)=\"confirm()\"\n    [loading]=\"submitting\"\n    [disabled]=\"submitting\"\n  >\n    {{ 'create' | translate }}\n  </button>\n  <button\n    aui-button\n    auiDialogClose\n  >\n    {{ 'cancel' | translate }}\n  </button>\n</aui-dialog-footer>\n"]}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY3JkLWZvcm0vc3JjL2xpYi9maWVsZC1jb250cm9scy93aWRnZXRzL2Jhc2ljLWF1dGgtc2VjcmV0L3R5cGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgQmFzaWNBdXRoU2VjcmV0Q29uZmlnIHtcbiAgc2VjcmV0TmFtZT86IHN0cmluZztcbiAgdXNlcm5hbWVLZXk/OiBzdHJpbmc7XG4gIHVzZXJuYW1lRGVmYXVsdD86IHN0cmluZztcbiAgdXNlcm5hbWVSZWFkb25seT86IGJvb2xlYW47XG4gIHBhc3N3b3JkS2V5Pzogc3RyaW5nO1xuICBzdHJvbmdQYXNzd29yZD86IGJvb2xlYW47XG4gIHBhc3N3b3JkPzogYm9vbGVhbjtcbiAgbmFtZXNwYWNlPzogc3RyaW5nO1xuICBjbHVzdGVyPzogc3RyaW5nO1xufVxuIl19
@@ -0,0 +1,8 @@
1
+ export * from './array-table/component';
2
+ export * from './basic-auth-secret/component';
3
+ export * from './basic-auth-secret/create/component';
4
+ export * from './k8s-resource-prefix/component';
5
+ export * from './link/component';
6
+ export * from './resource-requirements/resource-requirements.component';
7
+ export * from './yaml-editor/yaml-editor.component';
8
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NyZC1mb3JtL3NyYy9saWIvZmllbGQtY29udHJvbHMvd2lkZ2V0cy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMsK0JBQStCLENBQUM7QUFDOUMsY0FBYyxzQ0FBc0MsQ0FBQztBQUNyRCxjQUFjLGlDQUFpQyxDQUFDO0FBQ2hELGNBQWMsa0JBQWtCLENBQUM7QUFDakMsY0FBYyx5REFBeUQsQ0FBQztBQUN4RSxjQUFjLHFDQUFxQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9hcnJheS10YWJsZS9jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9iYXNpYy1hdXRoLXNlY3JldC9jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9iYXNpYy1hdXRoLXNlY3JldC9jcmVhdGUvY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vazhzLXJlc291cmNlLXByZWZpeC9jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saW5rL2NvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3Jlc291cmNlLXJlcXVpcmVtZW50cy9yZXNvdXJjZS1yZXF1aXJlbWVudHMuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4veWFtbC1lZGl0b3IveWFtbC1lZGl0b3IuY29tcG9uZW50JztcbiJdfQ==