@valtimo/connector-management 4.15.3-next-main.14 → 4.16.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (48) hide show
  1. package/README.md +16 -7
  2. package/bundles/valtimo-connector-management.umd.js +244 -173
  3. package/bundles/valtimo-connector-management.umd.js.map +1 -1
  4. package/bundles/valtimo-connector-management.umd.min.js +2 -2
  5. package/bundles/valtimo-connector-management.umd.min.js.map +1 -1
  6. package/esm2015/lib/components/add-connector/add-connector.component.js +12 -8
  7. package/esm2015/lib/components/connector-link-extension/connector-link-extension.component.js +20 -11
  8. package/esm2015/lib/components/connector-link-extension-modal/connector-link-extension-modal.component.js +19 -17
  9. package/esm2015/lib/components/connector-management/connector-management.component.js +23 -15
  10. package/esm2015/lib/components/connector-modal/connector-modal.component.js +2 -2
  11. package/esm2015/lib/components/edit-connector-form/edit-connector-form.component.js +1 -1
  12. package/esm2015/lib/components/edit-connector-properties/edit-connector-properties.component.js +17 -13
  13. package/esm2015/lib/components/edit-product-aanvragen-connector/edit-product-aanvragen-connector.component.js +20 -13
  14. package/esm2015/lib/components/edit-product-aanvragen-connector/edit-product-aanvragen-connector.form.js +89 -89
  15. package/esm2015/lib/components/modify-connector/modify-connector.component.js +9 -7
  16. package/esm2015/lib/components/multi-value-connector-property/multi-value-connector-property.component.js +15 -11
  17. package/esm2015/lib/connector-management-routing.js +5 -8
  18. package/esm2015/lib/connector-management.module.js +5 -7
  19. package/esm2015/lib/extension/connector-management.extension.init.js +2 -2
  20. package/esm2015/lib/models/connector.model.js +1 -0
  21. package/esm2015/lib/models/index.js +20 -0
  22. package/esm2015/lib/models/object-sync.js +1 -0
  23. package/esm2015/lib/services/connector-management/connector-management.service.js +2 -2
  24. package/esm2015/lib/services/connector-management-state/connector-management-state.service.js +2 -2
  25. package/esm2015/lib/services/object-api-sync/object-api-sync.service.js +2 -2
  26. package/esm2015/public-api.js +2 -1
  27. package/esm2015/valtimo-connector-management.js +1 -1
  28. package/fesm2015/valtimo-connector-management.js +244 -192
  29. package/fesm2015/valtimo-connector-management.js.map +1 -1
  30. package/lib/components/add-connector/add-connector.component.d.ts +1 -1
  31. package/lib/components/connector-link-extension/connector-link-extension.component.d.ts +1 -1
  32. package/lib/components/connector-link-extension-modal/connector-link-extension-modal.component.d.ts +2 -2
  33. package/lib/components/connector-management/connector-management.component.d.ts +2 -1
  34. package/lib/components/connector-modal/connector-modal.component.d.ts +1 -1
  35. package/lib/components/edit-connector-form/edit-connector-form.component.d.ts +1 -1
  36. package/lib/components/edit-connector-properties/edit-connector-properties.component.d.ts +1 -1
  37. package/lib/components/edit-product-aanvragen-connector/edit-product-aanvragen-connector.component.d.ts +1 -1
  38. package/lib/components/modify-connector/modify-connector.component.d.ts +1 -1
  39. package/lib/components/multi-value-connector-property/multi-value-connector-property.component.d.ts +1 -1
  40. package/lib/models/connector.model.d.ts +36 -0
  41. package/lib/models/index.d.ts +2 -0
  42. package/lib/models/object-sync.d.ts +19 -0
  43. package/lib/services/connector-management/connector-management.service.d.ts +2 -1
  44. package/lib/services/connector-management-state/connector-management-state.service.d.ts +1 -1
  45. package/lib/services/object-api-sync/object-api-sync.service.d.ts +1 -1
  46. package/package.json +1 -1
  47. package/public-api.d.ts +1 -0
  48. package/valtimo-connector-management.metadata.json +1 -1
@@ -28,10 +28,14 @@ export class EditConnectorPropertiesComponent {
28
28
  this.modifiedProperties$ = new BehaviorSubject(undefined);
29
29
  this.editFields$ = new BehaviorSubject([]);
30
30
  this.connectorName$ = new BehaviorSubject('');
31
- this.saveButtonDisabled$ = combineLatest([this.editFields$, this.modifiedProperties$, this.connectorName$]).pipe(map(([editFields, modifiedProperties, connectorName]) => {
32
- const values = editFields.map((field) => get(modifiedProperties, field.key));
33
- const validValues = values.filter((value) => Array.isArray(value) ? value.length > 0 : value === 0 || value);
34
- return (editFields.length !== validValues.length) || !connectorName;
31
+ this.saveButtonDisabled$ = combineLatest([
32
+ this.editFields$,
33
+ this.modifiedProperties$,
34
+ this.connectorName$,
35
+ ]).pipe(map(([editFields, modifiedProperties, connectorName]) => {
36
+ const values = editFields.map(field => get(modifiedProperties, field.key));
37
+ const validValues = values.filter(value => Array.isArray(value) ? value.length > 0 : value === 0 || value);
38
+ return editFields.length !== validValues.length || !connectorName;
35
39
  }));
36
40
  this.disabled$ = this.stateService.inputDisabled$;
37
41
  }
@@ -44,13 +48,13 @@ export class EditConnectorPropertiesComponent {
44
48
  this.setName();
45
49
  }
46
50
  multiFieldValuesSet(event) {
47
- this.modifiedProperties$.pipe(take(1)).subscribe((properties) => {
51
+ this.modifiedProperties$.pipe(take(1)).subscribe(properties => {
48
52
  set(properties, event.editFieldKey, event.values);
49
53
  this.modifiedProperties$.next(properties);
50
54
  });
51
55
  }
52
56
  onSingleValueChange(value, editField) {
53
- this.modifiedProperties$.pipe(take(1)).subscribe((properties) => {
57
+ this.modifiedProperties$.pipe(take(1)).subscribe(properties => {
54
58
  set(properties, editField.key, editField.editType === 'string' ? value.trim() : parseInt(value, 10));
55
59
  this.modifiedProperties$.next(properties);
56
60
  });
@@ -61,7 +65,8 @@ export class EditConnectorPropertiesComponent {
61
65
  onSave() {
62
66
  this.stateService.disableInput();
63
67
  combineLatest([this.modifiedProperties$, this.connectorName$])
64
- .pipe(take(1)).subscribe(([properties, name]) => {
68
+ .pipe(take(1))
69
+ .subscribe(([properties, name]) => {
65
70
  this.propertiesSave.emit({ properties, name });
66
71
  });
67
72
  }
@@ -80,7 +85,7 @@ export class EditConnectorPropertiesComponent {
80
85
  setModifiedProperties(editFields) {
81
86
  const propertiesCopy = cloneDeep(this.properties);
82
87
  if (!this.withDefaults) {
83
- editFields.forEach((editField) => {
88
+ editFields.forEach(editField => {
84
89
  set(propertiesCopy, editField.key, undefined);
85
90
  });
86
91
  }
@@ -90,9 +95,8 @@ export class EditConnectorPropertiesComponent {
90
95
  const editFields = [];
91
96
  const keysToFilter = ['className'];
92
97
  const handlePropertyLevel = (propertyLevel, previousKeys) => {
93
- const propertyLevelKeys = Object.keys(propertyLevel)
94
- .filter((key) => !keysToFilter.includes(key));
95
- propertyLevelKeys.forEach((key) => {
98
+ const propertyLevelKeys = Object.keys(propertyLevel).filter(key => !keysToFilter.includes(key));
99
+ propertyLevelKeys.forEach(key => {
96
100
  const propertyValue = propertyLevel[key];
97
101
  const baseEditField = Object.assign({ key: previousKeys + key }, (this.withDefaults && { defaultValue: propertyValue }));
98
102
  if (typeof propertyValue === 'number') {
@@ -122,7 +126,7 @@ export class EditConnectorPropertiesComponent {
122
126
  EditConnectorPropertiesComponent.decorators = [
123
127
  { type: Component, args: [{
124
128
  selector: 'valtimo-edit-connector-properties',
125
- template: "<!--\n ~ Copyright 2015-2020 Ritense BV, the Netherlands.\n ~\n ~ Licensed under EUPL, Version 1.2 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" basis,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n -->\n\n<div class=\"edit-fields\" *ngIf=\"{editFields: editFields$ | async, disabled: disabled$ | async} as obs\">\n <ng-container *ngTemplateOutlet=\"nameInput;context:{disabled: obs.disabled}\"></ng-container>\n <ng-container *ngFor=\"let editField of obs.editFields\">\n <ng-container *ngIf=\"editField.editType === 'string' || editField.editType === 'number'\">\n <ng-container *ngTemplateOutlet=\"singleInput;context:{editField: editField, disabled: obs.disabled}\"></ng-container>\n </ng-container>\n <ng-container *ngIf=\"editField.editType === 'string[]' || editField.editType === 'number[]'\">\n <valtimo-multi-value-connector-property\n [editField]=\"editField\"\n (valuesSet)=\"multiFieldValuesSet($event)\"\n [disabled]=\"obs.disabled\"\n [defaultValue]=\"withDefaults && editField.defaultValue\"\n >\n </valtimo-multi-value-connector-property>\n </ng-container>\n </ng-container>\n <ng-container *ngTemplateOutlet=\"buttons;context:{disabled: obs.disabled}\"></ng-container>\n</div>\n\n<ng-template #nameInput let-disabled=\"disabled\">\n <div class=\"form-group row\">\n <label class=\"col-3 col-form-label text-sm-right\">\n {{'connectorManagement.inputLabels.connectorName' | translate}}\n </label>\n <div class=\"col-7\">\n <input\n class=\"form-control\"\n type=\"text\"\n (input)=\"onNameValueChange($event.target.value)\"\n [disabled]=\"disabled\"\n [value]=\"(withDefaults && defaultName) ? defaultName : ''\"\n >\n </div>\n </div>\n</ng-template>\n\n<ng-template #singleInput let-editField=\"editField\" let-disabled=\"disabled\">\n <div class=\"form-group row\">\n <label class=\"col-3 col-form-label text-sm-right\">\n {{'connectorManagement.inputLabels.' + editField.key | translate}}\n </label>\n <div class=\"col-7\">\n <input\n *ngIf=\"editField.editType === 'string'\"\n class=\"form-control\"\n type=\"text\"\n (input)=\"onSingleValueChange($event.target.value, editField)\"\n [disabled]=\"disabled\"\n [value]=\"withDefaults ? editField.defaultValue : ''\"\n >\n <input\n *ngIf=\"editField.editType === 'number'\"\n class=\"form-control\"\n type=\"number\"\n step=\"1\"\n min=\"0\"\n oninput=\"validity.valid||(value='');\"\n (input)=\"onSingleValueChange($event.target.value, editField)\"\n [disabled]=\"disabled\"\n [value]=\"withDefaults ? editField.defaultValue : ''\"\n >\n </div>\n </div>\n</ng-template>\n\n<ng-template #buttons let-disabled=\"disabled\">\n <div class=\"border-top mt-3 pt-6\">\n <div class=\"button-container\">\n <button class=\"btn btn-primary\" [disabled]=\"disabled || (saveButtonDisabled$ | async)\" (click)=\"onSave()\">\n <i class=\"icon mdi mdi-save mr-1\"></i>\n {{'connectorManagement.save' | translate}}\n </button>\n <button *ngIf=\"showDeleteButton\" class=\"btn btn-danger btn-space\" (click)=\"onDelete()\" [disabled]=\"disabled\">\n <i class=\"icon mdi mdi-delete mr-1\"></i>\n {{'connectorManagement.remove' | translate}}\n </button>\n </div>\n </div>\n</ng-template>\n",
129
+ template: "<!--\n ~ Copyright 2015-2020 Ritense BV, the Netherlands.\n ~\n ~ Licensed under EUPL, Version 1.2 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" basis,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n -->\n\n<div\n class=\"edit-fields\"\n *ngIf=\"{editFields: editFields$ | async, disabled: disabled$ | async} as obs\"\n>\n <ng-container *ngTemplateOutlet=\"nameInput; context: {disabled: obs.disabled}\"></ng-container>\n <ng-container *ngFor=\"let editField of obs.editFields\">\n <ng-container *ngIf=\"editField.editType === 'string' || editField.editType === 'number'\">\n <ng-container\n *ngTemplateOutlet=\"singleInput; context: {editField: editField, disabled: obs.disabled}\"\n ></ng-container>\n </ng-container>\n <ng-container *ngIf=\"editField.editType === 'string[]' || editField.editType === 'number[]'\">\n <valtimo-multi-value-connector-property\n [editField]=\"editField\"\n (valuesSet)=\"multiFieldValuesSet($event)\"\n [disabled]=\"obs.disabled\"\n [defaultValue]=\"withDefaults && editField.defaultValue\"\n >\n </valtimo-multi-value-connector-property>\n </ng-container>\n </ng-container>\n <ng-container *ngTemplateOutlet=\"buttons; context: {disabled: obs.disabled}\"></ng-container>\n</div>\n\n<ng-template #nameInput let-disabled=\"disabled\">\n <div class=\"form-group row\">\n <label class=\"col-3 col-form-label text-sm-right\">\n {{ 'connectorManagement.inputLabels.connectorName' | translate }}\n </label>\n <div class=\"col-7\">\n <input\n class=\"form-control\"\n type=\"text\"\n (input)=\"onNameValueChange($event.target.value)\"\n [disabled]=\"disabled\"\n [value]=\"withDefaults && defaultName ? defaultName : ''\"\n />\n </div>\n </div>\n</ng-template>\n\n<ng-template #singleInput let-editField=\"editField\" let-disabled=\"disabled\">\n <div class=\"form-group row\">\n <label class=\"col-3 col-form-label text-sm-right\">\n {{ 'connectorManagement.inputLabels.' + editField.key | translate }}\n </label>\n <div class=\"col-7\">\n <input\n *ngIf=\"editField.editType === 'string'\"\n class=\"form-control\"\n type=\"text\"\n (input)=\"onSingleValueChange($event.target.value, editField)\"\n [disabled]=\"disabled\"\n [value]=\"withDefaults ? editField.defaultValue : ''\"\n />\n <input\n *ngIf=\"editField.editType === 'number'\"\n class=\"form-control\"\n type=\"number\"\n step=\"1\"\n min=\"0\"\n oninput=\"validity.valid||(value='');\"\n (input)=\"onSingleValueChange($event.target.value, editField)\"\n [disabled]=\"disabled\"\n [value]=\"withDefaults ? editField.defaultValue : ''\"\n />\n </div>\n </div>\n</ng-template>\n\n<ng-template #buttons let-disabled=\"disabled\">\n <div class=\"border-top mt-3 pt-6\">\n <div class=\"button-container\">\n <button\n class=\"btn btn-primary\"\n [disabled]=\"disabled || (saveButtonDisabled$ | async)\"\n (click)=\"onSave()\"\n >\n <i class=\"icon mdi mdi-save mr-1\"></i>\n {{ 'connectorManagement.save' | translate }}\n </button>\n <button\n *ngIf=\"showDeleteButton\"\n class=\"btn btn-danger btn-space\"\n (click)=\"onDelete()\"\n [disabled]=\"disabled\"\n >\n <i class=\"icon mdi mdi-delete mr-1\"></i>\n {{ 'connectorManagement.remove' | translate }}\n </button>\n </div>\n </div>\n</ng-template>\n",
126
130
  styles: ["/*!\n * Copyright 2015-2020 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */.button-container{display:flex;flex-flow:row-reverse;justify-content:space-between;width:100%}"]
127
131
  },] }
128
132
  ];
@@ -137,4 +141,4 @@ EditConnectorPropertiesComponent.propDecorators = {
137
141
  propertiesSave: [{ type: Output }],
138
142
  connectorDelete: [{ type: Output }]
139
143
  };
140
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"edit-connector-properties.component.js","sourceRoot":"","sources":["../../../../../../../projects/valtimo/connector-management/src/lib/components/edit-connector-properties/edit-connector-properties.component.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright 2015-2020 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {Component, EventEmitter, Input, OnChanges, OnInit, Output} from '@angular/core';\nimport {ConnectorProperties, ConnectorPropertyEditField, ConnectorPropertyValueType} from '@valtimo/contract';\nimport {BehaviorSubject, combineLatest, Observable} from 'rxjs';\nimport {map, take} from 'rxjs/operators';\nimport {set, get, cloneDeep} from 'lodash';\nimport {ConnectorManagementStateService} from '../../services/connector-management-state/connector-management-state.service';\n\n@Component({\n  selector: 'valtimo-edit-connector-properties',\n  templateUrl: './edit-connector-properties.component.html',\n  styleUrls: ['./edit-connector-properties.component.scss']\n})\nexport class EditConnectorPropertiesComponent implements OnInit, OnChanges {\n  @Input() properties: ConnectorProperties;\n  @Input() withDefaults = false;\n  @Input() showDeleteButton = false;\n  @Input() defaultName!: string;\n\n  @Output() propertiesSave = new EventEmitter<{properties: ConnectorProperties, name: string}>();\n  @Output() connectorDelete = new EventEmitter<any>();\n\n  readonly disabled$!: Observable<boolean>;\n\n  readonly modifiedProperties$ = new BehaviorSubject<ConnectorProperties>(undefined);\n\n  readonly editFields$ = new BehaviorSubject<Array<ConnectorPropertyEditField>>([]);\n\n  readonly connectorName$ = new BehaviorSubject<string>('');\n\n  readonly saveButtonDisabled$ = combineLatest([this.editFields$, this.modifiedProperties$, this.connectorName$]).pipe(\n    map(([editFields, modifiedProperties, connectorName]) => {\n      const values = editFields.map((field) => get(modifiedProperties, field.key));\n      const validValues = values.filter((value) => Array.isArray(value) ? value.length > 0 : value === 0 || value);\n\n      return (editFields.length !== validValues.length) || !connectorName;\n    })\n  );\n\n  constructor(\n    private readonly stateService: ConnectorManagementStateService\n  ) {\n    this.disabled$ = this.stateService.inputDisabled$;\n  }\n\n  ngOnInit(): void {\n    this.setEditFields();\n    this.setName();\n  }\n\n  ngOnChanges(): void {\n    this.setEditFields();\n    this.setName();\n  }\n\n  multiFieldValuesSet(event: { editFieldKey: string, values: Array<string> | Array<number> }): void {\n    this.modifiedProperties$.pipe(take(1)).subscribe((properties) => {\n      set(properties, event.editFieldKey, event.values);\n      this.modifiedProperties$.next(properties);\n    });\n  }\n\n  onSingleValueChange(value: any, editField: ConnectorPropertyEditField): void {\n    this.modifiedProperties$.pipe(take(1)).subscribe((properties) => {\n      set(properties, editField.key, editField.editType === 'string' ? value.trim() : parseInt(value, 10));\n      this.modifiedProperties$.next(properties);\n    });\n  }\n\n  onNameValueChange(value: string): void {\n    this.connectorName$.next(value.trim());\n  }\n\n  onSave(): void {\n    this.stateService.disableInput();\n\n    combineLatest([this.modifiedProperties$, this.connectorName$])\n      .pipe(take(1)).subscribe(([properties, name]) => {\n        this.propertiesSave.emit({properties, name });\n      }\n    );\n  }\n\n  onDelete(): void {\n    this.stateService.disableInput();\n    this.connectorDelete.emit();\n  }\n\n  private setName(): void {\n    if (this.withDefaults && this.defaultName) {\n      this.connectorName$.next(this.defaultName);\n    } else {\n      this.connectorName$.next('');\n    }\n  }\n\n  private setModifiedProperties(editFields: Array<ConnectorPropertyEditField>): void {\n    const propertiesCopy = cloneDeep(this.properties);\n\n    if (!this.withDefaults) {\n      editFields.forEach((editField) => {\n        set(\n          propertiesCopy,\n          editField.key,\n          undefined\n        );\n      });\n    }\n\n    this.modifiedProperties$.next(propertiesCopy);\n  }\n\n  private setEditFields(): void {\n    const editFields: Array<ConnectorPropertyEditField> = [];\n    const keysToFilter = ['className'];\n\n    const handlePropertyLevel = (propertyLevel: ConnectorProperties, previousKeys: string) => {\n      const propertyLevelKeys = Object.keys(propertyLevel)\n        .filter((key) => !keysToFilter.includes(key));\n\n      propertyLevelKeys.forEach((key) => {\n        const propertyValue = propertyLevel[key];\n        const baseEditField = {\n          key: previousKeys + key,\n          ...(this.withDefaults && {defaultValue: (propertyValue as ConnectorPropertyValueType)})\n        };\n\n        if (typeof propertyValue === 'number') {\n          editFields.push({...baseEditField, editType: 'number'});\n        } else if (Array.isArray(propertyValue)) {\n          if (propertyValue[0] && typeof propertyValue[0] === 'number') {\n            editFields.push({...baseEditField, editType: 'number[]'});\n          } else {\n            editFields.push({...baseEditField, editType: 'string[]'});\n          }\n        } else if (typeof propertyValue === 'string') {\n          editFields.push({...baseEditField, editType: 'string'});\n        } else if (typeof propertyValue === 'object') {\n          handlePropertyLevel(propertyValue, `${previousKeys}${key}.`);\n        }\n      });\n    };\n\n    handlePropertyLevel(this.properties, '');\n\n    this.editFields$.next(editFields);\n    this.setModifiedProperties(editFields);\n  }\n}\n"]}
144
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"edit-connector-properties.component.js","sourceRoot":"/tmp/jenkins-4c3bb770/workspace/Valtimo_-_Angular_Libraries_main/projects/valtimo/connector-management/src/","sources":["lib/components/edit-connector-properties/edit-connector-properties.component.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright 2015-2020 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {Component, EventEmitter, Input, OnChanges, OnInit, Output} from '@angular/core';\nimport {\n  ConnectorProperties,\n  ConnectorPropertyEditField,\n  ConnectorPropertyValueType,\n} from '../../models';\nimport {BehaviorSubject, combineLatest, Observable} from 'rxjs';\nimport {map, take} from 'rxjs/operators';\nimport {set, get, cloneDeep} from 'lodash';\nimport {ConnectorManagementStateService} from '../../services/connector-management-state/connector-management-state.service';\n\n@Component({\n  selector: 'valtimo-edit-connector-properties',\n  templateUrl: './edit-connector-properties.component.html',\n  styleUrls: ['./edit-connector-properties.component.scss'],\n})\nexport class EditConnectorPropertiesComponent implements OnInit, OnChanges {\n  @Input() properties: ConnectorProperties;\n  @Input() withDefaults = false;\n  @Input() showDeleteButton = false;\n  @Input() defaultName!: string;\n\n  @Output() propertiesSave = new EventEmitter<{properties: ConnectorProperties; name: string}>();\n  @Output() connectorDelete = new EventEmitter<any>();\n\n  readonly disabled$!: Observable<boolean>;\n\n  readonly modifiedProperties$ = new BehaviorSubject<ConnectorProperties>(undefined);\n\n  readonly editFields$ = new BehaviorSubject<Array<ConnectorPropertyEditField>>([]);\n\n  readonly connectorName$ = new BehaviorSubject<string>('');\n\n  readonly saveButtonDisabled$ = combineLatest([\n    this.editFields$,\n    this.modifiedProperties$,\n    this.connectorName$,\n  ]).pipe(\n    map(([editFields, modifiedProperties, connectorName]) => {\n      const values = editFields.map(field => get(modifiedProperties, field.key));\n      const validValues = values.filter(value =>\n        Array.isArray(value) ? value.length > 0 : value === 0 || value\n      );\n\n      return editFields.length !== validValues.length || !connectorName;\n    })\n  );\n\n  constructor(private readonly stateService: ConnectorManagementStateService) {\n    this.disabled$ = this.stateService.inputDisabled$;\n  }\n\n  ngOnInit(): void {\n    this.setEditFields();\n    this.setName();\n  }\n\n  ngOnChanges(): void {\n    this.setEditFields();\n    this.setName();\n  }\n\n  multiFieldValuesSet(event: {editFieldKey: string; values: Array<string> | Array<number>}): void {\n    this.modifiedProperties$.pipe(take(1)).subscribe(properties => {\n      set(properties, event.editFieldKey, event.values);\n      this.modifiedProperties$.next(properties);\n    });\n  }\n\n  onSingleValueChange(value: any, editField: ConnectorPropertyEditField): void {\n    this.modifiedProperties$.pipe(take(1)).subscribe(properties => {\n      set(\n        properties,\n        editField.key,\n        editField.editType === 'string' ? value.trim() : parseInt(value, 10)\n      );\n      this.modifiedProperties$.next(properties);\n    });\n  }\n\n  onNameValueChange(value: string): void {\n    this.connectorName$.next(value.trim());\n  }\n\n  onSave(): void {\n    this.stateService.disableInput();\n\n    combineLatest([this.modifiedProperties$, this.connectorName$])\n      .pipe(take(1))\n      .subscribe(([properties, name]) => {\n        this.propertiesSave.emit({properties, name});\n      });\n  }\n\n  onDelete(): void {\n    this.stateService.disableInput();\n    this.connectorDelete.emit();\n  }\n\n  private setName(): void {\n    if (this.withDefaults && this.defaultName) {\n      this.connectorName$.next(this.defaultName);\n    } else {\n      this.connectorName$.next('');\n    }\n  }\n\n  private setModifiedProperties(editFields: Array<ConnectorPropertyEditField>): void {\n    const propertiesCopy = cloneDeep(this.properties);\n\n    if (!this.withDefaults) {\n      editFields.forEach(editField => {\n        set(propertiesCopy, editField.key, undefined);\n      });\n    }\n\n    this.modifiedProperties$.next(propertiesCopy);\n  }\n\n  private setEditFields(): void {\n    const editFields: Array<ConnectorPropertyEditField> = [];\n    const keysToFilter = ['className'];\n\n    const handlePropertyLevel = (propertyLevel: ConnectorProperties, previousKeys: string) => {\n      const propertyLevelKeys = Object.keys(propertyLevel).filter(\n        key => !keysToFilter.includes(key)\n      );\n\n      propertyLevelKeys.forEach(key => {\n        const propertyValue = propertyLevel[key];\n        const baseEditField = {\n          key: previousKeys + key,\n          ...(this.withDefaults && {defaultValue: propertyValue as ConnectorPropertyValueType}),\n        };\n\n        if (typeof propertyValue === 'number') {\n          editFields.push({...baseEditField, editType: 'number'});\n        } else if (Array.isArray(propertyValue)) {\n          if (propertyValue[0] && typeof propertyValue[0] === 'number') {\n            editFields.push({...baseEditField, editType: 'number[]'});\n          } else {\n            editFields.push({...baseEditField, editType: 'string[]'});\n          }\n        } else if (typeof propertyValue === 'string') {\n          editFields.push({...baseEditField, editType: 'string'});\n        } else if (typeof propertyValue === 'object') {\n          handlePropertyLevel(propertyValue, `${previousKeys}${key}.`);\n        }\n      });\n    };\n\n    handlePropertyLevel(this.properties, '');\n\n    this.editFields$.next(editFields);\n    this.setModifiedProperties(editFields);\n  }\n}\n"]}
@@ -16,7 +16,7 @@
16
16
  import { Component, EventEmitter, Input, Output } from '@angular/core';
17
17
  import { editProductAanvragenConnectorForm } from './edit-product-aanvragen-connector.form';
18
18
  import { FormMappingService, FormTranslationService } from '@valtimo/form';
19
- import { DocumentService } from '@valtimo/document';
19
+ import { DocumentService, } from '@valtimo/document';
20
20
  import { BehaviorSubject, combineLatest, Subject } from 'rxjs';
21
21
  import { cloneDeep } from 'lodash';
22
22
  import { TranslateService } from '@ngx-translate/core';
@@ -32,11 +32,11 @@ export class EditProductAanvragenConnectorComponent {
32
32
  this.connectorDelete = new EventEmitter();
33
33
  this.formRefresh$ = new Subject();
34
34
  this.formDefinition$ = new BehaviorSubject(undefined);
35
- this.translatedFormDefinition$ = this.formDefinition$.pipe(map((definition) => this.formTranslationService.translateForm(definition)));
35
+ this.translatedFormDefinition$ = this.formDefinition$.pipe(map(definition => this.formTranslationService.translateForm(definition)));
36
36
  this.caseDefinitionOptions = [];
37
37
  this.processDocumentDefinitionOptions = {};
38
38
  this.options = {
39
- disableAlerts: true
39
+ disableAlerts: true,
40
40
  };
41
41
  this.mapCaseDefinitionKeyComponent = (component) => {
42
42
  if (component.key === 'caseDefinitionKey') {
@@ -70,7 +70,8 @@ export class EditProductAanvragenConnectorComponent {
70
70
  properties.openNotificatieProperties.baseUrl = submission.openNotificationsBaseUrl;
71
71
  properties.openNotificatieProperties.clientId = submission.openNotificationsClientId;
72
72
  properties.openNotificatieProperties.secret = submission.openNotificationsSecret;
73
- properties.openNotificatieProperties.callbackBaseUrl = submission.openNotificationsCallbackBaseUrl;
73
+ properties.openNotificatieProperties.callbackBaseUrl =
74
+ submission.openNotificationsCallbackBaseUrl;
74
75
  properties.aanvragerRolTypeUrl = submission.applicantRoleTypeUrl;
75
76
  properties.typeMapping = submission.productAanvraagTypes;
76
77
  this.propertiesSave.emit({ properties, name: submission.connectorName });
@@ -79,8 +80,10 @@ export class EditProductAanvragenConnectorComponent {
79
80
  this.connectorDelete.emit();
80
81
  }
81
82
  openFormDefinitionSubscription() {
82
- this.formDefinitionSubscription = combineLatest([this.formDefinition$, this.translateService.stream('key')])
83
- .subscribe(([form]) => {
83
+ this.formDefinitionSubscription = combineLatest([
84
+ this.formDefinition$,
85
+ this.translateService.stream('key'),
86
+ ]).subscribe(([form]) => {
84
87
  const translatedForm = this.formTranslationService.translateForm(form);
85
88
  this.refreshForm({ form: translatedForm });
86
89
  });
@@ -99,7 +102,8 @@ export class EditProductAanvragenConnectorComponent {
99
102
  submission.openNotificationsBaseUrl = properties.openNotificatieProperties.baseUrl;
100
103
  submission.openNotificationsClientId = properties.openNotificatieProperties.clientId;
101
104
  submission.openNotificationsSecret = properties.openNotificatieProperties.secret;
102
- submission.openNotificationsCallbackBaseUrl = properties.openNotificatieProperties.callbackBaseUrl;
105
+ submission.openNotificationsCallbackBaseUrl =
106
+ properties.openNotificatieProperties.callbackBaseUrl;
103
107
  submission.applicantRoleTypeUrl = properties.aanvragerRolTypeUrl;
104
108
  submission.productAanvraagTypes = properties.typeMapping;
105
109
  submission.connectorName = this.defaultName;
@@ -110,13 +114,15 @@ export class EditProductAanvragenConnectorComponent {
110
114
  }
111
115
  loadDefinitions() {
112
116
  let documentDefinitions;
113
- this.documentService.getAllDefinitions().pipe(tap((resDocumentDefinitions) => documentDefinitions = resDocumentDefinitions.content), switchMap((resDocumentDefinitions) => combineLatest(resDocumentDefinitions.content.map((definition) => this.documentService.findProcessDocumentDefinitions(definition.id.name)))), tap((res) => {
117
+ this.documentService
118
+ .getAllDefinitions()
119
+ .pipe(tap(resDocumentDefinitions => (documentDefinitions = resDocumentDefinitions.content)), switchMap(resDocumentDefinitions => combineLatest(resDocumentDefinitions.content.map(definition => this.documentService.findProcessDocumentDefinitions(definition.id.name)))), tap(res => {
114
120
  var _a;
115
- this.caseDefinitionOptions = documentDefinitions.map((documentDefinition) => {
121
+ this.caseDefinitionOptions = documentDefinitions.map(documentDefinition => {
116
122
  return { label: documentDefinition.id.name, value: documentDefinition.id.name };
117
123
  });
118
124
  documentDefinitions.forEach((documentDefinition, index) => {
119
- this.processDocumentDefinitionOptions[documentDefinition.id.name] = res[index].map((processDocumentDefinition) => processDocumentDefinition.id.processDefinitionKey);
125
+ this.processDocumentDefinitionOptions[documentDefinition.id.name] = res[index].map(processDocumentDefinition => processDocumentDefinition.id.processDefinitionKey);
120
126
  });
121
127
  window['productRequestDefinitions'] = this.processDocumentDefinitionOptions;
122
128
  const definitionWithCaseDefinitionOptions = this.formMappingService.mapComponents(this.formDefinition$.getValue(), this.mapCaseDefinitionKeyComponent);
@@ -124,13 +130,14 @@ export class EditProductAanvragenConnectorComponent {
124
130
  if ((_a = this.properties) === null || _a === void 0 ? void 0 : _a.aanvragerRolTypeUrl) {
125
131
  this.prefillForm();
126
132
  }
127
- })).subscribe();
133
+ }))
134
+ .subscribe();
128
135
  }
129
136
  }
130
137
  EditProductAanvragenConnectorComponent.decorators = [
131
138
  { type: Component, args: [{
132
139
  selector: 'valtimo-edit-product-aanvragen-connector',
133
- template: "<!--\n ~ Copyright 2015-2021 Ritense BV, the Netherlands.\n ~\n ~ Licensed under EUPL, Version 1.2 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" basis,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n -->\n\n<div\n *ngIf=\"translatedFormDefinition$ | async as definition\"\n class=\"edit-product-request\"\n [ngClass]=\"{'has-delete': showDeleteButton}\"\n>\n <valtimo-form-io\n [form]=\"definition\"\n [formRefresh$]=\"formRefresh$\"\n [options]=\"options\"\n (submit)=\"onSubmit($event)\"\n >\n </valtimo-form-io>\n\n <button *ngIf=\"showDeleteButton\" class=\"btn btn-danger btn-space\" (click)=\"onDelete()\">\n <i class=\"icon mdi mdi-delete mr-1\"></i>\n {{'connectorManagement.remove' | translate}}\n </button>\n</div>\n\n",
140
+ template: "<!--\n ~ Copyright 2015-2021 Ritense BV, the Netherlands.\n ~\n ~ Licensed under EUPL, Version 1.2 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" basis,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n -->\n\n<div\n *ngIf=\"translatedFormDefinition$ | async as definition\"\n class=\"edit-product-request\"\n [ngClass]=\"{'has-delete': showDeleteButton}\"\n>\n <valtimo-form-io\n [form]=\"definition\"\n [formRefresh$]=\"formRefresh$\"\n [options]=\"options\"\n (submit)=\"onSubmit($event)\"\n >\n </valtimo-form-io>\n\n <button *ngIf=\"showDeleteButton\" class=\"btn btn-danger btn-space\" (click)=\"onDelete()\">\n <i class=\"icon mdi mdi-delete mr-1\"></i>\n {{ 'connectorManagement.remove' | translate }}\n </button>\n</div>\n",
134
141
  styles: ["/*!\n * Copyright 2015-2021 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */.edit-product-request ::ng-deep .btn-wizard-nav-cancel{display:none}.edit-product-request ::ng-deep .list-inline{display:flex;flex-direction:row;justify-content:flex-end}.edit-product-request ::ng-deep .col-sm-2{flex:0 0 25%;max-width:25%}.edit-product-request ::ng-deep .edit-grid-component>label{display:none}.edit-product-request.has-delete ::ng-deep .list-inline{margin-bottom:-30px}.edit-product-request .btn-danger{position:relative}"]
135
142
  },] }
136
143
  ];
@@ -147,4 +154,4 @@ EditProductAanvragenConnectorComponent.propDecorators = {
147
154
  propertiesSave: [{ type: Output }],
148
155
  connectorDelete: [{ type: Output }]
149
156
  };
150
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"edit-product-aanvragen-connector.component.js","sourceRoot":"","sources":["../../../../../../../projects/valtimo/connector-management/src/lib/components/edit-product-aanvragen-connector/edit-product-aanvragen-connector.component.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright 2015-2021 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {Component, EventEmitter, Input, OnDestroy, OnInit, Output} from '@angular/core';\nimport {editProductAanvragenConnectorForm} from './edit-product-aanvragen-connector.form';\nimport {FormMappingService, FormTranslationService} from '@valtimo/form';\nimport {DocumentService} from '@valtimo/document';\nimport {ExtendedComponentSchema} from 'formiojs';\nimport {BehaviorSubject, combineLatest, Subject, Subscription} from 'rxjs';\nimport {ConnectorProperties, DocumentDefinition, DocumentDefinitions, ProcessDocumentDefinition} from '@valtimo/contract';\nimport {FormioForm, FormioRefreshValue} from 'angular-formio';\nimport {FormioOptions} from 'angular-formio/formio.common';\nimport {cloneDeep} from 'lodash';\nimport {TranslateService} from '@ngx-translate/core';\nimport {map, switchMap, tap} from 'rxjs/operators';\n\n@Component({\n  selector: 'valtimo-edit-product-aanvragen-connector',\n  templateUrl: './edit-product-aanvragen-connector.component.html',\n  styleUrls: ['./edit-product-aanvragen-connector.component.scss']\n})\nexport class EditProductAanvragenConnectorComponent implements OnInit, OnDestroy {\n  @Input() properties: ConnectorProperties;\n  @Input() defaultName!: string;\n  @Input() showDeleteButton = false;\n\n  @Output() propertiesSave = new EventEmitter<{properties: ConnectorProperties, name: string}>();\n  @Output() connectorDelete = new EventEmitter<any>();\n\n  formRefresh$ = new Subject<FormioRefreshValue>();\n  formDefinition$ = new BehaviorSubject<FormioForm>(undefined);\n  translatedFormDefinition$ = this.formDefinition$.pipe(\n    map((definition) => this.formTranslationService.translateForm(definition))\n  );\n  caseDefinitionOptions: Array<{label: string, value: string}> = [];\n  processDocumentDefinitionOptions: {[caseDefinitionId: string]: Array<string>} = {};\n\n  readonly options: FormioOptions = {\n    disableAlerts: true\n  };\n\n  private formDefinitionSubscription!: Subscription;\n  private translateSubscription!: Subscription;\n\n  constructor(\n    private readonly formTranslationService: FormTranslationService,\n    private readonly formMappingService: FormMappingService,\n    private readonly documentService: DocumentService,\n    private readonly translateService: TranslateService\n  ) {\n  }\n\n  ngOnInit(): void {\n    window['productRequestDefinitions'] = {};\n    this.openFormDefinitionSubscription();\n    this.formDefinition$.next(editProductAanvragenConnectorForm);\n    this.loadDefinitions();\n  }\n\n  ngOnDestroy(): void {\n    this.formDefinitionSubscription?.unsubscribe();\n    this.translateSubscription?.unsubscribe();\n  }\n\n  onSubmit(event: any): void {\n    const submission = event.data;\n    const properties = cloneDeep(this.properties);\n\n    properties.objectsApiProperties.objectsApi.url = submission.objectsApiUrl;\n    properties.objectsApiProperties.objectsApi.token = submission.objectsApiToken;\n    properties.objectsApiProperties.objectsTypeApi.url = submission.objectTypesApiUrl;\n    properties.objectsApiProperties.objectsTypeApi.token = submission.objectTypesApiToken;\n\n    properties.objectsApiProperties.objectType.name = submission.objectTypeName;\n    properties.objectsApiProperties.objectType.title = submission.objectTypeTitle;\n    properties.objectsApiProperties.objectType.url = submission.objectTypeUrl;\n    properties.objectsApiProperties.objectType.typeVersion = submission.objectTypeVersion;\n\n    properties.openNotificatieProperties.baseUrl = submission.openNotificationsBaseUrl;\n    properties.openNotificatieProperties.clientId = submission.openNotificationsClientId;\n    properties.openNotificatieProperties.secret = submission.openNotificationsSecret;\n    properties.openNotificatieProperties.callbackBaseUrl = submission.openNotificationsCallbackBaseUrl;\n\n    properties.aanvragerRolTypeUrl = submission.applicantRoleTypeUrl;\n\n    properties.typeMapping = submission.productAanvraagTypes;\n\n    this.propertiesSave.emit({properties, name: submission.connectorName});\n  }\n\n  onDelete(): void {\n    this.connectorDelete.emit();\n  }\n\n  private openFormDefinitionSubscription(): void {\n    this.formDefinitionSubscription = combineLatest([this.formDefinition$, this.translateService.stream('key')])\n      .subscribe(([form]) => {\n        const translatedForm = this.formTranslationService.translateForm(form);\n        this.refreshForm({form: translatedForm});\n      });\n  }\n\n  private prefillForm(): void {\n    const properties = cloneDeep(this.properties);\n    const submission: {[key: string]: string} = {};\n\n    submission.objectsApiUrl = properties.objectsApiProperties.objectsApi.url;\n    submission.objectsApiToken = properties.objectsApiProperties.objectsApi.token;\n    submission.objectTypesApiUrl = properties.objectsApiProperties.objectsTypeApi.url;\n    submission.objectTypesApiToken = properties.objectsApiProperties.objectsTypeApi.token;\n\n    submission.objectTypeName = properties.objectsApiProperties.objectType.name;\n    submission.objectTypeTitle = properties.objectsApiProperties.objectType.title;\n    submission.objectTypeUrl = properties.objectsApiProperties.objectType.url;\n    submission.objectTypeVersion = properties.objectsApiProperties.objectType.typeVersion;\n\n    submission.openNotificationsBaseUrl = properties.openNotificatieProperties.baseUrl;\n    submission.openNotificationsClientId = properties.openNotificatieProperties.clientId;\n    submission.openNotificationsSecret = properties.openNotificatieProperties.secret;\n    submission.openNotificationsCallbackBaseUrl = properties.openNotificatieProperties.callbackBaseUrl;\n\n    submission.applicantRoleTypeUrl = properties.aanvragerRolTypeUrl;\n\n    submission.productAanvraagTypes = properties.typeMapping;\n\n    submission.connectorName = this.defaultName;\n\n    this.refreshForm({submission: {data: submission}});\n  }\n\n  private mapCaseDefinitionKeyComponent = (component: ExtendedComponentSchema): ExtendedComponentSchema => {\n    if (component.key === 'caseDefinitionKey') {\n      return {...component, disabled: false, data: {values: this.caseDefinitionOptions}};\n    }\n\n    return component;\n  }\n\n  private refreshForm(refreshValue: FormioRefreshValue): void {\n    this.formRefresh$.next(refreshValue);\n  }\n\n  private loadDefinitions(): void {\n    let documentDefinitions: Array<DocumentDefinition>;\n\n    this.documentService.getAllDefinitions().pipe(\n      tap((resDocumentDefinitions) => documentDefinitions = resDocumentDefinitions.content),\n      switchMap((resDocumentDefinitions) =>\n        combineLatest(resDocumentDefinitions.content.map((definition) =>\n          this.documentService.findProcessDocumentDefinitions(definition.id.name)))\n      ),\n      tap((res) => {\n        this.caseDefinitionOptions = documentDefinitions.map((documentDefinition) => {\n          return {label: documentDefinition.id.name, value: documentDefinition.id.name};\n        });\n\n        documentDefinitions.forEach((documentDefinition, index) => {\n          this.processDocumentDefinitionOptions[documentDefinition.id.name] = res[index].map((processDocumentDefinition) =>\n            processDocumentDefinition.id.processDefinitionKey);\n        });\n\n        window['productRequestDefinitions'] = this.processDocumentDefinitionOptions;\n\n        const definitionWithCaseDefinitionOptions =\n          this.formMappingService.mapComponents(this.formDefinition$.getValue(), this.mapCaseDefinitionKeyComponent);\n\n        this.formDefinition$.next(definitionWithCaseDefinitionOptions);\n\n        if (this.properties?.aanvragerRolTypeUrl) {\n          this.prefillForm();\n        }\n      })\n    ).subscribe();\n  }\n}\n"]}
157
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"edit-product-aanvragen-connector.component.js","sourceRoot":"/tmp/jenkins-4c3bb770/workspace/Valtimo_-_Angular_Libraries_main/projects/valtimo/connector-management/src/","sources":["lib/components/edit-product-aanvragen-connector/edit-product-aanvragen-connector.component.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright 2015-2021 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {Component, EventEmitter, Input, OnDestroy, OnInit, Output} from '@angular/core';\nimport {editProductAanvragenConnectorForm} from './edit-product-aanvragen-connector.form';\nimport {FormMappingService, FormTranslationService} from '@valtimo/form';\nimport {\n  DocumentService,\n  DocumentDefinition,\n  DocumentDefinitions,\n  ProcessDocumentDefinition,\n} from '@valtimo/document';\nimport {ExtendedComponentSchema} from 'formiojs';\nimport {BehaviorSubject, combineLatest, Subject, Subscription} from 'rxjs';\nimport {ConnectorProperties} from '../../models';\nimport {FormioForm, FormioRefreshValue} from 'angular-formio';\nimport {FormioOptions} from 'angular-formio/formio.common';\nimport {cloneDeep} from 'lodash';\nimport {TranslateService} from '@ngx-translate/core';\nimport {map, switchMap, tap} from 'rxjs/operators';\n\n@Component({\n  selector: 'valtimo-edit-product-aanvragen-connector',\n  templateUrl: './edit-product-aanvragen-connector.component.html',\n  styleUrls: ['./edit-product-aanvragen-connector.component.scss'],\n})\nexport class EditProductAanvragenConnectorComponent implements OnInit, OnDestroy {\n  @Input() properties: ConnectorProperties;\n  @Input() defaultName!: string;\n  @Input() showDeleteButton = false;\n\n  @Output() propertiesSave = new EventEmitter<{properties: ConnectorProperties; name: string}>();\n  @Output() connectorDelete = new EventEmitter<any>();\n\n  formRefresh$ = new Subject<FormioRefreshValue>();\n  formDefinition$ = new BehaviorSubject<FormioForm>(undefined);\n  translatedFormDefinition$ = this.formDefinition$.pipe(\n    map(definition => this.formTranslationService.translateForm(definition))\n  );\n  caseDefinitionOptions: Array<{label: string; value: string}> = [];\n  processDocumentDefinitionOptions: {[caseDefinitionId: string]: Array<string>} = {};\n\n  readonly options: FormioOptions = {\n    disableAlerts: true,\n  };\n\n  private formDefinitionSubscription!: Subscription;\n  private translateSubscription!: Subscription;\n\n  constructor(\n    private readonly formTranslationService: FormTranslationService,\n    private readonly formMappingService: FormMappingService,\n    private readonly documentService: DocumentService,\n    private readonly translateService: TranslateService\n  ) {}\n\n  ngOnInit(): void {\n    window['productRequestDefinitions'] = {};\n    this.openFormDefinitionSubscription();\n    this.formDefinition$.next(editProductAanvragenConnectorForm);\n    this.loadDefinitions();\n  }\n\n  ngOnDestroy(): void {\n    this.formDefinitionSubscription?.unsubscribe();\n    this.translateSubscription?.unsubscribe();\n  }\n\n  onSubmit(event: any): void {\n    const submission = event.data;\n    const properties = cloneDeep(this.properties);\n\n    properties.objectsApiProperties.objectsApi.url = submission.objectsApiUrl;\n    properties.objectsApiProperties.objectsApi.token = submission.objectsApiToken;\n    properties.objectsApiProperties.objectsTypeApi.url = submission.objectTypesApiUrl;\n    properties.objectsApiProperties.objectsTypeApi.token = submission.objectTypesApiToken;\n\n    properties.objectsApiProperties.objectType.name = submission.objectTypeName;\n    properties.objectsApiProperties.objectType.title = submission.objectTypeTitle;\n    properties.objectsApiProperties.objectType.url = submission.objectTypeUrl;\n    properties.objectsApiProperties.objectType.typeVersion = submission.objectTypeVersion;\n\n    properties.openNotificatieProperties.baseUrl = submission.openNotificationsBaseUrl;\n    properties.openNotificatieProperties.clientId = submission.openNotificationsClientId;\n    properties.openNotificatieProperties.secret = submission.openNotificationsSecret;\n    properties.openNotificatieProperties.callbackBaseUrl =\n      submission.openNotificationsCallbackBaseUrl;\n\n    properties.aanvragerRolTypeUrl = submission.applicantRoleTypeUrl;\n\n    properties.typeMapping = submission.productAanvraagTypes;\n\n    this.propertiesSave.emit({properties, name: submission.connectorName});\n  }\n\n  onDelete(): void {\n    this.connectorDelete.emit();\n  }\n\n  private openFormDefinitionSubscription(): void {\n    this.formDefinitionSubscription = combineLatest([\n      this.formDefinition$,\n      this.translateService.stream('key'),\n    ]).subscribe(([form]) => {\n      const translatedForm = this.formTranslationService.translateForm(form);\n      this.refreshForm({form: translatedForm});\n    });\n  }\n\n  private prefillForm(): void {\n    const properties = cloneDeep(this.properties);\n    const submission: {[key: string]: string} = {};\n\n    submission.objectsApiUrl = properties.objectsApiProperties.objectsApi.url;\n    submission.objectsApiToken = properties.objectsApiProperties.objectsApi.token;\n    submission.objectTypesApiUrl = properties.objectsApiProperties.objectsTypeApi.url;\n    submission.objectTypesApiToken = properties.objectsApiProperties.objectsTypeApi.token;\n\n    submission.objectTypeName = properties.objectsApiProperties.objectType.name;\n    submission.objectTypeTitle = properties.objectsApiProperties.objectType.title;\n    submission.objectTypeUrl = properties.objectsApiProperties.objectType.url;\n    submission.objectTypeVersion = properties.objectsApiProperties.objectType.typeVersion;\n\n    submission.openNotificationsBaseUrl = properties.openNotificatieProperties.baseUrl;\n    submission.openNotificationsClientId = properties.openNotificatieProperties.clientId;\n    submission.openNotificationsSecret = properties.openNotificatieProperties.secret;\n    submission.openNotificationsCallbackBaseUrl =\n      properties.openNotificatieProperties.callbackBaseUrl;\n\n    submission.applicantRoleTypeUrl = properties.aanvragerRolTypeUrl;\n\n    submission.productAanvraagTypes = properties.typeMapping;\n\n    submission.connectorName = this.defaultName;\n\n    this.refreshForm({submission: {data: submission}});\n  }\n\n  private mapCaseDefinitionKeyComponent = (\n    component: ExtendedComponentSchema\n  ): ExtendedComponentSchema => {\n    if (component.key === 'caseDefinitionKey') {\n      return {...component, disabled: false, data: {values: this.caseDefinitionOptions}};\n    }\n\n    return component;\n  };\n\n  private refreshForm(refreshValue: FormioRefreshValue): void {\n    this.formRefresh$.next(refreshValue);\n  }\n\n  private loadDefinitions(): void {\n    let documentDefinitions: Array<DocumentDefinition>;\n\n    this.documentService\n      .getAllDefinitions()\n      .pipe(\n        tap(resDocumentDefinitions => (documentDefinitions = resDocumentDefinitions.content)),\n        switchMap(resDocumentDefinitions =>\n          combineLatest(\n            resDocumentDefinitions.content.map(definition =>\n              this.documentService.findProcessDocumentDefinitions(definition.id.name)\n            )\n          )\n        ),\n        tap(res => {\n          this.caseDefinitionOptions = documentDefinitions.map(documentDefinition => {\n            return {label: documentDefinition.id.name, value: documentDefinition.id.name};\n          });\n\n          documentDefinitions.forEach((documentDefinition, index) => {\n            this.processDocumentDefinitionOptions[documentDefinition.id.name] = res[index].map(\n              processDocumentDefinition => processDocumentDefinition.id.processDefinitionKey\n            );\n          });\n\n          window['productRequestDefinitions'] = this.processDocumentDefinitionOptions;\n\n          const definitionWithCaseDefinitionOptions = this.formMappingService.mapComponents(\n            this.formDefinition$.getValue(),\n            this.mapCaseDefinitionKeyComponent\n          );\n\n          this.formDefinition$.next(definitionWithCaseDefinitionOptions);\n\n          if (this.properties?.aanvragerRolTypeUrl) {\n            this.prefillForm();\n          }\n        })\n      )\n      .subscribe();\n  }\n}\n"]}