NIFI-13110: (#8719)

- Auto-selecting the relationship when the source processor only offers a single relationship.

This closes #8719
This commit is contained in:
Matt Gilman 2024-04-30 22:22:53 -04:00 committed by GitHub
parent 99d8433b7d
commit 5a5947d1b0
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
1 changed files with 57 additions and 28 deletions

View File

@ -20,6 +20,7 @@ import { ControlValueAccessor, FormsModule, NG_VALUE_ACCESSOR } from '@angular/f
import { MatCheckboxModule } from '@angular/material/checkbox'; import { MatCheckboxModule } from '@angular/material/checkbox';
import { Relationship } from '../../../../../../state/flow'; import { Relationship } from '../../../../../../state/flow';
import { NiFiCommon } from '../../../../../../../../service/nifi-common.service';
export interface RelationshipItem { export interface RelationshipItem {
relationshipName: string; relationshipName: string;
@ -53,8 +54,8 @@ export class SourceProcessor implements ControlValueAccessor {
isDisabled = false; isDisabled = false;
isTouched = false; isTouched = false;
onTouched!: () => void; onTouched: (() => void) | null = null;
onChange!: (selectedRelationships: string[]) => void; onChange: ((selectedRelationships: string[]) => void) | null = null;
name!: string; name!: string;
relationships!: Relationship[]; relationships!: Relationship[];
@ -62,8 +63,21 @@ export class SourceProcessor implements ControlValueAccessor {
relationshipItems!: RelationshipItem[]; relationshipItems!: RelationshipItem[];
selectedRelationships!: string[]; selectedRelationships!: string[];
constructor(private nifiCommon: NiFiCommon) {}
processRelationships(): void { processRelationships(): void {
if (this.relationships && this.selectedRelationships) { if (this.relationships) {
if (this.nifiCommon.isEmpty(this.selectedRelationships)) {
this.relationshipItems = this.relationships.map((relationship) => {
return {
relationshipName: relationship.name,
selected: this.relationships.length === 1,
available: true
};
});
this.considerDefaultSelection();
} else {
this.relationshipItems = this.relationships.map((relationship) => { this.relationshipItems = this.relationships.map((relationship) => {
return { return {
relationshipName: relationship.name, relationshipName: relationship.name,
@ -85,13 +99,26 @@ export class SourceProcessor implements ControlValueAccessor {
}); });
} }
} }
}
considerDefaultSelection(): void {
const callbacksConfigured: boolean = this.onChange != null && this.onTouched != null;
const autoSelected: boolean =
this.relationships?.length === 1 && this.nifiCommon.isEmpty(this.selectedRelationships);
if (callbacksConfigured && autoSelected) {
this.handleChanged();
}
}
registerOnChange(onChange: (selectedPrioritizers: string[]) => void): void { registerOnChange(onChange: (selectedPrioritizers: string[]) => void): void {
this.onChange = onChange; this.onChange = onChange;
this.considerDefaultSelection();
} }
registerOnTouched(onTouch: () => void): void { registerOnTouched(onTouch: () => void): void {
this.onTouched = onTouch; this.onTouched = onTouch;
this.considerDefaultSelection();
} }
setDisabledState(isDisabled: boolean): void { setDisabledState(isDisabled: boolean): void {
@ -104,6 +131,7 @@ export class SourceProcessor implements ControlValueAccessor {
} }
handleChanged() { handleChanged() {
if (this.onTouched && this.onChange) {
// mark the component as touched if not already // mark the component as touched if not already
if (!this.isTouched) { if (!this.isTouched) {
this.isTouched = true; this.isTouched = true;
@ -113,6 +141,7 @@ export class SourceProcessor implements ControlValueAccessor {
// emit the changes // emit the changes
this.onChange(this.serializeSelectedRelationships()); this.onChange(this.serializeSelectedRelationships());
} }
}
private serializeSelectedRelationships(): string[] { private serializeSelectedRelationships(): string[] {
return this.relationshipItems.filter((item) => item.selected).map((item) => item.relationshipName); return this.relationshipItems.filter((item) => item.selected).map((item) => item.relationshipName);