Merge branch 'dev' into sana
This commit is contained in:
commit
7784870446
13 changed files with 309 additions and 91 deletions
|
@ -1,6 +1,5 @@
|
|||
import { NgModule } from '@angular/core';
|
||||
import { NgModule, LOCALE_ID } from '@angular/core';
|
||||
import { BrowserModule } from '@angular/platform-browser';
|
||||
|
||||
import { AppRoutingModule } from './app-routing.module';
|
||||
import { AppComponent } from './app.component';
|
||||
import { PageAccueilComponent } from './pages/page-accueil/page-accueil.component';
|
||||
|
@ -40,6 +39,9 @@ import { FooterComponent } from './components/footer/footer.component';
|
|||
import { PageDeleteAccountComponent } from './pages/page-delete-account/page-delete-account.component';
|
||||
import { PageUpdateAccountComponent } from './pages/page-update-account/page-update-account.component';
|
||||
import { DayPilot, DayPilotModule } from "@daypilot/daypilot-lite-angular";
|
||||
import { registerLocaleData } from '@angular/common';
|
||||
import localeFr from '@angular/common/locales/fr';
|
||||
registerLocaleData(localeFr)
|
||||
|
||||
@NgModule({
|
||||
declarations: [
|
||||
|
@ -78,6 +80,7 @@ import { DayPilot, DayPilotModule } from "@daypilot/daypilot-lite-angular";
|
|||
FooterComponent,
|
||||
PageDeleteAccountComponent,
|
||||
PageUpdateAccountComponent,
|
||||
|
||||
],
|
||||
imports: [
|
||||
BrowserModule,
|
||||
|
@ -86,9 +89,10 @@ import { DayPilot, DayPilotModule } from "@daypilot/daypilot-lite-angular";
|
|||
HttpClientModule,
|
||||
FormsModule,
|
||||
AutofocusFixModule.forRoot(),
|
||||
DayPilotModule
|
||||
DayPilotModule,
|
||||
],
|
||||
providers: [
|
||||
{provide: LOCALE_ID, useValue: "fr-FR" }
|
||||
|
||||
],
|
||||
bootstrap: [AppComponent],
|
||||
|
|
|
@ -1,46 +1,135 @@
|
|||
<div class="menu">
|
||||
<div *ngFor="let menu of listMenus">
|
||||
<p>{{ menu.dateMenu }} {{ menu.libelle }}</p>
|
||||
</div>
|
||||
|
||||
<ng-template #content let-modal>
|
||||
<div class="modal-header">
|
||||
<h4 class="modal-title" id="modal-basic-title">
|
||||
Ajouter un menu
|
||||
</h4>
|
||||
<button type="button" class="close" aria-label="Close" (click)="modal.dismiss('Cross click')">
|
||||
|
||||
<span aria-hidden="true">
|
||||
×
|
||||
</span>
|
||||
<h4 class="modal-title" id="modal-basic-title">Ajouter un menu</h4>
|
||||
<button
|
||||
type="button"
|
||||
class="close"
|
||||
aria-label="Close"
|
||||
(click)="modal.dismiss('Cross click')"
|
||||
>
|
||||
<span aria-hidden="true"> × </span>
|
||||
</button>
|
||||
</div>
|
||||
<div class="modal-body">
|
||||
<form [formGroup]="menuForm">
|
||||
<div class="form-group">
|
||||
<label for="dateMenu">
|
||||
Date
|
||||
</label>
|
||||
<div class="input-group">
|
||||
<input id="dateMenu" class="form-control" formControlName="dateMenuFc" placeholder="yyyy-mm-dd" name="date"
|
||||
>
|
||||
<input id="libelle" class="form-control" formControlName="libelleFc" placeholder="" name="libelle"
|
||||
>
|
||||
<input
|
||||
type="date"
|
||||
id="dateMenu"
|
||||
class="form-control"
|
||||
formControlName="dateMenuFc"
|
||||
placeholder="Date"
|
||||
name="date"
|
||||
/>
|
||||
|
||||
<input
|
||||
id="repasMidi"
|
||||
class="form-control"
|
||||
formControlName="repasMidiFc"
|
||||
placeholder="Repas du midi"
|
||||
name="repasMidi"
|
||||
/>
|
||||
|
||||
<input
|
||||
id="repasSoir"
|
||||
class="form-control"
|
||||
formControlName="repasSoirFc"
|
||||
placeholder="Repas du soir"
|
||||
name="repasSoir"
|
||||
/>
|
||||
</div>
|
||||
</div>
|
||||
</form>
|
||||
</div>
|
||||
<div class="modal-footer">
|
||||
<button type="button" class="btn btn-outline-dark" (click)="modal.close(saveMenu())">
|
||||
Save
|
||||
<button
|
||||
type="button"
|
||||
class="btn btn-outline-dark"
|
||||
(click)="modal.close(saveMenu())"
|
||||
>
|
||||
Enregistrer
|
||||
</button>
|
||||
</div>
|
||||
</ng-template>
|
||||
|
||||
<button class="btn btn-lg btn-outline-primary" (click)="open(content)">
|
||||
Ajouter un menu
|
||||
<button type="button" class="btn btn-outline-warning" (click)="open(content)">
|
||||
Ajouter un menu
|
||||
</button>
|
||||
|
||||
|
||||
|
||||
<div class="container mt-5 menu">
|
||||
<div class="row d-flex justify-content-center">
|
||||
<div class="col-md-auto" *ngFor="let menu of listMenus">
|
||||
<div class="card p-3 py-4 align-items" style="width: 14rem">
|
||||
<p class="jour">{{ menu.dateMenu | date: "EEEE":"fr" }}</p>
|
||||
<div class="tag">
|
||||
<p class="repas">Midi</p>
|
||||
<p>{{ menu.repasMidi }}</p>
|
||||
</div>
|
||||
<div class="tag">
|
||||
<p class="repas">Soir</p>
|
||||
<p>{{ menu.repasSoir }}</p>
|
||||
</div>
|
||||
<ng-template #content let-modal>
|
||||
<div class="modal-header">
|
||||
<h4 class="modal-title" id="modal-basic-title">
|
||||
Mettre à jour un menu
|
||||
</h4>
|
||||
<button
|
||||
type="button"
|
||||
class="close"
|
||||
aria-label="Close"
|
||||
(click)="modal.dismiss('Cross click')"
|
||||
>
|
||||
<span aria-hidden="true"> × </span>
|
||||
</button>
|
||||
</div>
|
||||
<div class="modal-body">
|
||||
<form [formGroup]="upMenuForm">
|
||||
<div class="form-group">
|
||||
<div class="input-group">
|
||||
<input
|
||||
type="date"
|
||||
id="dateMenu"
|
||||
class="form-control"
|
||||
formControlName="dateMenuFc"
|
||||
value="{{ menu.dateMenu }}"
|
||||
placeholder="Date"
|
||||
name="date"
|
||||
/>
|
||||
<input
|
||||
id="repasMidi"
|
||||
class="form-control"
|
||||
formControlName="repasMidiFc"
|
||||
value="{{ menu.repasMidi }}"
|
||||
placeholder="Repas du midi"
|
||||
name="repasMidi"
|
||||
/>
|
||||
<input
|
||||
id="repasSoir"
|
||||
class="form-control"
|
||||
formControlName="repasSoirFc"
|
||||
value="{{ menu.repasSoir }}"
|
||||
placeholder="Repas du soir"
|
||||
name="repasSoir"
|
||||
/>
|
||||
</div>
|
||||
</div>
|
||||
</form>
|
||||
</div>
|
||||
<div class="modal-footer">
|
||||
<button
|
||||
type="button"
|
||||
class="btn btn-outline-dark"
|
||||
(click)="modal.close(updateMenu(menu.id))"
|
||||
>
|
||||
Mettre à jour
|
||||
</button>
|
||||
</div>
|
||||
</ng-template>
|
||||
<i class="bi bi-pencil-square" (click)="open(content)"></i>
|
||||
<i class="bi bi-trash3" (click)="deleteMenu(menu.id)"></i>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
|
|
@ -1,3 +1,36 @@
|
|||
.menu {
|
||||
margin-left: 500px;
|
||||
.card {
|
||||
min-height: 22rem;
|
||||
margin-left: 75px;
|
||||
margin-bottom: 30px;
|
||||
border: 1px solid #f7c02b;
|
||||
border-radius: 8px;
|
||||
position: relative;
|
||||
overflow: hidden;
|
||||
box-shadow: 5px 5px 5px gray;
|
||||
}
|
||||
|
||||
.tag {
|
||||
margin-top: 20px;
|
||||
background-color: #fad980;
|
||||
margin-left: -8px;
|
||||
width: 13rem;
|
||||
border: 1px solid #fad980;
|
||||
border-radius: 8px;
|
||||
}
|
||||
.bi {
|
||||
margin-top: 10px;
|
||||
}
|
||||
|
||||
.btn {
|
||||
margin-top: 10px;
|
||||
color: black;
|
||||
box-shadow: 5px 5px 5px gray;
|
||||
}
|
||||
|
||||
.jour {
|
||||
font-weight: bolder;
|
||||
font-size: 25px;
|
||||
}
|
||||
.repas {
|
||||
font-weight: bold;
|
||||
}
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
import { Component, OnInit } from '@angular/core';
|
||||
import { Component, Input, OnInit } from '@angular/core';
|
||||
import { ActivatedRoute, Router } from '@angular/router';
|
||||
import { Menu } from 'src/app/models/menu';
|
||||
import { MenusService } from 'src/app/services/menus.service';
|
||||
|
@ -22,6 +22,8 @@ closeResult = '';
|
|||
public listMenus:any[];
|
||||
public menuId : any;
|
||||
public menuForm : FormGroup;
|
||||
public upMenuForm : FormGroup;
|
||||
|
||||
|
||||
constructor(
|
||||
private menusService: MenusService,
|
||||
|
@ -31,32 +33,77 @@ public menuForm : FormGroup;
|
|||
private fb: FormBuilder
|
||||
) {
|
||||
this.listMenus=[];
|
||||
this.menuId=0;
|
||||
this.menuForm = new FormGroup({});
|
||||
}
|
||||
this.upMenuForm = this.initForm();
|
||||
}
|
||||
|
||||
//delete d'un menu
|
||||
deleteMenu(id_menu : number): void {
|
||||
window.alert("Le menu a bien été supprimé!")
|
||||
this.menusService.deleteMenu(id_menu)?.subscribe((resp) => {
|
||||
this.router.navigate(['menu']);
|
||||
});
|
||||
|
||||
}
|
||||
|
||||
//updateMenu
|
||||
updateMenu(id_menu : number): void {
|
||||
|
||||
const dateValue = this.menuForm.value['dateMenuFc'];
|
||||
const repasMidiValue = this.menuForm.value['repasMidiFc'];
|
||||
const repasSoirValue = this.menuForm.value['repasSoirFc'];
|
||||
|
||||
|
||||
const menu: Menu = {
|
||||
dateMenu: dateValue,
|
||||
repasMidi: repasMidiValue,
|
||||
repasSoir: repasSoirValue,
|
||||
id: 0
|
||||
};
|
||||
|
||||
console.log(id_menu);
|
||||
|
||||
this.menusService.updateMenu(menu, id_menu)?.subscribe((resp) => {
|
||||
console.log("ok");
|
||||
this.router.navigate(['menu']);
|
||||
});
|
||||
}
|
||||
|
||||
//Méthode qui initialise les champs du formulaire avec les infos de la BDD
|
||||
private initForm(menu?: Menu): FormGroup {
|
||||
return this.fb.group({
|
||||
dateMenu: [menu ? menu.dateMenu : ''],
|
||||
libelle: [menu ? menu.repasMidi : ''],
|
||||
repas: [menu ? menu.repasSoir : ''],
|
||||
|
||||
});
|
||||
}
|
||||
|
||||
|
||||
//ajout d'un menu
|
||||
saveMenu(): void {
|
||||
|
||||
const dateValue = this.menuForm.value['dateMenuFc'];
|
||||
const libelleValue = this.menuForm.value['libelleFc'];
|
||||
const repasMidiValue = this.menuForm.value['repasMidiFc'];
|
||||
const repasSoirValue = this.menuForm.value['repasSoirFc'];
|
||||
|
||||
|
||||
const menu: Menu = {
|
||||
dateMenu: dateValue,
|
||||
libelle: libelleValue,
|
||||
repasMidi: repasMidiValue,
|
||||
repasSoir: repasSoirValue,
|
||||
id: 0
|
||||
};
|
||||
|
||||
// if (menu.dateMenu != undefined && menu.libelle != '') {
|
||||
if (menu.dateMenu !=='') {
|
||||
|
||||
console.log(dateValue);
|
||||
console.log(menu.dateMenu);
|
||||
this.menusService.addMenu(menu)?.subscribe((resp) => {
|
||||
this.router.navigate(['menu']);
|
||||
});
|
||||
// } else {
|
||||
// this.router.navigate(['menu']);
|
||||
// }
|
||||
} else {
|
||||
this.router.navigate(['accueil']);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
@ -66,12 +113,15 @@ saveMenu(): void {
|
|||
this.menusService.getMenu()?.subscribe((listMenus: any[])=>{
|
||||
console.log(listMenus);
|
||||
this.listMenus=listMenus;
|
||||
|
||||
});
|
||||
|
||||
|
||||
this.menuForm = this.fb.group(
|
||||
{
|
||||
dateMenuFc: new FormControl('',[Validators.required]),
|
||||
libelleFc: new FormControl('',[Validators.required]),
|
||||
repasFc: new FormControl('',[Validators.required]),
|
||||
}
|
||||
);
|
||||
}
|
||||
|
@ -99,11 +149,3 @@ open(content: any) {
|
|||
|
||||
|
||||
|
||||
//modif d'un menu
|
||||
// this.menuId=this.route.snapshot.paramMap.get('id');
|
||||
// this.menusService.getMenuById(this.menuId)
|
||||
// .subscribe((this.listMenus:any)=>)
|
||||
|
||||
//delete d'un menu
|
||||
|
||||
|
||||
|
|
|
@ -2,6 +2,8 @@ import { Membre } from './membre';
|
|||
import { Team } from './team';
|
||||
|
||||
export interface Menu {
|
||||
libelle: string;
|
||||
dateMenu: Date;
|
||||
dateMenu: string;
|
||||
repasMidi: string;
|
||||
repasSoir: string;
|
||||
id: number;
|
||||
}
|
||||
|
|
|
@ -1,9 +1,32 @@
|
|||
<app-header></app-header>
|
||||
<app-side-bar></app-side-bar>
|
||||
<app-meteo></app-meteo>
|
||||
|
||||
<div class="container">
|
||||
|
||||
<div>
|
||||
<h3 class="titre">Bienvenue {{conectedUser.prenom}}!!</h3>
|
||||
</div>
|
||||
|
||||
<div class="row d-flex align-items-center flex-row">
|
||||
|
||||
<div class="col-4">
|
||||
<div class="flex-row border">
|
||||
<app-meteo></app-meteo>
|
||||
</div>
|
||||
<div class="flex-row border">
|
||||
<span>Humeur en attente component</span>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="col-8 border">
|
||||
<app-calendrier>A venir</app-calendrier>
|
||||
</div>
|
||||
|
||||
</div>
|
||||
|
||||
|
||||
<div class="d-flex justify-content-center">
|
||||
<button button type="button" class="btn btn-primary btn-lg" routerLink="../creation-team"
|
||||
routerLinkActive="active-custom">Créer ma team</button>
|
||||
</div>
|
||||
<div class="row">
|
||||
<app-card-member>A modifier</app-card-member>
|
||||
</div>
|
||||
|
||||
</div>
|
|
@ -1,5 +1,22 @@
|
|||
.titre{
|
||||
text-align: center;
|
||||
font-weight: bold;
|
||||
}
|
||||
|
||||
.meteo {
|
||||
display: flex;
|
||||
margin-left: 300px;
|
||||
margin-left: 500px;
|
||||
margin-top: -60px;
|
||||
}
|
||||
|
||||
.container {
|
||||
display: flex;
|
||||
padding: 10px;
|
||||
border: 1px solid 8c2e9b;
|
||||
}
|
||||
|
||||
|
||||
|
||||
.calendrier{
|
||||
align-content: flex-end;
|
||||
}
|
|
@ -1,4 +1,8 @@
|
|||
import { HttpClient } from '@angular/common/http';
|
||||
import { Component, OnInit } from '@angular/core';
|
||||
import { Router } from '@angular/router';
|
||||
import { MembreService } from 'src/app/services/membre.service';
|
||||
import { TokenService } from 'src/app/services/token.service';
|
||||
|
||||
@Component({
|
||||
selector: 'app-page-dashboard',
|
||||
|
@ -7,9 +11,26 @@ import { Component, OnInit } from '@angular/core';
|
|||
})
|
||||
export class PageDashboardComponent implements OnInit {
|
||||
|
||||
constructor() { }
|
||||
conectedUser: any;
|
||||
|
||||
ngOnInit(): void {
|
||||
constructor(private membreService: MembreService,
|
||||
private http: HttpClient,
|
||||
private router: Router,
|
||||
private tokenService: TokenService) {
|
||||
}
|
||||
|
||||
ngOnInit(): void {
|
||||
this.membreService.getMembreId(this.tokenService.getCurrentMembreId()).subscribe((result) => {
|
||||
this.conectedUser = result ;
|
||||
console.log(result);
|
||||
})
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
// récuperer l id du membre s=qui est connecté
|
||||
//recuperer l id dans le token grace au user id du getCurrentMembreId
|
||||
// placer ce userId dans la methode getMembreId a la place de l id
|
||||
//********************************************************************
|
||||
}
|
||||
|
|
|
@ -1,29 +1,12 @@
|
|||
<app-header></app-header>
|
||||
<div class="row">
|
||||
<div class="col-md-auto">
|
||||
<app-side-bar></app-side-bar>
|
||||
<app-side-bar class="sidebarMenu"></app-side-bar>
|
||||
</div>
|
||||
<div class=" col compte text-center">
|
||||
<h1>Menu de la semaine</h1>
|
||||
<main class="contenu-compte">
|
||||
<div class="col menu text-center">
|
||||
<h2>Menu de la semaine</h2>
|
||||
<main class="contenu-menu">
|
||||
<app-card-menu></app-card-menu>
|
||||
<div class="d-flex justify-content-center">
|
||||
|
||||
</div>
|
||||
<div class="d-flex justify-content-center">
|
||||
|
||||
</div>
|
||||
<div class="d-flex justify-content-center">
|
||||
|
||||
</div>
|
||||
<div class="d-flex justify-content-center">
|
||||
|
||||
</div>
|
||||
<div class="d-flex justify-content-center">
|
||||
|
||||
</div>
|
||||
<div class="d-flex justify-content-center">
|
||||
|
||||
</div>
|
||||
</main>
|
||||
</div>
|
||||
</div>
|
||||
|
|
|
@ -21,12 +21,11 @@ export class MembreService {
|
|||
}
|
||||
|
||||
getMembreId(id: any): Observable<any> {
|
||||
return this.http.get(`${this.apiUrl}/membres/1` + id);
|
||||
return this.http.get(`${this.apiUrl}/membres/` + id);
|
||||
}
|
||||
|
||||
addMembre(membre: Membre): Observable<any> {
|
||||
console.log(membre);
|
||||
|
||||
return this.http.post(`${this.apiUrl}/membres/sign-up`, membre);
|
||||
}
|
||||
|
||||
|
|
|
@ -44,13 +44,17 @@ apiUrl: string;
|
|||
|
||||
}
|
||||
|
||||
deleteMenu(id: any): Observable<any> {
|
||||
return this.http.delete(`${this.apiUrl}/menus/delete/`+ id);
|
||||
deleteMenu(id:number): Observable<any> {
|
||||
return this.http.delete(`${this.apiUrl}/menus/delete/${id}`);
|
||||
}
|
||||
|
||||
updateMenu(menu: Menu): Observable<any> {
|
||||
return this.http.put(`${this.apiUrl}/contacts/update/`, menu);
|
||||
}
|
||||
|
||||
updateMenu(menu: Menu, id:number): Observable<any> | void {
|
||||
const teamId = this.tokenService.getCurrentTeamId();
|
||||
if (teamId){
|
||||
return this.http.put(`${this.apiUrl}/menus/update/${teamId}/${id}`, menu);
|
||||
}else {
|
||||
this.router.navigate(['accueil']);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
|
|
@ -24,7 +24,7 @@ tokenKey = environment.tokenKey;
|
|||
const token = this.getToken();
|
||||
if(token) {
|
||||
const decodedToken = jwt_decode<any>(token);
|
||||
const userId = decodedToken.sub;
|
||||
const userId = decodedToken.userId;
|
||||
return userId;
|
||||
} else {
|
||||
return null;
|
||||
|
|
Loading…
Add table
Reference in a new issue