@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,5 @@
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ export * from './public-api';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWxhdWRhLWZlLWNyZC1mb3JtLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vbGlicy9jcmQtZm9ybS9zcmMvYWxhdWRhLWZlLWNyZC1mb3JtLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyxjQUFjLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEdlbmVyYXRlZCBidW5kbGUgaW5kZXguIERvIG5vdCBlZGl0LlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vcHVibGljLWFwaSc7XG4iXX0=
@@ -0,0 +1,117 @@
1
+ import { Directive, EventEmitter, Input, Output, } from '@angular/core';
2
+ import { last } from 'lodash-es';
3
+ import { CrdFormComponent } from '../crd-form/component';
4
+ import { Validations, } from '../types';
5
+ import { getFieldDisplayName, getFormData, modifyArrayFieldPathIndex, } from '../utils';
6
+ import { isFolded, repairFieldChildPathByCorrectIndex } from '../utils/helper';
7
+ import * as i0 from "@angular/core";
8
+ import * as i1 from "../crd-form/component";
9
+ export class BaseOperandFiledArrayComponent {
10
+ get expanded() {
11
+ return this._expanded ?? !isFolded(this.arrayFieldGroup);
12
+ }
13
+ set expanded(expanded) {
14
+ this._expanded = expanded;
15
+ }
16
+ constructor(crdForm) {
17
+ this.crdForm = crdForm;
18
+ this.readonly = false;
19
+ this.valueChange = new EventEmitter();
20
+ this.itemRemove = new EventEmitter();
21
+ this.getFieldDisplayName = getFieldDisplayName;
22
+ }
23
+ ngOnChanges({ arrayFieldGroup, formDataState }) {
24
+ if (!this.basicArrayFieldTemplate &&
25
+ arrayFieldGroup.currentValue?.fieldLists?.length > 0) {
26
+ this.basicArrayFieldTemplate = last(arrayFieldGroup.currentValue.fieldLists);
27
+ }
28
+ if (formDataState?.currentValue && formDataState?.previousValue) {
29
+ const currValue = getFormData(formDataState.currentValue, this.arrayFieldGroup.path);
30
+ const arrayFieldLength = this.arrayFieldGroup.fieldLists?.length;
31
+ if (currValue?.size > arrayFieldLength) {
32
+ Array.from({ length: currValue.size - arrayFieldLength }).forEach(() => {
33
+ this.addItem();
34
+ });
35
+ }
36
+ }
37
+ }
38
+ fieldValueChange(e) {
39
+ this.valueChange.emit(e);
40
+ }
41
+ addItem() {
42
+ const newFields = this.basicArrayFieldTemplate.map(field => {
43
+ const toPath = modifyArrayFieldPathIndex(field.path, () => this.arrayFieldGroup.fieldLists.length);
44
+ return {
45
+ ...repairFieldChildPathByCorrectIndex(field, field.path, toPath),
46
+ };
47
+ });
48
+ this.arrayFieldGroup.fieldLists = [
49
+ ...this.arrayFieldGroup.fieldLists,
50
+ newFields,
51
+ ];
52
+ }
53
+ removeItem(index) {
54
+ const groupToRemove = this.arrayFieldGroup.fieldLists[index];
55
+ const groupUntouched = this.arrayFieldGroup.fieldLists.filter((_, idx) => idx < index);
56
+ const groupToLeftShift = this.arrayFieldGroup.fieldLists.filter((_, idx) => idx > index);
57
+ const leftShiftedGroups = groupToLeftShift.map(group => group.map(field => {
58
+ const toPath = modifyArrayFieldPathIndex(field.path, idx => idx - 1);
59
+ return {
60
+ ...repairFieldChildPathByCorrectIndex(field, field.path, toPath),
61
+ };
62
+ }));
63
+ this.arrayFieldGroup.fieldLists = [...groupUntouched, ...leftShiftedGroups];
64
+ const [match, formDataPathToRemove] =
65
+ // eslint-disable-next-line regexp/strict
66
+ /^(.*\[\d+]).*$/.exec(groupToRemove?.[0].path) || [];
67
+ if (match) {
68
+ this.itemRemove.next(formDataPathToRemove);
69
+ }
70
+ this.crdForm.controlMap.forEach((_, key) => {
71
+ if (key.startsWith(`${this.arrayFieldGroup.path}[${this.arrayFieldGroup.fieldLists.length}]`)) {
72
+ this.crdForm.controlMap.delete(key);
73
+ }
74
+ });
75
+ this.crdForm.refreshValidation();
76
+ this.deleteFormData(`${this.arrayFieldGroup.path}[${index}]`);
77
+ }
78
+ deleteFormData(path) {
79
+ this.valueChange.next({
80
+ field: {
81
+ ...this.arrayFieldGroup,
82
+ path,
83
+ },
84
+ data: null,
85
+ });
86
+ }
87
+ fieldIsRequired(field) {
88
+ return (field?.required ||
89
+ Object.keys(field?.validations || {})?.includes(Validations.required));
90
+ }
91
+ get columnFields() {
92
+ return this.basicArrayFieldTemplate;
93
+ }
94
+ trackByFn(index) {
95
+ return index;
96
+ }
97
+ static { this.ɵfac = function BaseOperandFiledArrayComponent_Factory(t) { return new (t || BaseOperandFiledArrayComponent)(i0.ɵɵdirectiveInject(i1.CrdFormComponent)); }; }
98
+ static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: BaseOperandFiledArrayComponent, inputs: { arrayFieldGroup: "arrayFieldGroup", formDataState: "formDataState", formErrors: "formErrors", isArrayTable: "isArrayTable", readonly: "readonly" }, outputs: { valueChange: "valueChange", itemRemove: "itemRemove" }, features: [i0.ɵɵNgOnChangesFeature] }); }
99
+ }
100
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(BaseOperandFiledArrayComponent, [{
101
+ type: Directive
102
+ }], () => [{ type: i1.CrdFormComponent }], { arrayFieldGroup: [{
103
+ type: Input
104
+ }], formDataState: [{
105
+ type: Input
106
+ }], formErrors: [{
107
+ type: Input
108
+ }], isArrayTable: [{
109
+ type: Input
110
+ }], readonly: [{
111
+ type: Input
112
+ }], valueChange: [{
113
+ type: Output
114
+ }], itemRemove: [{
115
+ type: Output
116
+ }] }); })();
117
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-array.js","sourceRoot":"","sources":["../../../../../../libs/crd-form/src/lib/abstract/base-array.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Directive,\n  EventEmitter,\n  Input,\n  OnChanges,\n  Output,\n  SimpleChanges,\n} from '@angular/core';\nimport { last } from 'lodash-es';\n\nimport { CrdFormComponent } from '../crd-form/component';\nimport {\n  FieldValueChangeEvent,\n  FormDataState,\n  FormErrors,\n  OperandArrayFieldGroup,\n  OperandField,\n  Validations,\n} from '../types';\nimport {\n  getFieldDisplayName,\n  getFormData,\n  modifyArrayFieldPathIndex,\n} from '../utils';\nimport { isFolded, repairFieldChildPathByCorrectIndex } from '../utils/helper';\n\n@Directive()\nexport class BaseOperandFiledArrayComponent implements OnChanges {\n  @Input() arrayFieldGroup: OperandArrayFieldGroup;\n  @Input() formDataState: FormDataState;\n  @Input() formErrors: FormErrors;\n  @Input() isArrayTable: boolean;\n  @Input() readonly = false;\n\n  @Output() valueChange = new EventEmitter();\n  @Output() itemRemove = new EventEmitter();\n\n  private _expanded: boolean;\n\n  get expanded() {\n    return this._expanded ?? !isFolded(this.arrayFieldGroup);\n  }\n\n  set expanded(expanded: boolean) {\n    this._expanded = expanded;\n  }\n\n  basicArrayFieldTemplate: OperandField[];\n\n  getFieldDisplayName = getFieldDisplayName;\n\n  constructor(public readonly crdForm: CrdFormComponent) {}\n\n  ngOnChanges({ arrayFieldGroup, formDataState }: SimpleChanges) {\n    if (\n      !this.basicArrayFieldTemplate &&\n      arrayFieldGroup.currentValue?.fieldLists?.length > 0\n    ) {\n      this.basicArrayFieldTemplate = last(\n        arrayFieldGroup.currentValue.fieldLists,\n      );\n    }\n    if (formDataState?.currentValue && formDataState?.previousValue) {\n      const currValue = getFormData(\n        formDataState.currentValue,\n        this.arrayFieldGroup.path,\n      );\n      const arrayFieldLength = this.arrayFieldGroup.fieldLists?.length;\n      if (currValue?.size > arrayFieldLength) {\n        Array.from({ length: currValue.size - arrayFieldLength }).forEach(\n          () => {\n            this.addItem();\n          },\n        );\n      }\n    }\n  }\n\n  fieldValueChange(e: FieldValueChangeEvent) {\n    this.valueChange.emit(e);\n  }\n\n  addItem() {\n    const newFields = this.basicArrayFieldTemplate.map(field => {\n      const toPath = modifyArrayFieldPathIndex(\n        field.path,\n        () => this.arrayFieldGroup.fieldLists.length,\n      );\n      return {\n        ...repairFieldChildPathByCorrectIndex(field, field.path, toPath),\n      } as OperandField;\n    });\n    this.arrayFieldGroup.fieldLists = [\n      ...this.arrayFieldGroup.fieldLists,\n      newFields,\n    ];\n  }\n\n  removeItem(index: number) {\n    const groupToRemove = this.arrayFieldGroup.fieldLists[index];\n    const groupUntouched = this.arrayFieldGroup.fieldLists.filter(\n      (_, idx) => idx < index,\n    );\n    const groupToLeftShift = this.arrayFieldGroup.fieldLists.filter(\n      (_, idx) => idx > index,\n    );\n\n    const leftShiftedGroups = groupToLeftShift.map(group =>\n      group.map(field => {\n        const toPath = modifyArrayFieldPathIndex(field.path, idx => idx - 1);\n        return {\n          ...repairFieldChildPathByCorrectIndex(field, field.path, toPath),\n        } as OperandField;\n      }),\n    );\n\n    this.arrayFieldGroup.fieldLists = [...groupUntouched, ...leftShiftedGroups];\n\n    const [match, formDataPathToRemove] =\n      // eslint-disable-next-line regexp/strict\n      /^(.*\\[\\d+]).*$/.exec(groupToRemove?.[0].path) || [];\n    if (match) {\n      this.itemRemove.next(formDataPathToRemove);\n    }\n\n    this.crdForm.controlMap.forEach((_, key) => {\n      if (\n        key.startsWith(\n          `${this.arrayFieldGroup.path}[${this.arrayFieldGroup.fieldLists.length}]`,\n        )\n      ) {\n        this.crdForm.controlMap.delete(key);\n      }\n    });\n    this.crdForm.refreshValidation();\n\n    this.deleteFormData(`${this.arrayFieldGroup.path}[${index}]`);\n  }\n\n  private deleteFormData(path: string) {\n    this.valueChange.next({\n      field: {\n        ...this.arrayFieldGroup,\n        path,\n      },\n      data: null,\n    });\n  }\n\n  fieldIsRequired(field: OperandField) {\n    return (\n      field?.required ||\n      Object.keys(field?.validations || {})?.includes(Validations.required)\n    );\n  }\n\n  get columnFields() {\n    return this.basicArrayFieldTemplate;\n  }\n\n  trackByFn(index: number) {\n    return index;\n  }\n}\n"]}
@@ -0,0 +1,334 @@
1
+ import { __decorate, __metadata } from "tslib";
2
+ import { LabelPosition } from '@alauda/ui';
3
+ import { ObservableInput, } from '@alauda-fe/common';
4
+ import { ChangeDetectionStrategy, Component, ContentChildren, EventEmitter, Input, Output, QueryList, ViewChild, } from '@angular/core';
5
+ import { NgForm } from '@angular/forms';
6
+ import { List, Map as $Map, fromJS } from 'immutable';
7
+ import { flattenDeep, fromPairs, isEmpty, uniq } from 'lodash-es';
8
+ import { Observable } from 'rxjs';
9
+ import { RemoteWidgetsService } from '../remote-widgets';
10
+ import { SpecCapability, } from '../types';
11
+ import { CrdFormCustomDescriptionDirective, parseArrayPath, SCHEMA_PATH, createCapabilityField, normalizePath, pathToArray, getCustomDescription, getOperandPath, getPathFromTagPath, getFieldsByPath, fieldShouldReveal, getDefaultValue, } from '../utils';
12
+ import { differPathsTag, getAllOtherTagPath, matchValueAgainstOneOf, } from './helper';
13
+ import * as i0 from "@angular/core";
14
+ import * as i1 from "../remote-widgets";
15
+ const _c0 = ["form"];
16
+ function CrdFormComponent_ng_container_2_Template(rf, ctx) { if (rf & 1) {
17
+ const _r1 = i0.ɵɵgetCurrentView();
18
+ i0.ɵɵelementContainerStart(0);
19
+ i0.ɵɵelementStart(1, "acl-operand-field", 4);
20
+ i0.ɵɵpipe(2, "pure");
21
+ i0.ɵɵpipe(3, "async");
22
+ i0.ɵɵlistener("valueChange", function CrdFormComponent_ng_container_2_Template_acl_operand_field_valueChange_1_listener($event) { i0.ɵɵrestoreView(_r1); const ctx_r1 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r1.fieldValueChange($event)); });
23
+ i0.ɵɵelementEnd();
24
+ i0.ɵɵelementContainerEnd();
25
+ } if (rf & 2) {
26
+ const field_r3 = ctx.$implicit;
27
+ const ctx_r1 = i0.ɵɵnextContext();
28
+ i0.ɵɵadvance();
29
+ i0.ɵɵproperty("fields", ctx_r1.fields)("field", field_r3)("formDataState", ctx_r1.formDataState)("readonly", ctx_r1.readonly)("customDescription", i0.ɵɵpipeBind3(2, 6, ctx_r1.customDescriptions, ctx_r1.getCustomDescription, field_r3))("remoteModuleDefinition", i0.ɵɵpipeBind1(3, 10, ctx_r1.remoteModuleDefinition$));
30
+ } }
31
+ function CrdFormComponent_ng_container_3_Template(rf, ctx) { if (rf & 1) {
32
+ const _r4 = i0.ɵɵgetCurrentView();
33
+ i0.ɵɵelementContainerStart(0);
34
+ i0.ɵɵelementStart(1, "acl-operand-field-group", 5);
35
+ i0.ɵɵlistener("valueChange", function CrdFormComponent_ng_container_3_Template_acl_operand_field_group_valueChange_1_listener($event) { i0.ɵɵrestoreView(_r4); const ctx_r1 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r1.fieldValueChange($event)); });
36
+ i0.ɵɵelementEnd();
37
+ i0.ɵɵelementContainerEnd();
38
+ } if (rf & 2) {
39
+ const group_r5 = ctx.$implicit;
40
+ const ctx_r1 = i0.ɵɵnextContext();
41
+ i0.ɵɵadvance();
42
+ i0.ɵɵproperty("fields", ctx_r1.fields)("fieldGroup", group_r5)("formDataState", ctx_r1.formDataState)("formErrors", ctx_r1.formErrors)("readonly", ctx_r1.readonly)("customDescriptions", ctx_r1.customDescriptions);
43
+ } }
44
+ function CrdFormComponent_ng_container_4_Template(rf, ctx) { if (rf & 1) {
45
+ const _r6 = i0.ɵɵgetCurrentView();
46
+ i0.ɵɵelementContainerStart(0);
47
+ i0.ɵɵelementStart(1, "acl-operand-array-field-group", 6);
48
+ i0.ɵɵlistener("valueChange", function CrdFormComponent_ng_container_4_Template_acl_operand_array_field_group_valueChange_1_listener($event) { i0.ɵɵrestoreView(_r6); const ctx_r1 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r1.fieldValueChange($event)); })("itemRemove", function CrdFormComponent_ng_container_4_Template_acl_operand_array_field_group_itemRemove_1_listener($event) { i0.ɵɵrestoreView(_r6); const ctx_r1 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r1.deleteFormData($event)); });
49
+ i0.ɵɵelementEnd();
50
+ i0.ɵɵelementContainerEnd();
51
+ } if (rf & 2) {
52
+ const group_r7 = ctx.$implicit;
53
+ const ctx_r1 = i0.ɵɵnextContext();
54
+ i0.ɵɵadvance();
55
+ i0.ɵɵproperty("arrayFieldGroup", group_r7)("formDataState", ctx_r1.formDataState)("readonly", ctx_r1.readonly);
56
+ } }
57
+ function CrdFormComponent_ng_container_5_Template(rf, ctx) { if (rf & 1) {
58
+ const _r8 = i0.ɵɵgetCurrentView();
59
+ i0.ɵɵelementContainerStart(0);
60
+ i0.ɵɵelementStart(1, "acl-operand-advanced-field-group", 7);
61
+ i0.ɵɵlistener("valueChange", function CrdFormComponent_ng_container_5_Template_acl_operand_advanced_field_group_valueChange_1_listener($event) { i0.ɵɵrestoreView(_r8); const ctx_r1 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r1.fieldValueChange($event)); });
62
+ i0.ɵɵelementEnd();
63
+ i0.ɵɵelementContainerEnd();
64
+ } if (rf & 2) {
65
+ const ctx_r1 = i0.ɵɵnextContext();
66
+ i0.ɵɵadvance();
67
+ i0.ɵɵproperty("fields", ctx_r1.fields)("fieldList", ctx_r1.advancedFields)("formDataState", ctx_r1.formDataState)("readonly", ctx_r1.readonly);
68
+ } }
69
+ export class CrdFormComponent {
70
+ constructor(rws) {
71
+ this.rws = rws;
72
+ this.debug = false;
73
+ this.openApiSchemaPath = SCHEMA_PATH;
74
+ this.readonly = false;
75
+ this.labelPosition = LabelPosition.Right;
76
+ this.formStateChange = new EventEmitter();
77
+ this.formSchemaChange = new EventEmitter();
78
+ this.formErrors = {};
79
+ // 一个全局的 controlMap,方便控制 field 主动校验。
80
+ // 该 controlMap 以及所有 field 里的 control 实例,都是为了数据追踪与错误同步(control.error -> crdForm error),本身不影响提交,由 crd-form 的 error 去阻塞提交。
81
+ this.controlMap = new Map();
82
+ this.remoteModuleDefinition$ = this.rws.remoteModule$;
83
+ this.getCustomDescription = getCustomDescription;
84
+ // 被隐藏起来的表单的路径集合
85
+ this.dirtyPathsSet = new Set();
86
+ }
87
+ ngOnChanges({ openApiSchema, descriptors, data }) {
88
+ if (openApiSchema?.currentValue || descriptors?.currentValue) {
89
+ this.setUpForm();
90
+ }
91
+ else if (data?.currentValue) {
92
+ this.formDataState = fromJS(data.currentValue);
93
+ }
94
+ }
95
+ setUpForm() {
96
+ this.formDataState = fromJS(this.data || {});
97
+ const { normalFields, fieldGroups, arrayFieldGroups, advancedFields, descriptorFields, openApiFields, basicFields, } = createCapabilityField(this.descriptors || [], this.openApiSchema || {}, this.data, this.openApiSchemaPath);
98
+ this.fields = basicFields.filter(fieldShouldReveal);
99
+ if (this.debug) {
100
+ /* eslint-disable no-console */
101
+ console.info('openApiFields:', openApiFields);
102
+ console.info('descriptorFields:', descriptorFields);
103
+ console.info('basicFields:', basicFields);
104
+ console.info('normalFields', normalFields);
105
+ console.info('fieldGroups:', fieldGroups);
106
+ console.info('arrayFieldGroups:', arrayFieldGroups);
107
+ console.info('advancedFields:', advancedFields);
108
+ /* eslint-enable no-console */
109
+ }
110
+ this.normalFields = normalFields;
111
+ this.fieldGroups = fieldGroups;
112
+ this.arrayFieldGroups = arrayFieldGroups;
113
+ this.advancedFields = advancedFields;
114
+ this.formSchemaChange.emit({
115
+ openApiFields,
116
+ descriptorFields,
117
+ });
118
+ }
119
+ fieldValueChange(event) {
120
+ let onceDirtyPathsSet = new Set();
121
+ // TODO: 待review确认后移除该开关
122
+ if (this.formContext?.gates?.includes('onceDirtyPathsSet')) {
123
+ const operandPath = getOperandPath(event.field);
124
+ // 如果表单被隐藏且这次change是因为直接改变了包含该路径的父路径的值(例如编辑yaml)
125
+ // 那就阻止此子路径值的change逻辑
126
+ if (this.dirtyPathsSet.has(operandPath) &&
127
+ this._lastUpdateField?.path &&
128
+ operandPath.startsWith(`${this._lastUpdateField.path}.`)) {
129
+ return;
130
+ }
131
+ }
132
+ else {
133
+ onceDirtyPathsSet = this.dirtyPathsSet;
134
+ }
135
+ const eventData = event.data;
136
+ if (event.field.capabilities.some(c => c.startsWith(SpecCapability.oneOf))) {
137
+ const { dirtyPaths, validPaths } = this.resolveExpiredPath(event.field, eventData);
138
+ dirtyPaths.forEach(path => {
139
+ this.dirtyPathsSet.add(normalizePath(path));
140
+ onceDirtyPathsSet.add(normalizePath(path));
141
+ });
142
+ validPaths.forEach(path => {
143
+ this.updateValidPathValue(path);
144
+ });
145
+ }
146
+ const allOtherPaths = getAllOtherTagPath(this.fields, Array.from(onceDirtyPathsSet));
147
+ const removedPaths = uniq(
148
+ // 同一 path 可能有多个 tag,假设某个 tagged path 有效,则其对应 path 数据不应该删除
149
+ differPathsTag(Array.from(onceDirtyPathsSet), allOtherPaths).map(path => getPathFromTagPath(path))).filter(
150
+ // 只清空叶子结点,以适配 yaml 情况
151
+ path => !this.fields.some(field => {
152
+ const isParentPath = field.path.startsWith(`${path}.`);
153
+ if (isParentPath) {
154
+ // 该 field 亦为 dirty,不以为依据
155
+ return !onceDirtyPathsSet.has(field.path);
156
+ }
157
+ return false;
158
+ }));
159
+ if (eventData == null && !this.keepEmptyPath) {
160
+ if (!onceDirtyPathsSet.has(getOperandPath(event.field))) {
161
+ this.deleteFormData(event.field.path);
162
+ }
163
+ }
164
+ else {
165
+ this.updateFormData(event.field, eventData);
166
+ }
167
+ removedPaths.forEach(path => {
168
+ this.deleteFormData(path);
169
+ });
170
+ this.refreshValidation();
171
+ this.formStateChange.emit({
172
+ data: this.formDataState.toJS(),
173
+ errors: this.formErrors,
174
+ });
175
+ }
176
+ deleteFormData(path) {
177
+ this.formDataState = this.formDataState.deleteIn(pathToArray(path));
178
+ this.controlMap.get(path)?.setValue(null);
179
+ this.formStateChange.emit({
180
+ data: this.formDataState.toJS(),
181
+ errors: this.formErrors,
182
+ });
183
+ }
184
+ updateValidPathValue(path) {
185
+ // 如果有效路径是上一次的无效路径,则意味着该路径的值在上次被重置了,所以当该路径又需要显示给用户时应该使用默认值
186
+ const useDefault = this.dirtyPathsSet.has(normalizePath(path));
187
+ this.dirtyPathsSet.delete(normalizePath(path));
188
+ // 如果对一组表单都有依赖,那路径可能是这组表单的父路径,所以需要把所有子孙都找出来
189
+ const fields = getFieldsByPath(path, [
190
+ ...this.normalFields,
191
+ ...flattenDeep(this.fieldGroups.map(group => group.fieldList)),
192
+ ...flattenDeep(this.arrayFieldGroups.map(arrayGroup => arrayGroup.fieldLists)),
193
+ ...this.advancedFields,
194
+ ]);
195
+ fields.forEach(field => {
196
+ // 理论上 oneof 只影响视图,但实际还会影响 formDataState,所以需要同步更新 formDataState
197
+ let value = this.controlMap.get(getOperandPath(field)).value;
198
+ if (!value && useDefault) {
199
+ value = getDefaultValue(field);
200
+ }
201
+ this.updateFormData(field, value);
202
+ });
203
+ }
204
+ updateFormData(field, data) {
205
+ if (!field)
206
+ return;
207
+ const { match, index, pathBeforeIndex, pathAfterIndex } = parseArrayPath(field.path);
208
+ if (match && index === 0) {
209
+ this.formDataState = this.initializeFormDataArrayProperty(this.formDataState, pathBeforeIndex, pathAfterIndex, data);
210
+ }
211
+ this.formDataState = this.formDataState.setIn(pathToArray(field.path), data);
212
+ this._lastUpdateField = field;
213
+ }
214
+ refreshValidation() {
215
+ const errors = Array.from(this.controlMap).reduce((acc, [pathWithTag, control]) => {
216
+ if (this.dirtyPathsSet.has(pathWithTag)) {
217
+ return acc;
218
+ }
219
+ const path = getPathFromTagPath(pathWithTag);
220
+ acc[path] = isEmpty(control.errors) ? null : control.errors;
221
+ return acc;
222
+ }, {});
223
+ const result = fromPairs(Object.entries(errors ?? {}).filter(([_k, v]) => !!v));
224
+ this.formErrors = isEmpty(result) ? null : result;
225
+ }
226
+ // 当某个 field 发生数据变化,返回其相关 oneOf path 是否应该移除
227
+ // 仅当当前 field 中 oneOf 条件与当前数据不匹配,
228
+ resolveExpiredPath(field, currentValue) {
229
+ const { dirtyPaths, validPaths } = matchValueAgainstOneOf(field, currentValue);
230
+ const otherFieldStatus = this.fields
231
+ .filter(i => getOperandPath(i) !== getOperandPath(field))
232
+ .map(field => ({
233
+ path: getOperandPath(field),
234
+ result: matchValueAgainstOneOf(field, this.controlMap.get(getOperandPath(field))?.value),
235
+ }));
236
+ const newDirtyPaths = validPaths.filter(path => {
237
+ // 当前 valid path 在其他 field 中为 dirty,若该 field 本身也为 dirty 则忽略该影响,仍然判定为 valid,否则(该 field 有效)认定为 dirty
238
+ const fieldCandidates = otherFieldStatus.filter(status => status.result.dirtyPaths.includes(path));
239
+ return fieldCandidates.some(({ path }) => !otherFieldStatus.some(status => status.result.dirtyPaths.includes(path)));
240
+ });
241
+ return {
242
+ dirtyPaths: [...dirtyPaths, ...newDirtyPaths],
243
+ validPaths: validPaths.filter(path => !newDirtyPaths.includes(path)),
244
+ };
245
+ }
246
+ initializeFormDataArrayProperty(state, pathBeforeIndex, pathAfterIndex, value) {
247
+ if (state.getIn([...pathToArray(pathBeforeIndex), 0])) {
248
+ return state;
249
+ }
250
+ const item = $Map({}).setIn(pathToArray(pathAfterIndex), value);
251
+ const list = List([item]);
252
+ return state.setIn(pathToArray(pathBeforeIndex), list);
253
+ }
254
+ submit() {
255
+ this.refreshValidation();
256
+ this.form.onSubmit(null);
257
+ }
258
+ static { this.ɵfac = function CrdFormComponent_Factory(t) { return new (t || CrdFormComponent)(i0.ɵɵdirectiveInject(i1.RemoteWidgetsService)); }; }
259
+ static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: CrdFormComponent, selectors: [["acl-crd-form"]], contentQueries: function CrdFormComponent_ContentQueries(rf, ctx, dirIndex) { if (rf & 1) {
260
+ i0.ɵɵcontentQuery(dirIndex, CrdFormCustomDescriptionDirective, 4);
261
+ } if (rf & 2) {
262
+ let _t;
263
+ i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.customDescriptions = _t);
264
+ } }, viewQuery: function CrdFormComponent_Query(rf, ctx) { if (rf & 1) {
265
+ i0.ɵɵviewQuery(_c0, 7);
266
+ } if (rf & 2) {
267
+ let _t;
268
+ i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.form = _t.first);
269
+ } }, inputs: { openApiSchema: "openApiSchema", descriptors: "descriptors", data: "data", debug: "debug", openApiSchemaPath: "openApiSchemaPath", readonly: "readonly", labelWidth: "labelWidth", labelPosition: "labelPosition", cluster: "cluster", namespace: "namespace", formContext: "formContext", keepEmptyPath: "keepEmptyPath", effectControlDefaultValue: "effectControlDefaultValue", uiContext: "uiContext", widgets: "widgets" }, outputs: { formStateChange: "formStateChange", formSchemaChange: "formSchemaChange" }, features: [i0.ɵɵNgOnChangesFeature], decls: 6, vars: 7, consts: [["form", "ngForm"], ["auiForm", "", 3, "aclScrollToFirstInvalid", "auiFormLabelPosition", "auiFormLabelWidth"], [4, "ngFor", "ngForOf"], [4, "ngIf"], [3, "valueChange", "fields", "field", "formDataState", "readonly", "customDescription", "remoteModuleDefinition"], [3, "valueChange", "fields", "fieldGroup", "formDataState", "formErrors", "readonly", "customDescriptions"], [3, "valueChange", "itemRemove", "arrayFieldGroup", "formDataState", "readonly"], [3, "valueChange", "fields", "fieldList", "formDataState", "readonly"]], template: function CrdFormComponent_Template(rf, ctx) { if (rf & 1) {
270
+ i0.ɵɵelementStart(0, "form", 1, 0);
271
+ i0.ɵɵtemplate(2, CrdFormComponent_ng_container_2_Template, 4, 12, "ng-container", 2)(3, CrdFormComponent_ng_container_3_Template, 2, 6, "ng-container", 2)(4, CrdFormComponent_ng_container_4_Template, 2, 3, "ng-container", 2)(5, CrdFormComponent_ng_container_5_Template, 2, 4, "ng-container", 3);
272
+ i0.ɵɵelementEnd();
273
+ } if (rf & 2) {
274
+ i0.ɵɵproperty("aclScrollToFirstInvalid", !!ctx.formErrors)("auiFormLabelPosition", ctx.labelPosition)("auiFormLabelWidth", ctx.labelWidth);
275
+ i0.ɵɵadvance(2);
276
+ i0.ɵɵproperty("ngForOf", ctx.normalFields);
277
+ i0.ɵɵadvance();
278
+ i0.ɵɵproperty("ngForOf", ctx.fieldGroups);
279
+ i0.ɵɵadvance();
280
+ i0.ɵɵproperty("ngForOf", ctx.arrayFieldGroups);
281
+ i0.ɵɵadvance();
282
+ i0.ɵɵproperty("ngIf", ctx.advancedFields == null ? null : ctx.advancedFields.length);
283
+ } }, styles: ["[_nghost-%COMP%]{width:100%}"], changeDetection: 0 }); }
284
+ }
285
+ __decorate([
286
+ ObservableInput(),
287
+ __metadata("design:type", Observable)
288
+ ], CrdFormComponent.prototype, "formContext$", void 0);
289
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(CrdFormComponent, [{
290
+ type: Component,
291
+ args: [{ selector: 'acl-crd-form', changeDetection: ChangeDetectionStrategy.OnPush, template: "<form\n auiForm\n [aclScrollToFirstInvalid]=\"!!formErrors\"\n #form=\"ngForm\"\n [auiFormLabelPosition]=\"labelPosition\"\n [auiFormLabelWidth]=\"labelWidth\"\n>\n <!-- normal fields -->\n <ng-container *ngFor=\"let field of normalFields\">\n <acl-operand-field\n [fields]=\"fields\"\n [field]=\"field\"\n [formDataState]=\"formDataState\"\n [readonly]=\"readonly\"\n [customDescription]=\"\n customDescriptions | pure: getCustomDescription:field\n \"\n (valueChange)=\"fieldValueChange($event)\"\n [remoteModuleDefinition]=\"remoteModuleDefinition$ | async\"\n >\n </acl-operand-field>\n </ng-container>\n\n <!-- field groups \u517C\u5BB9\uFF0C\u9700\u8981\u4FDD\u7559-->\n <ng-container *ngFor=\"let group of fieldGroups\">\n <acl-operand-field-group\n [fields]=\"fields\"\n [fieldGroup]=\"group\"\n [formDataState]=\"formDataState\"\n [formErrors]=\"formErrors\"\n [readonly]=\"readonly\"\n (valueChange)=\"fieldValueChange($event)\"\n [customDescriptions]=\"customDescriptions\"\n >\n </acl-operand-field-group>\n </ng-container>\n\n <!-- array field groups \u517C\u5BB9\uFF0C\u9700\u8981\u4FDD\u7559 -->\n <ng-container *ngFor=\"let group of arrayFieldGroups\">\n <acl-operand-array-field-group\n [arrayFieldGroup]=\"group\"\n [formDataState]=\"formDataState\"\n [readonly]=\"readonly\"\n (valueChange)=\"fieldValueChange($event)\"\n (itemRemove)=\"deleteFormData($event)\"\n >\n </acl-operand-array-field-group>\n </ng-container>\n\n <!-- advanced fields -->\n <ng-container *ngIf=\"advancedFields?.length\">\n <acl-operand-advanced-field-group\n [fields]=\"fields\"\n [fieldList]=\"advancedFields\"\n [formDataState]=\"formDataState\"\n [readonly]=\"readonly\"\n (valueChange)=\"fieldValueChange($event)\"\n ></acl-operand-advanced-field-group>\n </ng-container>\n</form>\n", styles: [":host{width:100%}\n"] }]
292
+ }], () => [{ type: i1.RemoteWidgetsService }], { openApiSchema: [{
293
+ type: Input
294
+ }], descriptors: [{
295
+ type: Input
296
+ }], data: [{
297
+ type: Input
298
+ }], debug: [{
299
+ type: Input
300
+ }], openApiSchemaPath: [{
301
+ type: Input
302
+ }], readonly: [{
303
+ type: Input
304
+ }], labelWidth: [{
305
+ type: Input
306
+ }], labelPosition: [{
307
+ type: Input
308
+ }], cluster: [{
309
+ type: Input
310
+ }], namespace: [{
311
+ type: Input
312
+ }], formContext: [{
313
+ type: Input
314
+ }], formContext$: [], keepEmptyPath: [{
315
+ type: Input
316
+ }], effectControlDefaultValue: [{
317
+ type: Input
318
+ }], uiContext: [{
319
+ type: Input
320
+ }], formStateChange: [{
321
+ type: Output
322
+ }], formSchemaChange: [{
323
+ type: Output
324
+ }], form: [{
325
+ type: ViewChild,
326
+ args: ['form', { static: true }]
327
+ }], customDescriptions: [{
328
+ type: ContentChildren,
329
+ args: [CrdFormCustomDescriptionDirective]
330
+ }], widgets: [{
331
+ type: Input
332
+ }] }); })();
333
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(CrdFormComponent, { className: "CrdFormComponent", filePath: "lib/crd-form/component.ts", lineNumber: 64 }); })();
334
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"component.js","sourceRoot":"","sources":["../../../../../../libs/crd-form/src/lib/crd-form/component.ts","../../../../../../libs/crd-form/src/lib/crd-form/template.html"],"names":[],"mappings":"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","sourcesContent":["import { LabelPosition } from '@alauda/ui';\nimport {\n  Dictionary,\n  ObservableInput,\n  OpenAPIV3SchemaObject,\n} from '@alauda-fe/common';\nimport { ComponentType } from '@angular/cdk/portal';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  ContentChildren,\n  EventEmitter,\n  Input,\n  OnChanges,\n  Output,\n  QueryList,\n  SimpleChanges,\n  ViewChild,\n} from '@angular/core';\nimport { AbstractControl, NgForm } from '@angular/forms';\nimport { List, Map as $Map, fromJS } from 'immutable';\nimport { flattenDeep, fromPairs, isEmpty, uniq } from 'lodash-es';\nimport { Observable } from 'rxjs';\n\nimport { RemoteWidgetsService } from '../remote-widgets';\nimport {\n  Descriptor,\n  FieldValueChangeEvent,\n  FormDataState,\n  FormErrors,\n  FormState,\n  OperandArrayFieldGroup,\n  OperandField,\n  OperandFieldGroup,\n  SpecCapability,\n} from '../types';\nimport {\n  CrdFormCustomDescriptionDirective,\n  parseArrayPath,\n  SCHEMA_PATH,\n  createCapabilityField,\n  normalizePath,\n  pathToArray,\n  getCustomDescription,\n  getOperandPath,\n  getPathFromTagPath,\n  getFieldsByPath,\n  fieldShouldReveal,\n  getDefaultValue,\n} from '../utils';\n\nimport {\n  differPathsTag,\n  getAllOtherTagPath,\n  matchValueAgainstOneOf,\n} from './helper';\n\n@Component({\n  selector: 'acl-crd-form',\n  templateUrl: 'template.html',\n  styleUrls: ['styles.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class CrdFormComponent implements OnChanges {\n  @Input() openApiSchema: OpenAPIV3SchemaObject;\n  @Input() descriptors: Descriptor[];\n  @Input() data: unknown;\n  @Input() debug = false;\n  @Input() openApiSchemaPath: string | string[] = SCHEMA_PATH;\n  @Input() readonly = false;\n  @Input() labelWidth: string;\n  @Input() labelPosition: LabelPosition = LabelPosition.Right;\n\n  @Input() cluster?: string;\n  @Input() namespace?: string;\n\n  @Input() formContext: any;\n  @ObservableInput() formContext$: Observable<any>;\n\n  @Input() keepEmptyPath: boolean;\n\n  @Input() effectControlDefaultValue: boolean;\n\n  @Input() uiContext?: Record<string, any>;\n\n  @Output() formStateChange = new EventEmitter<FormState>();\n\n  @Output() formSchemaChange = new EventEmitter<any>();\n\n  @ViewChild('form', { static: true })\n  form: NgForm;\n\n  @ContentChildren(CrdFormCustomDescriptionDirective)\n  customDescriptions: QueryList<CrdFormCustomDescriptionDirective>;\n\n  @Input()\n  widgets: Array<{\n    descriptor: string;\n    component: ComponentType<any>;\n  }>;\n\n  formDataState: FormDataState;\n  formErrors: FormErrors = {};\n\n  fields: OperandField[];\n  normalFields: OperandField[];\n  fieldGroups: OperandFieldGroup[];\n  arrayFieldGroups: OperandArrayFieldGroup[];\n  advancedFields: OperandField[];\n  private _lastUpdateField: OperandField;\n\n  // 一个全局的 controlMap，方便控制 field 主动校验。\n  // 该 controlMap 以及所有 field 里的 control 实例，都是为了数据追踪与错误同步（control.error -> crdForm error），本身不影响提交，由 crd-form 的 error 去阻塞提交。\n  controlMap = new Map<string, AbstractControl>();\n\n  constructor(private readonly rws: RemoteWidgetsService) {}\n\n  remoteModuleDefinition$ = this.rws.remoteModule$;\n\n  ngOnChanges({ openApiSchema, descriptors, data }: SimpleChanges) {\n    if (openApiSchema?.currentValue || descriptors?.currentValue) {\n      this.setUpForm();\n    } else if (data?.currentValue) {\n      this.formDataState = fromJS(data.currentValue) as FormDataState;\n    }\n  }\n\n  getCustomDescription = getCustomDescription;\n\n  private setUpForm() {\n    this.formDataState = fromJS(this.data || {}) as FormDataState;\n\n    const {\n      normalFields,\n      fieldGroups,\n      arrayFieldGroups,\n      advancedFields,\n      descriptorFields,\n      openApiFields,\n      basicFields,\n    } = createCapabilityField(\n      this.descriptors || [],\n      this.openApiSchema || ({} as OpenAPIV3SchemaObject),\n      this.data,\n      this.openApiSchemaPath,\n    );\n\n    this.fields = basicFields.filter(fieldShouldReveal);\n    if (this.debug) {\n      /* eslint-disable  no-console */\n      console.info('openApiFields:', openApiFields);\n      console.info('descriptorFields:', descriptorFields);\n      console.info('basicFields:', basicFields);\n\n      console.info('normalFields', normalFields);\n\n      console.info('fieldGroups:', fieldGroups);\n      console.info('arrayFieldGroups:', arrayFieldGroups);\n      console.info('advancedFields:', advancedFields);\n      /* eslint-enable no-console */\n    }\n\n    this.normalFields = normalFields;\n    this.fieldGroups = fieldGroups;\n    this.arrayFieldGroups = arrayFieldGroups;\n    this.advancedFields = advancedFields;\n\n    this.formSchemaChange.emit({\n      openApiFields,\n      descriptorFields,\n    });\n  }\n\n  // 被隐藏起来的表单的路径集合\n  dirtyPathsSet = new Set<string>();\n\n  fieldValueChange(event: FieldValueChangeEvent) {\n    let onceDirtyPathsSet = new Set<string>();\n\n    // TODO: 待review确认后移除该开关\n    if ((this.formContext?.gates as string[])?.includes('onceDirtyPathsSet')) {\n      const operandPath = getOperandPath(event.field);\n      // 如果表单被隐藏且这次change是因为直接改变了包含该路径的父路径的值（例如编辑yaml）\n      // 那就阻止此子路径值的change逻辑\n      if (\n        this.dirtyPathsSet.has(operandPath) &&\n        this._lastUpdateField?.path &&\n        operandPath.startsWith(`${this._lastUpdateField.path}.`)\n      ) {\n        return;\n      }\n    } else {\n      onceDirtyPathsSet = this.dirtyPathsSet;\n    }\n\n    const eventData = event.data;\n    if (\n      event.field.capabilities.some(c => c.startsWith(SpecCapability.oneOf))\n    ) {\n      const { dirtyPaths, validPaths } = this.resolveExpiredPath(\n        event.field,\n        eventData,\n      );\n\n      dirtyPaths.forEach(path => {\n        this.dirtyPathsSet.add(normalizePath(path));\n        onceDirtyPathsSet.add(normalizePath(path));\n      });\n\n      validPaths.forEach(path => {\n        this.updateValidPathValue(path);\n      });\n    }\n    const allOtherPaths = getAllOtherTagPath(\n      this.fields,\n      Array.from(onceDirtyPathsSet),\n    );\n    const removedPaths = uniq(\n      // 同一 path 可能有多个 tag，假设某个 tagged path 有效，则其对应 path 数据不应该删除\n      differPathsTag(Array.from(onceDirtyPathsSet), allOtherPaths).map(path =>\n        getPathFromTagPath(path),\n      ),\n    ).filter(\n      // 只清空叶子结点，以适配 yaml 情况\n      path =>\n        !this.fields.some(field => {\n          const isParentPath = field.path.startsWith(`${path}.`);\n          if (isParentPath) {\n            // 该 field 亦为 dirty，不以为依据\n            return !onceDirtyPathsSet.has(field.path);\n          }\n          return false;\n        }),\n    );\n    if (eventData == null && !this.keepEmptyPath) {\n      if (!onceDirtyPathsSet.has(getOperandPath(event.field))) {\n        this.deleteFormData(event.field.path);\n      }\n    } else {\n      this.updateFormData(event.field, eventData);\n    }\n\n    removedPaths.forEach(path => {\n      this.deleteFormData(path);\n    });\n    this.refreshValidation();\n    this.formStateChange.emit({\n      data: this.formDataState.toJS(),\n      errors: this.formErrors,\n    });\n  }\n\n  deleteFormData(path: string) {\n    this.formDataState = this.formDataState.deleteIn(pathToArray(path));\n    this.controlMap.get(path)?.setValue(null);\n\n    this.formStateChange.emit({\n      data: this.formDataState.toJS(),\n      errors: this.formErrors,\n    });\n  }\n\n  private updateValidPathValue(path: string) {\n    // 如果有效路径是上一次的无效路径，则意味着该路径的值在上次被重置了，所以当该路径又需要显示给用户时应该使用默认值\n    const useDefault = this.dirtyPathsSet.has(normalizePath(path));\n    this.dirtyPathsSet.delete(normalizePath(path));\n    // 如果对一组表单都有依赖，那路径可能是这组表单的父路径，所以需要把所有子孙都找出来\n    const fields = getFieldsByPath(path, [\n      ...this.normalFields,\n      ...flattenDeep(this.fieldGroups.map(group => group.fieldList)),\n      ...flattenDeep(\n        this.arrayFieldGroups.map(arrayGroup => arrayGroup.fieldLists),\n      ),\n      ...this.advancedFields,\n    ]);\n    fields.forEach(field => {\n      // 理论上 oneof 只影响视图，但实际还会影响 formDataState，所以需要同步更新 formDataState\n      let value = this.controlMap.get(getOperandPath(field)).value;\n      if (!value && useDefault) {\n        value = getDefaultValue(field);\n      }\n      this.updateFormData(field, value);\n    });\n  }\n\n  private updateFormData(field: OperandField, data: unknown) {\n    if (!field) return;\n    const { match, index, pathBeforeIndex, pathAfterIndex } = parseArrayPath(\n      field.path,\n    );\n    if (match && index === 0) {\n      this.formDataState = this.initializeFormDataArrayProperty(\n        this.formDataState,\n        pathBeforeIndex,\n        pathAfterIndex,\n        data,\n      );\n    }\n    this.formDataState = this.formDataState.setIn(\n      pathToArray(field.path),\n      data,\n    );\n    this._lastUpdateField = field;\n  }\n\n  refreshValidation() {\n    const errors = Array.from(this.controlMap).reduce(\n      (acc, [pathWithTag, control]) => {\n        if (this.dirtyPathsSet.has(pathWithTag)) {\n          return acc;\n        }\n        const path = getPathFromTagPath(pathWithTag);\n        acc[path] = isEmpty(control.errors) ? null : control.errors;\n        return acc;\n      },\n      {} as Dictionary<FormErrors>,\n    );\n    const result = fromPairs(\n      Object.entries(errors ?? {}).filter(([_k, v]) => !!v),\n    );\n\n    this.formErrors = isEmpty(result) ? null : result;\n  }\n\n  // 当某个 field 发生数据变化，返回其相关 oneOf path 是否应该移除\n  // 仅当当前 field 中 oneOf 条件与当前数据不匹配，\n  private resolveExpiredPath(field: OperandField, currentValue: any) {\n    const { dirtyPaths, validPaths } = matchValueAgainstOneOf(\n      field,\n      currentValue,\n    );\n    const otherFieldStatus = this.fields\n      .filter(i => getOperandPath(i) !== getOperandPath(field))\n      .map(field => ({\n        path: getOperandPath(field),\n        result: matchValueAgainstOneOf(\n          field,\n          this.controlMap.get(getOperandPath(field))?.value,\n        ),\n      }));\n\n    const newDirtyPaths = validPaths.filter(path => {\n      // 当前 valid path 在其他 field 中为 dirty，若该 field 本身也为 dirty 则忽略该影响，仍然判定为 valid，否则（该 field 有效）认定为 dirty\n      const fieldCandidates = otherFieldStatus.filter(status =>\n        status.result.dirtyPaths.includes(path),\n      );\n      return fieldCandidates.some(\n        ({ path }) =>\n          !otherFieldStatus.some(status =>\n            status.result.dirtyPaths.includes(path),\n          ),\n      );\n    });\n    return {\n      dirtyPaths: [...dirtyPaths, ...newDirtyPaths],\n      validPaths: validPaths.filter(path => !newDirtyPaths.includes(path)),\n    };\n  }\n\n  private initializeFormDataArrayProperty(\n    state: FormDataState,\n    pathBeforeIndex: string,\n    pathAfterIndex: string,\n    value: any,\n  ) {\n    if (state.getIn([...pathToArray(pathBeforeIndex), 0])) {\n      return state;\n    }\n    const item = $Map({}).setIn(pathToArray(pathAfterIndex), value);\n    const list = List([item]);\n    return state.setIn(pathToArray(pathBeforeIndex), list);\n  }\n\n  submit() {\n    this.refreshValidation();\n    this.form.onSubmit(null);\n  }\n}\n","<form\n  auiForm\n  [aclScrollToFirstInvalid]=\"!!formErrors\"\n  #form=\"ngForm\"\n  [auiFormLabelPosition]=\"labelPosition\"\n  [auiFormLabelWidth]=\"labelWidth\"\n>\n  <!-- normal fields -->\n  <ng-container *ngFor=\"let field of normalFields\">\n    <acl-operand-field\n      [fields]=\"fields\"\n      [field]=\"field\"\n      [formDataState]=\"formDataState\"\n      [readonly]=\"readonly\"\n      [customDescription]=\"\n        customDescriptions | pure: getCustomDescription:field\n      \"\n      (valueChange)=\"fieldValueChange($event)\"\n      [remoteModuleDefinition]=\"remoteModuleDefinition$ | async\"\n    >\n    </acl-operand-field>\n  </ng-container>\n\n  <!-- field groups 兼容，需要保留-->\n  <ng-container *ngFor=\"let group of fieldGroups\">\n    <acl-operand-field-group\n      [fields]=\"fields\"\n      [fieldGroup]=\"group\"\n      [formDataState]=\"formDataState\"\n      [formErrors]=\"formErrors\"\n      [readonly]=\"readonly\"\n      (valueChange)=\"fieldValueChange($event)\"\n      [customDescriptions]=\"customDescriptions\"\n    >\n    </acl-operand-field-group>\n  </ng-container>\n\n  <!-- array field groups 兼容，需要保留 -->\n  <ng-container *ngFor=\"let group of arrayFieldGroups\">\n    <acl-operand-array-field-group\n      [arrayFieldGroup]=\"group\"\n      [formDataState]=\"formDataState\"\n      [readonly]=\"readonly\"\n      (valueChange)=\"fieldValueChange($event)\"\n      (itemRemove)=\"deleteFormData($event)\"\n    >\n    </acl-operand-array-field-group>\n  </ng-container>\n\n  <!-- advanced fields -->\n  <ng-container *ngIf=\"advancedFields?.length\">\n    <acl-operand-advanced-field-group\n      [fields]=\"fields\"\n      [fieldList]=\"advancedFields\"\n      [formDataState]=\"formDataState\"\n      [readonly]=\"readonly\"\n      (valueChange)=\"fieldValueChange($event)\"\n    ></acl-operand-advanced-field-group>\n  </ng-container>\n</form>\n"]}
@@ -0,0 +1,32 @@
1
+ import { differenceBy } from 'lodash-es';
2
+ import { convertValue, getOneOfMap, getOperandPath, getPathFromTagPath, normalizePath, } from '../utils';
3
+ // 去除 others 和 paths 中主 path 相同的部分
4
+ export function differPathsTag(paths, others) {
5
+ return differenceBy(paths, others, pathWithTag => getPathFromTagPath(pathWithTag));
6
+ }
7
+ export function getAllOtherTagPath(fields, paths) {
8
+ return fields
9
+ .map(path => getOperandPath(path))
10
+ .filter(path => !paths.includes(path));
11
+ }
12
+ export function matchValueAgainstOneOf(field, currentValue) {
13
+ // oneOfMap 里应当为 tagged path
14
+ const oneOfMap = getOneOfMap(field);
15
+ // 使用两个 set 处理多条 OneOf 中存在公共 path 的情形
16
+ const dirtyPathSet = new Set();
17
+ const validPathSet = new Set();
18
+ Object.entries(oneOfMap).forEach(([value, paths]) => {
19
+ paths.forEach(path => {
20
+ (convertValue(value, field.type) === currentValue
21
+ ? validPathSet
22
+ : dirtyPathSet).add(path);
23
+ });
24
+ });
25
+ return {
26
+ dirtyPaths: Array.from(dirtyPathSet)
27
+ .filter(i => !validPathSet.has(i))
28
+ .map(path => normalizePath(path)),
29
+ validPaths: Array.from(validPathSet).map(path => normalizePath(path)),
30
+ };
31
+ }
32
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVscGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jcmQtZm9ybS9zcmMvbGliL2NyZC1mb3JtL2hlbHBlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sV0FBVyxDQUFDO0FBR3pDLE9BQU8sRUFDTCxZQUFZLEVBQ1osV0FBVyxFQUNYLGNBQWMsRUFDZCxrQkFBa0IsRUFDbEIsYUFBYSxHQUNkLE1BQU0sVUFBVSxDQUFDO0FBRWxCLGtDQUFrQztBQUNsQyxNQUFNLFVBQVUsY0FBYyxDQUFDLEtBQWUsRUFBRSxNQUFnQjtJQUM5RCxPQUFPLFlBQVksQ0FBQyxLQUFLLEVBQUUsTUFBTSxFQUFFLFdBQVcsQ0FBQyxFQUFFLENBQy9DLGtCQUFrQixDQUFDLFdBQVcsQ0FBQyxDQUNoQyxDQUFDO0FBQ0osQ0FBQztBQUVELE1BQU0sVUFBVSxrQkFBa0IsQ0FBQyxNQUFzQixFQUFFLEtBQWU7SUFDeEUsT0FBTyxNQUFNO1NBQ1YsR0FBRyxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxDQUFDO1NBQ2pDLE1BQU0sQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDO0FBQzNDLENBQUM7QUFFRCxNQUFNLFVBQVUsc0JBQXNCLENBQUMsS0FBbUIsRUFBRSxZQUFpQjtJQUMzRSw0QkFBNEI7SUFDNUIsTUFBTSxRQUFRLEdBQUcsV0FBVyxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ3BDLHFDQUFxQztJQUNyQyxNQUFNLFlBQVksR0FBRyxJQUFJLEdBQUcsRUFBVSxDQUFDO0lBQ3ZDLE1BQU0sWUFBWSxHQUFHLElBQUksR0FBRyxFQUFVLENBQUM7SUFDdkMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxRQUFRLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLEtBQUssRUFBRSxLQUFLLENBQUMsRUFBRSxFQUFFO1FBQ2xELEtBQUssQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLEVBQUU7WUFDbkIsQ0FBQyxZQUFZLENBQUMsS0FBSyxFQUFFLEtBQUssQ0FBQyxJQUFJLENBQUMsS0FBSyxZQUFZO2dCQUMvQyxDQUFDLENBQUMsWUFBWTtnQkFDZCxDQUFDLENBQUMsWUFBWSxDQUNmLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ2QsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDLENBQUMsQ0FBQztJQUNILE9BQU87UUFDTCxVQUFVLEVBQUUsS0FBSyxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUM7YUFDakMsTUFBTSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxZQUFZLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDO2FBQ2pDLEdBQUcsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUNuQyxVQUFVLEVBQUUsS0FBSyxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLENBQUM7S0FDdEUsQ0FBQztBQUNKLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBkaWZmZXJlbmNlQnkgfSBmcm9tICdsb2Rhc2gtZXMnO1xuXG5pbXBvcnQgeyBPcGVyYW5kRmllbGQgfSBmcm9tICcuLi90eXBlcyc7XG5pbXBvcnQge1xuICBjb252ZXJ0VmFsdWUsXG4gIGdldE9uZU9mTWFwLFxuICBnZXRPcGVyYW5kUGF0aCxcbiAgZ2V0UGF0aEZyb21UYWdQYXRoLFxuICBub3JtYWxpemVQYXRoLFxufSBmcm9tICcuLi91dGlscyc7XG5cbi8vIOWOu+mZpCBvdGhlcnMg5ZKMIHBhdGhzIOS4reS4uyBwYXRoIOebuOWQjOeahOmDqOWIhlxuZXhwb3J0IGZ1bmN0aW9uIGRpZmZlclBhdGhzVGFnKHBhdGhzOiBzdHJpbmdbXSwgb3RoZXJzOiBzdHJpbmdbXSkge1xuICByZXR1cm4gZGlmZmVyZW5jZUJ5KHBhdGhzLCBvdGhlcnMsIHBhdGhXaXRoVGFnID0+XG4gICAgZ2V0UGF0aEZyb21UYWdQYXRoKHBhdGhXaXRoVGFnKSxcbiAgKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGdldEFsbE90aGVyVGFnUGF0aChmaWVsZHM6IE9wZXJhbmRGaWVsZFtdLCBwYXRoczogc3RyaW5nW10pIHtcbiAgcmV0dXJuIGZpZWxkc1xuICAgIC5tYXAocGF0aCA9PiBnZXRPcGVyYW5kUGF0aChwYXRoKSlcbiAgICAuZmlsdGVyKHBhdGggPT4gIXBhdGhzLmluY2x1ZGVzKHBhdGgpKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIG1hdGNoVmFsdWVBZ2FpbnN0T25lT2YoZmllbGQ6IE9wZXJhbmRGaWVsZCwgY3VycmVudFZhbHVlOiBhbnkpIHtcbiAgLy8gb25lT2ZNYXAg6YeM5bqU5b2T5Li6IHRhZ2dlZCBwYXRoXG4gIGNvbnN0IG9uZU9mTWFwID0gZ2V0T25lT2ZNYXAoZmllbGQpO1xuICAvLyDkvb/nlKjkuKTkuKogc2V0IOWkhOeQhuWkmuadoSBPbmVPZiDkuK3lrZjlnKjlhazlhbEgcGF0aCDnmoTmg4XlvaJcbiAgY29uc3QgZGlydHlQYXRoU2V0ID0gbmV3IFNldDxzdHJpbmc+KCk7XG4gIGNvbnN0IHZhbGlkUGF0aFNldCA9IG5ldyBTZXQ8c3RyaW5nPigpO1xuICBPYmplY3QuZW50cmllcyhvbmVPZk1hcCkuZm9yRWFjaCgoW3ZhbHVlLCBwYXRoc10pID0+IHtcbiAgICBwYXRocy5mb3JFYWNoKHBhdGggPT4ge1xuICAgICAgKGNvbnZlcnRWYWx1ZSh2YWx1ZSwgZmllbGQudHlwZSkgPT09IGN1cnJlbnRWYWx1ZVxuICAgICAgICA/IHZhbGlkUGF0aFNldFxuICAgICAgICA6IGRpcnR5UGF0aFNldFxuICAgICAgKS5hZGQocGF0aCk7XG4gICAgfSk7XG4gIH0pO1xuICByZXR1cm4ge1xuICAgIGRpcnR5UGF0aHM6IEFycmF5LmZyb20oZGlydHlQYXRoU2V0KVxuICAgICAgLmZpbHRlcihpID0+ICF2YWxpZFBhdGhTZXQuaGFzKGkpKVxuICAgICAgLm1hcChwYXRoID0+IG5vcm1hbGl6ZVBhdGgocGF0aCkpLFxuICAgIHZhbGlkUGF0aHM6IEFycmF5LmZyb20odmFsaWRQYXRoU2V0KS5tYXAocGF0aCA9PiBub3JtYWxpemVQYXRoKHBhdGgpKSxcbiAgfTtcbn1cbiJdfQ==