From 8e0c68e5cc8e39b544ed44a7885d1f04f7ae6f42 Mon Sep 17 00:00:00 2001 From: Matt Gilman Date: Mon, 29 Jan 2024 15:49:59 -0500 Subject: [PATCH] NIFI-12663: Error Handling in CS Listing (#8305) * NIFI-12663: - Handling API error responses in the Management Controller Services page. * NIFI-12679: - Renaming components based on review feedback. - Using ng-content in page-content component. - Removing the problematic route when navigating to the error page. - Fixing logic when handling service loading errors. - Handling errors in the Property Table Helper service. * NIFI-12679: - Addressing review feedback. --- .../main/nifi/src/app/app-routing.module.ts | 4 + .../src/main/nifi/src/app/app.module.ts | 6 +- .../error/feature/error-routing.module.ts | 28 +++++++ .../feature/error.component.html} | 13 ++- .../feature/error.component.scss} | 6 +- .../error/feature/error.component.spec.ts | 50 +++++++++++ .../pages/error/feature/error.component.ts | 32 +++++++ .../app/pages/error/feature/error.module.ts | 29 +++++++ .../flow-designer/service/flow.service.ts | 4 - .../create-port/create-port.component.html | 2 +- .../port/create-port/create-port.component.ts | 4 +- .../port/edit-port/edit-port.component.html | 2 +- .../port/edit-port/edit-port.component.ts | 8 +- .../create-process-group.component.html | 1 + .../create-process-group.component.ts | 4 +- .../group-components.component.ts | 2 - .../edit-processor.component.html | 1 + .../edit-processor.component.spec.ts | 19 ++++- .../edit-processor.component.ts | 4 +- .../pages/login/feature/login.component.html | 16 ++-- .../app/pages/login/feature/login.module.ts | 7 +- .../ui/login-form/login-form.component.html | 2 +- .../management-controller-services/index.ts | 3 +- .../management-controller-services.actions.ts | 4 +- .../management-controller-services.effects.ts | 84 +++++++++++-------- .../management-controller-services.reducer.ts | 10 +-- ...anagement-controller-services.selectors.ts | 5 ++ .../management-controller-services.module.ts | 3 +- .../src/app/service/error-helper.service.ts | 69 +++++++++++++++ .../app/service/extension-types.service.ts | 2 +- .../app/service/guard/authentication.guard.ts | 8 +- .../interceptors/auth.interceptor.spec.ts | 10 ++- .../service/interceptors/auth.interceptor.ts | 47 +++++++++-- .../service/property-table-helper.service.ts | 53 ++++++++++-- .../nifi/src/app/state/error/error.actions.ts | 29 +++++++ .../nifi/src/app/state/error/error.effects.ts | 55 ++++++++++++ .../nifi/src/app/state/error/error.reducer.ts | 50 +++++++++++ .../src/app/state/error/error.selectors.ts | 25 ++++++ .../main/nifi/src/app/state/error/index.ts | 28 +++++++ .../src/main/nifi/src/app/state/index.ts | 4 + .../edit-controller-service.component.html | 1 + .../edit-controller-service.component.spec.ts | 19 ++++- .../edit-controller-service.component.ts | 4 +- .../error-banner/error-banner.component.html | 32 +++++++ .../error-banner/error-banner.component.scss | 27 ++++++ .../error-banner.component.spec.ts} | 14 ++-- .../error-banner/error-banner.component.ts} | 33 ++++---- .../page-content/page-content.component.html} | 10 +-- .../page-content/page-content.component.scss} | 4 +- .../page-content.component.spec.ts} | 13 ++- .../page-content/page-content.component.ts} | 17 ++-- 51 files changed, 749 insertions(+), 158 deletions(-) create mode 100644 nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/error/feature/error-routing.module.ts rename nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/{flow-designer/ui/common/banner/banner.component.html => error/feature/error.component.html} (61%) rename nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/{flow-designer/ui/common/banner/banner.component.scss => error/feature/error.component.scss} (88%) create mode 100644 nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/error/feature/error.component.spec.ts create mode 100644 nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/error/feature/error.component.ts create mode 100644 nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/error/feature/error.module.ts create mode 100644 nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/service/error-helper.service.ts create mode 100644 nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/state/error/error.actions.ts create mode 100644 nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/state/error/error.effects.ts create mode 100644 nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/state/error/error.reducer.ts create mode 100644 nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/state/error/error.selectors.ts create mode 100644 nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/state/error/index.ts create mode 100644 nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/ui/common/error-banner/error-banner.component.html create mode 100644 nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/ui/common/error-banner/error-banner.component.scss rename nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/{pages/flow-designer/ui/common/banner/banner.component.spec.ts => ui/common/error-banner/error-banner.component.spec.ts} (79%) rename nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/{pages/flow-designer/ui/common/banner/banner.component.ts => ui/common/error-banner/error-banner.component.ts} (56%) rename nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/{pages/login/ui/login-message/login-message.component.html => ui/common/page-content/page-content.component.html} (73%) rename nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/{pages/login/ui/login-message/login-message.component.scss => ui/common/page-content/page-content.component.scss} (96%) rename nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/{pages/login/ui/login-message/login-message.component.spec.ts => ui/common/page-content/page-content.component.spec.ts} (78%) rename nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/{pages/login/ui/login-message/login-message.component.ts => ui/common/page-content/page-content.component.ts} (73%) diff --git a/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/app-routing.module.ts b/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/app-routing.module.ts index 3a70a49d5b..704d6df973 100644 --- a/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/app-routing.module.ts +++ b/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/app-routing.module.ts @@ -24,6 +24,10 @@ const routes: Routes = [ path: 'login', loadChildren: () => import('./pages/login/feature/login.module').then((m) => m.LoginModule) }, + { + path: 'error', + loadChildren: () => import('./pages/error/feature/error.module').then((m) => m.ErrorModule) + }, { path: 'settings', canMatch: [authenticationGuard], diff --git a/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/app.module.ts b/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/app.module.ts index 749a8dda7a..56c94fe9c4 100644 --- a/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/app.module.ts +++ b/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/app.module.ts @@ -42,6 +42,8 @@ import { ControllerServiceStateEffects } from './state/contoller-service-state/c import { SystemDiagnosticsEffects } from './state/system-diagnostics/system-diagnostics.effects'; import { FlowConfigurationEffects } from './state/flow-configuration/flow-configuration.effects'; import { ComponentStateEffects } from './state/component-state/component-state.effects'; +import { ErrorEffects } from './state/error/error.effects'; +import { MatSnackBarModule } from '@angular/material/snack-bar'; @NgModule({ declarations: [AppComponent], @@ -60,6 +62,7 @@ import { ComponentStateEffects } from './state/component-state/component-state.e navigationActionTiming: NavigationActionTiming.PostActivation }), EffectsModule.forRoot( + ErrorEffects, CurrentUserEffects, ExtensionTypesEffects, AboutEffects, @@ -76,7 +79,8 @@ import { ComponentStateEffects } from './state/component-state/component-state.e }), MatProgressSpinnerModule, MatNativeDateModule, - MatDialogModule + MatDialogModule, + MatSnackBarModule ], providers: [ { diff --git a/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/error/feature/error-routing.module.ts b/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/error/feature/error-routing.module.ts new file mode 100644 index 0000000000..110e54ca8c --- /dev/null +++ b/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/error/feature/error-routing.module.ts @@ -0,0 +1,28 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one or more + * contributor license agreements. See the NOTICE file distributed with + * this work for additional information regarding copyright ownership. + * The ASF licenses this file to You under the Apache License, Version 2.0 + * (the "License"); you may not use this file except in compliance with + * the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +import { NgModule } from '@angular/core'; +import { RouterModule, Routes } from '@angular/router'; +import { Error } from './error.component'; + +const routes: Routes = [{ path: '', component: Error }]; + +@NgModule({ + imports: [RouterModule.forChild(routes)], + exports: [RouterModule] +}) +export class ErrorRoutingModule {} diff --git a/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/flow-designer/ui/common/banner/banner.component.html b/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/error/feature/error.component.html similarity index 61% rename from nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/flow-designer/ui/common/banner/banner.component.html rename to nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/error/feature/error.component.html index 7fa5559faf..2dcd49203f 100644 --- a/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/flow-designer/ui/common/banner/banner.component.html +++ b/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/error/feature/error.component.html @@ -15,4 +15,15 @@ ~ limitations under the License. --> -
{{ message }}
+
+ + +
{{ errorDetail.message }}
+
+
+ + +
Please check the logs or navigate home and try again.
+
+
+
diff --git a/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/flow-designer/ui/common/banner/banner.component.scss b/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/error/feature/error.component.scss similarity index 88% rename from nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/flow-designer/ui/common/banner/banner.component.scss rename to nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/error/feature/error.component.scss index d6751e31d6..ed2e32658f 100644 --- a/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/flow-designer/ui/common/banner/banner.component.scss +++ b/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/error/feature/error.component.scss @@ -15,8 +15,6 @@ * limitations under the License. */ -div { - &.error { - background-color: #ffcdd2; - } +.error-background { + background: #fff url(../../../../assets/icons/bg-error.png) left top no-repeat; } diff --git a/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/error/feature/error.component.spec.ts b/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/error/feature/error.component.spec.ts new file mode 100644 index 0000000000..795a953ec6 --- /dev/null +++ b/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/error/feature/error.component.spec.ts @@ -0,0 +1,50 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one or more + * contributor license agreements. See the NOTICE file distributed with + * this work for additional information regarding copyright ownership. + * The ASF licenses this file to You under the Apache License, Version 2.0 + * (the "License"); you may not use this file except in compliance with + * the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +import { ComponentFixture, TestBed } from '@angular/core/testing'; + +import { Error } from './error.component'; +import { provideMockStore } from '@ngrx/store/testing'; +import { initialState } from '../../../state/current-user/current-user.reducer'; +import { Component } from '@angular/core'; + +describe('Error', () => { + let component: Error; + let fixture: ComponentFixture; + + @Component({ + selector: 'page-content', + standalone: true, + template: '' + }) + class MockPageContent {} + + beforeEach(() => { + TestBed.configureTestingModule({ + declarations: [Error], + imports: [MockPageContent], + providers: [provideMockStore({ initialState })] + }); + fixture = TestBed.createComponent(Error); + component = fixture.componentInstance; + fixture.detectChanges(); + }); + + it('should create', () => { + expect(component).toBeTruthy(); + }); +}); diff --git a/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/error/feature/error.component.ts b/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/error/feature/error.component.ts new file mode 100644 index 0000000000..2bfa544afd --- /dev/null +++ b/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/error/feature/error.component.ts @@ -0,0 +1,32 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one or more + * contributor license agreements. See the NOTICE file distributed with + * this work for additional information regarding copyright ownership. + * The ASF licenses this file to You under the Apache License, Version 2.0 + * (the "License"); you may not use this file except in compliance with + * the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +import { Component } from '@angular/core'; +import { Store } from '@ngrx/store'; +import { selectFullScreenError } from '../../../state/error/error.selectors'; +import { NiFiState } from '../../../state'; + +@Component({ + selector: 'error', + templateUrl: './error.component.html', + styleUrls: ['./error.component.scss'] +}) +export class Error { + errorDetail$ = this.store.select(selectFullScreenError); + + constructor(private store: Store) {} +} diff --git a/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/error/feature/error.module.ts b/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/error/feature/error.module.ts new file mode 100644 index 0000000000..2e1fb41518 --- /dev/null +++ b/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/error/feature/error.module.ts @@ -0,0 +1,29 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one or more + * contributor license agreements. See the NOTICE file distributed with + * this work for additional information regarding copyright ownership. + * The ASF licenses this file to You under the Apache License, Version 2.0 + * (the "License"); you may not use this file except in compliance with + * the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +import { NgModule } from '@angular/core'; +import { CommonModule } from '@angular/common'; +import { Error } from './error.component'; +import { ErrorRoutingModule } from './error-routing.module'; +import { PageContent } from '../../../ui/common/page-content/page-content.component'; + +@NgModule({ + declarations: [Error], + exports: [Error], + imports: [CommonModule, ErrorRoutingModule, PageContent] +}) +export class ErrorModule {} diff --git a/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/flow-designer/service/flow.service.ts b/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/flow-designer/service/flow.service.ts index 8d841d986c..818e802663 100644 --- a/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/flow-designer/service/flow.service.ts +++ b/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/flow-designer/service/flow.service.ts @@ -18,7 +18,6 @@ import { Injectable } from '@angular/core'; import { Observable } from 'rxjs'; import { HttpClient } from '@angular/common/http'; -import { CanvasUtils } from './canvas-utils.service'; import { ComponentRunStatusRequest, CreateComponentRequest, @@ -48,7 +47,6 @@ export class FlowService implements PropertyDescriptorRetriever { constructor( private httpClient: HttpClient, - private canvasUtils: CanvasUtils, private client: Client, private nifiCommon: NiFiCommon ) {} @@ -198,12 +196,10 @@ export class FlowService implements PropertyDescriptorRetriever { } updateComponent(updateComponent: UpdateComponentRequest): Observable { - // return throwError('API Error'); return this.httpClient.put(this.nifiCommon.stripProtocol(updateComponent.uri), updateComponent.payload); } deleteComponent(deleteComponent: DeleteComponentRequest): Observable { - // return throwError('API Error'); const revision: any = this.client.getRevision(deleteComponent.entity); return this.httpClient.delete(this.nifiCommon.stripProtocol(deleteComponent.uri), { params: revision }); } diff --git a/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/flow-designer/ui/canvas/items/port/create-port/create-port.component.html b/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/flow-designer/ui/canvas/items/port/create-port/create-port.component.html index 04feabd8f9..b214a166d2 100644 --- a/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/flow-designer/ui/canvas/items/port/create-port/create-port.component.html +++ b/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/flow-designer/ui/canvas/items/port/create-port/create-port.component.html @@ -17,7 +17,7 @@

Create New {{ portTypeLabel }}

- + {{ portTypeLabel }} Name diff --git a/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/flow-designer/ui/canvas/items/port/create-port/create-port.component.ts b/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/flow-designer/ui/canvas/items/port/create-port/create-port.component.ts index eb7a38c31f..926aa98daa 100644 --- a/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/flow-designer/ui/canvas/items/port/create-port/create-port.component.ts +++ b/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/flow-designer/ui/canvas/items/port/create-port/create-port.component.ts @@ -28,7 +28,7 @@ import { ComponentType, SelectOption, TextTipInput } from '../../../../../../../ import { MatInputModule } from '@angular/material/input'; import { MatSelectModule } from '@angular/material/select'; import { MatTooltipModule } from '@angular/material/tooltip'; -import { Banner } from '../../../../common/banner/banner.component'; +import { ErrorBanner } from '../../../../../../../ui/common/error-banner/error-banner.component'; import { AsyncPipe, NgForOf, NgIf } from '@angular/common'; import { MatButtonModule } from '@angular/material/button'; import { NifiSpinnerDirective } from '../../../../../../../ui/common/spinner/nifi-spinner.directive'; @@ -44,7 +44,7 @@ import { NifiTooltipDirective } from '../../../../../../../ui/common/tooltips/ni MatInputModule, MatSelectModule, MatTooltipModule, - Banner, + ErrorBanner, NgIf, NgForOf, MatButtonModule, diff --git a/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/flow-designer/ui/canvas/items/port/edit-port/edit-port.component.html b/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/flow-designer/ui/canvas/items/port/edit-port/edit-port.component.html index 9bb3faf242..2742b7170c 100644 --- a/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/flow-designer/ui/canvas/items/port/edit-port/edit-port.component.html +++ b/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/flow-designer/ui/canvas/items/port/edit-port/edit-port.component.html @@ -17,7 +17,7 @@

Edit {{ portTypeLabel }}

- +
diff --git a/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/flow-designer/ui/canvas/items/port/edit-port/edit-port.component.ts b/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/flow-designer/ui/canvas/items/port/edit-port/edit-port.component.ts index 94b68953d1..2fbe452dc4 100644 --- a/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/flow-designer/ui/canvas/items/port/edit-port/edit-port.component.ts +++ b/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/flow-designer/ui/canvas/items/port/edit-port/edit-port.component.ts @@ -24,7 +24,7 @@ import { updateComponent } from '../../../../../state/flow/flow.actions'; import { Client } from '../../../../../../../service/client.service'; import { EditComponentDialogRequest } from '../../../../../state/flow'; import { ComponentType } from '../../../../../../../state/shared'; -import { Banner } from '../../../../common/banner/banner.component'; +import { ErrorBanner } from '../../../../../../../ui/common/error-banner/error-banner.component'; import { MatInputModule } from '@angular/material/input'; import { MatCheckboxModule } from '@angular/material/checkbox'; import { MatButtonModule } from '@angular/material/button'; @@ -38,7 +38,7 @@ import { NifiSpinnerDirective } from '../../../../../../../ui/common/spinner/nif templateUrl: './edit-port.component.html', imports: [ ReactiveFormsModule, - Banner, + ErrorBanner, MatDialogModule, MatInputModule, MatCheckboxModule, @@ -68,10 +68,6 @@ export class EditPort { this.portTypeLabel = 'Output Port'; } - // TODO - consider updating the request to only provide the id of the port and selecting that item - // from the store. this would also allow us to be informed when another client has submitted an - // update to the same port which this editing is happening - // build the form this.editPortForm = this.formBuilder.group({ name: new FormControl(request.entity.component.name, Validators.required), diff --git a/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/flow-designer/ui/canvas/items/process-group/create-process-group/create-process-group.component.html b/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/flow-designer/ui/canvas/items/process-group/create-process-group/create-process-group.component.html index 6ce3fb0f78..965492caca 100644 --- a/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/flow-designer/ui/canvas/items/process-group/create-process-group/create-process-group.component.html +++ b/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/flow-designer/ui/canvas/items/process-group/create-process-group/create-process-group.component.html @@ -17,6 +17,7 @@

Create Process Group

+ Name diff --git a/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/flow-designer/ui/canvas/items/process-group/create-process-group/create-process-group.component.ts b/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/flow-designer/ui/canvas/items/process-group/create-process-group/create-process-group.component.ts index 74b8865aed..2caa01168e 100644 --- a/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/flow-designer/ui/canvas/items/process-group/create-process-group/create-process-group.component.ts +++ b/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/flow-designer/ui/canvas/items/process-group/create-process-group/create-process-group.component.ts @@ -24,7 +24,7 @@ import { createProcessGroup, uploadProcessGroup } from '../../../../../state/flo import { SelectOption, TextTipInput } from '../../../../../../../state/shared'; import { selectSaving } from '../../../../../state/flow/flow.selectors'; import { AsyncPipe, NgForOf, NgIf } from '@angular/common'; -import { Banner } from '../../../../common/banner/banner.component'; +import { ErrorBanner } from '../../../../../../../ui/common/error-banner/error-banner.component'; import { MatButtonModule } from '@angular/material/button'; import { MatFormFieldModule } from '@angular/material/form-field'; import { MatInputModule } from '@angular/material/input'; @@ -42,7 +42,7 @@ import { NiFiCommon } from '../../../../../../../service/nifi-common.service'; standalone: true, imports: [ AsyncPipe, - Banner, + ErrorBanner, MatButtonModule, MatDialogModule, MatFormFieldModule, diff --git a/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/flow-designer/ui/canvas/items/process-group/group-components/group-components.component.ts b/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/flow-designer/ui/canvas/items/process-group/group-components/group-components.component.ts index 690f03f3e4..84bd09f637 100644 --- a/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/flow-designer/ui/canvas/items/process-group/group-components/group-components.component.ts +++ b/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/flow-designer/ui/canvas/items/process-group/group-components/group-components.component.ts @@ -24,7 +24,6 @@ import { groupComponents } from '../../../../../state/flow/flow.actions'; import { ComponentType, SelectOption, TextTipInput } from '../../../../../../../state/shared'; import { selectSaving } from '../../../../../state/flow/flow.selectors'; import { AsyncPipe, NgForOf, NgIf } from '@angular/common'; -import { Banner } from '../../../../common/banner/banner.component'; import { MatButtonModule } from '@angular/material/button'; import { MatFormFieldModule } from '@angular/material/form-field'; import { MatInputModule } from '@angular/material/input'; @@ -42,7 +41,6 @@ import { Client } from '../../../../../../../service/client.service'; standalone: true, imports: [ AsyncPipe, - Banner, MatButtonModule, MatDialogModule, MatFormFieldModule, diff --git a/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/flow-designer/ui/canvas/items/processor/edit-processor/edit-processor.component.html b/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/flow-designer/ui/canvas/items/processor/edit-processor/edit-processor.component.html index 166f54860f..8a67cb245a 100644 --- a/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/flow-designer/ui/canvas/items/processor/edit-processor/edit-processor.component.html +++ b/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/flow-designer/ui/canvas/items/processor/edit-processor/edit-processor.component.html @@ -17,6 +17,7 @@

Edit Processor

+ diff --git a/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/flow-designer/ui/canvas/items/processor/edit-processor/edit-processor.component.spec.ts b/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/flow-designer/ui/canvas/items/processor/edit-processor/edit-processor.component.spec.ts index 18db2e5513..c181d773a3 100644 --- a/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/flow-designer/ui/canvas/items/processor/edit-processor/edit-processor.component.spec.ts +++ b/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/flow-designer/ui/canvas/items/processor/edit-processor/edit-processor.component.spec.ts @@ -22,6 +22,9 @@ import { EditComponentDialogRequest } from '../../../../../state/flow'; import { MAT_DIALOG_DATA } from '@angular/material/dialog'; import { ComponentType } from '../../../../../../../state/shared'; import { BrowserAnimationsModule } from '@angular/platform-browser/animations'; +import { Component } from '@angular/core'; +import { provideMockStore } from '@ngrx/store/testing'; +import { initialState } from '../../../../../../../state/error/error.reducer'; describe('EditProcessor', () => { let component: EditProcessor; @@ -719,10 +722,22 @@ describe('EditProcessor', () => { } }; + @Component({ + selector: 'error-banner', + standalone: true, + template: '' + }) + class MockErrorBanner {} + beforeEach(() => { TestBed.configureTestingModule({ - imports: [EditProcessor, BrowserAnimationsModule], - providers: [{ provide: MAT_DIALOG_DATA, useValue: data }] + imports: [EditProcessor, MockErrorBanner, BrowserAnimationsModule], + providers: [ + { provide: MAT_DIALOG_DATA, useValue: data }, + provideMockStore({ + initialState + }) + ] }); fixture = TestBed.createComponent(EditProcessor); component = fixture.componentInstance; diff --git a/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/flow-designer/ui/canvas/items/processor/edit-processor/edit-processor.component.ts b/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/flow-designer/ui/canvas/items/processor/edit-processor/edit-processor.component.ts index 6cb5893bd7..c494728d35 100644 --- a/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/flow-designer/ui/canvas/items/processor/edit-processor/edit-processor.component.ts +++ b/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/flow-designer/ui/canvas/items/processor/edit-processor/edit-processor.component.ts @@ -47,6 +47,7 @@ import { RelationshipConfiguration, RelationshipSettings } from './relationship-settings/relationship-settings.component'; +import { ErrorBanner } from '../../../../../../../ui/common/error-banner/error-banner.component'; @Component({ selector: 'edit-processor', @@ -68,7 +69,8 @@ import { NifiSpinnerDirective, NifiTooltipDirective, RunDurationSlider, - RelationshipSettings + RelationshipSettings, + ErrorBanner ], styleUrls: ['./edit-processor.component.scss'] }) diff --git a/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/login/feature/login.component.html b/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/login/feature/login.component.html index 81fb3394e3..3f6d3a7f34 100644 --- a/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/login/feature/login.component.html +++ b/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/login/feature/login.component.html @@ -23,12 +23,16 @@ - + +
{{ access.error.message }}
+
- + +
{{ access.accessStatus.message }}
+
@@ -36,11 +40,9 @@ - + +
This NiFi is not configured to support username/password logins.
+
diff --git a/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/login/feature/login.module.ts b/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/login/feature/login.module.ts index 339c933ede..9d317caa47 100644 --- a/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/login/feature/login.module.ts +++ b/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/login/feature/login.module.ts @@ -28,11 +28,11 @@ import { EffectsModule } from '@ngrx/effects'; import { loginFeatureKey, reducers } from '../state'; import { AccessEffects } from '../state/access/access.effects'; import { LoginForm } from '../ui/login-form/login-form.component'; -import { LoginMessage } from '../ui/login-message/login-message.component'; +import { PageContent } from '../../../ui/common/page-content/page-content.component'; import { NgxSkeletonLoaderModule } from 'ngx-skeleton-loader'; @NgModule({ - declarations: [Login, LoginForm, LoginMessage], + declarations: [Login, LoginForm], exports: [Login], imports: [ CommonModule, @@ -44,7 +44,8 @@ import { NgxSkeletonLoaderModule } from 'ngx-skeleton-loader'; MatFormFieldModule, MatInputModule, MatButtonModule, - NgxSkeletonLoaderModule + NgxSkeletonLoaderModule, + PageContent ] }) export class LoginModule {} diff --git a/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/login/ui/login-form/login-form.component.html b/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/login/ui/login-form/login-form.component.html index bad2efb042..7f5d6dc18e 100644 --- a/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/login/ui/login-form/login-form.component.html +++ b/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/src/app/pages/login/ui/login-form/login-form.component.html @@ -15,7 +15,7 @@ ~ limitations under the License. --> -