diff --git a/src/app/modules/admin/admin-routing.module.ts b/src/app/modules/admin/admin-routing.module.ts index e7225ab..ac27963 100644 --- a/src/app/modules/admin/admin-routing.module.ts +++ b/src/app/modules/admin/admin-routing.module.ts @@ -6,7 +6,7 @@ import { PageTableauComponent } from './pages/page-tableau/page-tableau.componen const routes: Routes = [ { path: '', redirectTo: 'tableau', pathMatch: 'full'}, - { path: 'modifier', component: PageModifierComponent }, + { path: 'modifier/:id', component: PageModifierComponent }, { path: 'ajouter', component: PageAjouterComponent }, { path: 'tableau', component: PageTableauComponent }, ]; diff --git a/src/app/modules/admin/components/formulaire/formulaire.component.html b/src/app/modules/admin/components/formulaire/formulaire.component.html index 0b8b45e..45bc618 100644 --- a/src/app/modules/admin/components/formulaire/formulaire.component.html +++ b/src/app/modules/admin/components/formulaire/formulaire.component.html @@ -1,126 +1,108 @@ -
-
- - -
-
- - -
-
- - -
-
- - -
-
- - -
-
- - -
- - - -
+
+
+
+ + +
+
+ + +
+
+ + +
+
+ + +
+
+ + +
+
+ + +
+ +
+
diff --git a/src/app/modules/admin/components/formulaire/formulaire.component.scss b/src/app/modules/admin/components/formulaire/formulaire.component.scss index e69de29..1b527e6 100644 --- a/src/app/modules/admin/components/formulaire/formulaire.component.scss +++ b/src/app/modules/admin/components/formulaire/formulaire.component.scss @@ -0,0 +1,75 @@ +.login-form { + height: 100vh; + padding-top: 40px; + background-color: #f5f5f5; +} + +.form-plant { + width: 100%; + max-width: 330px; + padding: 15px; + margin-top: 50px; + margin-left: auto; + margin-right: auto; + border: solid 1px; + border-radius: 10px; + background-color: #64c982; + border-color: #64c982; +} + +.form-plant .checkbox { + font-weight: 400; +} + +.form-plant .form-floating:focus-within { + z-index: 2; +} + +.form-plant input[type="email"] { + margin-bottom: 10px; + border-bottom-right-radius: 0; + border-bottom-left-radius: 0; +} + +.form-plant input[type="color"] { + border: none; + margin-bottom: 10px; + margin-top: -70px; + margin-left: 100px; + border-radius: 50%; + width: 100px; + height: 100px; +} + +.form-plant input[type="color"]::-webkit-color-swatch { + border: none; + margin-top: -15px; + border-radius: 80%; + width: 80px; + height: 80px; +} + +.form-plant input[type="text"] { + margin-bottom: 10px; + border-bottom-right-radius: 0; + border-bottom-left-radius: 0; +} + +.form-plant input[type="date"] { + margin-bottom: 10px; + border-bottom-right-radius: 0; + border-bottom-left-radius: 0; +} + +.form-plant input[type="password"] { + margin-bottom: 10px; + border-top-left-radius: 0; + border-top-right-radius: 0; +} + +.btn-outline-success { + margin-top: 10px; + background-color: #ffff; + color: #64c982 !important; + border-color: #64c982 !important; +} diff --git a/src/app/modules/admin/components/formulaire/formulaire.component.ts b/src/app/modules/admin/components/formulaire/formulaire.component.ts index d3730f6..5457afe 100644 --- a/src/app/modules/admin/components/formulaire/formulaire.component.ts +++ b/src/app/modules/admin/components/formulaire/formulaire.component.ts @@ -1,5 +1,7 @@ -import { Component, OnInit } from '@angular/core'; -import { FormGroup } from '@angular/forms'; +import { Component, Input, OnInit } from '@angular/core'; +import { FormBuilder, FormControl, FormGroup, Validators } from '@angular/forms'; +import { Plant } from '../../models/plant'; +import { AdminService } from '../../services/admin.service'; @Component({ selector: 'app-formulaire', @@ -8,10 +10,26 @@ import { FormGroup } from '@angular/forms'; }) export class FormulaireComponent implements OnInit { plantForm!: FormGroup; - constructor() {} + @Input() buttonLabel!: string; + @Input() plantInfos: any; + @Input() isAdd : boolean = true; - ngOnInit(): void {} + constructor(private formBuilder: FormBuilder) {} - onSubmit(){} + ngOnInit(): void { + this.plantForm = this.formBuilder.group( + { + nameFc: new FormControl(this.plantInfos.product_name, [Validators.required]), + priceFc: new FormControl(this.plantInfos.product_price, [Validators.required]), + quantityFc: new FormControl(this.plantInfos.product_quantity, [Validators.required]), + inStockFc: new FormControl(this.plantInfos.product_instock, [Validators.required]), + categoryFc: new FormControl(this.plantInfos.product_breadcrumb_label, [Validators.required]), + ratingFc: new FormControl(this.plantInfos.product_rating, [Validators.required]), + }); + } + + addPlant(){} + + updatePlant(){} } diff --git a/src/app/modules/admin/models/plant.ts b/src/app/modules/admin/models/plant.ts index e334571..5de6238 100644 --- a/src/app/modules/admin/models/plant.ts +++ b/src/app/modules/admin/models/plant.ts @@ -5,7 +5,7 @@ export class Plant { public name: string='', public price: number =1, public quantity: number= 0, - public instock: boolean= true, + public instock: string[]=['disponible', 'patriellement disponible', 'non disponible'], public category:Category, public urlPicture: string = "https//picsum.photos/id/18/200/300", public rating: number = 0, diff --git a/src/app/modules/admin/pages/page-modifier/page-modifier.component.html b/src/app/modules/admin/pages/page-modifier/page-modifier.component.html index 1c0ec6f..de5769d 100644 --- a/src/app/modules/admin/pages/page-modifier/page-modifier.component.html +++ b/src/app/modules/admin/pages/page-modifier/page-modifier.component.html @@ -1 +1,2 @@ -

page-modifier works!

+

Modifier la plante

+ diff --git a/src/app/modules/admin/pages/page-modifier/page-modifier.component.scss b/src/app/modules/admin/pages/page-modifier/page-modifier.component.scss index e69de29..8a0fa8b 100644 --- a/src/app/modules/admin/pages/page-modifier/page-modifier.component.scss +++ b/src/app/modules/admin/pages/page-modifier/page-modifier.component.scss @@ -0,0 +1,5 @@ +h1{ + color: rgba(0, 0, 0, 0.658); + font-size: 28px; + margin-top: 20px; +} diff --git a/src/app/modules/admin/pages/page-modifier/page-modifier.component.ts b/src/app/modules/admin/pages/page-modifier/page-modifier.component.ts index 70691bc..23a6585 100644 --- a/src/app/modules/admin/pages/page-modifier/page-modifier.component.ts +++ b/src/app/modules/admin/pages/page-modifier/page-modifier.component.ts @@ -1,4 +1,8 @@ import { Component, OnInit } from '@angular/core'; +import { FormBuilder, FormControl, FormGroup, Validators } from '@angular/forms'; +import { ActivatedRoute, Router } from '@angular/router'; +import { Plant } from '../../models/plant'; +import { AdminService } from '../../services/admin.service'; @Component({ selector: 'app-page-modifier', @@ -6,10 +10,72 @@ import { Component, OnInit } from '@angular/core'; styleUrls: ['./page-modifier.component.scss'] }) export class PageModifierComponent implements OnInit { + plantForm: FormGroup; + updatePlantForm: FormGroup; + plantInfos: any; + plantId: any; - constructor() { } + + + constructor(private adminService: AdminService, + private router: Router, + private fb: FormBuilder, + private route: ActivatedRoute) { + this.updatePlantForm = new FormGroup({}); + this.plantForm = this.initForm(); + } ngOnInit(): void { + /** Pour récuperer l'id de la plante à modifier **/ + this.plantId = this.route.snapshot.paramMap.get('id'); + + /** Appel Api **/ + this.adminService + .getPlantById(this.plantId) + .subscribe((plantInfos: any) => { + this.plantInfos = plantInfos; + console.log(this.plantInfos); + console.log(this.plantInfos.product_name); + }); + } + + /** Méthode qui initialise les champs du formulaire avec les infos du db Json **/ + private initForm(plant?: Plant): FormGroup { + + return this.fb.group({ + nom:[plant ? plant.name : ''], + price: [plant ? plant.price : ''], + quantity: [plant ? plant.quantity : ''], + category: [plant ? plant.category : ''], + rating: [plant ? plant.rating : ''], + inStock: [plant ? plant.instock : ['']], + }); + } + + + /** Méthode qui envoie les champs modifiés pour mise à jour **/ + public onSubmit(): void { + const nameValue = this.updatePlantForm.value['nameFc']; + const priceValue = this.updatePlantForm.value['priceFc']; + const ratingValue = this.updatePlantForm.value['ratingFc']; + const quantityValue = this.updatePlantForm.value['quantityFc']; + const categoryValue = this.updatePlantForm.value['categoryFc']; + const inStockValue = this.updatePlantForm.value['inStockFc']; + const urlPicture = "https//picsum.photos/id/18/200/300"; + + const plant: Plant = { + id: this.plantId, + name: nameValue, + price: priceValue, + quantity: quantityValue, + rating: ratingValue, + category: categoryValue, + instock: [inStockValue], + urlPicture + }; + this.adminService.updatePlant(plant)?.subscribe((resp) => { + this.router.navigate(['admin']); + }); } } diff --git a/src/app/modules/admin/pages/page-tableau/page-tableau.component.html b/src/app/modules/admin/pages/page-tableau/page-tableau.component.html index 1799f8b..f3617e7 100644 --- a/src/app/modules/admin/pages/page-tableau/page-tableau.component.html +++ b/src/app/modules/admin/pages/page-tableau/page-tableau.component.html @@ -20,9 +20,9 @@ {{products.price}} {{products.quantity}} {{products.instock}} - + {{products.category}} {{products.rating}} - + diff --git a/src/app/modules/admin/services/admin.service.ts b/src/app/modules/admin/services/admin.service.ts index c4d1aa5..5e70439 100644 --- a/src/app/modules/admin/services/admin.service.ts +++ b/src/app/modules/admin/services/admin.service.ts @@ -45,4 +45,13 @@ export class AdminService { // getData(): Observable { // return this.httpClient.get(`${this.apiUrl}/list_products`); // } + + /** Récupérer une plante par son Id **/ + getPlantById(id: any): Observable { + return this.httpClient.get(`${this.apiUrl}/list_products/${id}`); + } + /** Modifier Plante **/ + updatePlant(plant: Plant): Observable { + return this.httpClient.put(`${this.apiUrl}/list_products/${plant.id}`, plant); + } }