Angular 7 - изменить базовый URL-адрес одного компонента внутри маршрутов
Все мои маршруты идут во множественном числе builder-jobs/
но я хотел бы знать, могу ли я изменить один, чтобы перейти на builder-job/:id
но оставьте остальное как builder-jobs
Это мой текущий файл модуля - builder-jobs.module.ts
:
import { NgModule } from '@angular/core';
import { CommonModule } from '@angular/common';
import { Routes, RouterModule } from '@angular/router';
import { BuilderJobModule } from '@/modules/builder-jobs/builder-job.module';
import {
QualityInspectionAddComponent,
QualityInspectionViewComponent,
SafetyInspectionAddComponent,
SafetyInspectionViewComponent,
} from '@/modules/jobs/job.module';
import { AuthGuard } from '@/guards/auth/auth.guard';
import { Role } from '@/models/role';
import { BuilderJobsCalendarComponent } from './builder-jobs-calendar/builder-jobs-calendar.component';
import { BuilderJobsViewComponent } from './builder-jobs-view/builder-jobs-view.component';
import { BuilderJobsAddComponent } from './builder-jobs-add/builder-jobs-add.component';
import { BuilderJobComponent } from './builder-job/builder-job.component';
export const routes: Routes = [
{
path: 'view',
component: BuilderJobsViewComponent,
canActivate: [AuthGuard],
data: { roles: [Role.Admin, Role.Supervisor, Role.CrewLeader] }
},
{
path: 'add',
component: BuilderJobsAddComponent,
canActivate: [AuthGuard],
data: { roles: [Role.Admin] }
},
{
path: 'calendar',
component: BuilderJobsCalendarComponent,
canActivate: [AuthGuard],
data: { roles: [Role.Admin, Role.Supervisor] }
},
{
path: ':id',
canActivate: [AuthGuard],
component: BuilderJobComponent,
data: { roles: [Role.Admin, Role.Supervisor, Role.CrewLeader] }
},
{
path: ':id/safety-inspection/:checklist_id',
canActivate: [AuthGuard],
component: SafetyInspectionViewComponent
},
{
path: ':id/safety-inspection-add',
canActivate: [AuthGuard],
component: SafetyInspectionAddComponent
},
{
path: ':id/quality-inspection/:checklist_id',
canActivate: [AuthGuard],
component: QualityInspectionViewComponent
},
{
path: ':id/quality-inspection-add',
canActivate: [AuthGuard],
component: QualityInspectionAddComponent
},
{
path: '',
redirectTo: '/builder-jobs/view',
pathMatch: 'full'
},
{
path: '**',
redirectTo: '/builder-jobs/view',
pathMatch: 'full'
}
];
@NgModule({
declarations: [
BuilderJobsCalendarComponent,
BuilderJobsViewComponent,
BuilderJobsAddComponent,
BuilderJobComponent,
],
imports: [
CommonModule,
BuilderJobModule,
RouterModule.forChild(routes),
],
})
export class BuilderJobsModule { }
Я хочу изменить конкретный маршрут:
{
path: ':id',
canActivate: [AuthGuard],
component: BuilderJobComponent,
data: { roles: [Role.Admin, Role.Supervisor, Role.CrewLeader] }
},
Я попытался path: 'builder-job/:id'
но это, похоже, не работает - переходит на 404
вот мой app-routing.module.ts
import { NgModule } from '@angular/core';
import { Routes, RouterModule, PreloadAllModules} from '@angular/router';
import { AuthGuard } from '@/guards/auth/auth.guard';
import { DashboardComponent } from '@/views/dashboard/dashboard.component';
import { PageNotFoundComponent } from '@/views/page-not-found/page-not-found.component';
import { LoginComponent } from '@/views/login/login.component';
import { PasswordResetComponent } from '@/views/password-reset/password-reset.component';
import { NewPasswordComponent } from '@/views/new-password/new-password.component';
import { Role } from '@/models/role';
const routes: Routes = [
{
path: 'incidents',
canActivate: [AuthGuard],
loadChildren: () => import('@/views/incidents/incidents.module').then(mod => mod.IncidentsModule)
},
{
path: 'dashboard',
canActivate: [AuthGuard],
loadChildren: () => import('@/views/dashboard/dashboard.module').then(mod => mod.DashboardModule)
},
{
path: 'builders',
canActivate: [AuthGuard],
loadChildren: () => import('@/views/builders/builders.module').then(mod => mod.BuildersModule),
},
{
path: 'communities',
canActivate: [AuthGuard],
loadChildren: () => import('@/views/communities/communities.module').then(mod => mod.CommunitiesModule),
data: { roles: [Role.Admin, Role.Supervisor, Role.CrewLeader] }
},
{
path: 'reroof-jobs',
loadChildren: () => import('@/views/reroof-jobs/reroof-jobs.module').then(mod => mod.ReroofJobsModule),
canActivate: [AuthGuard],
data: { roles: [Role.Admin] }
},
{
path: 'builder-jobs',
canActivate: [AuthGuard],
loadChildren: () => import('@/views/builder-jobs/builder-jobs.module').then(mod => mod.BuilderJobsModule),
data: { roles: [Role.Admin, Role.Supervisor, Role.CrewLeader] }
},
{
path: 'repair-jobs',
canActivate: [AuthGuard],
loadChildren: () => import('@/views/repair-jobs/repair-jobs.module').then(mod => mod.RepairJobsModule),
data: { roles: [Role.Admin, Role.Supervisor, Role.CrewLeader] }
},
{
path: 'warranty-jobs',
canActivate: [AuthGuard],
loadChildren: () => import('@/views/warranty-jobs/warranty-jobs.module').then(mod => mod.WarrantyJobsModule),
data: { roles: [Role.Admin, Role.Supervisor, Role.CrewLeader] }
},
{
path: 'employees',
canActivate: [AuthGuard],
loadChildren: () => import('@/views/employees/employees.module').then(mod => mod.EmployeesModule),
data: { roles: [Role.Admin, Role.Supervisor] }
},
{
path: 'contacts',
canActivate: [AuthGuard],
loadChildren: () => import('@/views/contacts/contacts.module').then(mod => mod.ContactsModule),
data: { roles: [Role.Admin, Role.Supervisor] }
},
{
path: 'users',
canActivate: [AuthGuard],
loadChildren: () => import('@/views/users/users.module').then(mod => mod.UsersModule),
data: { roles: [Role.Admin, Role.Supervisor] }
},
{
path: 'time-entries',
canActivate: [AuthGuard],
loadChildren: () => import('@/views/time/time.module').then(mod => mod.TimeModule),
data: { roles: [Role.Admin, Role.Supervisor, Role.CrewLeader] }
},
{
path: 'alerts',
canActivate: [AuthGuard],
loadChildren: () => import('@/views/alerts/alerts.module').then(mod => mod.AlertsModule),
data: { roles: [Role.Admin, Role.Supervisor, Role.CrewLeader] }
},
{
path: 'login',
component: LoginComponent
},
{
path: 'password-reset',
component: PasswordResetComponent
},
{
path: 'new-password',
component: NewPasswordComponent
},
{
path: '',
redirectTo: '/dashboard',
pathMatch: 'full'
},
{
path: '',
component: DashboardComponent,
canActivate: [AuthGuard],
children: [
{
path: '',
canActivateChild: [AuthGuard],
children: []
}
]
},
{
path: '**',
component: PageNotFoundComponent
}
];
@NgModule({
imports: [
RouterModule.forRoot( routes )
],
exports: [
RouterModule
],
})
export class AppRoutingModule { }