У меня есть компонент с именем customers(dialog window)
, внутри него есть 2 компонента с именем list и display , Из компонента list я буду выдвигать некоторый объектк таблице , присутствующей в компоненте display , например:
КОД КОМПОНЕНТОВ:
list.component.html
<h3>List</h3>
<form [formGroup]="addListForm">
<mat-form-field>
<mat-select formControlName="CustomerIds" placeholder="Select Customer" multiple>
<mat-option *ngFor="let customer of customers" [value]="customer" >
{{customer.name}}
</mat-option>
</mat-select>
</mat-form-field>
<br>
<button (click)="onAdd()">Add</button>
</form>
list.component.ts
import {Component, OnInit } from '@angular/core';
import { FormBuilder,FormGroup } from '@angular/forms';
import { ContactService } from '../contacts.service';
import { MatOptionSelectionChange } from '@angular/material';
import { ICustomer } from '../models';
import { DataService } from '../data.service';
@Component({
selector: 'app-list',
templateUrl: './list.component.html',
styleUrls: ['./list.component.css']
})
export class ListComponent implements OnInit {
public customers: ICustomer;
public someCustomer: ICustomer;
public addListForm: FormGroup;
constructor(private fb: FormBuilder,
private myService: ContactService,
public dataService: DataService) { }
public async ngOnInit(): Promise<void> {
this.addListForm = this.fb.group({
CustomerIds: [null],
});
this.customers = await this.myService.getCustomers('');
}
public async selected(event: MatOptionSelectionChange, customer: ICustomer): Promise<void> {
this.myService.onCustomerSelect.next(customer);
}
public onAdd(): void {
this.someCustomer = this.addListForm.value;
this.dataService.onSelectCustomer.next(this.someCustomer);
}
}
display.component.html
<table mat-table [dataSource]="selectedCustomers?.CustomerIds" >
.....
</table>
display.component.ts
import {Component, OnInit } from '@angular/core';
import { FormBuilder,FormGroup } from '@angular/forms';
import { ICustomer } from '../models';
import { DataService } from '../data.service';
@Component({
selector: 'app-display',
templateUrl: './display.component.html',
styleUrls: ['./display.component.css']
})
export class DisplayComponent implements OnInit {
public contacts: ICustomer;
public selectedCustomers: any;
public displayForm: FormGroup;
public addCustomer: any;
public displayedColumns: string[] = ['name', 'email', 'phone', 'button'];
constructor(private fb: FormBuilder,public dataService: DataService) { }
public async ngOnInit(): Promise<void> {
this.displayForm = this.fb.group({
});
this.dataService.onSelectCustomer.subscribe(value => {
this.selectedCustomers = value;
});
}
}
Теперь я вытолкну несколько объектов (клиентов) из списка компонент отображение компонента, и я закрою диалоговое окно. Если я снова открою диалоговое окно, данные таблицы должны быть очищены без каких-либо ранее выдвинутых данных из списка компонента. Как я могуочистить кеш таблицы?
Stackblitz DEMO