Как перезагрузить компонент обратно из дочернего маршрута? - PullRequest
0 голосов
/ 04 октября 2019

У меня проблема с кодом:

//routes
 const routes: Routes = [
  {path: '', component: HomeComponent},
  {path: 'users', component: UsersComponent,
    children: [
      {path: ':userId', component: UserComponent},
      {path: ':userId/edit', component: UserEditComponent}
    ]

  },
  {path: 'jobs', component: JobsComponent, 
    children:[
      {path: ':mainNumber', component: JobComponent},
      {path: ':mainNumber/edit', component: JobEditComponent}
    ]
  }

//jobs component ts:


import { Component, OnInit, Input } from '@angular/core';
import { JobService } from '../job.service';
import { Job } from '../model/job.model';
import { UsersService } from '../users/users.service';

import { Router, ActivatedRoute, Params } from '@angular/router';

@Component({
  selector: 'app-jobs',
  templateUrl: './jobs.component.html',
  styleUrls: ['./jobs.component.css']
})
export class JobsComponent implements OnInit {

  jobs: Job[];
  constructor(private jobService: JobService, private userService: UsersService, 
              private router: Router, private activatedRoute: ActivatedRoute) {}

  ngOnInit() {
    this.jobs = this.jobService.getJobs();

    this.activatedRoute.queryParams.subscribe((queryParams: Params)=>{
      if(queryParams['userId']){
        let userId = +queryParams['userId'];  
        this.jobs = this.jobService.getJobByUser(userId);       
      }
    });
  }

  onClick(maninNumber: number){

     this.router.navigate([maninNumber], {relativeTo: this.activatedRoute});

  }
}

//jobs component html:

<div class="container">
    <div class="row">
        <div class="col-md-7">
            <table class="table table-bordered">
                <thead>
                    <tr>
                        <th scope="col">Lp.</th>
                        <th scope="col">L. dz.</th>
                        <th scope="col">Rodzaj sprawy</th>
                        <th scope="col">Osoba prowadząca</th>
                        <th scope="col">Opis sprawy</th>
                        <th scope="col">Wnioskodawca</th>
                        <th scope="col">Status</th>
                    </tr>
                </thead>
                <tbody *ngFor="let job of jobs; let i = index;">
                    <tr clickOnRowDirective (click)="onClick(job.mainNumber)">
                        <th scope="row">{‌{ i + 1 }}</th>
                        <td>{‌{ job.caseNr }}</td>
                        <td>{‌{ job.caseType }}</td>
                        <td>{‌{ job.fullName }}</td>
                        <td>{‌{ job.what }}</td>
                        <td>{‌{ job.who }}</td>
                        <td>{‌{ job.status }}</td>            
                    </tr>
                </tbody>
            </table>
        </div>
        <div class="col-md-5">
            <router-outlet></router-outlet>
        </div>
    </div>
</div>

//app component

<div class="container">
  <h3 class="p-3">jaobAssist</h3>
  <ul class="nav nav-tabs justify-content-left">
    <li class="nav-item">
      <a class="nav-link" 
      [routerLink]="['/']"
      routerLinkActive="active"
      [routerLinkActiveOptions]="{exact:true}">
      Menu</a>
    </li>
    <li class="nav justify-content-center">
      <a class="nav-link" 
        [routerLink]="['/users']"
        routerLinkActive="active">
        Użytkownicy</a>
    </li>
    <li class="nav justify-content-center">
      <a class="nav-link"
      [routerLink]="['/jobs']"
      routerLinkActive="active">
      Sprawy</a>
    </li>
  </ul>
  <router-outlet></router-outlet>
</div>

Предположения проекта:

  1. Компонент задания отображает все объекты задания в таблице.

  2. Объекты заданий можно фильтровать с помощью параметра userId. В этом случае я получаю все задания указанного пользователя, отраженные в JobsComponent (путь: / jobs? UserId = 1). Можно щелкнуть по одному объекту задания (строка в таблице), что переключает навигацию на страницу, например, / jobs / 1481 (один JobComponent отображается в JobComponent html с помощью функции маршрутизатора-выхода)

Здесьвопрос.

Когда я нахожусь на одном из дочерних путей, указанных выше (например, / jobs? userId = 1 / jobs / 1788), и я хочу вернуться к / jobs (нажав nav-tabs: [routerLink] = "['/ jobs']"), который при вводе отображает все объекты заданий, происходит перенаправление на / jobs, но я получил то же представление о JobsComponent, содержащем отфильтрованные объекты.

Как добитьсяфункциональность, чтобы перезагрузить все объекты заданий и воспроизвести его?

Заранее спасибо

...