Skip to content

Commit

Permalink
[NIFI-13621] - UI - handle backend errors when hitting the search api (
Browse files Browse the repository at this point in the history
…#9133)

This closes #9133
  • Loading branch information
rfellows authored Jul 31, 2024
1 parent 8ad6aa6 commit 83d2078
Show file tree
Hide file tree
Showing 2 changed files with 55 additions and 22 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@
<form [formGroup]="searchForm">
<ng-template
cdkConnectedOverlay
[cdkConnectedOverlayDisableClose]="true"
[cdkConnectedOverlayOrigin]="searchInput"
[cdkConnectedOverlayOpen]="searching || searchingResultsVisible"
[cdkConnectedOverlayPositions]="positions"
Expand Down Expand Up @@ -180,6 +181,7 @@
matInput
placeholder="Search"
class="search-input surface-contrast"
(keydown)="onKeydown($event)"
[class.open]="searchInputVisible"
cdkOverlayOrigin
#searchInput="cdkOverlayOrigin"
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@
import { Component, DestroyRef, ElementRef, inject, Input, OnInit, ViewChild } from '@angular/core';
import { FormBuilder, FormGroup, ReactiveFormsModule } from '@angular/forms';
import { initialState } from '../../../../state/flow/flow.reducer';
import { debounceTime, filter, switchMap, tap } from 'rxjs';
import { debounceTime, filter, take, tap } from 'rxjs';
import { ComponentSearchResult, SearchService } from '../../../../service/search.service';
import {
CdkConnectedOverlay,
Expand All @@ -35,10 +35,13 @@ import { MatFormFieldModule } from '@angular/material/form-field';
import { MatInputModule } from '@angular/material/input';
import { CanvasState } from '../../../../state';
import { Store } from '@ngrx/store';
import * as FlowActions from '../../../../state/flow/flow.actions';
import { centerSelectedComponents, setAllowTransition } from '../../../../state/flow/flow.actions';
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
import { NifiTooltipDirective, selectCurrentRoute } from '@nifi/shared';
import { SearchMatchTip } from '../../../../../../ui/common/tooltips/search-match-tip/search-match-tip.component';
import { HttpErrorResponse } from '@angular/common/http';
import { ErrorHelper } from '../../../../../../service/error-helper.service';

@Component({
selector: 'search',
Expand Down Expand Up @@ -100,7 +103,8 @@ export class Search implements OnInit {
constructor(
private formBuilder: FormBuilder,
private searchService: SearchService,
private store: Store<CanvasState>
private store: Store<CanvasState>,
private errorHelper: ErrorHelper
) {
this.searchForm = this.formBuilder.group({ searchBar: '' });

Expand All @@ -122,27 +126,38 @@ export class Search implements OnInit {
takeUntilDestroyed(this.destroyRef),
filter((data) => data?.trim().length > 0),
debounceTime(500),
tap(() => (this.searching = true)),
switchMap((query: string) => this.searchService.search(query, this.currentProcessGroupId))
tap(() => (this.searching = true))
)
.subscribe((response) => {
const results = response.searchResultsDTO;

this.processorResults = results.processorResults;
this.connectionResults = results.connectionResults;
this.processGroupResults = results.processGroupResults;
this.inputPortResults = results.inputPortResults;
this.outputPortResults = results.outputPortResults;
this.remoteProcessGroupResults = results.remoteProcessGroupResults;
this.funnelResults = results.funnelResults;
this.labelResults = results.labelResults;
this.controllerServiceNodeResults = results.controllerServiceNodeResults;
this.parameterContextResults = results.parameterContextResults;
this.parameterProviderNodeResults = results.parameterProviderNodeResults;
this.parameterResults = results.parameterResults;

this.searchingResultsVisible = true;
this.searching = false;
.subscribe((query) => {
this.searchService
.search(query, this.currentProcessGroupId)
.pipe(take(1))
.subscribe({
next: (response) => {
const results = response.searchResultsDTO;

this.processorResults = results.processorResults;
this.connectionResults = results.connectionResults;
this.processGroupResults = results.processGroupResults;
this.inputPortResults = results.inputPortResults;
this.outputPortResults = results.outputPortResults;
this.remoteProcessGroupResults = results.remoteProcessGroupResults;
this.funnelResults = results.funnelResults;
this.labelResults = results.labelResults;
this.controllerServiceNodeResults = results.controllerServiceNodeResults;
this.parameterContextResults = results.parameterContextResults;
this.parameterProviderNodeResults = results.parameterProviderNodeResults;
this.parameterResults = results.parameterResults;

this.searchingResultsVisible = true;
this.searching = false;
},
error: (errorResponse: HttpErrorResponse) => {
this.searchingResultsVisible = false;
this.searching = false;
this.snackBarOrFullScreenError(errorResponse);
}
});
});
}

Expand Down Expand Up @@ -207,4 +222,20 @@ export class Search implements OnInit {
this.store.dispatch(setAllowTransition({ allowTransition: true }));
}
}

onKeydown(event: KeyboardEvent): void {
if (event.key === 'Escape') {
this.searchingResultsVisible = false;
}
}

private snackBarOrFullScreenError(errorResponse: HttpErrorResponse) {
if (this.errorHelper.showErrorInContext(errorResponse.status)) {
this.store.dispatch(
FlowActions.flowSnackbarError({ error: this.errorHelper.getErrorString(errorResponse) })
);
} else {
this.store.dispatch(this.errorHelper.fullScreenError(errorResponse));
}
}
}

0 comments on commit 83d2078

Please sign in to comment.