From efb86420d05c8a309da294d3b8a1ce1e07bb1997 Mon Sep 17 00:00:00 2001 From: HarmandI Date: Mon, 14 Feb 2022 11:28:50 +0100 Subject: [PATCH] todo en cours --- package-lock.json | 10 ++-- package.json | 1 + .../to-do-list/to-do-list.component.html | 47 ++++++++++++------- .../to-do-list/to-do-list.component.scss | 27 ++++++----- .../to-do-list/to-do-list.component.ts | 35 ++++++++++---- .../page-to-do-list.component.html | 8 +++- .../page-to-do-list.component.ts | 13 ++++- src/app/services/todo-service.service.ts | 43 ----------------- src/app/services/todo.service.spec.ts | 16 +++++++ src/app/services/todo.service.ts | 30 ++++++++++++ 10 files changed, 143 insertions(+), 87 deletions(-) delete mode 100644 src/app/services/todo-service.service.ts create mode 100644 src/app/services/todo.service.spec.ts create mode 100644 src/app/services/todo.service.ts diff --git a/package-lock.json b/package-lock.json index 53c24c2..11d31e8 100644 --- a/package-lock.json +++ b/package-lock.json @@ -2325,11 +2325,6 @@ "integrity": "sha512-5p6WTN0DdTGVQk6VjcEju19IgaHudalcfabD7yhDGeA6bcQnmL+CpveLJq/3hvfwd1aof6L386Ougkx6RfyMIQ==", "dev": true }, - "angular-autofocus-fix": { - "version": "0.1.2", - "resolved": "https://registry.npmjs.org/angular-autofocus-fix/-/angular-autofocus-fix-0.1.2.tgz", - "integrity": "sha512-P5l24by1q6CSaRW/yrjJis56SuECQwXGbwFOfrk6URn3ir+uDrabykF1vjQwKYPrhF2W/JdBfXeMwuKnQ94Bmg==" - }, "ansi-colors": { "version": "4.1.1", "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-4.1.1.tgz", @@ -2649,6 +2644,11 @@ "resolved": "https://registry.npmjs.org/bootstrap/-/bootstrap-5.1.3.tgz", "integrity": "sha512-fcQztozJ8jToQWXxVuEyXWW+dSo8AiXWKwiSSrKWsRB/Qt+Ewwza+JWoLKiTuQLaEPhdNAJ7+Dosc9DOIqNy7Q==" }, + "bootstrap-icons": { + "version": "1.7.2", + "resolved": "https://registry.npmjs.org/bootstrap-icons/-/bootstrap-icons-1.7.2.tgz", + "integrity": "sha512-NiR2PqC73AQOPdVSu6GJfnk+hN2z6powcistXk1JgPnKuoV2FSdSl26w931Oz9HYbKCcKUSB6ncZTYJAYJl3QQ==" + }, "brace-expansion": { "version": "1.1.11", "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", diff --git a/package.json b/package.json index 1507a28..f135ddb 100644 --- a/package.json +++ b/package.json @@ -19,6 +19,7 @@ "@angular/platform-browser-dynamic": "~13.0.0", "@angular/router": "~13.0.0", "bootstrap": "^5.1.3", + "bootstrap-icons": "^1.7.2", "jwt-decode": "^3.1.2", "ngx-autofocus-fix": "^1.0.4", "rxjs": "~7.4.0", diff --git a/src/app/components/to-do-list/to-do-list.component.html b/src/app/components/to-do-list/to-do-list.component.html index 2b17875..9c94a23 100644 --- a/src/app/components/to-do-list/to-do-list.component.html +++ b/src/app/components/to-do-list/to-do-list.component.html @@ -1,40 +1,55 @@ + +
+ +
-
+ + +
- {{ todo.title }} + {{ tache.texte }}
-
×
+
×
+ + +
-
- -
+
diff --git a/src/app/components/to-do-list/to-do-list.component.scss b/src/app/components/to-do-list/to-do-list.component.scss index f0dac87..9ff8f30 100644 --- a/src/app/components/to-do-list/to-do-list.component.scss +++ b/src/app/components/to-do-list/to-do-list.component.scss @@ -1,5 +1,15 @@ +.todo-title { + width: 25%; + padding: 10px 18px; + font-size: xx-large; + margin-bottom: 16px; + &:focus { + outline: 0; + } +} + .todo-input { - width: 100%; + width: 20%; padding: 10px 18px; font-size: 18px; margin-bottom: 16px; @@ -7,6 +17,8 @@ outline: 0; } } + + .element { margin-bottom: 12px; display: flex; @@ -16,6 +28,7 @@ } .deleteTache { + width: 75%; cursor: pointer; margin-left: 14px; &:hover { @@ -40,11 +53,12 @@ margin-left: 12px; width: 100%; padding: 10px; - border: 1px solid #ccc; //override defaults + border: 1px solid rgb(204, 204, 204); //override defaults font-family: 'Avenir', Helvetica, Arial, sans-serif; &:focus { outline: none; + background-color:aquamarine; } } @@ -53,15 +67,6 @@ color: grey; } -.extra-container { - display: flex; - align-items: center; - justify-content: space-between; - font-size: 16px; - border-top: 1px solid lightgrey; - padding-top: 14px; - margin-bottom: 14px; -} button { font-size: 14px; diff --git a/src/app/components/to-do-list/to-do-list.component.ts b/src/app/components/to-do-list/to-do-list.component.ts index fb23768..361390e 100644 --- a/src/app/components/to-do-list/to-do-list.component.ts +++ b/src/app/components/to-do-list/to-do-list.component.ts @@ -1,5 +1,7 @@ -import { Component, OnInit } from '@angular/core'; +import { Component, Input, OnInit } from '@angular/core'; +import { Router } from '@angular/router'; import { Todo } from 'src/app/interfaces/todo'; +import { TodoService } from 'src/app/services/todo.service'; @Component({ selector: 'app-to-do-list', @@ -7,6 +9,7 @@ import { Todo } from 'src/app/interfaces/todo'; styleUrls: ['./to-do-list.component.scss'], }) export class ToDoListComponent implements OnInit { + @Input() todo : any; public beforeEditCache: string; public todos: Todo[]; public todoTitle: string; @@ -14,8 +17,9 @@ export class ToDoListComponent implements OnInit { public filter : string; public casesRestantes : boolean; public masterSelected: boolean; + public result : any; - constructor() { + constructor(private TodoService : TodoService, private router: Router ) { this.beforeEditCache = ''; this.todos = []; this.todoTitle = ''; @@ -23,9 +27,11 @@ export class ToDoListComponent implements OnInit { this.filter =''; this.casesRestantes=true; this.masterSelected= false; + } ngOnInit(): void { + //this.refreshTodo(); this.beforeEditCache = ''; this.casesRestantes=true; this.filter='tous'; @@ -53,8 +59,11 @@ export class ToDoListComponent implements OnInit { ]; } //ajouter tache - addTitle(): void { - if (this.todoTitle.trim().length === 0) { + addTache(): void { + this.TodoService.addTache(todo).subscribe((resp)=>{ + this.router.navigate(['to-do-list']) + }) + /* if (this.todoTitle.trim().length === 0) { return; } @@ -65,8 +74,13 @@ export class ToDoListComponent implements OnInit { editing: false, }); this.todoTitle = ''; - this.idTodo++; + this.idTodo++; */ } + /* if (contact.nom !== '') { + this.repertoireService.addContact(contact).subscribe((resp) => { + this.router.navigate(['repertoire/']); + }); */ + //modifier la tâche modifier(todo: Todo): void { @@ -90,9 +104,14 @@ export class ToDoListComponent implements OnInit { } //supprimer la tache - deleteTodo(id: number): void { - this.todos = this.todos.filter((todo) => todo.id !== id); - } + deleteTodo(id: number) { + this.TodoService.deleteTacheById(id).subscribe( + resp =>{ + window.location.reload(); + } + );} + + //nombre de tâches restantes toDoRest(): number{ diff --git a/src/app/pages/page-to-do-list/page-to-do-list.component.html b/src/app/pages/page-to-do-list/page-to-do-list.component.html index 9eed39a..f58dc34 100644 --- a/src/app/pages/page-to-do-list/page-to-do-list.component.html +++ b/src/app/pages/page-to-do-list/page-to-do-list.component.html @@ -1,5 +1,9 @@ -
- +
+
+
+ +
+
diff --git a/src/app/pages/page-to-do-list/page-to-do-list.component.ts b/src/app/pages/page-to-do-list/page-to-do-list.component.ts index c7240b0..81ebd86 100644 --- a/src/app/pages/page-to-do-list/page-to-do-list.component.ts +++ b/src/app/pages/page-to-do-list/page-to-do-list.component.ts @@ -1,4 +1,7 @@ import { Component, OnInit } from '@angular/core'; +import { TodoService } from 'src/app/services/todo.service'; + + @Component({ selector: 'app-page-to-do-list', @@ -6,10 +9,18 @@ import { Component, OnInit } from '@angular/core'; styleUrls: ['./page-to-do-list.component.scss'] }) export class PageToDoListComponent implements OnInit { + public result : any; - constructor() { } + constructor(private TodoService : TodoService) { } ngOnInit(): void { + this.TodoService.getToDoListByTeamId().subscribe((data :any)=>{ + + this.result = data; + console.log(data); + }); + + } } diff --git a/src/app/services/todo-service.service.ts b/src/app/services/todo-service.service.ts deleted file mode 100644 index e0d597a..0000000 --- a/src/app/services/todo-service.service.ts +++ /dev/null @@ -1,43 +0,0 @@ -import { HttpClient } from '@angular/common/http'; -import { Injectable } from '@angular/core'; -import { environment } from 'src/environments/environment'; - -@Injectable({ - providedIn: 'root' -}) -export class TodoServiceService { - private toDoList: any; - private apiUrl: string; - - - constructor(private http: HttpClient) { - this.apiUrl = environment.apiUrl; - } - - //consulter toDoList - getToDoList(){ - this.toDoList = this.http.get(`${this.apiUrl}/todolist/team/{team_id}`); - return this.toDoList; - console.log(this.toDoList) -} - -//ajouter une tache - addTitle(title:string){ - this.toDoList.push({ - title:title, - isChecked: false - }); - } -// cocher et décocher la checkbox - checkOrUnCheckTitle($key: string,flag: boolean){ - this.toDoList.update($key,{isChecked:flag}); - } - -//supprimer la tache -removeTitle($key : string){ - this.toDoList.remove($key); -} - - - -} diff --git a/src/app/services/todo.service.spec.ts b/src/app/services/todo.service.spec.ts new file mode 100644 index 0000000..41eb649 --- /dev/null +++ b/src/app/services/todo.service.spec.ts @@ -0,0 +1,16 @@ +import { TestBed } from '@angular/core/testing'; + +import { TodoService } from './todo.service'; + +describe('TodoService', () => { + let service: TodoService; + + beforeEach(() => { + TestBed.configureTestingModule({}); + service = TestBed.inject(TodoService); + }); + + it('should be created', () => { + expect(service).toBeTruthy(); + }); +}); diff --git a/src/app/services/todo.service.ts b/src/app/services/todo.service.ts new file mode 100644 index 0000000..7202261 --- /dev/null +++ b/src/app/services/todo.service.ts @@ -0,0 +1,30 @@ +import { HttpClient } from '@angular/common/http'; +import { Injectable } from '@angular/core'; +import { Observable } from 'rxjs'; +import { environment } from 'src/environments/environment'; +import { Todo } from '../interfaces/todo'; + +@Injectable({ + providedIn: 'root', +}) +export class TodoService { + private toDoList: any; + private apiUrl: string; + + constructor(private http: HttpClient) { + this.apiUrl = environment.apiUrl; + } + + getToDoListByTeamId(): Observable { + return this.http.get(`${this.apiUrl}/todolist/team/1`); + } + + deleteTacheById(idTache: any): Observable { + return this.http.delete(`${this.apiUrl}/taches/delete/${idTache}`,{responseType:'text'}); + } + + addTache(todo:Todo): Observable { + console.log(todo); + return this.http.post(`${this.apiUrl}/taches/add`, todo); + } +}