import { Injectable } from '@angular/core'; import { HttpResponse } from '@angular/common/http'; import { Resolve, ActivatedRouteSnapshot, RouterStateSnapshot, Routes } from '@angular/router'; import { UserRouteAccessService } from 'app/core'; import { Observable, of } from 'rxjs'; import { filter, map } from 'rxjs/operators'; import { Customer } from 'app/shared/model/customer.model'; import { CustomerService } from './customer.service'; import { CustomerComponent } from './customer.component'; import { CustomerDetailComponent } from './customer-detail.component'; import { CustomerUpdateComponent } from './customer-update.component'; import { CustomerDeletePopupComponent } from './customer-delete-dialog.component'; import { ICustomer } from 'app/shared/model/customer.model'; @Injectable({ providedIn: 'root' }) export class CustomerResolve implements Resolve { constructor(private service: CustomerService) {} resolve(route: ActivatedRouteSnapshot, state: RouterStateSnapshot): Observable { const id = route.params['id'] ? route.params['id'] : null; if (id) { return this.service.find(id).pipe( filter((response: HttpResponse) => response.ok), map((customer: HttpResponse) => customer.body) ); } return of(new Customer()); } } export const customerRoute: Routes = [ { path: '', component: CustomerComponent, data: { authorities: ['ROLE_USER'], pageTitle: 'hsadminNgApp.customer.home.title' }, canActivate: [UserRouteAccessService] }, { path: ':id/view', component: CustomerDetailComponent, resolve: { customer: CustomerResolve }, data: { authorities: ['ROLE_USER'], pageTitle: 'hsadminNgApp.customer.home.title' }, canActivate: [UserRouteAccessService] }, { path: 'new', component: CustomerUpdateComponent, resolve: { customer: CustomerResolve }, data: { authorities: ['ROLE_USER'], pageTitle: 'hsadminNgApp.customer.home.title' }, canActivate: [UserRouteAccessService] }, { path: ':id/edit', component: CustomerUpdateComponent, resolve: { customer: CustomerResolve }, data: { authorities: ['ROLE_USER'], pageTitle: 'hsadminNgApp.customer.home.title' }, canActivate: [UserRouteAccessService] } ]; export const customerPopupRoute: Routes = [ { path: ':id/delete', component: CustomerDeletePopupComponent, resolve: { customer: CustomerResolve }, data: { authorities: ['ROLE_USER'], pageTitle: 'hsadminNgApp.customer.home.title' }, canActivate: [UserRouteAccessService], outlet: 'popup' } ];