supprimer

This commit is contained in:
Vincent Ramiere 2022-03-21 18:32:20 +01:00
parent 8b00bb2ba3
commit 1f747c6933
4 changed files with 6134 additions and 6123 deletions

12219
db.json

File diff suppressed because it is too large Load Diff

View File

@ -15,7 +15,7 @@
</thead> </thead>
<tbody> <tbody>
<tr *ngFor="let products of listData"> <tr *ngFor="let products of listData">
<th scope="row">{{products.product_id}}</th> <th scope="row">{{products.id}}</th>
<td>{{products.product_name}}</td> <td>{{products.product_name}}</td>
<td>{{products.product_price}}</td> <td>{{products.product_price}}</td>
<td>{{products.product_qty}}</td> <td>{{products.product_qty}}</td>
@ -23,7 +23,7 @@
<td>{{products.product_breadcrumb_label}}</td> <td>{{products.product_breadcrumb_label}}</td>
<td>{{products.product_rating}}</td> <td>{{products.product_rating}}</td>
<td><a class="bi-pencil-square" routerLink="../modifier"></a></td> <td><a class="bi-pencil-square" routerLink="../modifier"></a></td>
<td class="bi-trash-fill" style="color: red; cursor: pointer;" (click)="onClickDelete(products.product_id)"></td> <td class="bi-trash-fill" style="color: red; cursor: pointer;" (click)="onClickDelete(products.id)"></td>
</tr> </tr>
</tbody> </tbody>
</table> </table>

View File

@ -1,4 +1,5 @@
import { Component, OnInit } from '@angular/core'; import { Component, OnInit } from '@angular/core';
import { Plant } from '../../models/plant';
import { AdminService } from '../../services/admin.service'; import { AdminService } from '../../services/admin.service';
@Component({ @Component({
@ -21,6 +22,9 @@ export class PageTableauComponent implements OnInit {
onClickDelete(id: number){ onClickDelete(id: number){
console.log(id); console.log(id);
this.adminService.onClickDelete(id).subscribe((resp) => {
console.log("Suppression successful : ", resp);
});
} }

View File

@ -1,19 +1,47 @@
import { HttpClient } from '@angular/common/http'; import { HttpClient } from '@angular/common/http';
import { Injectable } from '@angular/core'; import { Injectable } from '@angular/core';
import { Observable } from 'rxjs'; import { Observable, Subject, tap, map } from 'rxjs';
import { environment } from 'src/environments/environment'; import { environment } from 'src/environments/environment';
//import { map } from 'underscore';
import { Plant } from '../models/plant';
@Injectable({ @Injectable({
providedIn: 'root' providedIn: 'root'
}) })
export class AdminService { export class AdminService {
apiUrl: string; apiUrl: string;
public collection$!: Observable<Plant[]>;
public subCollection$ = new Subject<Plant[]>();
constructor(private httpClient: HttpClient) { constructor(private httpClient: HttpClient) {
this.apiUrl = environment.apiUrl; this.apiUrl = environment.apiUrl;
this.collection$ = this.httpClient.get<Plant[]>(`${this.apiUrl}/list_products`).pipe(
map((tabObj : any[]) => {
return tabObj.map((obj: any) => {
//return new Plant(obj)
return new Plant(obj.product_name, obj.product_price,obj.product_quantity,obj.product_instock,obj.product_breadcrumb_label,obj.product_image_source,obj.product_rating,obj.id)
})
})
);
}
public refreshCollection(): void {
// On se sert de notre flux de donnée type observable froid
this.collection$.subscribe((listPlant: Plant[]) => {
// Utiliser un observable chaud (subject) pour nexter nos données recues de notre observable froid
this.subCollection$.next(listPlant);
})
} }
getData(): Observable<any[]> { getData(): Observable<any[]> {
return this.httpClient.get<any[]>(`${this.apiUrl}/list_products`); return this.httpClient.get<any[]>(`${this.apiUrl}/list_products`);
} }
onClickDelete(id: number): Observable<any> {
return this.httpClient.delete<any>(`${this.apiUrl}/list_products/${id}`).pipe(
tap(() => this.refreshCollection())
);
}
} }